[vlc-devel] [PATCH 1/6] os2: implement vlc_once()
KO Myung-Hun
komh78 at gmail.com
Fri Mar 23 10:52:29 CET 2018
Hi/2.
Rémi Denis-Courmont wrote:
> Le jeudi 22 mars 2018, 16:41:29 EET KO Myung-Hun a écrit :
>> ---
>> include/vlc_threads.h | 6 ++++++
>> src/os2/thread.c | 17 +++++++++++++++++
>> 2 files changed, 23 insertions(+)
>>
>> diff --git a/include/vlc_threads.h b/include/vlc_threads.h
>> index 37054a3ded..b7505da266 100644
>> --- a/include/vlc_threads.h
>> +++ b/include/vlc_threads.h
>> @@ -125,6 +125,12 @@ typedef struct
>> #define VLC_STATIC_COND { NULLHANDLE, 0, NULLHANDLE, 0 }
>> #define LIBVLC_NEED_SEMAPHORE
>> #define LIBVLC_NEED_RWLOCK
>> +typedef struct
>> +{
>> + unsigned done;
>> + vlc_mutex_t mutex;
>> +} vlc_once_t;
>> +#define VLC_STATIC_ONCE { 0, VLC_STATIC_MUTEX }
>> typedef struct vlc_threadvar *vlc_threadvar_t;
>> typedef struct vlc_timer *vlc_timer_t;
>>
>> diff --git a/src/os2/thread.c b/src/os2/thread.c
>> index 8f7b335ea4..52f58023b8 100644
>> --- a/src/os2/thread.c
>> +++ b/src/os2/thread.c
>> @@ -427,6 +427,23 @@ int vlc_cond_timedwait_daytime (vlc_cond_t *p_condvar,
>> vlc_mutex_t *p_mutex, return vlc_cond_wait_common (p_condvar, p_mutex,
>> ulTimeout);
>> }
>>
>> +void vlc_once(vlc_once_t *once, void (*cb)(void))
>> +{
>> + if( !once->done )
>
> This looks like a violation of the memory model.
>
Which memory model ? And any suggestion ?
>> + {
>> + vlc_mutex_lock( &once->mutex );
>> +
>> + if( !once->done )
>> + {
>> + cb();
>> +
>> + once->done = 1;
>> + }
>> +
>> + vlc_mutex_unlock( &once->mutex );
>> + }
>> +}
>> +
>> /*** Thread-specific variables (TLS) ***/
>> struct vlc_threadvar
>> {
>
>
--
KO Myung-Hun
Using Mozilla SeaMonkey 2.7.2
Under OS/2 Warp 4 for Korean with FixPak #15
In VirtualBox v4.1.32 on Intel Core i7-3615QM 2.30GHz with 8GB RAM
Korean OS/2 User Community : http://www.os2.kr/
More information about the vlc-devel
mailing list