aboutsummaryrefslogtreecommitdiffstats
path: root/security/selinux
diff options
context:
space:
mode:
authorEric Paris <eparis@redhat.com>2011-04-28 15:11:21 -0400
committerEric Paris <eparis@redhat.com>2011-04-28 15:15:52 -0400
commitbe30b16d43f4781406de0c08c96501dae4cc5a77 (patch)
tree957792a2eae5f16a87b79f4ca8aa434b6fa9c7de /security/selinux
parent03a4c0182a156547edd5f2717c1702590fe36bbf (diff)
SELinux: calculate and print hashtab stats with a generic function
We have custom debug functions like rangetr_hash_eval and symtab_hash_eval which do the same thing. Just create a generic function that takes the name of the hash table as an argument instead of having custom functions. Signed-off-by: Eric Paris <eparis@redhat.com> Reviewed-by: James Morris <jmorris@namei.org>
Diffstat (limited to 'security/selinux')
-rw-r--r--security/selinux/ss/policydb.c32
1 files changed, 13 insertions, 19 deletions
diff --git a/security/selinux/ss/policydb.c b/security/selinux/ss/policydb.c
index 4c1811972b8b..70c863bf715e 100644
--- a/security/selinux/ss/policydb.c
+++ b/security/selinux/ss/policydb.c
@@ -423,32 +423,26 @@ static int (*index_f[SYM_NUM]) (void *key, void *datum, void *datap) =
423}; 423};
424 424
425#ifdef DEBUG_HASHES 425#ifdef DEBUG_HASHES
426static void symtab_hash_eval(struct symtab *s) 426static void hash_eval(struct hashtab *h, const char *hash_name)
427{ 427{
428 int i; 428 struct hashtab_info info;
429
430 for (i = 0; i < SYM_NUM; i++) {
431 struct hashtab *h = s[i].table;
432 struct hashtab_info info;
433 429
434 hashtab_stat(h, &info); 430 hashtab_stat(h, &info);
435 printk(KERN_DEBUG "SELinux: %s: %d entries and %d/%d buckets used, " 431 printk(KERN_DEBUG "SELinux: %s: %d entries and %d/%d buckets used, "
436 "longest chain length %d\n", symtab_name[i], h->nel, 432 "longest chain length %d\n", hash_name, h->nel,
437 info.slots_used, h->size, info.max_chain_len); 433 info.slots_used, h->size, info.max_chain_len);
438 }
439} 434}
440 435
441static void rangetr_hash_eval(struct hashtab *h) 436static void symtab_hash_eval(struct symtab *s)
442{ 437{
443 struct hashtab_info info; 438 int i;
444 439
445 hashtab_stat(h, &info); 440 for (i = 0; i < SYM_NUM; i++)
446 printk(KERN_DEBUG "SELinux: rangetr: %d entries and %d/%d buckets used, " 441 hash_eval(s[i].table, symtab_name[i]);
447 "longest chain length %d\n", h->nel,
448 info.slots_used, h->size, info.max_chain_len);
449} 442}
443
450#else 444#else
451static inline void rangetr_hash_eval(struct hashtab *h) 445static inline void hash_eval(struct hashtab *h, char *hash_name)
452{ 446{
453} 447}
454#endif 448#endif
@@ -1802,7 +1796,7 @@ static int range_read(struct policydb *p, void *fp)
1802 rt = NULL; 1796 rt = NULL;
1803 r = NULL; 1797 r = NULL;
1804 } 1798 }
1805 rangetr_hash_eval(p->range_tr); 1799 hash_eval(p->range_tr, "rangetr");
1806 rc = 0; 1800 rc = 0;
1807out: 1801out:
1808 kfree(rt); 1802 kfree(rt);