Mon Sep 10 08:28:00 2001 Robert Collins <rbtcollins@hotmail.com>
* thread.h (MT_Interface): Remove pshared mutex array. Add a threadsafe list for mutex tracking (for fixupafter fork). * thread.cc (MTInterface::Init): Remove pshared mutex array. (pthread_mutex::pthread_mutex): Remove pshared mutex functionality. Fail with EINVAL on attempts to use pshared functionality. (__pthread_mutex_getpshared): Remove. (__pthread_cond_timedwait): Remove pshared mutex functionality. (__pthread_cond_wait): Ditto. (__pthread_mutex_init): Ditto. (__pthread_mutex_getprioceiling): Ditto. (__pthread_mutex_lock): Ditto. (__pthread_mutex_trylock): Ditto. (__pthread_mutex_unlock): Ditto. (__pthread_mutex_destroy): Ditto. (__pthread_mutex_setprioceiling): Ditto. (__pthread_mutexattr_setpshared): Ditto.
This commit is contained in:
parent
e3a4f8ef6f
commit
ac9841a070
@ -1,3 +1,22 @@
|
|||||||
|
Mon Sep 10 08:28:00 2001 Robert Collins <rbtcollins@hotmail.com>
|
||||||
|
|
||||||
|
* thread.h (MT_Interface): Remove pshared mutex array.
|
||||||
|
Add a threadsafe list for mutex tracking (for fixupafter fork).
|
||||||
|
* thread.cc (MTInterface::Init): Remove pshared mutex array.
|
||||||
|
(pthread_mutex::pthread_mutex): Remove pshared mutex functionality.
|
||||||
|
Fail with EINVAL on attempts to use pshared functionality.
|
||||||
|
(__pthread_mutex_getpshared): Remove.
|
||||||
|
(__pthread_cond_timedwait): Remove pshared mutex functionality.
|
||||||
|
(__pthread_cond_wait): Ditto.
|
||||||
|
(__pthread_mutex_init): Ditto.
|
||||||
|
(__pthread_mutex_getprioceiling): Ditto.
|
||||||
|
(__pthread_mutex_lock): Ditto.
|
||||||
|
(__pthread_mutex_trylock): Ditto.
|
||||||
|
(__pthread_mutex_unlock): Ditto.
|
||||||
|
(__pthread_mutex_destroy): Ditto.
|
||||||
|
(__pthread_mutex_setprioceiling): Ditto.
|
||||||
|
(__pthread_mutexattr_setpshared): Ditto.
|
||||||
|
|
||||||
Sun Sep 9 23:09:00 2001 Corinna Vinschen <corinna@vinschen.de>
|
Sun Sep 9 23:09:00 2001 Corinna Vinschen <corinna@vinschen.de>
|
||||||
|
|
||||||
* pwdgrp.h (pwdgrp_check::set_last_modified): Call GetFileTime()
|
* pwdgrp.h (pwdgrp_check::set_last_modified): Call GetFileTime()
|
||||||
|
@ -304,9 +304,6 @@ MTinterface::Init (int forked)
|
|||||||
|
|
||||||
/*possible the atfork lists should be inited here as well */
|
/*possible the atfork lists should be inited here as well */
|
||||||
|
|
||||||
for (int i = 0; i < 256; i++)
|
|
||||||
pshared_mutexs[i] = NULL;
|
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
item->function = NULL;
|
item->function = NULL;
|
||||||
|
|
||||||
@ -515,17 +512,11 @@ pthread_key::get ()
|
|||||||
return TlsGetValue (dwTlsIndex);
|
return TlsGetValue (dwTlsIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define SYS_BASE (unsigned char) 0xC0
|
|
||||||
// Note: the order is important. This is an overloaded pthread_mutex_t from
|
|
||||||
// userland
|
|
||||||
typedef struct _pshared_mutex {
|
|
||||||
unsigned char id;
|
|
||||||
unsigned char reserved;
|
|
||||||
unsigned char reserved2;
|
|
||||||
unsigned char flags;
|
|
||||||
} pshared_mutex;
|
|
||||||
|
|
||||||
/*pshared mutexs:
|
/*pshared mutexs:
|
||||||
|
|
||||||
|
* REMOVED FROM CURRENT. These can be reinstated with the daemon, when all the
|
||||||
|
gymnastics can be a lot easier.
|
||||||
|
|
||||||
*the mutex_t (size 4) is not used as a verifyable object because we cannot
|
*the mutex_t (size 4) is not used as a verifyable object because we cannot
|
||||||
*guarantee the same address space for all processes.
|
*guarantee the same address space for all processes.
|
||||||
*we use the following:
|
*we use the following:
|
||||||
@ -545,79 +536,12 @@ typedef struct _pshared_mutex {
|
|||||||
*Isn't duplicated, it's reopened.
|
*Isn't duplicated, it's reopened.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
pthread_mutex::pthread_mutex (unsigned short id):verifyable_object (PTHREAD_MUTEX_MAGIC)
|
|
||||||
{
|
|
||||||
//FIXME: set an appropriate security mask - probably everyone.
|
|
||||||
if (MT_INTERFACE->pshared_mutexs[id])
|
|
||||||
return;
|
|
||||||
char stringbuf[29];
|
|
||||||
snprintf (stringbuf, 29, "CYGWINMUTEX0x%0x", id & 0x000f);
|
|
||||||
system_printf ("name of mutex to transparently open %s\n",stringbuf);
|
|
||||||
this->win32_obj_id =::CreateMutex (&sec_none_nih, false, stringbuf);
|
|
||||||
if (win32_obj_id==0 || (win32_obj_id && GetLastError () != ERROR_ALREADY_EXISTS))
|
|
||||||
{
|
|
||||||
// the mutex has been deleted or we couldn't get access.
|
|
||||||
// the error_already_exists test is because we are only opening an
|
|
||||||
// existint mutex here
|
|
||||||
system_printf ("couldn't get pshared mutex %x, %d\n",win32_obj_id, GetLastError ());
|
|
||||||
CloseHandle (win32_obj_id);
|
|
||||||
magic = 0;
|
|
||||||
win32_obj_id = NULL;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
pshared = PTHREAD_PROCESS_SHARED;
|
|
||||||
|
|
||||||
MT_INTERFACE->pshared_mutexs[id] = this;
|
|
||||||
}
|
|
||||||
|
|
||||||
pthread_mutex::pthread_mutex (pthread_mutex_t *mutex, pthread_mutexattr *attr):verifyable_object (PTHREAD_MUTEX_MAGIC)
|
|
||||||
{
|
|
||||||
/*attr checked in the C call */
|
|
||||||
if (attr && attr->pshared==PTHREAD_PROCESS_SHARED)
|
|
||||||
{
|
|
||||||
//FIXME: set an appropriate security mask - probably everyone.
|
|
||||||
// This does open a D.O.S. - the name is guessable (if you are willing to run
|
|
||||||
// thru all possible address values :]
|
|
||||||
char stringbuf[29];
|
|
||||||
unsigned short id = 1;
|
|
||||||
while (id < 256)
|
|
||||||
{
|
|
||||||
snprintf (stringbuf, 29, "CYGWINMUTEX0x%0x", id & 0x000f);
|
|
||||||
system_printf ("name of mutex to create %s\n",stringbuf);
|
|
||||||
this->win32_obj_id =::CreateMutex (&sec_none_nih, false, stringbuf);
|
|
||||||
if (this->win32_obj_id && GetLastError () != ERROR_ALREADY_EXISTS)
|
|
||||||
{
|
|
||||||
MT_INTERFACE->pshared_mutexs[id] = this;
|
|
||||||
pshared_mutex *pmutex=(pshared_mutex *)(mutex);
|
|
||||||
pmutex->id = id;
|
|
||||||
pmutex->flags = SYS_BASE;
|
|
||||||
pshared = PTHREAD_PROCESS_SHARED;
|
|
||||||
condwaits = 0;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
id++;
|
|
||||||
CloseHandle (win32_obj_id);
|
|
||||||
}
|
|
||||||
magic = 0;
|
|
||||||
win32_obj_id = NULL;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
this->win32_obj_id =::CreateMutex (&sec_none_nih, false, NULL);
|
|
||||||
|
|
||||||
if (!win32_obj_id)
|
|
||||||
magic = 0;
|
|
||||||
condwaits = 0;
|
|
||||||
pshared = PTHREAD_PROCESS_PRIVATE;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pthread_mutex::pthread_mutex (pthread_mutexattr *attr):verifyable_object (PTHREAD_MUTEX_MAGIC)
|
pthread_mutex::pthread_mutex (pthread_mutexattr *attr):verifyable_object (PTHREAD_MUTEX_MAGIC)
|
||||||
{
|
{
|
||||||
/*attr checked in the C call */
|
/*attr checked in the C call */
|
||||||
if (attr && attr->pshared==PTHREAD_PROCESS_SHARED)
|
if (attr && attr->pshared==PTHREAD_PROCESS_SHARED)
|
||||||
{
|
{
|
||||||
/*for pshared mutex's we need the mutex address */
|
// fail
|
||||||
magic = 0;
|
magic = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -655,26 +579,6 @@ pthread_mutex::UnLock ()
|
|||||||
return ReleaseMutex (win32_obj_id);
|
return ReleaseMutex (win32_obj_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
pthread_mutex **
|
|
||||||
__pthread_mutex_getpshared (pthread_mutex_t *mutex)
|
|
||||||
{
|
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE) != SYS_BASE)
|
|
||||||
return (pthread_mutex **) mutex;
|
|
||||||
pshared_mutex *pmutex=(pshared_mutex *)(mutex);
|
|
||||||
if ((MT_INTERFACE->pshared_mutexs[pmutex->id]) != NULL)
|
|
||||||
return &(MT_INTERFACE->pshared_mutexs[pmutex->id]);
|
|
||||||
/*attempt to get the existing mutex */
|
|
||||||
pthread_mutex *newmutex;
|
|
||||||
newmutex = new pthread_mutex (pmutex->id);
|
|
||||||
if (!verifyable_object_isvalid (newmutex, PTHREAD_MUTEX_MAGIC))
|
|
||||||
{
|
|
||||||
delete (newmutex);
|
|
||||||
MT_INTERFACE->pshared_mutexs[pmutex->id] = NULL;
|
|
||||||
return &(MT_INTERFACE->pshared_mutexs[0]);
|
|
||||||
}
|
|
||||||
return &(MT_INTERFACE->pshared_mutexs[pmutex->id]);
|
|
||||||
}
|
|
||||||
|
|
||||||
pthread_mutexattr::pthread_mutexattr ():verifyable_object (PTHREAD_MUTEXATTR_MAGIC),
|
pthread_mutexattr::pthread_mutexattr ():verifyable_object (PTHREAD_MUTEXATTR_MAGIC),
|
||||||
pshared (PTHREAD_PROCESS_PRIVATE), mutextype (PTHREAD_MUTEX_DEFAULT)
|
pshared (PTHREAD_PROCESS_PRIVATE), mutextype (PTHREAD_MUTEX_DEFAULT)
|
||||||
{
|
{
|
||||||
@ -1631,8 +1535,6 @@ __pthread_cond_signal (pthread_cond_t *cond)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// FIXME: pshared mutexs have the cond count in the shared memory area.
|
|
||||||
// We need to accomodate that.
|
|
||||||
int
|
int
|
||||||
__pthread_cond_timedwait (pthread_cond_t *cond, pthread_mutex_t *mutex,
|
__pthread_cond_timedwait (pthread_cond_t *cond, pthread_mutex_t *mutex,
|
||||||
const struct timespec *abstime)
|
const struct timespec *abstime)
|
||||||
@ -1645,11 +1547,7 @@ __pthread_cond_timedwait (pthread_cond_t *cond, pthread_mutex_t *mutex,
|
|||||||
pthread_mutex **themutex = NULL;
|
pthread_mutex **themutex = NULL;
|
||||||
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
||||||
__pthread_mutex_init (mutex, NULL);
|
__pthread_mutex_init (mutex, NULL);
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE == SYS_BASE))
|
themutex = mutex;
|
||||||
// a pshared mutex
|
|
||||||
themutex = __pthread_mutex_getpshared (mutex);
|
|
||||||
else
|
|
||||||
themutex = mutex;
|
|
||||||
|
|
||||||
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
@ -1700,11 +1598,7 @@ __pthread_cond_wait (pthread_cond_t *cond, pthread_mutex_t *mutex)
|
|||||||
pthread_mutex_t *themutex = mutex;
|
pthread_mutex_t *themutex = mutex;
|
||||||
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
||||||
__pthread_mutex_init (mutex, NULL);
|
__pthread_mutex_init (mutex, NULL);
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE == SYS_BASE))
|
themutex = mutex;
|
||||||
// a pshared mutex
|
|
||||||
themutex = __pthread_mutex_getpshared (mutex);
|
|
||||||
else
|
|
||||||
themutex = mutex;
|
|
||||||
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
if (!verifyable_object_isvalid (*cond, PTHREAD_COND_MAGIC))
|
if (!verifyable_object_isvalid (*cond, PTHREAD_COND_MAGIC))
|
||||||
@ -1789,7 +1683,7 @@ int
|
|||||||
__pthread_kill (pthread_t thread, int sig)
|
__pthread_kill (pthread_t thread, int sig)
|
||||||
{
|
{
|
||||||
// lock myself, for the use of thread2signal
|
// lock myself, for the use of thread2signal
|
||||||
// two differ kills might clash: FIXME
|
// two different kills might clash: FIXME
|
||||||
|
|
||||||
if (!verifyable_object_isvalid (thread, PTHREAD_MAGIC))
|
if (!verifyable_object_isvalid (thread, PTHREAD_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
@ -1849,28 +1743,12 @@ int
|
|||||||
__pthread_mutex_init (pthread_mutex_t *mutex,
|
__pthread_mutex_init (pthread_mutex_t *mutex,
|
||||||
const pthread_mutexattr_t *attr)
|
const pthread_mutexattr_t *attr)
|
||||||
{
|
{
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE == SYS_BASE))
|
|
||||||
// a pshared mutex
|
|
||||||
return EBUSY;
|
|
||||||
if (attr && !verifyable_object_isvalid (*attr, PTHREAD_MUTEXATTR_MAGIC))
|
if (attr && !verifyable_object_isvalid (*attr, PTHREAD_MUTEXATTR_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
if (verifyable_object_isvalid (*mutex, PTHREAD_MUTEX_MAGIC))
|
if (verifyable_object_isvalid (*mutex, PTHREAD_MUTEX_MAGIC))
|
||||||
return EBUSY;
|
return EBUSY;
|
||||||
|
|
||||||
if (attr && (*attr)->pshared == PTHREAD_PROCESS_SHARED)
|
|
||||||
{
|
|
||||||
pthread_mutex_t throwaway = new pthread_mutex (mutex, (*attr));
|
|
||||||
mutex = __pthread_mutex_getpshared ((pthread_mutex_t *) mutex);
|
|
||||||
|
|
||||||
if (!verifyable_object_isvalid (*mutex, PTHREAD_MUTEX_MAGIC))
|
|
||||||
{
|
|
||||||
delete throwaway;
|
|
||||||
*mutex = NULL;
|
|
||||||
return EAGAIN;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
*mutex = new pthread_mutex (attr ? (*attr) : NULL);
|
*mutex = new pthread_mutex (attr ? (*attr) : NULL);
|
||||||
if (!verifyable_object_isvalid (*mutex, PTHREAD_MUTEX_MAGIC))
|
if (!verifyable_object_isvalid (*mutex, PTHREAD_MUTEX_MAGIC))
|
||||||
{
|
{
|
||||||
@ -1888,9 +1766,6 @@ __pthread_mutex_getprioceiling (const pthread_mutex_t *mutex,
|
|||||||
pthread_mutex_t *themutex=(pthread_mutex_t *) mutex;
|
pthread_mutex_t *themutex=(pthread_mutex_t *) mutex;
|
||||||
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
||||||
__pthread_mutex_init ((pthread_mutex_t *) mutex, NULL);
|
__pthread_mutex_init ((pthread_mutex_t *) mutex, NULL);
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE == SYS_BASE))
|
|
||||||
// a pshared mutex
|
|
||||||
themutex = __pthread_mutex_getpshared ((pthread_mutex_t *) mutex);
|
|
||||||
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
/*We don't define _POSIX_THREAD_PRIO_PROTECT because we do't currently support
|
/*We don't define _POSIX_THREAD_PRIO_PROTECT because we do't currently support
|
||||||
@ -1899,7 +1774,7 @@ __pthread_mutex_getprioceiling (const pthread_mutex_t *mutex,
|
|||||||
*We can support mutex priorities in the future though:
|
*We can support mutex priorities in the future though:
|
||||||
*Store a priority with each mutex.
|
*Store a priority with each mutex.
|
||||||
*When the mutex is optained, set the thread priority as appropriate
|
*When the mutex is optained, set the thread priority as appropriate
|
||||||
*When the mutex is released, reset the thre priority.
|
*When the mutex is released, reset the thread priority.
|
||||||
*/
|
*/
|
||||||
return ENOSYS;
|
return ENOSYS;
|
||||||
}
|
}
|
||||||
@ -1910,9 +1785,6 @@ __pthread_mutex_lock (pthread_mutex_t *mutex)
|
|||||||
pthread_mutex_t *themutex = mutex;
|
pthread_mutex_t *themutex = mutex;
|
||||||
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
||||||
__pthread_mutex_init (mutex, NULL);
|
__pthread_mutex_init (mutex, NULL);
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE) == SYS_BASE)
|
|
||||||
// a pshared mutex
|
|
||||||
themutex = __pthread_mutex_getpshared (mutex);
|
|
||||||
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
(*themutex)->Lock ();
|
(*themutex)->Lock ();
|
||||||
@ -1925,9 +1797,6 @@ __pthread_mutex_trylock (pthread_mutex_t *mutex)
|
|||||||
pthread_mutex_t *themutex = mutex;
|
pthread_mutex_t *themutex = mutex;
|
||||||
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
||||||
__pthread_mutex_init (mutex, NULL);
|
__pthread_mutex_init (mutex, NULL);
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE) == SYS_BASE)
|
|
||||||
// a pshared mutex
|
|
||||||
themutex = __pthread_mutex_getpshared (mutex);
|
|
||||||
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
if ((*themutex)->TryLock () == WAIT_TIMEOUT)
|
if ((*themutex)->TryLock () == WAIT_TIMEOUT)
|
||||||
@ -1940,9 +1809,6 @@ __pthread_mutex_unlock (pthread_mutex_t *mutex)
|
|||||||
{
|
{
|
||||||
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
||||||
__pthread_mutex_init (mutex, NULL);
|
__pthread_mutex_init (mutex, NULL);
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE) == SYS_BASE)
|
|
||||||
// a pshared mutex
|
|
||||||
mutex = __pthread_mutex_getpshared (mutex);
|
|
||||||
if (!verifyable_object_isvalid (*mutex, PTHREAD_MUTEX_MAGIC))
|
if (!verifyable_object_isvalid (*mutex, PTHREAD_MUTEX_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
(*mutex)->UnLock ();
|
(*mutex)->UnLock ();
|
||||||
@ -1954,9 +1820,6 @@ __pthread_mutex_destroy (pthread_mutex_t *mutex)
|
|||||||
{
|
{
|
||||||
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
||||||
return 0;
|
return 0;
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE) == SYS_BASE)
|
|
||||||
// a pshared mutex
|
|
||||||
mutex = __pthread_mutex_getpshared (mutex);
|
|
||||||
if (!verifyable_object_isvalid (*mutex, PTHREAD_MUTEX_MAGIC))
|
if (!verifyable_object_isvalid (*mutex, PTHREAD_MUTEX_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
|
|
||||||
@ -1976,9 +1839,6 @@ __pthread_mutex_setprioceiling (pthread_mutex_t *mutex, int prioceiling,
|
|||||||
pthread_mutex_t *themutex = mutex;
|
pthread_mutex_t *themutex = mutex;
|
||||||
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
if (*mutex == PTHREAD_MUTEX_INITIALIZER)
|
||||||
__pthread_mutex_init (mutex, NULL);
|
__pthread_mutex_init (mutex, NULL);
|
||||||
if ((((pshared_mutex *)(mutex))->flags & SYS_BASE == SYS_BASE))
|
|
||||||
// a pshared mutex
|
|
||||||
themutex = __pthread_mutex_getpshared (mutex);
|
|
||||||
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
if (!verifyable_object_isvalid (*themutex, PTHREAD_MUTEX_MAGIC))
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
return ENOSYS;
|
return ENOSYS;
|
||||||
@ -2086,7 +1946,7 @@ __pthread_mutexattr_setpshared (pthread_mutexattr_t *attr, int pshared)
|
|||||||
/*we don't use pshared for anything as yet. We need to test PROCESS_SHARED
|
/*we don't use pshared for anything as yet. We need to test PROCESS_SHARED
|
||||||
*functionality
|
*functionality
|
||||||
*/
|
*/
|
||||||
if (pshared != PTHREAD_PROCESS_PRIVATE && pshared != PTHREAD_PROCESS_SHARED)
|
if (pshared != PTHREAD_PROCESS_PRIVATE)
|
||||||
return EINVAL;
|
return EINVAL;
|
||||||
(*attr)->pshared = pshared;
|
(*attr)->pshared = pshared;
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -356,10 +356,8 @@ public:
|
|||||||
callback *pthread_child;
|
callback *pthread_child;
|
||||||
callback *pthread_parent;
|
callback *pthread_parent;
|
||||||
|
|
||||||
/* this is an associative array for the _exclusive_ use of pshared mutex's
|
// list of mutex's. USE THREADSAFE INSERTS AND DELETES.
|
||||||
* normal mutex's don't go here to reduce overhead and prevent serialisation.
|
class pthread_mutex * mutexs;
|
||||||
*/
|
|
||||||
class pthread_mutex * pshared_mutexs[256];
|
|
||||||
|
|
||||||
void Init (int);
|
void Init (int);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user