mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-27 01:27:21 +08:00
7311cc1f0c
allocate dynamically. (pinfo::set_acl): Replace sa_buf by dynamically allocated acl_buf. * sec_acl.cc (setacl): Allocate acl dynamically. * sec_helper.cc (sec_acl): Add test for alignment of acl when DEBUGGING is defined. (__sec_user): Same for sa_buf. * security.cc (verify_token): Define sd_buf as PSECURITY_DESCRIPTOR and allocate dynamically. (alloc_sd): Allocate acl dynamically. security.h (sec_user_nih): Change first parameter to SECURITY_ATTRIBUTES *. (sec_user): Ditto. * sigproc.cc (wait_sig): Define sa_buf as PSECURITY_ATTRIBUTES and allocate dynamically. * syscalls.cc (seteuid32): Define dacl_buf as PACL and allocate dynamically. * uinfo.cc (cygheap_user::init): Define sa_buf as PSECURITY_ATTRIBUTES and allocate dynamically. * winbase.h (ilockincr): Mark first argument of inline assembly as earlyclobber. (ilockdecr): Ditto.
68 lines
1.4 KiB
C
68 lines
1.4 KiB
C
/* winbase.h
|
|
|
|
Copyright 2002, 2003, 2004 Red Hat, Inc.
|
|
|
|
This software is a copyrighted work licensed under the terms of the
|
|
Cygwin license. Please consult the file "CYGWIN_LICENSE" for
|
|
details. */
|
|
|
|
#include_next "winbase.h"
|
|
|
|
#ifndef _WINBASE2_H
|
|
#define _WINBASE2_H
|
|
|
|
extern __inline__ long
|
|
ilockincr (long *m)
|
|
{
|
|
register int __res;
|
|
__asm__ __volatile__ ("\n\
|
|
movl $1,%0\n\
|
|
lock xadd %0,%1\n\
|
|
inc %0\n\
|
|
": "=&r" (__res), "=m" (*m): "m" (*m): "cc");
|
|
return __res;
|
|
}
|
|
|
|
extern __inline__ long
|
|
ilockdecr (long *m)
|
|
{
|
|
register int __res;
|
|
__asm__ __volatile__ ("\n\
|
|
movl $0xffffffff,%0\n\
|
|
lock xadd %0,%1\n\
|
|
dec %0\n\
|
|
": "=&r" (__res), "=m" (*m): "m" (*m): "cc");
|
|
return __res;
|
|
}
|
|
|
|
extern __inline__ long
|
|
ilockexch (long *t, long v)
|
|
{
|
|
register int __res;
|
|
__asm__ __volatile__ ("\n\
|
|
1: lock cmpxchgl %3,(%1)\n\
|
|
jne 1b\n\
|
|
": "=a" (__res), "=q" (t): "1" (t), "q" (v), "0" (*t): "cc");
|
|
return __res;
|
|
}
|
|
|
|
extern __inline__ long
|
|
ilockcmpexch (long *t, long v, long c)
|
|
{
|
|
register int __res;
|
|
__asm__ __volatile__ ("\n\
|
|
lock cmpxchgl %3,(%1)\n\
|
|
": "=a" (__res), "=q" (t) : "1" (t), "q" (v), "0" (c): "cc");
|
|
return __res;
|
|
}
|
|
|
|
#undef InterlockedIncrement
|
|
#define InterlockedIncrement ilockincr
|
|
#undef InterlockedDecrement
|
|
#define InterlockedDecrement ilockdecr
|
|
#undef InterlockedExchange
|
|
#define InterlockedExchange ilockexch
|
|
#undef InterlockedCompareExchange
|
|
#define InterlockedCompareExchange ilockcmpexch
|
|
#endif /*_WINBASE2_H*/
|