ima_main.c 27.2 KB
Newer Older
1
// SPDX-License-Identifier: GPL-2.0-only
2
/*
3 4
 * Integrity Measurement Architecture
 *
5 6 7 8 9 10 11 12 13
 * Copyright (C) 2005,2006,2007,2008 IBM Corporation
 *
 * Authors:
 * Reiner Sailer <sailer@watson.ibm.com>
 * Serge Hallyn <serue@us.ibm.com>
 * Kylene Hall <kylene@us.ibm.com>
 * Mimi Zohar <zohar@us.ibm.com>
 *
 * File: ima_main.c
14
 *	implements the IMA hooks: ima_bprm_check, ima_file_mmap,
15
 *	and ima_file_check.
16
 */
17

18
#include <linux/module.h>
19 20
#include <linux/file.h>
#include <linux/binfmts.h>
21
#include <linux/kernel_read_file.h>
22 23
#include <linux/mount.h>
#include <linux/mman.h>
24
#include <linux/slab.h>
M
Mimi Zohar 已提交
25
#include <linux/xattr.h>
26
#include <linux/ima.h>
27
#include <linux/iversion.h>
28
#include <linux/fs.h>
29 30 31

#include "ima.h"

M
Mimi Zohar 已提交
32 33 34 35 36 37
#ifdef CONFIG_IMA_APPRAISE
int ima_appraise = IMA_APPRAISE_ENFORCE;
#else
int ima_appraise;
#endif

38
int ima_hash_algo = HASH_ALGO_SHA1;
39 40 41 42

/* Actions (measure/appraisal) for which digest lists can be used */
int ima_digest_list_actions;

43
static int hash_setup_done;
44

45 46 47 48
static struct notifier_block ima_lsm_policy_notifier = {
	.notifier_call = ima_lsm_policy_change,
};

49 50
static int __init hash_setup(char *str)
{
51 52 53 54 55 56 57
	struct ima_template_desc *template_desc = ima_template_desc_current();
	int i;

	if (hash_setup_done)
		return 1;

	if (strcmp(template_desc->name, IMA_TEMPLATE_IMA_NAME) == 0) {
58
		if (strncmp(str, "sha1", 4) == 0) {
59
			ima_hash_algo = HASH_ALGO_SHA1;
60
		} else if (strncmp(str, "md5", 3) == 0) {
61
			ima_hash_algo = HASH_ALGO_MD5;
62 63 64
		} else {
			pr_err("invalid hash algorithm \"%s\" for template \"%s\"",
				str, IMA_TEMPLATE_IMA_NAME);
65
			return 1;
66
		}
67 68 69
		goto out;
	}

Y
Yisheng Xie 已提交
70
	i = match_string(hash_algo_name, HASH_ALGO__LAST, str);
71 72
	if (i < 0) {
		pr_err("invalid hash algorithm \"%s\"", str);
73
		return 1;
74
	}
Y
Yisheng Xie 已提交
75 76

	ima_hash_algo = i;
77 78
out:
	hash_setup_done = 1;
79 80 81 82
	return 1;
}
__setup("ima_hash=", hash_setup);

83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103
/* Prevent mmap'ing a file execute that is already mmap'ed write */
static int mmap_violation_check(enum ima_hooks func, struct file *file,
				char **pathbuf, const char **pathname,
				char *filename)
{
	struct inode *inode;
	int rc = 0;

	if ((func == MMAP_CHECK) && mapping_writably_mapped(file->f_mapping)) {
		rc = -ETXTBSY;
		inode = file_inode(file);

		if (!*pathbuf)	/* ima_rdwr_violation possibly pre-fetched */
			*pathname = ima_d_path(&file->f_path, pathbuf,
					       filename);
		integrity_audit_msg(AUDIT_INTEGRITY_DATA, inode, *pathname,
				    "mmap_file", "mmapped_writers", rc, 0);
	}
	return rc;
}

M
Mimi Zohar 已提交
104
/*
105
 * ima_rdwr_violation_check
M
Mimi Zohar 已提交
106
 *
107
 * Only invalidate the PCR for measured files:
108
 *	- Opening a file for write when already open for read,
M
Mimi Zohar 已提交
109 110
 *	  results in a time of measure, time of use (ToMToU) error.
 *	- Opening a file for read when already open for write,
111
 *	  could result in a file measurement error.
M
Mimi Zohar 已提交
112 113
 *
 */
114 115
static void ima_rdwr_violation_check(struct file *file,
				     struct integrity_iint_cache *iint,
116
				     int must_measure,
117
				     char **pathbuf,
118 119
				     const char **pathname,
				     char *filename)
