locking.h 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. /* $Id$ */
  2. /*
  3. *
  4. * Copyright (C) 2001-2003 FhG Fokus
  5. *
  6. * This file is part of ser, a free SIP server.
  7. *
  8. * ser is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation; either version 2 of the License, or
  11. * (at your option) any later version
  12. *
  13. * For a license to use the ser software under conditions
  14. * other than those described here, or to purchase support for this
  15. * software, please contact iptel.org by e-mail at the following addresses:
  16. * [email protected]
  17. *
  18. * ser is distributed in the hope that it will be useful,
  19. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  20. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  21. * GNU General Public License for more details.
  22. *
  23. * You should have received a copy of the GNU General Public License
  24. * along with this program; if not, write to the Free Software
  25. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  26. */
  27. /*
  28. * ser locking library
  29. *
  30. * 2002-12-16 created by andrei
  31. * 2003-02-20 s/gen_lock_t/gen_lock_t/ to avoid a type conflict
  32. * on solaris (andrei)
  33. * 2003-03-05 lock set support added for FAST_LOCK & SYSV (andrei)
  34. * 2003-03-06 split in two: lock_ops.h & lock_alloc.h, to avoid
  35. * shm_mem.h<->locking.h interdependency (andrei)
  36. * 2004-07-28 s/lock_set_t/gen_lock_set_t/ because of a type conflict
  37. * on darwin (andrei)
  38. *
  39. Implements (in lock_ops.h & lock_alloc.h):
  40. simple locks:
  41. -------------
  42. type: gen_lock_t
  43. gen_lock_t* lock_alloc(); - allocates a lock in shared mem.
  44. gen_lock_t* lock_init(gen_lock_t* lock); - inits the lock
  45. void lock_destroy(gen_lock_t* lock); - removes the lock (e.g sysv rmid)
  46. void lock_dealloc(gen_lock_t* lock); - deallocates the lock's shared m.
  47. void lock_get(gen_lock_t* lock); - lock (mutex down)
  48. void lock_release(gen_lock_t* lock); - unlock (mutex up)
  49. lock sets:
  50. ----------
  51. type: gen_lock_set_t
  52. gen_lock_set_t* lock_set_alloc(no) - allocs a lock set in shm.
  53. gen_lock_set_t* lock_set_init(gen_lock_set_t* set); - inits the lock set
  54. void lock_set_destroy(gen_lock_set_t* s); - removes the lock set
  55. void lock_set_dealloc(gen_lock_set_t* s); - deallocs the lock set shm.
  56. void lock_set_get(gen_lock_set_t* s, int i); - locks sem i from the set
  57. void lock_set_release(gen_lock_set_t* s, int i) - unlocks sem i from the set
  58. WARNING: - lock_set_init may fail for large number of sems (e.g. sysv).
  59. - signals are not treated! (some locks are "awakened" by the signals)
  60. */
  61. #ifndef _locking_h
  62. #define _locking_h
  63. /* the order is important */
  64. #include "lock_ops.h"
  65. #include "lock_alloc.h"
  66. #endif