sv.h 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. /*
  2. * Copyright (c) 2000-2002,2005 Silicon Graphics, Inc.
  3. * All Rights Reserved.
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU General Public License as
  7. * published by the Free Software Foundation.
  8. *
  9. * This program is distributed in the hope that it would be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. * GNU General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU General Public License
  15. * along with this program; if not, write the Free Software Foundation,
  16. * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  17. */
  18. #ifndef __XFS_SUPPORT_SV_H__
  19. #define __XFS_SUPPORT_SV_H__
  20. #include <linux/wait.h>
  21. #include <linux/sched.h>
  22. #include <linux/spinlock.h>
  23. /*
  24. * Synchronisation variables.
  25. *
  26. * (Parameters "pri", "svf" and "rts" are not implemented)
  27. */
  28. typedef struct sv_s {
  29. wait_queue_head_t waiters;
  30. } sv_t;
  31. #define SV_FIFO 0x0 /* sv_t is FIFO type */
  32. #define SV_LIFO 0x2 /* sv_t is LIFO type */
  33. #define SV_PRIO 0x4 /* sv_t is PRIO type */
  34. #define SV_KEYED 0x6 /* sv_t is KEYED type */
  35. #define SV_DEFAULT SV_FIFO
  36. static inline void _sv_wait(sv_t *sv, spinlock_t *lock, int state,
  37. unsigned long timeout)
  38. {
  39. DECLARE_WAITQUEUE(wait, current);
  40. add_wait_queue_exclusive(&sv->waiters, &wait);
  41. __set_current_state(state);
  42. spin_unlock(lock);
  43. schedule_timeout(timeout);
  44. remove_wait_queue(&sv->waiters, &wait);
  45. }
  46. #define sv_init(sv,flag,name) \
  47. init_waitqueue_head(&(sv)->waiters)
  48. #define sv_destroy(sv) \
  49. /*NOTHING*/
  50. #define sv_wait(sv, pri, lock, s) \
  51. _sv_wait(sv, lock, TASK_UNINTERRUPTIBLE, MAX_SCHEDULE_TIMEOUT)
  52. #define sv_wait_sig(sv, pri, lock, s) \
  53. _sv_wait(sv, lock, TASK_INTERRUPTIBLE, MAX_SCHEDULE_TIMEOUT)
  54. #define sv_timedwait(sv, pri, lock, s, svf, ts, rts) \
  55. _sv_wait(sv, lock, TASK_UNINTERRUPTIBLE, timespec_to_jiffies(ts))
  56. #define sv_timedwait_sig(sv, pri, lock, s, svf, ts, rts) \
  57. _sv_wait(sv, lock, TASK_INTERRUPTIBLE, timespec_to_jiffies(ts))
  58. #define sv_signal(sv) \
  59. wake_up(&(sv)->waiters)
  60. #define sv_broadcast(sv) \
  61. wake_up_all(&(sv)->waiters)
  62. #endif /* __XFS_SUPPORT_SV_H__ */