M
Mimi Zohar 已提交
120
{
121
	struct inode *inode = file_inode(file);
M
Mimi Zohar 已提交
122
	fmode_t mode = file->f_mode;
123
	bool send_tomtou = false, send_writers = false;
124

M
Mimi Zohar 已提交
125
	if (mode & FMODE_WRITE) {
126
		if (atomic_read(&inode->i_readcount) && IS_IMA(inode)) {
127 128
			if (!iint)
				iint = integrity_iint_find(inode);
129
			/* IMA_MEASURE is set from reader side */
130 131
			if (iint && test_bit(IMA_MUST_MEASURE,
						&iint->atomic_flags))
132 133
				send_tomtou = true;
		}
134
	} else {
135 136
		if (must_measure)
			set_bit(IMA_MUST_MEASURE, &iint->atomic_flags);
N
Nikolay Borisov 已提交
137
		if (inode_is_open_for_write(inode) && must_measure)
138
			send_writers = true;
M
Mimi Zohar 已提交
139
	}
140

141 142 143
	if (!send_tomtou && !send_writers)
		return;

144
	*pathname = ima_d_path(&file->f_path, pathbuf, filename);
145

146
	if (send_tomtou)
147 148
		ima_add_violation(file, *pathname, iint,
				  "invalid_pcr", "ToMToU");
149
	if (send_writers)
150
		ima_add_violation(file, *pathname, iint,
151
				  "invalid_pcr", "open_writers");
M
Mimi Zohar 已提交
152 153
}

154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205
static enum hash_algo ima_get_hash_algo(struct evm_ima_xattr_data *xattr_value,
					int xattr_len)
{
	struct signature_v2_hdr *sig;
	enum hash_algo ret;

	if (!xattr_value || xattr_len < 2)
		/* return default hash algo */
		return ima_hash_algo;

	switch (xattr_value->type) {
	case EVM_IMA_XATTR_DIGSIG:
		sig = (typeof(sig))xattr_value;
		if (sig->version != 2 || xattr_len < sizeof(*sig))
			return ima_hash_algo;
		return sig->hash_algo;
		break;
	case IMA_XATTR_DIGEST_NG:
		/* first byte contains algorithm id */
		ret = xattr_value->data[0];
		if (ret < HASH_ALGO__LAST)
			return ret;
		break;
	case IMA_XATTR_DIGEST:
		/* this is for backward compatibility */
		if (xattr_len == 21) {
			unsigned int zero = 0;
			if (!memcmp(&xattr_value->data[16], &zero, 4))
				return HASH_ALGO_MD5;
			else
				return HASH_ALGO_SHA1;
		} else if (xattr_len == 17)
			return HASH_ALGO_MD5;
		break;
	}

	/* return default hash algo */
	return ima_hash_algo;
}

static int ima_read_xattr(struct dentry *dentry,
			  struct evm_ima_xattr_data **xattr_value)
{
	ssize_t ret;

	ret = vfs_getxattr_alloc(dentry, XATTR_NAME_IMA, (char **)xattr_value,
				 0, GFP_NOFS);
	if (ret == -EOPNOTSUPP)
		ret = 0;
	return ret;
}

206
static void ima_check_last_writer(struct integrity_iint_cache *iint,
M
Mimi Zohar 已提交
207
				  struct inode *inode, struct file *file)
E
Eric Paris 已提交
208
{
A
Al Viro 已提交
209
	fmode_t mode = file->f_mode;
210
	bool update;
E
Eric Paris 已提交
211

M
Mimi Zohar 已提交
212 213 214
	if (!(mode & FMODE_WRITE))
		return;

215
	mutex_lock(&iint->mutex);
216
	if (atomic_read(&inode->i_writecount) == 1) {
217 218
		update = test_and_clear_bit(IMA_UPDATE_XATTR,
					    &iint->atomic_flags);
219
		if (!IS_I_VERSION(inode) ||
220
		    !inode_eq_iversion(inode, iint->version) ||
221 222
		    (iint->flags & IMA_NEW_FILE)) {
			iint->flags &= ~(IMA_DONE_MASK | IMA_NEW_FILE);
223
			iint->measured_pcrs = 0;
224
			if (update)
225 226
				ima_update_xattr(iint, file);
		}
M
Mimi Zohar 已提交
227
	}
228
	mutex_unlock(&iint->mutex);
E
Eric Paris 已提交
229 230
}

231 232 233 234
/**
 * ima_file_free - called on __fput()
 * @file: pointer to file structure being freed
 *
235
 * Flag files that changed, based on i_version
236 237 238
 */
void ima_file_free(struct file *file)
{
A
Al Viro 已提交
239
	struct inode *inode = file_inode(file);
240
	struct integrity_iint_cache *iint;
241

242
	if (!ima_policy_flag || !S_ISREG(inode->i_mode))
243
		return;
244

245
	iint = integrity_iint_find(inode);
M
Mimi Zohar 已提交
246 247
	if (!iint)
		return;
248

M
Mimi Zohar 已提交
249
	ima_check_last_writer(iint, inode, file);
250 251
}

252 253
static int process_measurement(struct file *file, const struct cred *cred,
			       u32 secid, char *buf, loff_t size, int mask,
254
			       enum ima_hooks func)
