ima_main.c 24.4 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 21 22
#include <linux/file.h>
#include <linux/binfmts.h>
#include <linux/mount.h>
#include <linux/mman.h>
23
#include <linux/slab.h>
M
Mimi Zohar 已提交
24
#include <linux/xattr.h>
25
#include <linux/ima.h>
26
#include <linux/iversion.h>
27
#include <linux/fs.h>
28 29 30

#include "ima.h"

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

37
int ima_hash_algo = HASH_ALGO_SHA1;
38
static int hash_setup_done;
39

40 41 42 43
static struct notifier_block ima_lsm_policy_notifier = {
	.notifier_call = ima_lsm_policy_change,
};

44 45
static int __init hash_setup(char *str)
{
46 47 48 49 50 51 52
	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) {
53
		if (strncmp(str, "sha1", 4) == 0) {
54
			ima_hash_algo = HASH_ALGO_SHA1;
55
		} else if (strncmp(str, "md5", 3) == 0) {
56
			ima_hash_algo = HASH_ALGO_MD5;
57 58 59
		} else {
			pr_err("invalid hash algorithm \"%s\" for template \"%s\"",
				str, IMA_TEMPLATE_IMA_NAME);
60
			return 1;
61
		}
62 63 64
		goto out;
	}

Y
Yisheng Xie 已提交
65
	i = match_string(hash_algo_name, HASH_ALGO__LAST, str);
66 67
	if (i < 0) {
		pr_err("invalid hash algorithm \"%s\"", str);
68
		return 1;
69
	}
Y
Yisheng Xie 已提交
70 71

	ima_hash_algo = i;
72 73
out:
	hash_setup_done = 1;
74 75 76 77
	return 1;
}
__setup("ima_hash=", hash_setup);

78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
/* 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 已提交
99
/*
100
 * ima_rdwr_violation_check
M
Mimi Zohar 已提交
101
 *
102
 * Only invalidate the PCR for measured files:
103
 *	- Opening a file for write when already open for read,
M
Mimi Zohar 已提交
104 105
 *	  results in a time of measure, time of use (ToMToU) error.
 *	- Opening a file for read when already open for write,
106
 *	  could result in a file measurement error.
M
Mimi Zohar 已提交
107 108
 *
 */
109 110
static void ima_rdwr_violation_check(struct file *file,
				     struct integrity_iint_cache *iint,
111
				     int must_measure,
112
				     char **pathbuf,
113 114
				     const char **pathname,
				     char *filename)
M
Mimi Zohar 已提交
115
{
116
	struct inode *inode = file_inode(file);
M
Mimi Zohar 已提交
117
	fmode_t mode = file->f_mode;
118
	bool send_tomtou = false, send_writers = false;
119

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

136 137 138
	if (!send_tomtou && !send_writers)
		return;

139
	*pathname = ima_d_path(&file->f_path, pathbuf, filename);
140

141
	if (send_tomtou)
142 143
		ima_add_violation(file, *pathname, iint,
				  "invalid_pcr", "ToMToU");
144
	if (send_writers)
145
		ima_add_violation(file, *pathname, iint,
146
				  "invalid_pcr", "open_writers");
M
Mimi Zohar 已提交
147 148
}

149
static void ima_check_last_writer(struct integrity_iint_cache *iint,
M
Mimi Zohar 已提交
150
				  struct inode *inode, struct file *file)
E
Eric Paris 已提交
151
{
A
Al Viro 已提交
152
	fmode_t mode = file->f_mode;
153
	bool update;
E
Eric Paris 已提交
154

M
Mimi Zohar 已提交
155 156 157
	if (!(mode & FMODE_WRITE))
		return;

158
	mutex_lock(&iint->mutex);
159
	if (atomic_read(&inode->i_writecount) == 1) {
160 161
		update = test_and_clear_bit(IMA_UPDATE_XATTR,
					    &iint->atomic_flags);
162
		if (!IS_I_VERSION(inode) ||
163
		    !inode_eq_iversion(inode, iint->version) ||
164 165
		    (iint->flags & IMA_NEW_FILE)) {
			iint->flags &= ~(IMA_DONE_MASK | IMA_NEW_FILE);
166
			iint->measured_pcrs = 0;
167
			if (update)
168 169
				ima_update_xattr(iint, file);
		}
M
Mimi Zohar 已提交
170
	}
171
	mutex_unlock(&iint->mutex);
E
Eric Paris 已提交
172 173
}

