policy.h (91de76e661a266731fc2889a398ad1694df9d523) policy.h (80c094a47dd4ea63375e3f60b5e076064f16e857)
1/*
2 * AppArmor security module
3 *
4 * This file contains AppArmor policy definitions.
5 *
6 * Copyright (C) 1998-2008 Novell/SUSE
7 * Copyright 2009-2010 Canonical Ltd.
8 *

--- 16 unchanged lines hidden (view full) ---

25
26#include "apparmor.h"
27#include "audit.h"
28#include "capability.h"
29#include "domain.h"
30#include "file.h"
31#include "lib.h"
32#include "label.h"
1/*
2 * AppArmor security module
3 *
4 * This file contains AppArmor policy definitions.
5 *
6 * Copyright (C) 1998-2008 Novell/SUSE
7 * Copyright 2009-2010 Canonical Ltd.
8 *

--- 16 unchanged lines hidden (view full) ---

25
26#include "apparmor.h"
27#include "audit.h"
28#include "capability.h"
29#include "domain.h"
30#include "file.h"
31#include "lib.h"
32#include "label.h"
33#include "net.h"
34#include "perms.h"
35#include "resource.h"
36
37
38struct aa_ns;
39
40extern int unprivileged_userns_apparmor_policy;
41

--- 65 unchanged lines hidden (view full) ---

107 * @audit: the auditing mode of the profile
108 * @mode: the enforcement mode of the profile
109 * @path_flags: flags controlling path generation behavior
110 * @disconnected: what to prepend if attach_disconnected is specified
111 * @size: the memory consumed by this profiles rules
112 * @policy: general match rules governing policy
113 * @file: The set of rules governing basic file access and domain transitions
114 * @caps: capabilities for the profile
33#include "perms.h"
34#include "resource.h"
35
36
37struct aa_ns;
38
39extern int unprivileged_userns_apparmor_policy;
40

--- 65 unchanged lines hidden (view full) ---

106 * @audit: the auditing mode of the profile
107 * @mode: the enforcement mode of the profile
108 * @path_flags: flags controlling path generation behavior
109 * @disconnected: what to prepend if attach_disconnected is specified
110 * @size: the memory consumed by this profiles rules
111 * @policy: general match rules governing policy
112 * @file: The set of rules governing basic file access and domain transitions
113 * @caps: capabilities for the profile
115 * @net: network controls for the profile
116 * @rlimits: rlimits for the profile
117 *
118 * @dents: dentries for the profiles file entries in apparmorfs
119 * @dirname: name of the profile dir in apparmorfs
120 * @data: hashtable for free-form policy aa_data
121 *
122 * The AppArmor profile contains the basic confinement data. Each profile
123 * has a name, and exists in a namespace. The @name and @exec_match are

--- 21 unchanged lines hidden (view full) ---

145 long mode;
146 u32 path_flags;
147 const char *disconnected;
148 int size;
149
150 struct aa_policydb policy;
151 struct aa_file_rules file;
152 struct aa_caps caps;
114 * @rlimits: rlimits for the profile
115 *
116 * @dents: dentries for the profiles file entries in apparmorfs
117 * @dirname: name of the profile dir in apparmorfs
118 * @data: hashtable for free-form policy aa_data
119 *
120 * The AppArmor profile contains the basic confinement data. Each profile
121 * has a name, and exists in a namespace. The @name and @exec_match are

--- 21 unchanged lines hidden (view full) ---

143 long mode;
144 u32 path_flags;
145 const char *disconnected;
146 int size;
147
148 struct aa_policydb policy;
149 struct aa_file_rules file;
150 struct aa_caps caps;
153 struct aa_net net;
154 struct aa_rlimit rlimits;
155
156 struct aa_loaddata *rawdata;
157 unsigned char *hash;
158 char *dirname;
159 struct dentry *dents[AAFS_PROF_SIZEOF];
160 struct rhashtable *data;
161 struct aa_label label;

--- 56 unchanged lines hidden (view full) ---

218 unsigned char class)
219{
220 if (profile->policy.dfa)
221 return aa_dfa_match_len(profile->policy.dfa,
222 profile->policy.start[0], &class, 1);
223 return 0;
224}
225
151 struct aa_rlimit rlimits;
152
153 struct aa_loaddata *rawdata;
154 unsigned char *hash;
155 char *dirname;
156 struct dentry *dents[AAFS_PROF_SIZEOF];
157 struct rhashtable *data;
158 struct aa_label label;

--- 56 unchanged lines hidden (view full) ---

215 unsigned char class)
216{
217 if (profile->policy.dfa)
218 return aa_dfa_match_len(profile->policy.dfa,
219 profile->policy.start[0], &class, 1);
220 return 0;
221}
222
226static inline unsigned int PROFILE_MEDIATES_AF(struct aa_profile *profile,
227 u16 AF) {
228 unsigned int state = PROFILE_MEDIATES(profile, AA_CLASS_NET);
229 u16 be_af = cpu_to_be16(AF);
230
231 if (!state)
232 return 0;
233 return aa_dfa_match_len(profile->policy.dfa, state, (char *) &be_af, 2);
234}
235
236/**
237 * aa_get_profile - increment refcount on profile @p
238 * @p: profile (MAYBE NULL)
239 *
240 * Returns: pointer to @p if @p is NULL will return NULL
241 * Requires: @p must be held with valid refcount when called
242 */
243static inline struct aa_profile *aa_get_profile(struct aa_profile *p)

--- 66 unchanged lines hidden ---
223/**
224 * aa_get_profile - increment refcount on profile @p
225 * @p: profile (MAYBE NULL)
226 *
227 * Returns: pointer to @p if @p is NULL will return NULL
228 * Requires: @p must be held with valid refcount when called
229 */
230static inline struct aa_profile *aa_get_profile(struct aa_profile *p)

--- 66 unchanged lines hidden ---