255
{
A
Al Viro 已提交
256
	struct inode *inode = file_inode(file);
257
	struct integrity_iint_cache *iint = NULL;
258
	struct ima_template_desc *template_desc = NULL;
259
	char *pathbuf = NULL;
260
	char filename[NAME_MAX];
261
	const char *pathname = NULL;
262
	int rc = 0, action, must_appraise = 0;
263
	int pcr = CONFIG_IMA_MEASURE_PCR_IDX;
264
	struct evm_ima_xattr_data *xattr_value = NULL;
265
	struct modsig *modsig = NULL;
266
	int xattr_len = 0;
267
	bool violation_check;
268
	enum hash_algo hash_algo;
269

270
	if (!ima_policy_flag || !S_ISREG(inode->i_mode))
271
		return 0;
E
Eric Paris 已提交
272

273 274 275 276
	/* Return an IMA_MEASURE, IMA_APPRAISE, IMA_AUDIT action
	 * bitmask based on the appraise/audit/measurement policy.
	 * Included is the appraise submask.
	 */
277
	action = ima_get_action(inode, cred, secid, mask, func, &pcr,
278
				&template_desc, NULL);
279
	violation_check = ((func == FILE_CHECK || func == MMAP_CHECK) &&
280 281
			   (ima_policy_flag & IMA_MEASURE));
	if (!action && !violation_check)
M
Mimi Zohar 已提交
282 283 284
		return 0;

	must_appraise = action & IMA_APPRAISE;
E
Eric Paris 已提交
285

286
	/*  Is the appraise rule hook specific?  */
287
	if (action & IMA_FILE_APPRAISE)
288
		func = FILE_CHECK;
289

A
Al Viro 已提交
290
	inode_lock(inode);
M
Mimi Zohar 已提交
291

292 293 294
	if (action) {
		iint = integrity_inode_get(inode);
		if (!iint)
295
			rc = -ENOMEM;
296 297
	}

298
	if (!rc && violation_check)
299
		ima_rdwr_violation_check(file, iint, action & IMA_MEASURE,
300
					 &pathbuf, &pathname, filename);
301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316

	inode_unlock(inode);

	if (rc)
		goto out;
	if (!action)
		goto out;

	mutex_lock(&iint->mutex);

	if (test_and_clear_bit(IMA_CHANGE_ATTR, &iint->atomic_flags))
		/* reset appraisal flags if ima_inode_post_setattr was called */
		iint->flags &= ~(IMA_APPRAISE | IMA_APPRAISED |
				 IMA_APPRAISE_SUBMASK | IMA_APPRAISED_SUBMASK |
				 IMA_ACTION_FLAGS);

317 318 319 320 321 322 323
	/*
	 * Re-evaulate the file if either the xattr has changed or the
	 * kernel has no way of detecting file change on the filesystem.
	 * (Limited to privileged mounted filesystems.)
	 */
	if (test_and_clear_bit(IMA_CHANGE_XATTR, &iint->atomic_flags) ||
	    ((inode->i_sb->s_iflags & SB_I_IMA_UNVERIFIABLE_SIGNATURE) &&
324 325
	     !(inode->i_sb->s_iflags & SB_I_UNTRUSTED_MOUNTER) &&
	     !(action & IMA_FAIL_UNVERIFIABLE_SIGS))) {
326
		iint->flags &= ~IMA_DONE_MASK;
327 328
		iint->measured_pcrs = 0;
	}
329

M
Mimi Zohar 已提交
330
	/* Determine if already appraised/measured based on bitmask
331 332 333
	 * (IMA_MEASURE, IMA_MEASURED, IMA_XXXX_APPRAISE, IMA_XXXX_APPRAISED,
	 *  IMA_AUDIT, IMA_AUDITED)
	 */
M
Mimi Zohar 已提交
334
	iint->flags |= action;
335
	action &= IMA_DO_MASK;
336 337 338 339 340
	action &= ~((iint->flags & (IMA_DONE_MASK ^ IMA_MEASURED)) >> 1);

	/* If target pcr is already measured, unset IMA_MEASURE action */
	if ((action & IMA_MEASURE) && (iint->measured_pcrs & (0x1 << pcr)))
		action ^= IMA_MEASURE;
M
Mimi Zohar 已提交
341

342 343 344 345 346 347 348 349 350 351 352 353
	/* HASH sets the digital signature and update flags, nothing else */
	if ((action & IMA_HASH) &&
	    !(test_bit(IMA_DIGSIG, &iint->atomic_flags))) {
		xattr_len = ima_read_xattr(file_dentry(file), &xattr_value);
		if ((xattr_value && xattr_len > 2) &&
		    (xattr_value->type == EVM_IMA_XATTR_DIGSIG))
			set_bit(IMA_DIGSIG, &iint->atomic_flags);
		iint->flags |= IMA_HASHED;
		action ^= IMA_HASH;
		set_bit(IMA_UPDATE_XATTR, &iint->atomic_flags);
	}

M
Mimi Zohar 已提交
354 355
	/* Nothing to do, just return existing appraised status */
	if (!action) {
356 357 358 359 360 361
		if (must_appraise) {
			rc = mmap_violation_check(func, file, &pathbuf,
						  &pathname, filename);
			if (!rc)
				rc = ima_get_cache_status(iint, func);
		}
362
		goto out_locked;
M
Mimi Zohar 已提交
363
	}
364

365
	if ((action & IMA_APPRAISE_SUBMASK) ||
366
	    strcmp(template_desc->name, IMA_TEMPLATE_IMA_NAME) != 0) {
367
		/* read 'security.ima' */
M
Miklos Szeredi 已提交
368
		xattr_len = ima_read_xattr(file_dentry(file), &xattr_value);
369

370 371 372 373 374 375 376 377 378 379 380 381
		/*
		 * Read the appended modsig if allowed by the policy, and allow
		 * an additional measurement list entry, if needed, based on the
		 * template format and whether the file was already measured.
		 */
		if (iint->flags & IMA_MODSIG_ALLOWED) {
			rc = ima_read_modsig(func, buf, size, &modsig);

			if (!rc && ima_template_has_modsig(template_desc) &&
			    iint->flags & IMA_MEASURED)
				action |= IMA_MEASURE;
		}
382 383
	}

384 385
	hash_algo = ima_get_hash_algo(xattr_value, xattr_len);

T
Thiago Jung Bauermann 已提交
386
	rc = ima_collect_measurement(iint, file, buf, size, hash_algo, modsig);
387
	if (rc != 0 && rc != -EBADF && rc != -EINVAL)
388
		goto out_locked;
389

390 391
	if (!pathbuf)	/* ima_rdwr_violation possibly pre-fetched */
		pathname = ima_d_path(&file->f_path, &pathbuf, filename);
392

M
Mimi Zohar 已提交
393
	if (action & IMA_MEASURE)
394
		ima_store_measurement(iint, file, pathname,
395
				      xattr_value, xattr_len, modsig, pcr,
396
				      template_desc);
397
	if (rc == 0 && (action & IMA_APPRAISE_SUBMASK)) {
398 399 400 401 402 403 404 405
		rc = ima_check_blacklist(iint, modsig, pcr);
		if (rc != -EPERM) {
			inode_lock(inode);
			rc = ima_appraise_measurement(func, iint, file,
						      pathname, xattr_value,
						      xattr_len, modsig);
			inode_unlock(inode);
		}
406 407 408
		if (!rc)
			rc = mmap_violation_check(func, file, &pathbuf,
						  &pathname, filename);
409
	}
P
Peter Moody 已提交
410
	if (action & IMA_AUDIT)
411
		ima_audit_measurement(iint, pathname);
412

413 414
	if ((file->f_flags & O_DIRECT) && (iint->flags & IMA_PERMIT_DIRECTIO))
		rc = 0;
415 416
out_locked:
	if ((mask & MAY_WRITE) && test_bit(IMA_DIGSIG, &iint->atomic_flags) &&
417
	     !(iint->flags & IMA_NEW_FILE))
418
		rc = -EACCES;
419
	mutex_unlock(&iint->mutex);
420
	kfree(xattr_value);
421
	ima_free_modsig(modsig);
422
out:
D
Dmitry Kasatkin 已提交
423 424
	if (pathbuf)
		__putname(pathbuf);
425 426 427 428 429 430
	if (must_appraise) {
		if (rc && (ima_appraise & IMA_APPRAISE_ENFORCE))
			return -EACCES;
		if (file->f_mode & FMODE_WRITE)
			set_bit(IMA_UPDATE_XATTR, &iint->atomic_flags);
	}
431
	return 0;
432 433 434 435 436 437 438 439 440 441
}