174 175 176 177
/**
 * ima_file_free - called on __fput()
 * @file: pointer to file structure being freed
 *
178
 * Flag files that changed, based on i_version
179 180 181
 */
void ima_file_free(struct file *file)
{
A
Al Viro 已提交
182
	struct inode *inode = file_inode(file);
183
	struct integrity_iint_cache *iint;
184

185
	if (!ima_policy_flag || !S_ISREG(inode->i_mode))
186
		return;
187

188
	iint = integrity_iint_find(inode);
M
Mimi Zohar 已提交
189 190
	if (!iint)
		return;
191

M
Mimi Zohar 已提交
192
	ima_check_last_writer(iint, inode, file);
193 194
}

195 196
static int process_measurement(struct file *file, const struct cred *cred,
			       u32 secid, char *buf, loff_t size, int mask,
197
			       enum ima_hooks func)
198
{
A
Al Viro 已提交
199
	struct inode *inode = file_inode(file);
200
	struct integrity_iint_cache *iint = NULL;
201
	struct ima_template_desc *template_desc = NULL;
202
	char *pathbuf = NULL;
203
	char filename[NAME_MAX];
204
	const char *pathname = NULL;
205
	int rc = 0, action, must_appraise = 0;
206
	int pcr = CONFIG_IMA_MEASURE_PCR_IDX;
207
	struct evm_ima_xattr_data *xattr_value = NULL;
208
	struct modsig *modsig = NULL;
209
	int xattr_len = 0;
210
	bool violation_check;
211
	enum hash_algo hash_algo;
212

213
	if (!ima_policy_flag || !S_ISREG(inode->i_mode))
214
		return 0;
E
Eric Paris 已提交
215

216 217 218 219
	/* Return an IMA_MEASURE, IMA_APPRAISE, IMA_AUDIT action
	 * bitmask based on the appraise/audit/measurement policy.
	 * Included is the appraise submask.
	 */
220
	action = ima_get_action(inode, cred, secid, mask, func, &pcr,
221
				&template_desc, NULL);
222
	violation_check = ((func == FILE_CHECK || func == MMAP_CHECK) &&
223 224
			   (ima_policy_flag & IMA_MEASURE));
	if (!action && !violation_check)
M
Mimi Zohar 已提交
225 226 227
		return 0;

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

229
	/*  Is the appraise rule hook specific?  */
230
	if (action & IMA_FILE_APPRAISE)
231
		func = FILE_CHECK;
232

A
Al Viro 已提交
233
	inode_lock(inode);
M
Mimi Zohar 已提交
234

235 236 237
	if (action) {
		iint = integrity_inode_get(inode);
		if (!iint)
238
			rc = -ENOMEM;
239 240
	}

241
	if (!rc && violation_check)
242
		ima_rdwr_violation_check(file, iint, action & IMA_MEASURE,
243
					 &pathbuf, &pathname, filename);
244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259

	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);

260 261 262 263 264 265 266
	/*
	 * 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) &&
267 268
	     !(inode->i_sb->s_iflags & SB_I_UNTRUSTED_MOUNTER) &&
	     !(action & IMA_FAIL_UNVERIFIABLE_SIGS))) {
269
		iint->flags &= ~IMA_DONE_MASK;
270 271
		iint->measured_pcrs = 0;
	}
272

M
Mimi Zohar 已提交
273
	/* Determine if already appraised/measured based on bitmask
274 275 276
	 * (IMA_MEASURE, IMA_MEASURED, IMA_XXXX_APPRAISE, IMA_XXXX_APPRAISED,
	 *  IMA_AUDIT, IMA_AUDITED)
	 */
M
Mimi Zohar 已提交
277
	iint->flags |= action;
278
	action &= IMA_DO_MASK;
279 280 281 282 283
	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 已提交
284

285 286 287 288 289 290 291 292 293 294 295 296
	/* 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 已提交
297 298
	/* Nothing to do, just return existing appraised status */
	if (!action) {
299 300 301 302 303 304
		if (must_appraise) {
			rc = mmap_violation_check(func, file, &pathbuf,
						  &pathname, filename);
			if (!rc)
				rc = ima_get_cache_status(iint, func);
		}
305
		goto out_locked;
M
Mimi Zohar 已提交
306
	}
