Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp990451ybl; Wed, 4 Dec 2019 14:42:20 -0800 (PST) X-Google-Smtp-Source: APXvYqyqeRaMf99rr7W1bF1seeS9JduYFRtFlBBTHr0fluqVil/w8xdSvtyhmcxFQBBETr5nJJ+F X-Received: by 2002:a9d:6315:: with SMTP id q21mr4184868otk.15.1575499340671; Wed, 04 Dec 2019 14:42:20 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575499340; cv=none; d=google.com; s=arc-20160816; b=xC8xr6N6l9aCQ7GuhAWPK9w5JgBFmtDVZMgscyLgJtkaw11rUAw1rQutIxYqbRitaq ijJg7NrdGcSg5NSJYMQj6wJbOIqGrTdl3HRuMPI7H2RgwemkwIRLUSBj16i5Doc8Tp+A JaX39OXN60qoAhl+jQse+JhB3G7bjHOh4CzJ0A+c6Oo9QASLmg+u1Mk8yabqCHYo+1Oh gAmqpTgsJVvnaCeV99Pv/9vhki856RkYZtbmWSdFV5c9gXU1LInnY0ZZrhGRwBPvHBWT kSopsawZMkTEBoEe2kuufBbv3whIArF3nOZR+dDZQBTai7BKxFANJQAYkAY00G06TVye c83A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:dkim-filter; bh=ScSwEyZVOR1vts7e3eQmnQ7pZQAe+Gm5XUx2QTgbWGY=; b=H0/yGfa3YmGT22X7Bq8r32Am2kIamgrBCXMjoGe6GTnHcjxydfg7RwK3sYyvgH8HPl BP99I3QL3PpvykuR1ayaac6auxraLtSZYOVg5wgaKiQDCvMuxjGL9IXtSJfb64WJK1fk cThTAEwJaR73iA4/gDmM/SIt2JDTuWyvg3+tjvOGp7JOMjL6FKXmDuJtO2nVvdYCinl2 JqzKMVstqnj02HeOJJ60WfDG/S0hiO+btJn+bayAeiMDlxGctiG0OkW2FpEtpDO+0L4F rzff/kmpUrDoBHhxVsXgwntpV2bYt+fVQAIBTSDXqwra6KRH84WbDhPuPCbtlr+ram9Z tcdw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=bGBWRhQY; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linux.microsoft.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m24si3996044otn.67.2019.12.04.14.42.08; Wed, 04 Dec 2019 14:42:20 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@linux.microsoft.com header.s=default header.b=bGBWRhQY; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linux.microsoft.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728490AbfLDWll (ORCPT + 99 others); Wed, 4 Dec 2019 17:41:41 -0500 Received: from linux.microsoft.com ([13.77.154.182]:50178 "EHLO linux.microsoft.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728383AbfLDWlj (ORCPT ); Wed, 4 Dec 2019 17:41:39 -0500 Received: from nramas-ThinkStation-P520.corp.microsoft.com (unknown [131.107.174.108]) by linux.microsoft.com (Postfix) with ESMTPSA id F34DD20BE482; Wed, 4 Dec 2019 14:41:37 -0800 (PST) DKIM-Filter: OpenDKIM Filter v2.11.0 linux.microsoft.com F34DD20BE482 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linux.microsoft.com; s=default; t=1575499298; bh=ScSwEyZVOR1vts7e3eQmnQ7pZQAe+Gm5XUx2QTgbWGY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bGBWRhQYtmMx00NQfj8HkqB+ar5xp8uovBNqnHBtn0Gboy1Cnj/xplDMhqcx20Wo8 Yh+y0I0CpVyWHbQuw/WJniwhaXJa/enQC3Sh70SPFvQ9f+LCMC4InVec2JM1ls+R/Y M31KEU+3s02K9WQoHE4MtDK87DHlAkThCHFZyx4A= From: Lakshmi Ramasubramanian To: zohar@linux.ibm.com, linux-integrity@vger.kernel.org Cc: eric.snowberg@oracle.com, dhowells@redhat.com, mathew.j.martineau@linux.intel.com, matthewgarrett@google.com, sashal@kernel.org, jamorris@linux.microsoft.com, linux-kernel@vger.kernel.org, keyrings@vger.kernel.org Subject: [PATCH v10 6/6] IMA: Read keyrings= option from the IMA policy Date: Wed, 4 Dec 2019 14:41:31 -0800 Message-Id: <20191204224131.3384-7-nramas@linux.microsoft.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20191204224131.3384-1-nramas@linux.microsoft.com> References: <20191204224131.3384-1-nramas@linux.microsoft.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Read "keyrings=" option, if specified in the IMA policy, and store in the list of IMA rules when the configured IMA policy is read. This patch defines a new policy token enum namely Opt_keyrings and an option flag IMA_KEYRINGS for reading "keyrings=" option from the IMA policy. Updated ima_parse_rule() to parse "keyrings=" option in the policy. Updated ima_policy_show() to display "keyrings=" option. The following example illustrates how key measurement can be verified. Sample "key" measurement rule in the IMA policy: measure func=KEY_CHECK uid=0 keyrings=.ima|.evm template=ima-buf Display "key" measurement in the IMA measurement list: cat /sys/kernel/security/ima/ascii_runtime_measurements 10 faf3...e702 ima-buf sha256:27c915b8ddb9fae7214cf0a8a7043cc3eeeaa7539bcb136f8427067b5f6c3b7b .ima 308202863082...4aee Verify "key" measurement data for a key added to ".ima" keyring: cat /sys/kernel/security/integrity/ima/ascii_runtime_measurements | grep ".ima" | cut -d' ' -f 6 | xxd -r -p |tee ima-cert.der | sha256sum | cut -d' ' -f 1 The output of the above command should match the sha256 hash in the "key" measurement entry in the IMA measurement list. The file namely "ima-cert.der" generated by the above command should be a valid x509 certificate (in DER format) and should match the one that was used to import the key to the .ima keyring. The certificate file can be verified using openssl tool. Signed-off-by: Lakshmi Ramasubramanian --- security/integrity/ima/ima_policy.c | 29 ++++++++++++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) diff --git a/security/integrity/ima/ima_policy.c b/security/integrity/ima/ima_policy.c index 5db990c8b02d..73030a69d546 100644 --- a/security/integrity/ima/ima_policy.c +++ b/security/integrity/ima/ima_policy.c @@ -34,6 +34,7 @@ #define IMA_EUID 0x0080 #define IMA_PCR 0x0100 #define IMA_FSNAME 0x0200 +#define IMA_KEYRINGS 0x0400 #define UNKNOWN 0 #define MEASURE 0x0001 /* same as IMA_MEASURE */ @@ -821,7 +822,8 @@ enum { Opt_uid_gt, Opt_euid_gt, Opt_fowner_gt, Opt_uid_lt, Opt_euid_lt, Opt_fowner_lt, Opt_appraise_type, Opt_appraise_flag, - Opt_permit_directio, Opt_pcr, Opt_template, Opt_err + Opt_permit_directio, Opt_pcr, Opt_template, Opt_keyrings, + Opt_err }; static const match_table_t policy_tokens = { @@ -857,6 +859,7 @@ static const match_table_t policy_tokens = { {Opt_permit_directio, "permit_directio"}, {Opt_pcr, "pcr=%s"}, {Opt_template, "template=%s"}, + {Opt_keyrings, "keyrings=%s"}, {Opt_err, NULL} }; @@ -1106,6 +1109,23 @@ static int ima_parse_rule(char *rule, struct ima_rule_entry *entry) result = 0; entry->flags |= IMA_FSNAME; break; + case Opt_keyrings: + ima_log_string(ab, "keyrings", args[0].from); + + if ((entry->keyrings) || + (entry->action != MEASURE) || + (entry->func != KEY_CHECK)) { + result = -EINVAL; + break; + } + entry->keyrings = kstrdup(args[0].from, GFP_KERNEL); + if (!entry->keyrings) { + result = -ENOMEM; + break; + } + result = 0; + entry->flags |= IMA_KEYRINGS; + break; case Opt_fsuuid: ima_log_string(ab, "fsuuid", args[0].from); @@ -1481,6 +1501,13 @@ int ima_policy_show(struct seq_file *m, void *v) seq_puts(m, " "); } + if (entry->flags & IMA_KEYRINGS) { + if (entry->keyrings != NULL) + snprintf(tbuf, sizeof(tbuf), "%s", entry->keyrings); + seq_printf(m, pt(Opt_keyrings), tbuf); + seq_puts(m, " "); + } + if (entry->flags & IMA_PCR) { snprintf(tbuf, sizeof(tbuf), "%d", entry->pcr); seq_printf(m, pt(Opt_pcr), tbuf); -- 2.17.1