evm.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  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. extern int evm_initialized;
  21. extern char *evm_hmac;
  22. extern char *evm_hash;
  23. #define EVM_ATTR_FSUUID 0x0001
  24. extern int evm_hmac_attrs;
  25. extern struct crypto_shash *hmac_tfm;
  26. extern struct crypto_shash *hash_tfm;
  27. /* List of EVM protected security xattrs */
  28. extern char *evm_config_xattrnames[];
  29. int evm_init_key(void);
  30. int evm_update_evmxattr(struct dentry *dentry,
  31. const char *req_xattr_name,
  32. const char *req_xattr_value,
  33. size_t req_xattr_value_len);
  34. int evm_calc_hmac(struct dentry *dentry, const char *req_xattr_name,
  35. const char *req_xattr_value,
  36. size_t req_xattr_value_len, char *digest);
  37. int evm_calc_hash(struct dentry *dentry, const char *req_xattr_name,
  38. const char *req_xattr_value,
  39. size_t req_xattr_value_len, char *digest);
  40. int evm_init_hmac(struct inode *inode, const struct xattr *xattr,
  41. char *hmac_val);
  42. int evm_init_secfs(void);
  43. #endif