/**
 * ima_file_mmap - based on policy, collect/store measurement.
 * @file: pointer to the file to be measured (May be NULL)
 * @prot: contains the protection that will be applied by the kernel.
 *
 * Measure files being mmapped executable based on the ima_must_measure()
 * policy decision.
 *
442 443
 * On success return 0.  On integrity appraisal error, assuming the file
 * is in policy and IMA-appraisal is in enforcing mode, return -EACCES.
444 445 446
 */
int ima_file_mmap(struct file *file, unsigned long prot)
{
447 448 449 450 451
	u32 secid;

	if (file && (prot & PROT_EXEC)) {
		security_task_getsecid(current, &secid);
		return process_measurement(file, current_cred(), secid, NULL,
452
					   0, MAY_EXEC, MMAP_CHECK);
453 454
	}

455
	return 0;
456 457
}

458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483
/**
 * ima_file_mprotect - based on policy, limit mprotect change
 * @prot: contains the protection that will be applied by the kernel.
 *
 * Files can be mmap'ed read/write and later changed to execute to circumvent
 * IMA's mmap appraisal policy rules.  Due to locking issues (mmap semaphore
 * would be taken before i_mutex), files can not be measured or appraised at
 * this point.  Eliminate this integrity gap by denying the mprotect
 * PROT_EXECUTE change, if an mmap appraise policy rule exists.
 *
 * On mprotect change success, return 0.  On failure, return -EACESS.
 */
