evm.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (C) 2005-2010 IBM Corporation
  4. *
  5. * Authors:
  6. * Mimi Zohar <[email protected]>
  7. * Kylene Hall <[email protected]>
  8. *
  9. * File: evm.h
  10. */
  11. #ifndef __INTEGRITY_EVM_H
  12. #define __INTEGRITY_EVM_H
  13. #include <linux/xattr.h>
  14. #include <linux/security.h>
  15. #include "../integrity.h"
  16. #define EVM_INIT_HMAC 0x0001
  17. #define EVM_INIT_X509 0x0002
  18. #define EVM_ALLOW_METADATA_WRITES 0x0004
  19. #define EVM_SETUP_COMPLETE 0x80000000 /* userland has signaled key load */
  20. #define EVM_KEY_MASK (EVM_INIT_HMAC | EVM_INIT_X509)
  21. #define EVM_INIT_MASK (EVM_INIT_HMAC | EVM_INIT_X509 | EVM_SETUP_COMPLETE | \
  22. EVM_ALLOW_METADATA_WRITES)
  23. struct xattr_list {
  24. struct list_head list;
  25. char *name;
  26. bool enabled;
  27. };
  28. extern int evm_initialized;
  29. #define EVM_ATTR_FSUUID 0x0001
  30. extern int evm_hmac_attrs;
  31. /* List of EVM protected security xattrs */
  32. extern struct list_head evm_config_xattrnames;
  33. struct evm_digest {
  34. struct ima_digest_data hdr;
  35. char digest[IMA_MAX_DIGEST_SIZE];
  36. } __packed;
  37. int evm_init_key(void);
  38. int evm_update_evmxattr(struct dentry *dentry,
  39. const char *req_xattr_name,
  40. const char *req_xattr_value,
  41. size_t req_xattr_value_len);
  42. int evm_calc_hmac(struct dentry *dentry, const char *req_xattr_name,
  43. const char *req_xattr_value,
  44. size_t req_xattr_value_len, struct evm_digest *data);
  45. int evm_calc_hash(struct dentry *dentry, const char *req_xattr_name,
  46. const char *req_xattr_value,
  47. size_t req_xattr_value_len, char type,
  48. struct evm_digest *data);
  49. int evm_init_hmac(struct inode *inode, const struct xattr *xattr,
  50. char *hmac_val);
  51. int evm_init_secfs(void);
  52. #endif