| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 | /* Thread package specific definitions of stream lock type.  NPTL version.   Copyright (C) 2000, 2001, 2002, 2003, 2007 Free Software Foundation, Inc.   This file is part of the GNU C Library.   The GNU C Library is free software; you can redistribute it and/or   modify it under the terms of the GNU Lesser General Public   License as published by the Free Software Foundation; either   version 2.1 of the License, or (at your option) any later version.   The GNU C Library is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU   Lesser General Public License for more details.   You should have received a copy of the GNU Lesser General Public   License along with the GNU C Library; if not, see   <http://www.gnu.org/licenses/>.  */#ifndef _BITS_STDIO_LOCK_H#define _BITS_STDIO_LOCK_H 1#include <bits/libc-lock.h>#include <lowlevellock.h>/* The locking here is very inexpensive, even for inlining.  */#define _IO_lock_inexpensive	1typedef struct { int lock; int cnt; void *owner; } _IO_lock_t;#define _IO_lock_initializer { LLL_LOCK_INITIALIZER, 0, NULL }#define _IO_lock_init(_name) \  ((void) ((_name) = (_IO_lock_t) _IO_lock_initializer))#define _IO_lock_fini(_name) \  ((void) 0)#define _IO_lock_lock(_name) \  do {									      \    void *__meself = THREAD_SELF;						      \    if ((_name).owner != __meself)					      \      {									      \	lll_lock ((_name).lock, LLL_PRIVATE);				      \        (_name).owner = __meself;						      \      }									      \    ++(_name).cnt;							      \  } while (0)#define _IO_lock_trylock(_name) \  ({									      \    int __result = 0;							      \    void *__meself = THREAD_SELF;						      \    if ((_name).owner != __meself)					      \      {									      \        if (lll_trylock ((_name).lock) == 0)				      \          {								      \            (_name).owner = __meself;					      \            (_name).cnt = 1;						      \          }								      \        else								      \          __result = EBUSY;						      \      }									      \    else								      \      ++(_name).cnt;							      \    __result;								      \  })#define _IO_lock_unlock(_name) \  do {									      \    if (--(_name).cnt == 0)						      \      {									      \        (_name).owner = NULL;						      \	lll_unlock ((_name).lock, LLL_PRIVATE);				      \      }									      \  } while (0)#define _IO_cleanup_region_start(_fct, _fp) \  __libc_cleanup_region_start (((_fp)->_flags & _IO_USER_LOCK) == 0, _fct, _fp)#define _IO_cleanup_region_start_noarg(_fct) \  __libc_cleanup_region_start (1, _fct, NULL)#define _IO_cleanup_region_end(_doit) \  __libc_cleanup_region_end (_doit)#if defined _LIBC && !defined NOT_IN_libc# ifdef __EXCEPTIONS#  define _IO_acquire_lock(_fp) \  do {									      \    _IO_FILE *_IO_acquire_lock_file					      \	__attribute__((cleanup (_IO_acquire_lock_fct)))			      \	= (_fp);							      \    _IO_flockfile (_IO_acquire_lock_file);#  define _IO_acquire_lock_clear_flags2(_fp) \  do {									      \    _IO_FILE *_IO_acquire_lock_file					      \	__attribute__((cleanup (_IO_acquire_lock_clear_flags2_fct)))	      \	= (_fp);							      \    _IO_flockfile (_IO_acquire_lock_file);# else#  define _IO_acquire_lock(_fp) _IO_acquire_lock_needs_exceptions_enabled#  define _IO_acquire_lock_clear_flags2(_fp) _IO_acquire_lock (_fp)# endif# define _IO_release_lock(_fp) ; } while (0)#endif#endif /* bits/stdio-lock.h */
 |