int ima_file_mprotect(struct vm_area_struct *vma, unsigned long prot)
{
	struct ima_template_desc *template;
	struct file *file = vma->vm_file;
	char filename[NAME_MAX];
	char *pathbuf = NULL;
	const char *pathname = NULL;
	struct inode *inode;
	int result = 0;
	int action;
	u32 secid;
	int pcr;

	/* Is mprotect making an mmap'ed file executable? */
M
Mimi Zohar 已提交
484 485
	if (!(ima_policy_flag & IMA_APPRAISE) || !vma->vm_file ||
	    !(prot & PROT_EXEC) || (vma->vm_flags & VM_EXEC))
486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509
		return 0;

	security_task_getsecid(current, &secid);
	inode = file_inode(vma->vm_file);
	action = ima_get_action(inode, current_cred(), secid, MAY_EXEC,
				MMAP_CHECK, &pcr, &template, 0);

	/* Is the mmap'ed file in policy? */
	if (!(action & (IMA_MEASURE | IMA_APPRAISE_SUBMASK)))
		return 0;

	if (action & IMA_APPRAISE_SUBMASK)
		result = -EPERM;

	file = vma->vm_file;
	pathname = ima_d_path(&file->f_path, &pathbuf, filename);
	integrity_audit_msg(AUDIT_INTEGRITY_DATA, inode, pathname,
			    "collect_data", "failed-mprotect", result, 0);
	if (pathbuf)
		__putname(pathbuf);

	return result;
}

510 511 512 513 514 515 516 517 518 519
/**
 * ima_bprm_check - based on policy, collect/store measurement.
 * @bprm: contains the linux_binprm structure
 *
 * The OS protects against an executable file, already open for write,
 * from being executed in deny_write_access() and an executable file,
 * already open for execute, from being modified in get_write_access().
 * So we can be certain that what we verify and measure here is actually
 * what is being executed.
 *
520 521
 * On success return 0.  On integrity appraisal error, assuming the file
 * is in policy and IMA-appraisal is in enforcing mode, return -EACCES.
522 523 524
 */
int ima_bprm_check(struct linux_binprm *bprm)
{
525 526 527 528 529
	int ret;
	u32 secid;

	security_task_getsecid(current, &secid);
	ret = process_measurement(bprm->file, current_cred(), secid, NULL, 0,
530
				  MAY_EXEC, BPRM_CHECK);
531 532 533 534 535
	if (ret)
		return ret;

	security_cred_getsecid(bprm->cred, &secid);
	return process_measurement(bprm->file, bprm->cred, secid, NULL, 0,
536
				   MAY_EXEC, CREDS_CHECK);
537 538
}

M
Mimi Zohar 已提交
539 540 541
/**
 * ima_path_check - based on policy, collect/store measurement.
 * @file: pointer to the file to be measured
L
Lans Zhang 已提交
542
 * @mask: contains MAY_READ, MAY_WRITE, MAY_EXEC or MAY_APPEND
M
Mimi Zohar 已提交
543 544 545
 *
 * Measure files based on the ima_must_measure() policy decision.
 *
546 547
 * On success return 0.  On integrity appraisal error, assuming the file
 * is in policy and IMA-appraisal is in enforcing mode, return -EACCES.
M
Mimi Zohar 已提交
548
 */
549
int ima_file_check(struct file *file, int mask)
M
Mimi Zohar 已提交
550
{
551 552 553 554
	u32 secid;

	security_task_getsecid(current, &secid);
	return process_measurement(file, current_cred(), secid, NULL, 0,
L
Lans Zhang 已提交
555
				   mask & (MAY_READ | MAY_WRITE | MAY_EXEC |
556
					   MAY_APPEND), FILE_CHECK);
M
Mimi Zohar 已提交
557
}
558
EXPORT_SYMBOL_GPL(ima_file_check);
M
Mimi Zohar 已提交
559

560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595
/**
 * ima_file_hash - return the stored measurement if a file has been hashed and
 * is in the iint cache.
 * @file: pointer to the file
 * @buf: buffer in which to store the hash
 * @buf_size: length of the buffer
 *
 * On success, return the hash algorithm (as defined in the enum hash_algo).
 * If buf is not NULL, this function also outputs the hash into buf.
 * If the hash is larger than buf_size, then only buf_size bytes will be copied.
 * It generally just makes sense to pass a buffer capable of holding the largest
 * possible hash: IMA_MAX_DIGEST_SIZE.
 * The file hash returned is based on the entire file, including the appended
 * signature.
 *
 * If IMA is disabled or if no measurement is available, return -EOPNOTSUPP.
 * If the parameters are incorrect, return -EINVAL.
 */
