I'd avoid this kind of patch.

Rather add some "locked types", such as an array or more commonly a
queue...then it locks, do the operation (ie: remove, add), then
unlock. Someone could use that type inside a struct or as a value for
this ecore_thread_local_data_add(), then with the data he could change
the contents in a safe manner.

On Thu, Sep 28, 2017 at 10:31 PM, Cedric BAIL <cedric.b...@free.fr> wrote:
> cedric pushed a commit to branch master.
>
> http://git.enlightenment.org/core/efl.git/commit/?id=ab1080bdd36c1f80a287015dc50f81f3456321ad
>
> commit ab1080bdd36c1f80a287015dc50f81f3456321ad
> Author: Cedric Bail <ced...@osg.samsung.com>
> Date:   Thu Sep 28 18:17:57 2017 -0700
>
>     ecore: allow other thread to write local data on a thread to increase 
> utility.
> ---
>  src/lib/ecore/ecore_thread.c | 26 +++++++++++++++++---------
>  1 file changed, 17 insertions(+), 9 deletions(-)
>
> diff --git a/src/lib/ecore/ecore_thread.c b/src/lib/ecore/ecore_thread.c
> index 480aa1ce80..2c887e5de2 100644
> --- a/src/lib/ecore/ecore_thread.c
> +++ b/src/lib/ecore/ecore_thread.c
> @@ -1234,10 +1234,10 @@ ecore_thread_local_data_add(Ecore_Thread *thread,
>     if ((!thread) || (!key) || (!value))
>       return EINA_FALSE;
>
> -   if (!PHE(worker->self, PHS())) return EINA_FALSE;
> -
> +   LKL(worker->mutex);
>     if (!worker->hash)
>       worker->hash = eina_hash_string_small_new(_ecore_thread_data_free);
> +   LKU(worker->mutex);
>
>     if (!worker->hash)
>       return EINA_FALSE;
> @@ -1248,10 +1248,12 @@ ecore_thread_local_data_add(Ecore_Thread *thread,
>     d->data = value;
>     d->cb = cb;
>
> +   LKL(worker->mutex);
>     if (direct)
>       ret = eina_hash_direct_add(worker->hash, key, d);
>     else
>       ret = eina_hash_add(worker->hash, key, d);
> +   LKU(worker->mutex);
>     CDB(worker->cond);
>     return ret;
>  }
> @@ -1269,10 +1271,11 @@ ecore_thread_local_data_set(Ecore_Thread *thread,
>     if ((!thread) || (!key) || (!value))
>       return NULL;
>
> -   if (!PHE(worker->self, PHS())) return NULL;
>
> +   LKL(worker->mutex);
>     if (!worker->hash)
>       worker->hash = eina_hash_string_small_new(_ecore_thread_data_free);
> +   LKU(worker->mutex);
>
>     if (!worker->hash)
>       return NULL;
> @@ -1283,9 +1286,11 @@ ecore_thread_local_data_set(Ecore_Thread *thread,
>     d->data = value;
>     d->cb = cb;
>
> +   LKL(worker->mutex);
>     r = eina_hash_set(worker->hash, key, d);
> +   LKU(worker->mutex);
>     CDB(worker->cond);
> -
> +
>     if (r)
>       {
>         ret = r->data;
> @@ -1305,12 +1310,12 @@ ecore_thread_local_data_find(Ecore_Thread *thread,
>     if ((!thread) || (!key))
>       return NULL;
>
> -   if (!PHE(worker->self, PHS())) return NULL;
> -
>     if (!worker->hash)
>       return NULL;
>
> +   LKL(worker->mutex);
>     d = eina_hash_find(worker->hash, key);
> +   LKU(worker->mutex);
>     if (d)
>       return d->data;
>     return NULL;
> @@ -1321,15 +1326,18 @@ ecore_thread_local_data_del(Ecore_Thread *thread,
>                              const char   *key)
>  {
>     Ecore_Pthread_Worker *worker = (Ecore_Pthread_Worker *)thread;
> +   Eina_Bool r;
>
>     if ((!thread) || (!key))
>       return EINA_FALSE;
>
> -   if (!PHE(worker->self, PHS())) return EINA_FALSE;
> -
>     if (!worker->hash)
>       return EINA_FALSE;
> -   return eina_hash_del_by_key(worker->hash, key);
> +
> +   LKL(worker->mutex);
> +   r = eina_hash_del_by_key(worker->hash, key);
> +   LKU(worker->mutex);
> +   return r;
>  }
>
>  EAPI Eina_Bool
>
> --
>
>



-- 
Gustavo Sverzut Barbieri
--------------------------------------
Mobile: +55 (16) 99354-9890

------------------------------------------------------------------------------
Check out the vibrant tech community on one of the world's most
engaging tech sites, Slashdot.org! http://sdm.link/slashdot
_______________________________________________
enlightenment-devel mailing list
enlightenment-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/enlightenment-devel

Reply via email to