selinux: hash context structure directly
Always hashing the string representation is inefficient. Just hash the contents of the structure directly (using jhash). If the context is invalid (str & len are set), then hash the string as before, otherwise hash the structured data. Since the context hashing function is now faster (about 10 times), this patch decreases the overhead of security_transition_sid(), which is called from many hooks. The jhash function seemed as a good choice, since it is used as the default hashing algorithm in rhashtable. Signed-off-by: Ondrej Mosnacek <omosnace@redhat.com> Reviewed-by: Jeff Vander Stoep <jeffv@google.com> Tested-by: Jeff Vander Stoep <jeffv@google.com> [PM: fixed some spelling errors in the comments pointed out by JVS] Signed-off-by: Paul Moore <paul@paul-moore.com>
This commit is contained in:

committed by
Paul Moore

parent
e67b2ec9f6
commit
5007728980
@@ -8,7 +8,6 @@
|
||||
#define _SS_SERVICES_H_
|
||||
|
||||
#include "policydb.h"
|
||||
#include "context.h"
|
||||
|
||||
/* Mapping for a single class */
|
||||
struct selinux_mapping {
|
||||
@@ -37,6 +36,4 @@ void services_compute_xperms_drivers(struct extended_perms *xperms,
|
||||
void services_compute_xperms_decision(struct extended_perms_decision *xpermd,
|
||||
struct avtab_node *node);
|
||||
|
||||
int context_add_hash(struct policydb *policydb, struct context *context);
|
||||
|
||||
#endif /* _SS_SERVICES_H_ */
|
||||
|
Reference in New Issue
Block a user