Blame view

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