diff options
author | Thiago Jung Bauermann <bauerman@linux.ibm.com> | 2019-06-11 03:28:08 -0300 |
---|---|---|
committer | Mimi Zohar <zohar@linux.ibm.com> | 2019-06-30 17:54:41 -0400 |
commit | 650b29dbdf2caf7db27cdc8bfa8fc009b28a6ce3 (patch) | |
tree | 41585db527639befc8ae4ea09619ea40078b0fde /security/integrity/integrity.h | |
parent | 337619eb44ef663d329c5c19efd18488ce7de492 (diff) | |
download | linux-650b29dbdf2caf7db27cdc8bfa8fc009b28a6ce3.tar.bz2 |
integrity: Introduce struct evm_xattr
Even though struct evm_ima_xattr_data includes a fixed-size array to hold a
SHA1 digest, most of the code ignores the array and uses the struct to mean
"type indicator followed by data of unspecified size" and tracks the real
size of what the struct represents in a separate length variable.
The only exception to that is the EVM code, which correctly uses the
definition of struct evm_ima_xattr_data.
So make this explicit in the code by removing the length specification from
the array in struct evm_ima_xattr_data. Also, change the name of the
element from digest to data since in most places the array doesn't hold a
digest.
A separate struct evm_xattr is introduced, with the original definition of
evm_ima_xattr_data to be used in the places that actually expect that
definition, specifically the EVM HMAC code.
Signed-off-by: Thiago Jung Bauermann <bauerman@linux.ibm.com>
Signed-off-by: Mimi Zohar <zohar@linux.ibm.com>
Diffstat (limited to 'security/integrity/integrity.h')
-rw-r--r-- | security/integrity/integrity.h | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/security/integrity/integrity.h b/security/integrity/integrity.h index 7de59f44cba3..88a29f72a74f 100644 --- a/security/integrity/integrity.h +++ b/security/integrity/integrity.h @@ -79,6 +79,12 @@ enum evm_ima_xattr_type { struct evm_ima_xattr_data { u8 type; + u8 data[]; +} __packed; + +/* Only used in the EVM HMAC code. */ +struct evm_xattr { + struct evm_ima_xattr_data data; u8 digest[SHA1_DIGEST_SIZE]; } __packed; |