int ima_file_hash(struct file *file, char *buf, size_t buf_size)
{
	struct inode *inode;
	struct integrity_iint_cache *iint;
	int hash_algo;

	if (!file)
		return -EINVAL;

	if (!ima_policy_flag)
		return -EOPNOTSUPP;

	inode = file_inode(file);
	iint = integrity_iint_find(inode);
	if (!iint)
		return -EOPNOTSUPP;

	mutex_lock(&iint->mutex);
596 597 598 599 600 601 602 603 604 605

	/*
	 * ima_file_hash can be called when ima_collect_measurement has still
	 * not been called, we might not always have a hash.
	 */
	if (!iint->ima_hash) {
		mutex_unlock(&iint->mutex);
		return -EOPNOTSUPP;
	}

606 607 608 609 610 611 612 613 614 615 616 617 618
	if (buf) {
		size_t copied_size;

		copied_size = min_t(size_t, iint->ima_hash->length, buf_size);
		memcpy(buf, iint->ima_hash->digest, copied_size);
	}
	hash_algo = iint->ima_hash->algo;
	mutex_unlock(&iint->mutex);

	return hash_algo;
}
EXPORT_SYMBOL_GPL(ima_file_hash);

619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645
/**
 * ima_post_create_tmpfile - mark newly created tmpfile as new
 * @file : newly created tmpfile
 *
 * No measuring, appraising or auditing of newly created tmpfiles is needed.
 * Skip calling process_measurement(), but indicate which newly, created
 * tmpfiles are in policy.
 */
void ima_post_create_tmpfile(struct inode *inode)
{
	struct integrity_iint_cache *iint;
	int must_appraise;

	must_appraise = ima_must_appraise(inode, MAY_ACCESS, FILE_CHECK);
	if (!must_appraise)
		return;

	/* Nothing to do if we can't allocate memory */
	iint = integrity_inode_get(inode);
	if (!iint)
		return;

	/* needed for writing the security xattrs */
	set_bit(IMA_UPDATE_XATTR, &iint->atomic_flags);
	iint->ima_file_status = INTEGRITY_PASS;
}

646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662
/**
 * ima_post_path_mknod - mark as a new inode
 * @dentry: newly created dentry
 *
 * Mark files created via the mknodat syscall as new, so that the
 * file data can be written later.
 */
void ima_post_path_mknod(struct dentry *dentry)
{
	struct integrity_iint_cache *iint;
	struct inode *inode = dentry->d_inode;
	int must_appraise;

	must_appraise = ima_must_appraise(inode, MAY_ACCESS, FILE_CHECK);
	if (!must_appraise)
		return;

663
	/* Nothing to do if we can't allocate memory */
664
	iint = integrity_inode_get(inode);
665 666 667 668 669
	if (!iint)
		return;

	/* needed for re-opening empty files */
	iint->flags |= IMA_NEW_FILE;
670 671
}

672 673 674 675
/**
 * ima_read_file - pre-measure/appraise hook decision based on policy
 * @file: pointer to the file to be measured/appraised/audit
 * @read_id: caller identifier
676
 * @contents: whether a subsequent call will be made to ima_post_read_file()
677 678 679 680 681 682 683
 *
 * Permit reading a file based on policy. The policy rules are written
 * in terms of the policy identifier.  Appraising the integrity of
 * a file requires a file descriptor.
 *
 * For permission return 0, otherwise return -EACCES.
 */
684 685
int ima_read_file(struct file *file, enum kernel_read_file_id read_id,
		  bool contents)
686
{
687 688
	enum ima_hooks func;
	u32 secid;
689

690 691 692 693
	/*
	 * Do devices using pre-allocated memory run the risk of the
	 * firmware being accessible to the device prior to the completion
	 * of IMA's signature verification any more than when using two
694 695
	 * buffers? It may be desirable to include the buffer address
	 * in this API and walk all the dma_map_single() mappings to check.
696
	 */
697 698 699 700 701 702 703 704 705 706 707 708 709 710

	/*
	 * There will be a call made to ima_post_read_file() with
	 * a filled buffer, so we don't need to perform an extra
	 * read early here.
	 */
	if (contents)
		return 0;

	/* Read entire file for all partial reads. */
	func = read_idmap[read_id] ?: FILE_CHECK;
	security_task_getsecid(current, &secid);
	return process_measurement(file, current_cred(), secid, NULL,
				   0, MAY_READ, func);
711 712
}

713
const int read_idmap[READING_MAX_ID] = {
714 715 716 717
	[READING_FIRMWARE] = FIRMWARE_CHECK,
	[READING_MODULE] = MODULE_CHECK,
	[READING_KEXEC_IMAGE] = KEXEC_KERNEL_CHECK,
	[READING_KEXEC_INITRAMFS] = KEXEC_INITRAMFS_CHECK,
718
	[READING_POLICY] = POLICY_CHECK
719 720
};

