1 /* SPDX-License-Identifier: GPL-2.0 */
3 * Copyright (C) 2020-2024 Microsoft Corporation. All rights reserved.
9 #include <linux/file.h>
10 #include <linux/types.h>
15 #define IPE_EVAL_CTX_INIT ((struct ipe_eval_ctx){ 0 })
17 extern struct ipe_policy __rcu *ipe_active_policy;
18 extern bool success_audit;
21 struct ipe_superblock {
25 #ifdef CONFIG_IPE_PROP_DM_VERITY
27 #ifdef CONFIG_IPE_PROP_DM_VERITY_SIGNATURE
28 bool dm_verity_signed;
29 #endif /* CONFIG_IPE_PROP_DM_VERITY_SIGNATURE */
30 struct digest_info *root_hash;
32 #endif /* CONFIG_IPE_PROP_DM_VERITY */
34 #ifdef CONFIG_IPE_PROP_FS_VERITY_BUILTIN_SIG
36 bool fs_verity_signed;
38 #endif /* CONFIG_IPE_PROP_FS_VERITY_BUILTIN_SIG */
42 enum ipe_hook_type hook;
44 const struct file *file;
46 #ifdef CONFIG_IPE_PROP_DM_VERITY
47 const struct ipe_bdev *ipe_bdev;
48 #endif /* CONFIG_IPE_PROP_DM_VERITY */
49 #ifdef CONFIG_IPE_PROP_FS_VERITY
50 const struct inode *ino;
51 #endif /* CONFIG_IPE_PROP_FS_VERITY */
52 #ifdef CONFIG_IPE_PROP_FS_VERITY_BUILTIN_SIG
53 const struct ipe_inode *ipe_inode;
54 #endif /* CONFIG_IPE_PROP_FS_VERITY_BUILTIN_SIG */
64 void ipe_build_eval_ctx(struct ipe_eval_ctx *ctx,
65 const struct file *file,
67 enum ipe_hook_type hook);
68 int ipe_evaluate_event(const struct ipe_eval_ctx *const ctx);
70 #endif /* _IPE_EVAL_H */