evm.h 1.4 KB

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