721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736
/**
 * ima_post_read_file - in memory collect/appraise/audit measurement
 * @file: pointer to the file to be measured/appraised/audit
 * @buf: pointer to in memory file contents
 * @size: size of in memory file contents
 * @read_id: caller identifier
 *
 * Measure/appraise/audit in memory file based on policy.  Policy rules
 * are written in terms of a policy identifier.
 *
 * On success return 0.  On integrity appraisal error, assuming the file
 * is in policy and IMA-appraisal is in enforcing mode, return -EACCES.
 */
int ima_post_read_file(struct file *file, void *buf, loff_t size,
		       enum kernel_read_file_id read_id)
{
737
	enum ima_hooks func;
738
	u32 secid;
739

740 741 742 743
	/* permit signed certs */
	if (!file && read_id == READING_X509_CERTIFICATE)
		return 0;

744 745 746 747 748 749
	if (!file || !buf || size == 0) { /* should never happen */
		if (ima_appraise & IMA_APPRAISE_ENFORCE)
			return -EACCES;
		return 0;
	}

750
	func = read_idmap[read_id] ?: FILE_CHECK;
751 752
	security_task_getsecid(current, &secid);
	return process_measurement(file, current_cred(), secid, buf, size,
753
				   MAY_READ, func);
754 755
}

756 757 758
/**
 * ima_load_data - appraise decision based on policy
 * @id: kernel load data caller identifier
759 760
 * @contents: whether the full contents will be available in a later
 *	      call to ima_post_load_data().
761 762 763 764 765 766 767
 *
 * Callers of this LSM hook can not measure, appraise, or audit the
 * data provided by userspace.  Enforce policy rules requring a file
 * signature (eg. kexec'ed kernel image).
 *
 * For permission return 0, otherwise return -EACCES.
 */
768
int ima_load_data(enum kernel_load_data_id id, bool contents)
769
{
770
	bool ima_enforce, sig_enforce;
771

772 773
	ima_enforce =
		(ima_appraise & IMA_APPRAISE_ENFORCE) == IMA_APPRAISE_ENFORCE;
774 775 776

	switch (id) {
	case LOADING_KEXEC_IMAGE:
777
		if (IS_ENABLED(CONFIG_KEXEC_SIG)
778 779 780 781 782 783
		    && arch_ima_get_secureboot()) {
			pr_err("impossible to appraise a kernel image without a file descriptor; try using kexec_file_load syscall.\n");
			return -EACCES;
		}

		if (ima_enforce && (ima_appraise & IMA_APPRAISE_KEXEC)) {
784 785 786
			pr_err("impossible to appraise a kernel image without a file descriptor; try using kexec_file_load syscall.\n");
			return -EACCES;	/* INTEGRITY_UNKNOWN */
		}
787 788
		break;
	case LOADING_FIRMWARE:
789
		if (ima_enforce && (ima_appraise & IMA_APPRAISE_FIRMWARE) && !contents) {
790 791 792
			pr_err("Prevent firmware sysfs fallback loading.\n");
			return -EACCES;	/* INTEGRITY_UNKNOWN */
		}
793 794 795 796
		break;
	case LOADING_MODULE:
		sig_enforce = is_module_sig_enforced();

797 798
		if (ima_enforce && (!sig_enforce
				    && (ima_appraise & IMA_APPRAISE_MODULES))) {
799 800 801
			pr_err("impossible to appraise a module without a file descriptor. sig_enforce kernel parameter might help\n");
			return -EACCES;	/* INTEGRITY_UNKNOWN */
		}
802 803 804 805 806 807
	default:
		break;
	}
	return 0;
}

808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824
/**
 * ima_post_load_data - appraise decision based on policy
 * @buf: pointer to in memory file contents
 * @size: size of in memory file contents
 * @id: kernel load data caller identifier
 * @description: @id-specific description of contents
 *
 * Measure/appraise/audit in memory buffer based on policy.  Policy rules
 * are written in terms of a policy identifier.
 *
 * On success return 0.  On integrity appraisal error, assuming the file
 * is in policy and IMA-appraisal is in enforcing mode, return -EACCES.
 */
int ima_post_load_data(char *buf, loff_t size,
		       enum kernel_load_data_id load_id,
		       char *description)
{
825 826 827 828 829 830 831 832 833
	if (load_id == LOADING_FIRMWARE) {
		if ((ima_appraise & IMA_APPRAISE_FIRMWARE) &&
		    (ima_appraise & IMA_APPRAISE_ENFORCE)) {
			pr_err("Prevent firmware loading_store.\n");
			return -EACCES; /* INTEGRITY_UNKNOWN */
		}
		return 0;
	}

834 835 836
	return 0;
}

837 838
/*
 * process_buffer_measurement - Measure the buffer to ima log.
839
 * @inode: inode associated with the object being measured (NULL for KEY_CHECK)
840 841 842
 * @buf: pointer to the buffer that needs to be added to the log.
 * @size: size of buffer(in bytes).
 * @eventname: event name to be used for the buffer entry.
843 844
 * @func: IMA hook
 * @pcr: pcr to extend the measurement
845
 * @keyring: keyring name to determine the action to be performed
846 847 848
 *
 * Based on policy, the buffer is measured into the ima log.
 */
