evm: Refuse EVM_ALLOW_METADATA_WRITES only if an HMAC key is loaded
authorRoberto Sassu <roberto.sassu@huawei.com>
Fri, 14 May 2021 15:27:44 +0000 (17:27 +0200)
committerMimi Zohar <zohar@linux.ibm.com>
Fri, 21 May 2021 16:47:08 +0000 (12:47 -0400)
commit9acc89d31f0c94c8e573ed61f3e4340bbd526d0c
treebdd16363bef347fdd26f39735797816090f306cb
parentaa2ead71d9daa1b6645e1d25b1f14a6286b114d0
evm: Refuse EVM_ALLOW_METADATA_WRITES only if an HMAC key is loaded

EVM_ALLOW_METADATA_WRITES is an EVM initialization flag that can be set to
temporarily disable metadata verification until all xattrs/attrs necessary
to verify an EVM portable signature are copied to the file. This flag is
cleared when EVM is initialized with an HMAC key, to avoid that the HMAC is
calculated on unverified xattrs/attrs.

Currently EVM unnecessarily denies setting this flag if EVM is initialized
with a public key, which is not a concern as it cannot be used to trust
xattrs/attrs updates. This patch removes this limitation.

Fixes: ae1ba1676b88e ("EVM: Allow userland to permit modification of EVM-protected metadata")
Signed-off-by: Roberto Sassu <roberto.sassu@huawei.com>
Cc: stable@vger.kernel.org # 4.16.x
Signed-off-by: Mimi Zohar <zohar@linux.ibm.com>
Documentation/ABI/testing/evm
security/integrity/evm/evm_secfs.c