307

308
	if ((action & IMA_APPRAISE_SUBMASK) ||
309
	    strcmp(template_desc->name, IMA_TEMPLATE_IMA_NAME) != 0) {
310
		/* read 'security.ima' */
M
Miklos Szeredi 已提交
311
		xattr_len = ima_read_xattr(file_dentry(file), &xattr_value);
312

313 314 315 316 317 318 319 320 321 322 323 324
		/*
		 * 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;
		}
325 326
	}

327 328
	hash_algo = ima_get_hash_algo(xattr_value, xattr_len);

T
Thiago Jung Bauermann 已提交
329
	rc = ima_collect_measurement(iint, file, buf, size, hash_algo, modsig);
330
	if (rc != 0 && rc != -EBADF && rc != -EINVAL)
331
		goto out_locked;
332

333 334
	if (!pathbuf)	/* ima_rdwr_violation possibly pre-fetched */
		pathname = ima_d_path(&file->f_path, &pathbuf, filename);
335

M
Mimi Zohar 已提交
336
	if (action & IMA_MEASURE)
337
		ima_store_measurement(iint, file, pathname,
338
				      xattr_value, xattr_len, modsig, pcr,
339
				      template_desc);
340
	if (rc == 0 && (action & IMA_APPRAISE_SUBMASK)) {
341 342 343 344 345 346 347 348
		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);
		}
349 350 351
		if (!rc)
			rc = mmap_violation_check(func, file, &pathbuf,
						  &pathname, filename);
352
	}
P
Peter Moody 已提交
353
	if (action & IMA_AUDIT)
354
		ima_audit_measurement(iint, pathname);
355

356 357
	if ((file->f_flags & O_DIRECT) && (iint->flags & IMA_PERMIT_DIRECTIO))
		rc = 0;
358 359
out_locked:
	if ((mask & MAY_WRITE) && test_bit(IMA_DIGSIG, &iint->atomic_flags) &&
360
	     !(iint->flags & IMA_NEW_FILE))
361
		rc = -EACCES;
362
	mutex_unlock(&iint->mutex);
363
	kfree(xattr_value);
364
	ima_free_modsig(modsig);
365
out:
D
Dmitry Kasatkin 已提交
366 367
	if (pathbuf)
		__putname(pathbuf);
368 369 370 371 372 373
	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);
	}
374
	return 0;
375 376 377 378 379 380 381 382 383 384
}

/**
 * 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.
 *
385 386
 * On success return 0.  On integrity appraisal error, assuming the file
 * is in policy and IMA-appraisal is in enforcing mode, return -EACCES.
387 388 389
 */
int ima_file_mmap(struct file *file, unsigned long prot)
{
390 391 392 393 394
	u32 secid;

	if (file && (prot & PROT_EXEC)) {
		security_task_getsecid(current, &secid);
		return process_measurement(file, current_cred(), secid, NULL,
395
					   0, MAY_EXEC, MMAP_CHECK);
396 397
	}

398
	return 0;
399 400
}

401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426
/**
 * 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 已提交
427 428
	if (!(ima_policy_flag & IMA_APPRAISE) || !vma->vm_file ||
	    !(prot & PROT_EXEC) || (vma->vm_flags & VM_EXEC))
429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452
		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;
}

453 454 455 456 457 458 459 460 461 462
/**
 * 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.
 *
463 464
 * On success return 0.  On integrity appraisal error, assuming the file
 * is in policy and IMA-appraisal is in enforcing mode, return -EACCES.
465 466 467
 */
int ima_bprm_check(struct linux_binprm *bprm)
{
468 469 470 471 472
	int ret;
	u32 secid;

	security_task_getsecid(current, &secid);
	ret = process_measurement(bprm->file, current_cred(), secid, NULL, 0,
473
				  MAY_EXEC, BPRM_CHECK);
474 475 476 477 478
	if (ret)
		return ret;

	security_cred_getsecid(bprm->cred, &secid);
	return process_measurement(bprm->file, bprm->cred, secid, NULL, 0,
479
				   MAY_EXEC, CREDS_CHECK);
480 481
}

