klist.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * klist.h - Some generic list helpers, extending struct list_head a bit.
  3. *
  4. * Implementations are found in lib/klist.c
  5. *
  6. *
  7. * Copyright (C) 2005 Patrick Mochel
  8. *
  9. * This file is rleased under the GPL v2.
  10. */
  11. #ifndef _LINUX_KLIST_H
  12. #define _LINUX_KLIST_H
  13. #include <linux/spinlock.h>
  14. #include <linux/completion.h>
  15. #include <linux/kref.h>
  16. #include <linux/list.h>
  17. struct klist {
  18. spinlock_t k_lock;
  19. struct list_head k_list;
  20. };
  21. extern void klist_init(struct klist * k);
  22. struct klist_node {
  23. struct klist * n_klist;
  24. struct list_head n_node;
  25. struct kref n_ref;
  26. struct completion n_removed;
  27. };
  28. extern void klist_add_tail(struct klist_node * n, struct klist * k);
  29. extern void klist_add_head(struct klist_node * n, struct klist * k);
  30. extern void klist_del(struct klist_node * n);
  31. extern void klist_remove(struct klist_node * n);
  32. extern int klist_node_attached(struct klist_node * n);
  33. struct klist_iter {
  34. struct klist * i_klist;
  35. struct list_head * i_head;
  36. struct klist_node * i_cur;
  37. };
  38. extern void klist_iter_init(struct klist * k, struct klist_iter * i);
  39. extern void klist_iter_init_node(struct klist * k, struct klist_iter * i,
  40. struct klist_node * n);
  41. extern void klist_iter_exit(struct klist_iter * i);
  42. extern struct klist_node * klist_next(struct klist_iter * i);
  43. #endif