sidtab.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  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. struct context *sidtab_search_force(struct sidtab *s, u32 sid);
  30. int sidtab_map(struct sidtab *s,
  31. int (*apply) (u32 sid,
  32. struct context *context,
  33. void *args),
  34. void *args);
  35. int sidtab_context_to_sid(struct sidtab *s,
  36. struct context *context,
  37. u32 *sid);
  38. void sidtab_hash_eval(struct sidtab *h, char *tag);
  39. void sidtab_destroy(struct sidtab *s);
  40. void sidtab_set(struct sidtab *dst, struct sidtab *src);
  41. void sidtab_shutdown(struct sidtab *s);
  42. #endif /* _SS_SIDTAB_H_ */