M
Mimi Zohar 已提交
482 483 484
/**
 * ima_path_check - based on policy, collect/store measurement.
 * @file: pointer to the file to be measured
L
Lans Zhang 已提交
485
 * @mask: contains MAY_READ, MAY_WRITE, MAY_EXEC or MAY_APPEND
M
Mimi Zohar 已提交
486 487 488
 *
 * Measure files based on the ima_must_measure() policy decision.
 *
489 490
 * 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 已提交
491
 */
492
int ima_file_check(struct file *file, int mask)
M
Mimi Zohar 已提交
493
{
494 495 496 497
	u32 secid;

	security_task_getsecid(current, &secid);
	return process_measurement(file, current_cred(), secid, NULL, 0,
L
Lans Zhang 已提交
498
				   mask & (MAY_READ | MAY_WRITE | MAY_EXEC |
499
					   MAY_APPEND), FILE_CHECK);
M
Mimi Zohar 已提交
500
}
501
EXPORT_SYMBOL_GPL(ima_file_check);
M
Mimi Zohar 已提交
502

503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551
/**
 * 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);
	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);

552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578
/**
 * 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;
}

579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595
/**
 * 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;

596
	/* Nothing to do if we can't allocate memory */
597
	iint = integrity_inode_get(inode);
598 599 600 601 602
	if (!iint)
		return;

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

605 606 607 608 609 610 611 612 613 614 615 616 617
/**
 * 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
 *
 * 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.
 */
int ima_read_file(struct file *file, enum kernel_read_file_id read_id)
{
618 619 620 621 622 623 624 625
	/*
	 * READING_FIRMWARE_PREALLOC_BUFFER
	 *
	 * 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
	 * buffers?
	 */
626 627 628
	return 0;
}

629
const int read_idmap[READING_MAX_ID] = {
630
	[READING_FIRMWARE] = FIRMWARE_CHECK,
631
	[READING_FIRMWARE_PREALLOC_BUFFER] = FIRMWARE_CHECK,
632 633 634
	[READING_MODULE] = MODULE_CHECK,
	[READING_KEXEC_IMAGE] = KEXEC_KERNEL_CHECK,
	[READING_KEXEC_INITRAMFS] = KEXEC_INITRAMFS_CHECK,
635
	[READING_POLICY] = POLICY_CHECK
636 637
};

638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653
/**
 * 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)
{
654
	enum ima_hooks func;
655
	u32 secid;
656

657 658
	if (!file && read_id == READING_FIRMWARE) {
		if ((ima_appraise & IMA_APPRAISE_FIRMWARE) &&
659 660
		    (ima_appraise & IMA_APPRAISE_ENFORCE)) {
			pr_err("Prevent firmware loading_store.\n");
661
			return -EACCES;	/* INTEGRITY_UNKNOWN */
662
		}
663 664 665
		return 0;
	}

666 667 668 669
	/* permit signed certs */
	if (!file && read_id == READING_X509_CERTIFICATE)
		return 0;

670 671 672 673 674 675
	if (!file || !buf || size == 0) { /* should never happen */
		if (ima_appraise & IMA_APPRAISE_ENFORCE)
			return -EACCES;
		return 0;
	}

676
	func = read_idmap[read_id] ?: FILE_CHECK;
677 678
	security_task_getsecid(current, &secid);
	return process_measurement(file, current_cred(), secid, buf, size,
679
				   MAY_READ, func);
680 681
}

682 683 684 685 686 687 688 689 690 691 692 693
/**
 * ima_load_data - appraise decision based on policy
 * @id: kernel load data caller identifier
 *
 * 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.
 */
