• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * AppArmor security module
4  *
5  * This file contains AppArmor functions for unpacking policy loaded from
6  * userspace.
7  *
8  * Copyright (C) 1998-2008 Novell/SUSE
9  * Copyright 2009-2010 Canonical Ltd.
10  *
11  * AppArmor uses a serialized binary format for loading policy. To find
12  * policy format documentation see Documentation/admin-guide/LSM/apparmor.rst
13  * All policy is validated before it is used.
14  */
15 
16 #include <asm/unaligned.h>
17 #include <linux/ctype.h>
18 #include <linux/errno.h>
19 
20 #include "include/apparmor.h"
21 #include "include/audit.h"
22 #include "include/cred.h"
23 #include "include/crypto.h"
24 #include "include/match.h"
25 #include "include/path.h"
26 #include "include/policy.h"
27 #include "include/policy_unpack.h"
28 
29 #define K_ABI_MASK 0x3ff
30 #define FORCE_COMPLAIN_FLAG 0x800
31 #define VERSION_LT(X, Y) (((X) & K_ABI_MASK) < ((Y) & K_ABI_MASK))
32 #define VERSION_GT(X, Y) (((X) & K_ABI_MASK) > ((Y) & K_ABI_MASK))
33 
34 #define v5	5	/* base version */
35 #define v6	6	/* per entry policydb mediation check */
36 #define v7	7
37 #define v8	8	/* full network masking */
38 
39 /*
40  * The AppArmor interface treats data as a type byte followed by the
41  * actual data.  The interface has the notion of a a named entry
42  * which has a name (AA_NAME typecode followed by name string) followed by
43  * the entries typecode and data.  Named types allow for optional
44  * elements and extensions to be added and tested for without breaking
45  * backwards compatibility.
46  */
47 
48 enum aa_code {
49 	AA_U8,
50 	AA_U16,
51 	AA_U32,
52 	AA_U64,
53 	AA_NAME,		/* same as string except it is items name */
54 	AA_STRING,
55 	AA_BLOB,
56 	AA_STRUCT,
57 	AA_STRUCTEND,
58 	AA_LIST,
59 	AA_LISTEND,
60 	AA_ARRAY,
61 	AA_ARRAYEND,
62 };
63 
64 /*
65  * aa_ext is the read of the buffer containing the serialized profile.  The
66  * data is copied into a kernel buffer in apparmorfs and then handed off to
67  * the unpack routines.
68  */
69 struct aa_ext {
70 	void *start;
71 	void *end;
72 	void *pos;		/* pointer to current position in the buffer */
73 	u32 version;
74 };
75 
76 /* audit callback for unpack fields */
audit_cb(struct audit_buffer * ab,void * va)77 static void audit_cb(struct audit_buffer *ab, void *va)
78 {
79 	struct common_audit_data *sa = va;
80 
81 	if (aad(sa)->iface.ns) {
82 		audit_log_format(ab, " ns=");
83 		audit_log_untrustedstring(ab, aad(sa)->iface.ns);
84 	}
85 	if (aad(sa)->name) {
86 		audit_log_format(ab, " name=");
87 		audit_log_untrustedstring(ab, aad(sa)->name);
88 	}
89 	if (aad(sa)->iface.pos)
90 		audit_log_format(ab, " offset=%ld", aad(sa)->iface.pos);
91 }
92 
93 /**
94  * audit_iface - do audit message for policy unpacking/load/replace/remove
95  * @new: profile if it has been allocated (MAYBE NULL)
96  * @ns_name: name of the ns the profile is to be loaded to (MAY BE NULL)
97  * @name: name of the profile being manipulated (MAYBE NULL)
98  * @info: any extra info about the failure (MAYBE NULL)
99  * @e: buffer position info
100  * @error: error code
101  *
102  * Returns: %0 or error
103  */
audit_iface(struct aa_profile * new,const char * ns_name,const char * name,const char * info,struct aa_ext * e,int error)104 static int audit_iface(struct aa_profile *new, const char *ns_name,
105 		       const char *name, const char *info, struct aa_ext *e,
106 		       int error)
107 {
108 	struct aa_profile *profile = labels_profile(aa_current_raw_label());
109 	DEFINE_AUDIT_DATA(sa, LSM_AUDIT_DATA_NONE, NULL);
110 	if (e)
111 		aad(&sa)->iface.pos = e->pos - e->start;
112 	aad(&sa)->iface.ns = ns_name;
113 	if (new)
114 		aad(&sa)->name = new->base.hname;
115 	else
116 		aad(&sa)->name = name;
117 	aad(&sa)->info = info;
118 	aad(&sa)->error = error;
119 
120 	return aa_audit(AUDIT_APPARMOR_STATUS, profile, &sa, audit_cb);
121 }
122 
__aa_loaddata_update(struct aa_loaddata * data,long revision)123 void __aa_loaddata_update(struct aa_loaddata *data, long revision)
124 {
125 	AA_BUG(!data);
126 	AA_BUG(!data->ns);
127 	AA_BUG(!data->dents[AAFS_LOADDATA_REVISION]);
128 	AA_BUG(!mutex_is_locked(&data->ns->lock));
129 	AA_BUG(data->revision > revision);
130 
131 	data->revision = revision;
132 	d_inode(data->dents[AAFS_LOADDATA_DIR])->i_mtime =
133 		current_time(d_inode(data->dents[AAFS_LOADDATA_DIR]));
134 	d_inode(data->dents[AAFS_LOADDATA_REVISION])->i_mtime =
135 		current_time(d_inode(data->dents[AAFS_LOADDATA_REVISION]));
136 }
137 
aa_rawdata_eq(struct aa_loaddata * l,struct aa_loaddata * r)138 bool aa_rawdata_eq(struct aa_loaddata *l, struct aa_loaddata *r)
139 {
140 	if (l->size != r->size)
141 		return false;
142 	if (aa_g_hash_policy && memcmp(l->hash, r->hash, aa_hash_size()) != 0)
143 		return false;
144 	return memcmp(l->data, r->data, r->size) == 0;
145 }
146 
147 /*
148  * need to take the ns mutex lock which is NOT safe most places that
149  * put_loaddata is called, so we have to delay freeing it
150  */
do_loaddata_free(struct work_struct * work)151 static void do_loaddata_free(struct work_struct *work)
152 {
153 	struct aa_loaddata *d = container_of(work, struct aa_loaddata, work);
154 	struct aa_ns *ns = aa_get_ns(d->ns);
155 
156 	if (ns) {
157 		mutex_lock_nested(&ns->lock, ns->level);
158 		__aa_fs_remove_rawdata(d);
159 		mutex_unlock(&ns->lock);
160 		aa_put_ns(ns);
161 	}
162 
163 	kzfree(d->hash);
164 	kzfree(d->name);
165 	kvfree(d->data);
166 	kzfree(d);
167 }
168 
aa_loaddata_kref(struct kref * kref)169 void aa_loaddata_kref(struct kref *kref)
170 {
171 	struct aa_loaddata *d = container_of(kref, struct aa_loaddata, count);
172 
173 	if (d) {
174 		INIT_WORK(&d->work, do_loaddata_free);
175 		schedule_work(&d->work);
176 	}
177 }
178 
aa_loaddata_alloc(size_t size)179 struct aa_loaddata *aa_loaddata_alloc(size_t size)
180 {
181 	struct aa_loaddata *d;
182 
183 	d = kzalloc(sizeof(*d), GFP_KERNEL);
184 	if (d == NULL)
185 		return ERR_PTR(-ENOMEM);
186 	d->data = kvzalloc(size, GFP_KERNEL);
187 	if (!d->data) {
188 		kfree(d);
189 		return ERR_PTR(-ENOMEM);
190 	}
191 	kref_init(&d->count);
192 	INIT_LIST_HEAD(&d->list);
193 
194 	return d;
195 }
196 
197 /* test if read will be in packed data bounds */
inbounds(struct aa_ext * e,size_t size)198 static bool inbounds(struct aa_ext *e, size_t size)
199 {
200 	return (size <= e->end - e->pos);
201 }
202 
kvmemdup(const void * src,size_t len)203 static void *kvmemdup(const void *src, size_t len)
204 {
205 	void *p = kvmalloc(len, GFP_KERNEL);
206 
207 	if (p)
208 		memcpy(p, src, len);
209 	return p;
210 }
211 
212 /**
213  * aa_u16_chunck - test and do bounds checking for a u16 size based chunk
214  * @e: serialized data read head (NOT NULL)
215  * @chunk: start address for chunk of data (NOT NULL)
216  *
217  * Returns: the size of chunk found with the read head at the end of the chunk.
218  */
unpack_u16_chunk(struct aa_ext * e,char ** chunk)219 static size_t unpack_u16_chunk(struct aa_ext *e, char **chunk)
220 {
221 	size_t size = 0;
222 	void *pos = e->pos;
223 
224 	if (!inbounds(e, sizeof(u16)))
225 		goto fail;
226 	size = le16_to_cpu(get_unaligned((__le16 *) e->pos));
227 	e->pos += sizeof(__le16);
228 	if (!inbounds(e, size))
229 		goto fail;
230 	*chunk = e->pos;
231 	e->pos += size;
232 	return size;
233 
234 fail:
235 	e->pos = pos;
236 	return 0;
237 }
238 
239 /* unpack control byte */
unpack_X(struct aa_ext * e,enum aa_code code)240 static bool unpack_X(struct aa_ext *e, enum aa_code code)
241 {
242 	if (!inbounds(e, 1))
243 		return 0;
244 	if (*(u8 *) e->pos != code)
245 		return 0;
246 	e->pos++;
247 	return 1;
248 }
249 
250 /**
251  * unpack_nameX - check is the next element is of type X with a name of @name
252  * @e: serialized data extent information  (NOT NULL)
253  * @code: type code
254  * @name: name to match to the serialized element.  (MAYBE NULL)
255  *
256  * check that the next serialized data element is of type X and has a tag
257  * name @name.  If @name is specified then there must be a matching
258  * name element in the stream.  If @name is NULL any name element will be
259  * skipped and only the typecode will be tested.
260  *
261  * Returns 1 on success (both type code and name tests match) and the read
262  * head is advanced past the headers
263  *
264  * Returns: 0 if either match fails, the read head does not move
265  */
unpack_nameX(struct aa_ext * e,enum aa_code code,const char * name)266 static bool unpack_nameX(struct aa_ext *e, enum aa_code code, const char *name)
267 {
268 	/*
269 	 * May need to reset pos if name or type doesn't match
270 	 */
271 	void *pos = e->pos;
272 	/*
273 	 * Check for presence of a tagname, and if present name size
274 	 * AA_NAME tag value is a u16.
275 	 */
276 	if (unpack_X(e, AA_NAME)) {
277 		char *tag = NULL;
278 		size_t size = unpack_u16_chunk(e, &tag);
279 		/* if a name is specified it must match. otherwise skip tag */
280 		if (name && (!size || tag[size-1] != '\0' || strcmp(name, tag)))
281 			goto fail;
282 	} else if (name) {
283 		/* if a name is specified and there is no name tag fail */
284 		goto fail;
285 	}
286 
287 	/* now check if type code matches */
288 	if (unpack_X(e, code))
289 		return 1;
290 
291 fail:
292 	e->pos = pos;
293 	return 0;
294 }
295 
unpack_u8(struct aa_ext * e,u8 * data,const char * name)296 static bool unpack_u8(struct aa_ext *e, u8 *data, const char *name)
297 {
298 	void *pos = e->pos;
299 
300 	if (unpack_nameX(e, AA_U8, name)) {
301 		if (!inbounds(e, sizeof(u8)))
302 			goto fail;
303 		if (data)
304 			*data = get_unaligned((u8 *)e->pos);
305 		e->pos += sizeof(u8);
306 		return 1;
307 	}
308 
309 fail:
310 	e->pos = pos;
311 	return 0;
312 }
313 
unpack_u32(struct aa_ext * e,u32 * data,const char * name)314 static bool unpack_u32(struct aa_ext *e, u32 *data, const char *name)
315 {
316 	void *pos = e->pos;
317 
318 	if (unpack_nameX(e, AA_U32, name)) {
319 		if (!inbounds(e, sizeof(u32)))
320 			goto fail;
321 		if (data)
322 			*data = le32_to_cpu(get_unaligned((__le32 *) e->pos));
323 		e->pos += sizeof(u32);
324 		return 1;
325 	}
326 
327 fail:
328 	e->pos = pos;
329 	return 0;
330 }
331 
unpack_u64(struct aa_ext * e,u64 * data,const char * name)332 static bool unpack_u64(struct aa_ext *e, u64 *data, const char *name)
333 {
334 	void *pos = e->pos;
335 
336 	if (unpack_nameX(e, AA_U64, name)) {
337 		if (!inbounds(e, sizeof(u64)))
338 			goto fail;
339 		if (data)
340 			*data = le64_to_cpu(get_unaligned((__le64 *) e->pos));
341 		e->pos += sizeof(u64);
342 		return 1;
343 	}
344 
345 fail:
346 	e->pos = pos;
347 	return 0;
348 }
349 
unpack_array(struct aa_ext * e,const char * name)350 static size_t unpack_array(struct aa_ext *e, const char *name)
351 {
352 	void *pos = e->pos;
353 
354 	if (unpack_nameX(e, AA_ARRAY, name)) {
355 		int size;
356 		if (!inbounds(e, sizeof(u16)))
357 			goto fail;
358 		size = (int)le16_to_cpu(get_unaligned((__le16 *) e->pos));
359 		e->pos += sizeof(u16);
360 		return size;
361 	}
362 
363 fail:
364 	e->pos = pos;
365 	return 0;
366 }
367 
unpack_blob(struct aa_ext * e,char ** blob,const char * name)368 static size_t unpack_blob(struct aa_ext *e, char **blob, const char *name)
369 {
370 	void *pos = e->pos;
371 
372 	if (unpack_nameX(e, AA_BLOB, name)) {
373 		u32 size;
374 		if (!inbounds(e, sizeof(u32)))
375 			goto fail;
376 		size = le32_to_cpu(get_unaligned((__le32 *) e->pos));
377 		e->pos += sizeof(u32);
378 		if (inbounds(e, (size_t) size)) {
379 			*blob = e->pos;
380 			e->pos += size;
381 			return size;
382 		}
383 	}
384 
385 fail:
386 	e->pos = pos;
387 	return 0;
388 }
389 
unpack_str(struct aa_ext * e,const char ** string,const char * name)390 static int unpack_str(struct aa_ext *e, const char **string, const char *name)
391 {
392 	char *src_str;
393 	size_t size = 0;
394 	void *pos = e->pos;
395 	*string = NULL;
396 	if (unpack_nameX(e, AA_STRING, name)) {
397 		size = unpack_u16_chunk(e, &src_str);
398 		if (size) {
399 			/* strings are null terminated, length is size - 1 */
400 			if (src_str[size - 1] != 0)
401 				goto fail;
402 			*string = src_str;
403 
404 			return size;
405 		}
406 	}
407 
408 fail:
409 	e->pos = pos;
410 	return 0;
411 }
412 
unpack_strdup(struct aa_ext * e,char ** string,const char * name)413 static int unpack_strdup(struct aa_ext *e, char **string, const char *name)
414 {
415 	const char *tmp;
416 	void *pos = e->pos;
417 	int res = unpack_str(e, &tmp, name);
418 	*string = NULL;
419 
420 	if (!res)
421 		return 0;
422 
423 	*string = kmemdup(tmp, res, GFP_KERNEL);
424 	if (!*string) {
425 		e->pos = pos;
426 		return 0;
427 	}
428 
429 	return res;
430 }
431 
432 
433 /**
434  * unpack_dfa - unpack a file rule dfa
435  * @e: serialized data extent information (NOT NULL)
436  *
437  * returns dfa or ERR_PTR or NULL if no dfa
438  */
unpack_dfa(struct aa_ext * e)439 static struct aa_dfa *unpack_dfa(struct aa_ext *e)
440 {
441 	char *blob = NULL;
442 	size_t size;
443 	struct aa_dfa *dfa = NULL;
444 
445 	size = unpack_blob(e, &blob, "aadfa");
446 	if (size) {
447 		/*
448 		 * The dfa is aligned with in the blob to 8 bytes
449 		 * from the beginning of the stream.
450 		 * alignment adjust needed by dfa unpack
451 		 */
452 		size_t sz = blob - (char *) e->start -
453 			((e->pos - e->start) & 7);
454 		size_t pad = ALIGN(sz, 8) - sz;
455 		int flags = TO_ACCEPT1_FLAG(YYTD_DATA32) |
456 			TO_ACCEPT2_FLAG(YYTD_DATA32) | DFA_FLAG_VERIFY_STATES;
457 		dfa = aa_dfa_unpack(blob + pad, size - pad, flags);
458 
459 		if (IS_ERR(dfa))
460 			return dfa;
461 
462 	}
463 
464 	return dfa;
465 }
466 
467 /**
468  * unpack_trans_table - unpack a profile transition table
469  * @e: serialized data extent information  (NOT NULL)
470  * @profile: profile to add the accept table to (NOT NULL)
471  *
472  * Returns: 1 if table successfully unpacked
473  */
unpack_trans_table(struct aa_ext * e,struct aa_profile * profile)474 static bool unpack_trans_table(struct aa_ext *e, struct aa_profile *profile)
475 {
476 	void *saved_pos = e->pos;
477 
478 	/* exec table is optional */
479 	if (unpack_nameX(e, AA_STRUCT, "xtable")) {
480 		int i, size;
481 
482 		size = unpack_array(e, NULL);
483 		/* currently 4 exec bits and entries 0-3 are reserved iupcx */
484 		if (size > 16 - 4)
485 			goto fail;
486 		profile->file.trans.table = kcalloc(size, sizeof(char *),
487 						    GFP_KERNEL);
488 		if (!profile->file.trans.table)
489 			goto fail;
490 
491 		profile->file.trans.size = size;
492 		for (i = 0; i < size; i++) {
493 			char *str;
494 			int c, j, pos, size2 = unpack_strdup(e, &str, NULL);
495 			/* unpack_strdup verifies that the last character is
496 			 * null termination byte.
497 			 */
498 			if (!size2)
499 				goto fail;
500 			profile->file.trans.table[i] = str;
501 			/* verify that name doesn't start with space */
502 			if (isspace(*str))
503 				goto fail;
504 
505 			/* count internal #  of internal \0 */
506 			for (c = j = 0; j < size2 - 1; j++) {
507 				if (!str[j]) {
508 					pos = j;
509 					c++;
510 				}
511 			}
512 			if (*str == ':') {
513 				/* first character after : must be valid */
514 				if (!str[1])
515 					goto fail;
516 				/* beginning with : requires an embedded \0,
517 				 * verify that exactly 1 internal \0 exists
518 				 * trailing \0 already verified by unpack_strdup
519 				 *
520 				 * convert \0 back to : for label_parse
521 				 */
522 				if (c == 1)
523 					str[pos] = ':';
524 				else if (c > 1)
525 					goto fail;
526 			} else if (c)
527 				/* fail - all other cases with embedded \0 */
528 				goto fail;
529 		}
530 		if (!unpack_nameX(e, AA_ARRAYEND, NULL))
531 			goto fail;
532 		if (!unpack_nameX(e, AA_STRUCTEND, NULL))
533 			goto fail;
534 	}
535 	return 1;
536 
537 fail:
538 	aa_free_domain_entries(&profile->file.trans);
539 	e->pos = saved_pos;
540 	return 0;
541 }
542 
unpack_xattrs(struct aa_ext * e,struct aa_profile * profile)543 static bool unpack_xattrs(struct aa_ext *e, struct aa_profile *profile)
544 {
545 	void *pos = e->pos;
546 
547 	if (unpack_nameX(e, AA_STRUCT, "xattrs")) {
548 		int i, size;
549 
550 		size = unpack_array(e, NULL);
551 		profile->xattr_count = size;
552 		profile->xattrs = kcalloc(size, sizeof(char *), GFP_KERNEL);
553 		if (!profile->xattrs)
554 			goto fail;
555 		for (i = 0; i < size; i++) {
556 			if (!unpack_strdup(e, &profile->xattrs[i], NULL))
557 				goto fail;
558 		}
559 		if (!unpack_nameX(e, AA_ARRAYEND, NULL))
560 			goto fail;
561 		if (!unpack_nameX(e, AA_STRUCTEND, NULL))
562 			goto fail;
563 	}
564 
565 	return 1;
566 
567 fail:
568 	e->pos = pos;
569 	return 0;
570 }
571 
unpack_secmark(struct aa_ext * e,struct aa_profile * profile)572 static bool unpack_secmark(struct aa_ext *e, struct aa_profile *profile)
573 {
574 	void *pos = e->pos;
575 	int i, size;
576 
577 	if (unpack_nameX(e, AA_STRUCT, "secmark")) {
578 		size = unpack_array(e, NULL);
579 
580 		profile->secmark = kcalloc(size, sizeof(struct aa_secmark),
581 					   GFP_KERNEL);
582 		if (!profile->secmark)
583 			goto fail;
584 
585 		profile->secmark_count = size;
586 
587 		for (i = 0; i < size; i++) {
588 			if (!unpack_u8(e, &profile->secmark[i].audit, NULL))
589 				goto fail;
590 			if (!unpack_u8(e, &profile->secmark[i].deny, NULL))
591 				goto fail;
592 			if (!unpack_strdup(e, &profile->secmark[i].label, NULL))
593 				goto fail;
594 		}
595 		if (!unpack_nameX(e, AA_ARRAYEND, NULL))
596 			goto fail;
597 		if (!unpack_nameX(e, AA_STRUCTEND, NULL))
598 			goto fail;
599 	}
600 
601 	return 1;
602 
603 fail:
604 	if (profile->secmark) {
605 		for (i = 0; i < size; i++)
606 			kfree(profile->secmark[i].label);
607 		kfree(profile->secmark);
608 		profile->secmark_count = 0;
609 		profile->secmark = NULL;
610 	}
611 
612 	e->pos = pos;
613 	return 0;
614 }
615 
unpack_rlimits(struct aa_ext * e,struct aa_profile * profile)616 static bool unpack_rlimits(struct aa_ext *e, struct aa_profile *profile)
617 {
618 	void *pos = e->pos;
619 
620 	/* rlimits are optional */
621 	if (unpack_nameX(e, AA_STRUCT, "rlimits")) {
622 		int i, size;
623 		u32 tmp = 0;
624 		if (!unpack_u32(e, &tmp, NULL))
625 			goto fail;
626 		profile->rlimits.mask = tmp;
627 
628 		size = unpack_array(e, NULL);
629 		if (size > RLIM_NLIMITS)
630 			goto fail;
631 		for (i = 0; i < size; i++) {
632 			u64 tmp2 = 0;
633 			int a = aa_map_resource(i);
634 			if (!unpack_u64(e, &tmp2, NULL))
635 				goto fail;
636 			profile->rlimits.limits[a].rlim_max = tmp2;
637 		}
638 		if (!unpack_nameX(e, AA_ARRAYEND, NULL))
639 			goto fail;
640 		if (!unpack_nameX(e, AA_STRUCTEND, NULL))
641 			goto fail;
642 	}
643 	return 1;
644 
645 fail:
646 	e->pos = pos;
647 	return 0;
648 }
649 
strhash(const void * data,u32 len,u32 seed)650 static u32 strhash(const void *data, u32 len, u32 seed)
651 {
652 	const char * const *key = data;
653 
654 	return jhash(*key, strlen(*key), seed);
655 }
656 
datacmp(struct rhashtable_compare_arg * arg,const void * obj)657 static int datacmp(struct rhashtable_compare_arg *arg, const void *obj)
658 {
659 	const struct aa_data *data = obj;
660 	const char * const *key = arg->key;
661 
662 	return strcmp(data->key, *key);
663 }
664 
665 /**
666  * unpack_profile - unpack a serialized profile
667  * @e: serialized data extent information (NOT NULL)
668  *
669  * NOTE: unpack profile sets audit struct if there is a failure
670  */
unpack_profile(struct aa_ext * e,char ** ns_name)671 static struct aa_profile *unpack_profile(struct aa_ext *e, char **ns_name)
672 {
673 	struct aa_profile *profile = NULL;
674 	const char *tmpname, *tmpns = NULL, *name = NULL;
675 	const char *info = "failed to unpack profile";
676 	size_t ns_len;
677 	struct rhashtable_params params = { 0 };
678 	char *key = NULL;
679 	struct aa_data *data;
680 	int i, error = -EPROTO;
681 	kernel_cap_t tmpcap;
682 	u32 tmp;
683 
684 	*ns_name = NULL;
685 
686 	/* check that we have the right struct being passed */
687 	if (!unpack_nameX(e, AA_STRUCT, "profile"))
688 		goto fail;
689 	if (!unpack_str(e, &name, NULL))
690 		goto fail;
691 	if (*name == '\0')
692 		goto fail;
693 
694 	tmpname = aa_splitn_fqname(name, strlen(name), &tmpns, &ns_len);
695 	if (tmpns) {
696 		if (!tmpname) {
697 			info = "empty profile name";
698 			goto fail;
699 		}
700 		*ns_name = kstrndup(tmpns, ns_len, GFP_KERNEL);
701 		if (!*ns_name) {
702 			info = "out of memory";
703 			goto fail;
704 		}
705 		name = tmpname;
706 	}
707 
708 	profile = aa_alloc_profile(name, NULL, GFP_KERNEL);
709 	if (!profile)
710 		return ERR_PTR(-ENOMEM);
711 
712 	/* profile renaming is optional */
713 	(void) unpack_str(e, &profile->rename, "rename");
714 
715 	/* attachment string is optional */
716 	(void) unpack_str(e, &profile->attach, "attach");
717 
718 	/* xmatch is optional and may be NULL */
719 	profile->xmatch = unpack_dfa(e);
720 	if (IS_ERR(profile->xmatch)) {
721 		error = PTR_ERR(profile->xmatch);
722 		profile->xmatch = NULL;
723 		info = "bad xmatch";
724 		goto fail;
725 	}
726 	/* xmatch_len is not optional if xmatch is set */
727 	if (profile->xmatch) {
728 		if (!unpack_u32(e, &tmp, NULL)) {
729 			info = "missing xmatch len";
730 			goto fail;
731 		}
732 		profile->xmatch_len = tmp;
733 	}
734 
735 	/* disconnected attachment string is optional */
736 	(void) unpack_str(e, &profile->disconnected, "disconnected");
737 
738 	/* per profile debug flags (complain, audit) */
739 	if (!unpack_nameX(e, AA_STRUCT, "flags")) {
740 		info = "profile missing flags";
741 		goto fail;
742 	}
743 	info = "failed to unpack profile flags";
744 	if (!unpack_u32(e, &tmp, NULL))
745 		goto fail;
746 	if (tmp & PACKED_FLAG_HAT)
747 		profile->label.flags |= FLAG_HAT;
748 	if (!unpack_u32(e, &tmp, NULL))
749 		goto fail;
750 	if (tmp == PACKED_MODE_COMPLAIN || (e->version & FORCE_COMPLAIN_FLAG))
751 		profile->mode = APPARMOR_COMPLAIN;
752 	else if (tmp == PACKED_MODE_KILL)
753 		profile->mode = APPARMOR_KILL;
754 	else if (tmp == PACKED_MODE_UNCONFINED)
755 		profile->mode = APPARMOR_UNCONFINED;
756 	if (!unpack_u32(e, &tmp, NULL))
757 		goto fail;
758 	if (tmp)
759 		profile->audit = AUDIT_ALL;
760 
761 	if (!unpack_nameX(e, AA_STRUCTEND, NULL))
762 		goto fail;
763 
764 	/* path_flags is optional */
765 	if (unpack_u32(e, &profile->path_flags, "path_flags"))
766 		profile->path_flags |= profile->label.flags &
767 			PATH_MEDIATE_DELETED;
768 	else
769 		/* set a default value if path_flags field is not present */
770 		profile->path_flags = PATH_MEDIATE_DELETED;
771 
772 	info = "failed to unpack profile capabilities";
773 	if (!unpack_u32(e, &(profile->caps.allow.cap[0]), NULL))
774 		goto fail;
775 	if (!unpack_u32(e, &(profile->caps.audit.cap[0]), NULL))
776 		goto fail;
777 	if (!unpack_u32(e, &(profile->caps.quiet.cap[0]), NULL))
778 		goto fail;
779 	if (!unpack_u32(e, &tmpcap.cap[0], NULL))
780 		goto fail;
781 
782 	info = "failed to unpack upper profile capabilities";
783 	if (unpack_nameX(e, AA_STRUCT, "caps64")) {
784 		/* optional upper half of 64 bit caps */
785 		if (!unpack_u32(e, &(profile->caps.allow.cap[1]), NULL))
786 			goto fail;
787 		if (!unpack_u32(e, &(profile->caps.audit.cap[1]), NULL))
788 			goto fail;
789 		if (!unpack_u32(e, &(profile->caps.quiet.cap[1]), NULL))
790 			goto fail;
791 		if (!unpack_u32(e, &(tmpcap.cap[1]), NULL))
792 			goto fail;
793 		if (!unpack_nameX(e, AA_STRUCTEND, NULL))
794 			goto fail;
795 	}
796 
797 	info = "failed to unpack extended profile capabilities";
798 	if (unpack_nameX(e, AA_STRUCT, "capsx")) {
799 		/* optional extended caps mediation mask */
800 		if (!unpack_u32(e, &(profile->caps.extended.cap[0]), NULL))
801 			goto fail;
802 		if (!unpack_u32(e, &(profile->caps.extended.cap[1]), NULL))
803 			goto fail;
804 		if (!unpack_nameX(e, AA_STRUCTEND, NULL))
805 			goto fail;
806 	}
807 
808 	if (!unpack_xattrs(e, profile)) {
809 		info = "failed to unpack profile xattrs";
810 		goto fail;
811 	}
812 
813 	if (!unpack_rlimits(e, profile)) {
814 		info = "failed to unpack profile rlimits";
815 		goto fail;
816 	}
817 
818 	if (!unpack_secmark(e, profile)) {
819 		info = "failed to unpack profile secmark rules";
820 		goto fail;
821 	}
822 
823 	if (unpack_nameX(e, AA_STRUCT, "policydb")) {
824 		/* generic policy dfa - optional and may be NULL */
825 		info = "failed to unpack policydb";
826 		profile->policy.dfa = unpack_dfa(e);
827 		if (IS_ERR(profile->policy.dfa)) {
828 			error = PTR_ERR(profile->policy.dfa);
829 			profile->policy.dfa = NULL;
830 			goto fail;
831 		} else if (!profile->policy.dfa) {
832 			error = -EPROTO;
833 			goto fail;
834 		}
835 		if (!unpack_u32(e, &profile->policy.start[0], "start"))
836 			/* default start state */
837 			profile->policy.start[0] = DFA_START;
838 		/* setup class index */
839 		for (i = AA_CLASS_FILE; i <= AA_CLASS_LAST; i++) {
840 			profile->policy.start[i] =
841 				aa_dfa_next(profile->policy.dfa,
842 					    profile->policy.start[0],
843 					    i);
844 		}
845 		if (!unpack_nameX(e, AA_STRUCTEND, NULL))
846 			goto fail;
847 	} else
848 		profile->policy.dfa = aa_get_dfa(nulldfa);
849 
850 	/* get file rules */
851 	profile->file.dfa = unpack_dfa(e);
852 	if (IS_ERR(profile->file.dfa)) {
853 		error = PTR_ERR(profile->file.dfa);
854 		profile->file.dfa = NULL;
855 		info = "failed to unpack profile file rules";
856 		goto fail;
857 	} else if (profile->file.dfa) {
858 		if (!unpack_u32(e, &profile->file.start, "dfa_start"))
859 			/* default start state */
860 			profile->file.start = DFA_START;
861 	} else if (profile->policy.dfa &&
862 		   profile->policy.start[AA_CLASS_FILE]) {
863 		profile->file.dfa = aa_get_dfa(profile->policy.dfa);
864 		profile->file.start = profile->policy.start[AA_CLASS_FILE];
865 	} else
866 		profile->file.dfa = aa_get_dfa(nulldfa);
867 
868 	if (!unpack_trans_table(e, profile)) {
869 		info = "failed to unpack profile transition table";
870 		goto fail;
871 	}
872 
873 	if (unpack_nameX(e, AA_STRUCT, "data")) {
874 		info = "out of memory";
875 		profile->data = kzalloc(sizeof(*profile->data), GFP_KERNEL);
876 		if (!profile->data)
877 			goto fail;
878 
879 		params.nelem_hint = 3;
880 		params.key_len = sizeof(void *);
881 		params.key_offset = offsetof(struct aa_data, key);
882 		params.head_offset = offsetof(struct aa_data, head);
883 		params.hashfn = strhash;
884 		params.obj_cmpfn = datacmp;
885 
886 		if (rhashtable_init(profile->data, &params)) {
887 			info = "failed to init key, value hash table";
888 			goto fail;
889 		}
890 
891 		while (unpack_strdup(e, &key, NULL)) {
892 			data = kzalloc(sizeof(*data), GFP_KERNEL);
893 			if (!data) {
894 				kzfree(key);
895 				goto fail;
896 			}
897 
898 			data->key = key;
899 			data->size = unpack_blob(e, &data->data, NULL);
900 			data->data = kvmemdup(data->data, data->size);
901 			if (data->size && !data->data) {
902 				kzfree(data->key);
903 				kzfree(data);
904 				goto fail;
905 			}
906 
907 			rhashtable_insert_fast(profile->data, &data->head,
908 					       profile->data->p);
909 		}
910 
911 		if (!unpack_nameX(e, AA_STRUCTEND, NULL)) {
912 			info = "failed to unpack end of key, value data table";
913 			goto fail;
914 		}
915 	}
916 
917 	if (!unpack_nameX(e, AA_STRUCTEND, NULL)) {
918 		info = "failed to unpack end of profile";
919 		goto fail;
920 	}
921 
922 	return profile;
923 
924 fail:
925 	if (profile)
926 		name = NULL;
927 	else if (!name)
928 		name = "unknown";
929 	audit_iface(profile, NULL, name, info, e, error);
930 	aa_free_profile(profile);
931 
932 	return ERR_PTR(error);
933 }
934 
935 /**
936  * verify_head - unpack serialized stream header
937  * @e: serialized data read head (NOT NULL)
938  * @required: whether the header is required or optional
939  * @ns: Returns - namespace if one is specified else NULL (NOT NULL)
940  *
941  * Returns: error or 0 if header is good
942  */
verify_header(struct aa_ext * e,int required,const char ** ns)943 static int verify_header(struct aa_ext *e, int required, const char **ns)
944 {
945 	int error = -EPROTONOSUPPORT;
946 	const char *name = NULL;
947 	*ns = NULL;
948 
949 	/* get the interface version */
950 	if (!unpack_u32(e, &e->version, "version")) {
951 		if (required) {
952 			audit_iface(NULL, NULL, NULL, "invalid profile format",
953 				    e, error);
954 			return error;
955 		}
956 	}
957 
958 	/* Check that the interface version is currently supported.
959 	 * if not specified use previous version
960 	 * Mask off everything that is not kernel abi version
961 	 */
962 	if (VERSION_LT(e->version, v5) || VERSION_GT(e->version, v8)) {
963 		audit_iface(NULL, NULL, NULL, "unsupported interface version",
964 			    e, error);
965 		return error;
966 	}
967 
968 	/* read the namespace if present */
969 	if (unpack_str(e, &name, "namespace")) {
970 		if (*name == '\0') {
971 			audit_iface(NULL, NULL, NULL, "invalid namespace name",
972 				    e, error);
973 			return error;
974 		}
975 		if (*ns && strcmp(*ns, name))
976 			audit_iface(NULL, NULL, NULL, "invalid ns change", e,
977 				    error);
978 		else if (!*ns)
979 			*ns = name;
980 	}
981 
982 	return 0;
983 }
984 
verify_xindex(int xindex,int table_size)985 static bool verify_xindex(int xindex, int table_size)
986 {
987 	int index, xtype;
988 	xtype = xindex & AA_X_TYPE_MASK;
989 	index = xindex & AA_X_INDEX_MASK;
990 	if (xtype == AA_X_TABLE && index >= table_size)
991 		return 0;
992 	return 1;
993 }
994 
995 /* verify dfa xindexes are in range of transition tables */
verify_dfa_xindex(struct aa_dfa * dfa,int table_size)996 static bool verify_dfa_xindex(struct aa_dfa *dfa, int table_size)
997 {
998 	int i;
999 	for (i = 0; i < dfa->tables[YYTD_ID_ACCEPT]->td_lolen; i++) {
1000 		if (!verify_xindex(dfa_user_xindex(dfa, i), table_size))
1001 			return 0;
1002 		if (!verify_xindex(dfa_other_xindex(dfa, i), table_size))
1003 			return 0;
1004 	}
1005 	return 1;
1006 }
1007 
1008 /**
1009  * verify_profile - Do post unpack analysis to verify profile consistency
1010  * @profile: profile to verify (NOT NULL)
1011  *
1012  * Returns: 0 if passes verification else error
1013  */
verify_profile(struct aa_profile * profile)1014 static int verify_profile(struct aa_profile *profile)
1015 {
1016 	if (profile->file.dfa &&
1017 	    !verify_dfa_xindex(profile->file.dfa,
1018 			       profile->file.trans.size)) {
1019 		audit_iface(profile, NULL, NULL, "Invalid named transition",
1020 			    NULL, -EPROTO);
1021 		return -EPROTO;
1022 	}
1023 
1024 	return 0;
1025 }
1026 
aa_load_ent_free(struct aa_load_ent * ent)1027 void aa_load_ent_free(struct aa_load_ent *ent)
1028 {
1029 	if (ent) {
1030 		aa_put_profile(ent->rename);
1031 		aa_put_profile(ent->old);
1032 		aa_put_profile(ent->new);
1033 		kfree(ent->ns_name);
1034 		kzfree(ent);
1035 	}
1036 }
1037 
aa_load_ent_alloc(void)1038 struct aa_load_ent *aa_load_ent_alloc(void)
1039 {
1040 	struct aa_load_ent *ent = kzalloc(sizeof(*ent), GFP_KERNEL);
1041 	if (ent)
1042 		INIT_LIST_HEAD(&ent->list);
1043 	return ent;
1044 }
1045 
1046 /**
1047  * aa_unpack - unpack packed binary profile(s) data loaded from user space
1048  * @udata: user data copied to kmem  (NOT NULL)
1049  * @lh: list to place unpacked profiles in a aa_repl_ws
1050  * @ns: Returns namespace profile is in if specified else NULL (NOT NULL)
1051  *
1052  * Unpack user data and return refcounted allocated profile(s) stored in
1053  * @lh in order of discovery, with the list chain stored in base.list
1054  * or error
1055  *
1056  * Returns: profile(s) on @lh else error pointer if fails to unpack
1057  */
aa_unpack(struct aa_loaddata * udata,struct list_head * lh,const char ** ns)1058 int aa_unpack(struct aa_loaddata *udata, struct list_head *lh,
1059 	      const char **ns)
1060 {
1061 	struct aa_load_ent *tmp, *ent;
1062 	struct aa_profile *profile = NULL;
1063 	int error;
1064 	struct aa_ext e = {
1065 		.start = udata->data,
1066 		.end = udata->data + udata->size,
1067 		.pos = udata->data,
1068 	};
1069 
1070 	*ns = NULL;
1071 	while (e.pos < e.end) {
1072 		char *ns_name = NULL;
1073 		void *start;
1074 		error = verify_header(&e, e.pos == e.start, ns);
1075 		if (error)
1076 			goto fail;
1077 
1078 		start = e.pos;
1079 		profile = unpack_profile(&e, &ns_name);
1080 		if (IS_ERR(profile)) {
1081 			error = PTR_ERR(profile);
1082 			goto fail;
1083 		}
1084 
1085 		error = verify_profile(profile);
1086 		if (error)
1087 			goto fail_profile;
1088 
1089 		if (aa_g_hash_policy)
1090 			error = aa_calc_profile_hash(profile, e.version, start,
1091 						     e.pos - start);
1092 		if (error)
1093 			goto fail_profile;
1094 
1095 		ent = aa_load_ent_alloc();
1096 		if (!ent) {
1097 			error = -ENOMEM;
1098 			goto fail_profile;
1099 		}
1100 
1101 		ent->new = profile;
1102 		ent->ns_name = ns_name;
1103 		list_add_tail(&ent->list, lh);
1104 	}
1105 	udata->abi = e.version & K_ABI_MASK;
1106 	if (aa_g_hash_policy) {
1107 		udata->hash = aa_calc_hash(udata->data, udata->size);
1108 		if (IS_ERR(udata->hash)) {
1109 			error = PTR_ERR(udata->hash);
1110 			udata->hash = NULL;
1111 			goto fail;
1112 		}
1113 	}
1114 	return 0;
1115 
1116 fail_profile:
1117 	aa_put_profile(profile);
1118 
1119 fail:
1120 	list_for_each_entry_safe(ent, tmp, lh, list) {
1121 		list_del_init(&ent->list);
1122 		aa_load_ent_free(ent);
1123 	}
1124 
1125 	return error;
1126 }
1127