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 */