int ima_load_data(enum kernel_load_data_id id)
{
694
	bool ima_enforce, sig_enforce;
695

696 697
	ima_enforce =
		(ima_appraise & IMA_APPRAISE_ENFORCE) == IMA_APPRAISE_ENFORCE;
698 699 700

	switch (id) {
	case LOADING_KEXEC_IMAGE:
701
		if (IS_ENABLED(CONFIG_KEXEC_SIG)
702 703 704 705 706 707
		    && 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)) {
708 709 710
			pr_err("impossible to appraise a kernel image without a file descriptor; try using kexec_file_load syscall.\n");
			return -EACCES;	/* INTEGRITY_UNKNOWN */
		}
711 712
		break;
	case LOADING_FIRMWARE:
713
		if (ima_enforce && (ima_appraise & IMA_APPRAISE_FIRMWARE)) {
714 715 716
			pr_err("Prevent firmware sysfs fallback loading.\n");
			return -EACCES;	/* INTEGRITY_UNKNOWN */
		}
717 718 719 720
		break;
	case LOADING_MODULE:
		sig_enforce = is_module_sig_enforced();

721 722
		if (ima_enforce && (!sig_enforce
				    && (ima_appraise & IMA_APPRAISE_MODULES))) {
723 724 725
			pr_err("impossible to appraise a module without a file descriptor. sig_enforce kernel parameter might help\n");
			return -EACCES;	/* INTEGRITY_UNKNOWN */
		}
726 727 728 729 730 731
	default:
		break;
	}
	return 0;
}

732 733
/*
 * process_buffer_measurement - Measure the buffer to ima log.
734
 * @inode: inode associated with the object being measured (NULL for KEY_CHECK)
735 736 737
 * @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.
738 739
 * @func: IMA hook
 * @pcr: pcr to extend the measurement
740
 * @keyring: keyring name to determine the action to be performed
741 742 743
 *
 * Based on policy, the buffer is measured into the ima log.
 */
744
void process_buffer_measurement(struct inode *inode, const void *buf, int size,
745
				const char *eventname, enum ima_hooks func,
746
				int pcr, const char *keyring)
747 748
{
	int ret = 0;
749
	const char *audit_cause = "ENOMEM";
750 751 752
	struct ima_template_entry *entry = NULL;
	struct integrity_iint_cache iint = {};
	struct ima_event_data event_data = {.iint = &iint,
753 754 755
					    .filename = eventname,
					    .buf = buf,
					    .buf_len = size};
756
	struct ima_template_desc *template = NULL;
757 758 759 760 761 762
	struct {
		struct ima_digest_data hdr;
		char digest[IMA_MAX_DIGEST_SIZE];
	} hash = {};
	int violation = 0;
	int action = 0;
763
	u32 secid;
764

765 766 767
	if (!ima_policy_flag)
		return;

768 769 770 771 772 773 774 775 776
	/*
	 * 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);
777
		action = ima_get_action(inode, current_cred(), secid, 0, func,
778
					&pcr, &template, keyring);
779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797
		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;
		}
	}
798 799 800 801 802 803

	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);
804 805
	if (ret < 0) {
		audit_cause = "hashing_error";
806
		goto out;
807
	}
808

809
	ret = ima_alloc_init_template(&event_data, &entry, template);
810 811
	if (ret < 0) {
		audit_cause = "alloc_entry";
812
		goto out;
813
	}
814 815

	ret = ima_store_template(entry, violation, NULL, buf, pcr);
816 817
	if (ret < 0) {
		audit_cause = "store_entry";
818
		ima_free_template_entry(entry);
819
	}
820 821

out:
822
	if (ret < 0)
823 824 825
		integrity_audit_message(AUDIT_INTEGRITY_PCR, NULL, eventname,
					func_measure_str(func),
					audit_cause, ret, 0, ret);
826

827 828 829 830 831
	return;
}

/**
 * ima_kexec_cmdline - measure kexec cmdline boot args
832
 * @kernel_fd: file descriptor of the kexec kernel being loaded
833 834 835 836 837
 * @buf: pointer to buffer
 * @size: size of buffer
 *
 * Buffers can only be measured, not appraised.
 */
838
void ima_kexec_cmdline(int kernel_fd, const void *buf, int size)
839
{
840 841 842 843 844 845 846 847 848 849 850 851
	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);
852 853
}

854 855 856 857
static int __init init_ima(void)
{
	int error;

858
	ima_init_template_list();
859
	hash_setup(CONFIG_IMA_DEFAULT_HASH);
860
	error = ima_init();
861 862 863 864 865 866 867 868 869 870

	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();
	}

871 872 873
	if (error)
		return error;

874 875 876 877
	error = register_blocking_lsm_notifier(&ima_lsm_policy_notifier);
	if (error)
		pr_warn("Couldn't register LSM notifier, error %d\n", error);

878
	if (!error)
879
		ima_update_policy_flag();
880

881 882 883 884
	return error;
}

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