sidtab.h 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * A security identifier table (sidtab) is a hash table
  3. * of security context structures indexed by SID value.
  4. *
  5. * Author : Stephen Smalley, <sds@epoch.ncsc.mil>
  6. */
  7. #ifndef _SS_SIDTAB_H_
  8. #define _SS_SIDTAB_H_
  9. #include "context.h"
  10. struct sidtab_node {
  11. u32 sid; /* security identifier */
  12. struct context context; /* security context structure */
  13. struct sidtab_node *next;
  14. };
  15. #define SIDTAB_HASH_BITS 7
  16. #define SIDTAB_HASH_BUCKETS (1 << SIDTAB_HASH_BITS)
  17. #define SIDTAB_HASH_MASK (SIDTAB_HASH_BUCKETS-1)
  18. #define SIDTAB_SIZE SIDTAB_HASH_BUCKETS
  19. struct sidtab {
  20. struct sidtab_node **htable;
  21. unsigned int nel; /* number of elements */
  22. unsigned int next_sid; /* next SID to allocate */
  23. unsigned char shutdown;
  24. spinlock_t lock;
  25. };
  26. int sidtab_init(struct sidtab *s);
  27. int sidtab_insert(struct sidtab *s, u32 sid, struct context *context);
  28. struct context *sidtab_search(struct sidtab *s, u32 sid);
  29. int sidtab_map(struct sidtab *s,
  30. int (*apply) (u32 sid,
  31. struct context *context,
  32. void *args),
  33. void *args);
  34. void sidtab_map_remove_on_error(struct sidtab *s,
  35. int (*apply) (u32 sid,
  36. struct context *context,
  37. void *args),
  38. void *args);
  39. int sidtab_context_to_sid(struct sidtab *s,
  40. struct context *context,
  41. u32 *sid);
  42. void sidtab_hash_eval(struct sidtab *h, char *tag);
  43. void sidtab_destroy(struct sidtab *s);
  44. void sidtab_set(struct sidtab *dst, struct sidtab *src);
  45. void sidtab_shutdown(struct sidtab *s);
  46. #endif /* _SS_SIDTAB_H_ */