849
void process_buffer_measurement(struct inode *inode, const void *buf, int size,
850
				const char *eventname, enum ima_hooks func,
851
				int pcr, const char *keyring)
852 853
{
	int ret = 0;
854
	const char *audit_cause = "ENOMEM";
855 856 857
	struct ima_template_entry *entry = NULL;
	struct integrity_iint_cache iint = {};
	struct ima_event_data event_data = {.iint = &iint,
858 859 860
					    .filename = eventname,
					    .buf = buf,
					    .buf_len = size};
861
	struct ima_template_desc *template = NULL;
862 863 864 865 866 867
	struct {
		struct ima_digest_data hdr;
		char digest[IMA_MAX_DIGEST_SIZE];
	} hash = {};
	int violation = 0;
	int action = 0;
868
	u32 secid;
869

870 871 872
	if (!ima_policy_flag)
		return;

873 874 875 876 877 878 879 880 881
	/*
	 * Both LSM hooks and auxilary based buffer measurements are
	 * based on policy.  To avoid code duplication, differentiate
	 * between the LSM hooks and auxilary buffer measurements,
	 * retrieving the policy rule information only for the LSM hook
	 * buffer measurements.
	 */
	if (func) {
		security_task_getsecid(current, &secid);
882
		action = ima_get_action(inode, current_cred(), secid, 0, func,
883
					&pcr, &template, keyring);
884 885 886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902
		if (!(action & IMA_MEASURE))
			return;
	}

	if (!pcr)
		pcr = CONFIG_IMA_MEASURE_PCR_IDX;

	if (!template) {
		template = lookup_template_desc("ima-buf");
		ret = template_desc_init_fields(template->fmt,
						&(template->fields),
						&(template->num_fields));
		if (ret < 0) {
			pr_err("template %s init failed, result: %d\n",
			       (strlen(template->name) ?
				template->name : template->fmt), ret);
			return;
		}
	}
903 904 905 906 907 908

	iint.ima_hash = &hash.hdr;
	iint.ima_hash->algo = ima_hash_algo;
	iint.ima_hash->length = hash_digest_size[ima_hash_algo];

	ret = ima_calc_buffer_hash(buf, size, iint.ima_hash);
909 910
	if (ret < 0) {
		audit_cause = "hashing_error";
911
		goto out;
912
	}
913

914
	ret = ima_alloc_init_template(&event_data, &entry, template);
915 916
	if (ret < 0) {
		audit_cause = "alloc_entry";
917
		goto out;
918
	}
919 920

	ret = ima_store_template(entry, violation, NULL, buf, pcr);
921 922
	if (ret < 0) {
		audit_cause = "store_entry";
923
		ima_free_template_entry(entry);
924
	}
925 926

out:
927
	if (ret < 0)
928 929 930
		integrity_audit_message(AUDIT_INTEGRITY_PCR, NULL, eventname,
					func_measure_str(func),
					audit_cause, ret, 0, ret);
931

932 933 934 935 936
	return;
}

/**
 * ima_kexec_cmdline - measure kexec cmdline boot args
937
 * @kernel_fd: file descriptor of the kexec kernel being loaded
938 939 940 941 942
 * @buf: pointer to buffer
 * @size: size of buffer
 *
 * Buffers can only be measured, not appraised.
 */
943
void ima_kexec_cmdline(int kernel_fd, const void *buf, int size)
944
{
945 946 947 948 949 950 951 952 953 954 955 956
	struct fd f;

	if (!buf || !size)
		return;

	f = fdget(kernel_fd);
	if (!f.file)
		return;

	process_buffer_measurement(file_inode(f.file), buf, size,
				   "kexec-cmdline", KEXEC_CMDLINE, 0, NULL);
	fdput(f);
957 958
}

959 960 961 962
static int __init init_ima(void)
{
	int error;

963
	ima_init_template_list();
964
	hash_setup(CONFIG_IMA_DEFAULT_HASH);
965
	error = ima_init();
966 967 968 969 970 971 972 973 974 975

	if (error && strcmp(hash_algo_name[ima_hash_algo],
			    CONFIG_IMA_DEFAULT_HASH) != 0) {
		pr_info("Allocating %s failed, going to use default hash algorithm %s\n",
			hash_algo_name[ima_hash_algo], CONFIG_IMA_DEFAULT_HASH);
		hash_setup_done = 0;
		hash_setup(CONFIG_IMA_DEFAULT_HASH);
		error = ima_init();
	}

976 977 978
	if (error)
		return error;

979 980 981 982
	error = register_blocking_lsm_notifier(&ima_lsm_policy_notifier);
	if (error)
		pr_warn("Couldn't register LSM notifier, error %d\n", error);

983
	if (!error)
984
		ima_update_policy_flag();
985

986 987 988 989
	return error;
}

late_initcall(init_ima);	/* Start IMA after the TPM is available */