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*/
 |