mirror of
https://git.FreeBSD.org/src.git
synced 2024-12-24 11:29:10 +00:00
e5106342c6
_foo - wrapped system call foo - weak definition to _foo and for cancellation points: _foo - wrapped system call __foo - enter cancellation point, call _foo(), leave cancellation point foo - weak definition to __foo Change use of global _thread_run to call a function to get the currently running thread. Make all pthread_foo functions weak definitions to _pthread_foo, where _pthread_foo is the implementation. This allows an application to provide its own pthread functions. Provide slightly different versions of pthread_mutex_lock and pthread_mutex_init so that we can tell the difference between a libc mutex and an application mutex. Threads holding mutexes internal to libc should never be allowed to exit, call signal handlers, or cancel. Approved by: -arch
43 lines
817 B
C
43 lines
817 B
C
/*
|
|
* David Leonard <d@openbsd.org>, 1999. Public Domain.
|
|
*
|
|
* $OpenBSD: uthread_msync.c,v 1.2 1999/06/09 07:16:17 d Exp $
|
|
*
|
|
* $FreeBSD$
|
|
*/
|
|
|
|
#include <sys/types.h>
|
|
#include <sys/mman.h>
|
|
#include <pthread.h>
|
|
#include "pthread_private.h"
|
|
|
|
#pragma weak msync=__msync
|
|
|
|
int
|
|
_msync(void *addr, size_t len, int flags)
|
|
{
|
|
int ret;
|
|
|
|
ret = __sys_msync(addr, len, flags);
|
|
|
|
return (ret);
|
|
}
|
|
|
|
int
|
|
__msync(void *addr, size_t len, int flags)
|
|
{
|
|
int ret;
|
|
|
|
/*
|
|
* XXX This is quite pointless unless we know how to get the
|
|
* file descriptor associated with the memory, and lock it for
|
|
* write. The only real use of this wrapper is to guarantee
|
|
* a cancellation point, as per the standard. sigh.
|
|
*/
|
|
_thread_enter_cancellation_point();
|
|
ret = _msync(addr, len, flags);
|
|
_thread_leave_cancellation_point();
|
|
|
|
return ret;
|
|
}
|