8fbd574ef0
* posix_ipc.cc: Include thread.h and semaphore.h. Remove TODO comment. (ipc_names): Add max_len member. Set to maximum length of the path before tacking on the prefix path. Set prefix path for named semaphors to /dev/shm, as on Linux. (enum ipc_type_t): Change sem to semaphore to avoid name conflicts. (check_path): Detect empty paths. Use ipc_names's max_len member. Use __small_sprintf to create full object path name. Special case semaphores. (ipc_cond_init): Drop superfluous strcpy. (class ipc_flock): New class to simplify file locking in subsequent code. (struct mq_hdr): Raise size of mqh_uname to allow adding a unique LUID to the name. (mq_open): Fix formatting. Create unique synchronization object names using AllocateLocallyUniqueId. (struct sem_finfo): New structure defining named semaphore file content. (sem_open): Move here. Rework implementation to allow kernel persistent implementation of POSIX named semaphores. (_sem_close): Implement sem_close. (sem_close): Move here. Just call _sem_close with do_close parameter set to true. (sem_unlink): New function. * pthread.cc (mangle_sem_name): Remove. (sem_open): Move to posix_ipc.cc. (sem_close): Ditto. * syscalls.cc (close_all_files): Call semaphore::terminate here. * thread.cc: Fix formatting. Rearrange semaphore functions so that they are close together. (semaphore::semaphore): Rework to play nicely with new named semaphore implementation. (semaphore::_terminate): Call _sem_close if semaphore is a named semaphore. (semaphore::destroy): Don't destroy named semaphores. Return EINVAL instead. (semaphore::close): Only destroy named semaphores. Return EINVAL otherwise. (semaphore::open): Rework to play nicely with new named semaphore implementation. Loop through existing semaphores to be able to return same sem_t pointer as a former call on the same named semaphore. (semaphore::getinternal): New function called from _sem_close. * thread.h (class List): Make mx and head public. (class semaphore): Fix formatting. Align method declarations with implementation in thread.cc. Add members used for named semaphores. (semaphore::terminate): New static method. * include/semaphore.h: Redefine SEM_FAILED. Fix formatting. (sem_unlink): Add declaration. * include/cygwin/version.h: Bump API minor number.
198 lines
3.4 KiB
C++
198 lines
3.4 KiB
C++
/* pthread.cc: posix pthread interface for Cygwin
|
|
|
|
Copyright 1998, 1999, 2000, 2001, 2002, 2003, 2005, 2007 Red Hat, Inc.
|
|
|
|
Originally written by Marco Fuykschot <marco@ddi.nl>
|
|
|
|
This file is part of Cygwin.
|
|
|
|
This software is a copyrighted work licensed under the terms of the
|
|
Cygwin license. Please consult the file "CYGWIN_LICENSE" for
|
|
details. */
|
|
|
|
#include "winsup.h"
|
|
#include "thread.h"
|
|
#include "cygerrno.h"
|
|
#include "path.h"
|
|
#include "fhandler.h"
|
|
#include "dtable.h"
|
|
#include "cygheap.h"
|
|
#include <stdarg.h>
|
|
#include <sys/fcntl.h>
|
|
#include "cygtls.h"
|
|
|
|
extern "C"
|
|
{
|
|
/* ThreadCreation */
|
|
int
|
|
pthread_create (pthread_t * thread, const pthread_attr_t * attr,
|
|
void *(*start_routine) (void *), void *arg)
|
|
{
|
|
return pthread::create (thread, attr, start_routine, arg);
|
|
}
|
|
|
|
int
|
|
pthread_once (pthread_once_t * once_control, void (*init_routine) (void))
|
|
{
|
|
return pthread::once (once_control, init_routine);
|
|
}
|
|
|
|
int
|
|
pthread_atfork (void (*prepare)(void), void (*parent)(void), void (*child)(void))
|
|
{
|
|
return pthread::atfork (prepare, parent, child);
|
|
}
|
|
|
|
/* Thread Exit */
|
|
void
|
|
pthread_exit (void *value_ptr)
|
|
{
|
|
return pthread::self ()->exit (value_ptr);
|
|
}
|
|
|
|
int
|
|
pthread_join (pthread_t thread, void **return_val)
|
|
{
|
|
return pthread::join (&thread, (void **) return_val);
|
|
}
|
|
|
|
int
|
|
pthread_detach (pthread_t thread)
|
|
{
|
|
return pthread::detach (&thread);
|
|
}
|
|
|
|
|
|
/* This isn't a posix call... should we keep it? */
|
|
int
|
|
pthread_suspend (pthread_t thread)
|
|
{
|
|
return pthread::suspend (&thread);
|
|
}
|
|
|
|
/* same */
|
|
int
|
|
pthread_continue (pthread_t thread)
|
|
{
|
|
return pthread::resume (&thread);
|
|
}
|
|
|
|
unsigned long
|
|
pthread_getsequence_np (pthread_t * thread)
|
|
{
|
|
if (!pthread::is_good_object (thread))
|
|
return EINVAL;
|
|
return (*thread)->getsequence_np ();
|
|
}
|
|
|
|
/* ID */
|
|
|
|
pthread_t pthread_self ()
|
|
{
|
|
return pthread::self ();
|
|
}
|
|
|
|
/* Mutexes */
|
|
int
|
|
pthread_mutex_init (pthread_mutex_t * mutex, const pthread_mutexattr_t * attr)
|
|
{
|
|
return pthread_mutex::init (mutex, attr);
|
|
}
|
|
|
|
/* Synchronisation */
|
|
int
|
|
pthread_cond_init (pthread_cond_t * cond, const pthread_condattr_t * attr)
|
|
{
|
|
return pthread_cond::init (cond, attr);
|
|
}
|
|
|
|
/* RW Locks */
|
|
int
|
|
pthread_rwlock_init (pthread_rwlock_t *rwlock, const pthread_rwlockattr_t *attr)
|
|
{
|
|
return pthread_rwlock::init (rwlock, attr);
|
|
}
|
|
|
|
/* Cancelability */
|
|
|
|
int
|
|
pthread_cancel (pthread_t thread)
|
|
{
|
|
return pthread::cancel (thread);
|
|
}
|
|
|
|
int
|
|
pthread_setcancelstate (int state, int *oldstate)
|
|
{
|
|
return pthread::self ()->setcancelstate (state, oldstate);
|
|
}
|
|
|
|
int
|
|
pthread_setcanceltype (int type, int *oldtype)
|
|
{
|
|
return pthread::self ()->setcanceltype (type, oldtype);
|
|
}
|
|
|
|
void
|
|
pthread_testcancel ()
|
|
{
|
|
pthread::self ()->testcancel ();
|
|
}
|
|
|
|
void
|
|
_pthread_cleanup_push (__pthread_cleanup_handler *handler)
|
|
{
|
|
pthread::self ()->push_cleanup_handler (handler);
|
|
}
|
|
|
|
void
|
|
_pthread_cleanup_pop (int execute)
|
|
{
|
|
pthread::self ()->pop_cleanup_handler (execute);
|
|
}
|
|
|
|
/* Semaphores */
|
|
int
|
|
sem_init (sem_t * sem, int pshared, unsigned int value)
|
|
{
|
|
return semaphore::init (sem, pshared, value);
|
|
}
|
|
|
|
int
|
|
sem_destroy (sem_t * sem)
|
|
{
|
|
return semaphore::destroy (sem);
|
|
}
|
|
|
|
int
|
|
sem_wait (sem_t * sem)
|
|
{
|
|
return semaphore::wait (sem);
|
|
}
|
|
|
|
int
|
|
sem_trywait (sem_t * sem)
|
|
{
|
|
return semaphore::trywait (sem);
|
|
}
|
|
|
|
int
|
|
sem_timedwait (sem_t * sem, const struct timespec *abstime)
|
|
{
|
|
return semaphore::timedwait (sem, abstime);
|
|
}
|
|
|
|
int
|
|
sem_post (sem_t * sem)
|
|
{
|
|
return semaphore::post (sem);
|
|
}
|
|
|
|
int
|
|
sem_getvalue (sem_t * sem, int *sval)
|
|
{
|
|
return semaphore::getvalue (sem, sval);
|
|
}
|
|
|
|
}
|