Received: by 2002:a05:6a10:a852:0:0:0:0 with SMTP id d18csp378328pxy; Wed, 5 May 2021 04:36:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzZSZu3MpjsGSyfXn+BsrGoZ8a8cyyUFqWta3geA8CGe3BoBKSPxaMNtKqHybLZg2wBxD2D X-Received: by 2002:a65:6a4c:: with SMTP id o12mr27804549pgu.371.1620214616553; Wed, 05 May 2021 04:36:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620214616; cv=none; d=google.com; s=arc-20160816; b=dSgzLYkA5AJvmF6LwOYRhGlnbsfQqJjn1z6WmOFMUj6TocD040NbSgwTd3LA4+h8NZ Fnjp8x18jM78Y1xzOlyhqc8MRFhbE0V/jpeIHwjlSa8Km3BED2CUKatMM1ecyVPG6RAA e4iNL5HuY7Qzoy8+UfhCFKeRFkcnmSwFFzZo96uDkZoTHTGcS6NFEAbkD2z2/R0JE4uf PTcH4XswZEVEnLWJ5l07vSWvA97hVY0nkW3AQMzp7juZidzgMJhW9jY4hMH10LTtWtJC ZRcz+MRWCZMMdTLZLOBzL341kzIIqxLQVRXuT7XAZVM+wcEz9DLwRxcjWWCcC3ZUT95P qzDA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=hGC1zf2acsU9IGGz1d1JGSaVFdNba+whFcONp0LQTXY=; b=iug3nsvU4pTlsT0nw+MCWEmMNPFXQt1OIiBPHhqvV2erSISubyungQOpfnqwAHZaZ0 NFhq0Q4fGQRF6d8w3Abl8EWXYYLDaXJZP4XNTMCyPXjU2RWD+GzrLCnqF0WLmAQPOe52 a5xwdHqCztSOMtr8hLRBpPxMtjrCDPlENMB9u/u9NP3EEiVHJ3hvmZfG7D8s+pyMs2T8 q2m9bX3IHhX3dUESkNRMKC7A1gd/pkXoq4P3gk1xWu7PEoJ+XT1nGItmK7VLioFPHuGY qnPDgq2IM9WPFeJpZk9/5ALWKI2eIgai+2PXqEd5wg0H4p2kXp2431y6d94h8xUjiENf VuXA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g8si20822508pja.25.2021.05.05.04.36.43; Wed, 05 May 2021 04:36:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233120AbhEELe7 (ORCPT + 99 others); Wed, 5 May 2021 07:34:59 -0400 Received: from frasgout.his.huawei.com ([185.176.79.56]:3012 "EHLO frasgout.his.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233022AbhEELex (ORCPT ); Wed, 5 May 2021 07:34:53 -0400 Received: from fraeml714-chm.china.huawei.com (unknown [172.18.147.226]) by frasgout.his.huawei.com (SkyGuard) with ESMTP id 4FZvbB55dGz6yhpy; Wed, 5 May 2021 19:28:06 +0800 (CST) Received: from roberto-ThinkStation-P620.huawei.com (10.204.62.217) by fraeml714-chm.china.huawei.com (10.206.15.33) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2176.2; Wed, 5 May 2021 13:33:54 +0200 From: Roberto Sassu To: , CC: , , , Roberto Sassu Subject: [PATCH v6 09/11] ima: Allow imasig requirement to be satisfied by EVM portable signatures Date: Wed, 5 May 2021 13:33:27 +0200 Message-ID: <20210505113329.1410943-5-roberto.sassu@huawei.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210505112935.1410679-1-roberto.sassu@huawei.com> References: <20210505112935.1410679-1-roberto.sassu@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.204.62.217] X-ClientProxiedBy: lhreml752-chm.china.huawei.com (10.201.108.202) To fraeml714-chm.china.huawei.com (10.206.15.33) X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org System administrators can require that all accessed files have a signature by specifying appraise_type=imasig in a policy rule. Currently, IMA signatures satisfy this requirement. Appended signatures may also satisfy this requirement, but are not applicable as IMA signatures. IMA/appended signatures ensure data source authentication for file content and prevent any change. EVM signatures instead ensure data source authentication for file metadata. Given that the digest or signature of the file content must be included in the metadata, EVM signatures provide the same file data guarantees of IMA signatures, as well as providing file metadata guarantees. This patch lets systems protected with EVM signatures pass appraisal verification if the appraise_type=imasig requirement is specified in the policy. This facilitates deployment in the scenarios where only EVM signatures are available. The patch makes the following changes: file xattr types: security.ima: IMA_XATTR_DIGEST/IMA_XATTR_DIGEST_NG security.evm: EVM_XATTR_PORTABLE_DIGSIG execve(), mmap(), open() behavior (with appraise_type=imasig): before: denied (file without IMA signature, imasig requirement not met) after: allowed (file with EVM portable signature, imasig requirement met) open(O_WRONLY) behavior (without appraise_type=imasig): before: allowed (file without IMA signature, not immutable) after: denied (file with EVM portable signature, immutable) In addition, similarly to IMA signatures, this patch temporarily allows new files without or with incomplete metadata to be opened so that content can be written. Signed-off-by: Roberto Sassu Reviewed-by: Mimi Zohar --- security/integrity/ima/ima_appraise.c | 24 +++++++++++++++++------- 1 file changed, 17 insertions(+), 7 deletions(-) diff --git a/security/integrity/ima/ima_appraise.c b/security/integrity/ima/ima_appraise.c index 6d0983a97711..23af45d8ac58 100644 --- a/security/integrity/ima/ima_appraise.c +++ b/security/integrity/ima/ima_appraise.c @@ -242,12 +242,16 @@ static int xattr_verify(enum ima_hooks func, struct integrity_iint_cache *iint, hash_start = 1; fallthrough; case IMA_XATTR_DIGEST: - if (iint->flags & IMA_DIGSIG_REQUIRED) { - *cause = "IMA-signature-required"; - *status = INTEGRITY_FAIL; - break; + if (*status != INTEGRITY_PASS_IMMUTABLE) { + if (iint->flags & IMA_DIGSIG_REQUIRED) { + *cause = "IMA-signature-required"; + *status = INTEGRITY_FAIL; + break; + } + clear_bit(IMA_DIGSIG, &iint->atomic_flags); + } else { + set_bit(IMA_DIGSIG, &iint->atomic_flags); } - clear_bit(IMA_DIGSIG, &iint->atomic_flags); if (xattr_len - sizeof(xattr_value->type) - hash_start >= iint->ima_hash->length) /* @@ -417,6 +421,7 @@ int ima_appraise_measurement(enum ima_hooks func, cause = "missing-HMAC"; goto out; case INTEGRITY_FAIL_IMMUTABLE: + set_bit(IMA_DIGSIG, &iint->atomic_flags); fallthrough; case INTEGRITY_FAIL: /* Invalid HMAC/signature. */ cause = "invalid-HMAC"; @@ -461,9 +466,12 @@ int ima_appraise_measurement(enum ima_hooks func, status = INTEGRITY_PASS; } - /* Permit new files with file signatures, but without data. */ + /* + * Permit new files with file/EVM portable signatures, but + * without data. + */ if (inode->i_size == 0 && iint->flags & IMA_NEW_FILE && - xattr_value && xattr_value->type == EVM_IMA_XATTR_DIGSIG) { + test_bit(IMA_DIGSIG, &iint->atomic_flags)) { status = INTEGRITY_PASS; } @@ -581,6 +589,8 @@ int ima_inode_setxattr(struct dentry *dentry, const char *xattr_name, if (!xattr_value_len || (xvalue->type >= IMA_XATTR_LAST)) return -EINVAL; digsig = (xvalue->type == EVM_IMA_XATTR_DIGSIG); + } else if (!strcmp(xattr_name, XATTR_NAME_EVM) && xattr_value_len > 0) { + digsig = (xvalue->type == EVM_XATTR_PORTABLE_DIGSIG); } if (result == 1 || evm_status_revalidate(xattr_name)) { ima_reset_appraise_flags(d_backing_inode(dentry), digsig); -- 2.25.1