Commit 858452ff authored by Roberto Sassu's avatar Roberto Sassu Committed by Greg Kroah-Hartman

ima: fix invalid memory reference

commit 7b7e5916 upstream.

Don't free a valid measurement entry on TPM PCR extend failure.
Signed-off-by: default avatarRoberto Sassu <roberto.sassu@polito.it>
Signed-off-by: default avatarMimi Zohar <zohar@us.ibm.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 4483c1f0
...@@ -23,6 +23,8 @@ ...@@ -23,6 +23,8 @@
#include <linux/slab.h> #include <linux/slab.h>
#include "ima.h" #include "ima.h"
#define AUDIT_CAUSE_LEN_MAX 32
LIST_HEAD(ima_measurements); /* list of all measurements */ LIST_HEAD(ima_measurements); /* list of all measurements */
/* key: inode (before secure-hashing a file) */ /* key: inode (before secure-hashing a file) */
...@@ -94,7 +96,8 @@ static int ima_pcr_extend(const u8 *hash) ...@@ -94,7 +96,8 @@ static int ima_pcr_extend(const u8 *hash)
result = tpm_pcr_extend(TPM_ANY_NUM, CONFIG_IMA_MEASURE_PCR_IDX, hash); result = tpm_pcr_extend(TPM_ANY_NUM, CONFIG_IMA_MEASURE_PCR_IDX, hash);
if (result != 0) if (result != 0)
pr_err("IMA: Error Communicating to TPM chip\n"); pr_err("IMA: Error Communicating to TPM chip, result: %d\n",
result);
return result; return result;
} }
...@@ -106,8 +109,9 @@ int ima_add_template_entry(struct ima_template_entry *entry, int violation, ...@@ -106,8 +109,9 @@ int ima_add_template_entry(struct ima_template_entry *entry, int violation,
{ {
u8 digest[IMA_DIGEST_SIZE]; u8 digest[IMA_DIGEST_SIZE];
const char *audit_cause = "hash_added"; const char *audit_cause = "hash_added";
char tpm_audit_cause[AUDIT_CAUSE_LEN_MAX];
int audit_info = 1; int audit_info = 1;
int result = 0; int result = 0, tpmresult = 0;
mutex_lock(&ima_extend_list_mutex); mutex_lock(&ima_extend_list_mutex);
if (!violation) { if (!violation) {
...@@ -129,9 +133,11 @@ int ima_add_template_entry(struct ima_template_entry *entry, int violation, ...@@ -129,9 +133,11 @@ int ima_add_template_entry(struct ima_template_entry *entry, int violation,
if (violation) /* invalidate pcr */ if (violation) /* invalidate pcr */
memset(digest, 0xff, sizeof digest); memset(digest, 0xff, sizeof digest);
result = ima_pcr_extend(digest); tpmresult = ima_pcr_extend(digest);
if (result != 0) { if (tpmresult != 0) {
audit_cause = "TPM error"; snprintf(tpm_audit_cause, AUDIT_CAUSE_LEN_MAX, "TPM_error(%d)",
tpmresult);
audit_cause = tpm_audit_cause;
audit_info = 0; audit_info = 0;
} }
out: out:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment