evm.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /*
  2. * Copyright (C) 2005-2010 IBM Corporation
  3. *
  4. * Authors:
  5. * Mimi Zohar <zohar@us.ibm.com>
  6. * Kylene Hall <kjhall@us.ibm.com>
  7. *
  8. * This program is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, version 2 of the License.
  11. *
  12. * File: evm.h
  13. *
  14. */
  15. #ifndef __INTEGRITY_EVM_H
  16. #define __INTEGRITY_EVM_H
  17. #include <linux/xattr.h>
  18. #include <linux/security.h>
  19. #include "../integrity.h"
  20. #define EVM_INIT_HMAC 0x0001
  21. #define EVM_INIT_X509 0x0002
  22. extern int evm_initialized;
  23. extern char *evm_hmac;
  24. extern char *evm_hash;
  25. #define EVM_ATTR_FSUUID 0x0001
  26. extern int evm_hmac_attrs;
  27. extern struct crypto_shash *hmac_tfm;
  28. extern struct crypto_shash *hash_tfm;
  29. /* List of EVM protected security xattrs */
  30. extern char *evm_config_xattrnames[];
  31. int evm_init_key(void);
  32. int evm_update_evmxattr(struct dentry *dentry,
  33. const char *req_xattr_name,
  34. const char *req_xattr_value,
  35. size_t req_xattr_value_len);
  36. int evm_calc_hmac(struct dentry *dentry, const char *req_xattr_name,
  37. const char *req_xattr_value,
  38. size_t req_xattr_value_len, char *digest);
  39. int evm_calc_hash(struct dentry *dentry, const char *req_xattr_name,
  40. const char *req_xattr_value,
  41. size_t req_xattr_value_len, char *digest);
  42. int evm_init_hmac(struct inode *inode, const struct xattr *xattr,
  43. char *hmac_val);
  44. int evm_init_secfs(void);
  45. #endif