Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp3691451ybv; Mon, 10 Feb 2020 04:47:51 -0800 (PST) X-Google-Smtp-Source: APXvYqzJLNnlkIVKk5SnnYFsI3BWv+O+KN1FykG7sMl0sf1TTwBQj39jiLfvjW6B53/Uael/JPNx X-Received: by 2002:a05:6830:1689:: with SMTP id k9mr943751otr.311.1581338871516; Mon, 10 Feb 2020 04:47:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581338871; cv=none; d=google.com; s=arc-20160816; b=PoOZ+ghODdrJGARGKIYUGxgiWEApwFKxDjnpgDRtbRUWqZ3m/6lTcBJO/KyWWujQe/ Luzc1wL/O01IGgYdQqR7rRjTXZRXqn55R6BUuXjcMUrwmw3yLhTYT5r28vMjha9ti8PC EVPQ/BzIFhlwtAt8sgIMLPBD6AJh4AGKJEWXLEVBvTR4xbAgIrVPXtrg5BXjJeH+WQ3P 33cp4q9y2bEE1Feyb6vz7ahgbvnr/gQhOU2Cal3tQ0L7A7/VqbJeqC4b6KbpUJyQFhSX mggGA9au/xlH/XDSJ/TTkLASCl/bZPQMUtIDaLB4xDPwM6L+Hd4eOMxP5+Hca1fuFtl3 vIKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=OdLg2Hroj0PObxKa3gjTDzngEuxUZsAkOuRNnhb0grk=; b=InL48yszKnUhzgIiTW6gENBf40FuWSGL2TJO5QUN/Uj7KSMbYqiYvM7dlyixC8cwJs s28f4tULjCK92CrrBrgUC8P9Ap4/+Gxqh2vyFHw7QmRtxWwAXqRZNLyngkYIZVaoBNXx h2u8gK4j3/5mS5E4WT+dEYLSdkRmXYFc0m7V2AK4LJSlnODgdPBgz6L0BJKJuC1JTZS/ uB8Qs4gULMo/u27rwXmnYSBX89hNJSPHPFkWYFds2tZYf9/mAuw0A+l6AUgkEcT2cVlZ a1BphlVeKMep+ak+yQc09xLXhaiF9kIWr2/FvlmACLU5fkJ2bbq2Qg/dI71uTzjv8fm7 KbRg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="QiiO/ePc"; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d8si124933oti.306.2020.02.10.04.47.39; Mon, 10 Feb 2020 04:47:51 -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=@kernel.org header.s=default header.b="QiiO/ePc"; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729729AbgBJMrd (ORCPT + 99 others); Mon, 10 Feb 2020 07:47:33 -0500 Received: from mail.kernel.org ([198.145.29.99]:46294 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728791AbgBJMmP (ORCPT ); Mon, 10 Feb 2020 07:42:15 -0500 Received: from localhost (unknown [209.37.97.194]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id AC0E724649; Mon, 10 Feb 2020 12:42:14 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1581338534; bh=+E7je+NFtmGn49WxnLROcZktH8h8z2zuomszzMDNbuE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=QiiO/ePcI+F9ORfT1UR8s9akTPO6oTO+qH5hTdf5eVgcNLVSriQC3sFTHKpmmqPHf mmmC/2reghecS7t1W/K0/gqSvleV9gOfySwPdujm+ag2GQulOiWxNFCvX3hQKi+ZYv /QImsTuXf6FQScWkitYmpDFlTnfQOM8gBkCT0cdY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Tudor Ambarus , Herbert Xu , Sasha Levin Subject: [PATCH 5.5 362/367] crypto: atmel-{aes,tdes} - Do not save IV for ECB mode Date: Mon, 10 Feb 2020 04:34:35 -0800 Message-Id: <20200210122455.765754809@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200210122423.695146547@linuxfoundation.org> References: <20200210122423.695146547@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Tudor Ambarus [ Upstream commit c65d123742a7bf2a5bc9fa8398e1fd2376eb4c43 ] ECB mode does not use IV. Signed-off-by: Tudor Ambarus Signed-off-by: Herbert Xu Signed-off-by: Sasha Levin --- drivers/crypto/atmel-aes.c | 9 +++++++-- drivers/crypto/atmel-tdes.c | 7 +++++-- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/drivers/crypto/atmel-aes.c b/drivers/crypto/atmel-aes.c index 24f1fba6513ef..7b7079db2e860 100644 --- a/drivers/crypto/atmel-aes.c +++ b/drivers/crypto/atmel-aes.c @@ -515,6 +515,9 @@ static void atmel_aes_set_iv_as_last_ciphertext_block(struct atmel_aes_dev *dd) static inline int atmel_aes_complete(struct atmel_aes_dev *dd, int err) { + struct skcipher_request *req = skcipher_request_cast(dd->areq); + struct atmel_aes_reqctx *rctx = skcipher_request_ctx(req); + #if IS_ENABLED(CONFIG_CRYPTO_DEV_ATMEL_AUTHENC) if (dd->ctx->is_aead) atmel_aes_authenc_complete(dd, err); @@ -523,7 +526,8 @@ static inline int atmel_aes_complete(struct atmel_aes_dev *dd, int err) clk_disable(dd->iclk); dd->flags &= ~AES_FLAGS_BUSY; - if (!dd->ctx->is_aead) + if (!dd->ctx->is_aead && + (rctx->mode & AES_FLAGS_OPMODE_MASK) != AES_FLAGS_ECB) atmel_aes_set_iv_as_last_ciphertext_block(dd); if (dd->is_async) @@ -1121,7 +1125,8 @@ static int atmel_aes_crypt(struct skcipher_request *req, unsigned long mode) rctx = skcipher_request_ctx(req); rctx->mode = mode; - if (!(mode & AES_FLAGS_ENCRYPT) && (req->src == req->dst)) { + if ((mode & AES_FLAGS_OPMODE_MASK) != AES_FLAGS_ECB && + !(mode & AES_FLAGS_ENCRYPT) && req->src == req->dst) { unsigned int ivsize = crypto_skcipher_ivsize(skcipher); if (req->cryptlen >= ivsize) diff --git a/drivers/crypto/atmel-tdes.c b/drivers/crypto/atmel-tdes.c index 0c1f79b30fc1b..eaa14a80d40ce 100644 --- a/drivers/crypto/atmel-tdes.c +++ b/drivers/crypto/atmel-tdes.c @@ -600,12 +600,14 @@ atmel_tdes_set_iv_as_last_ciphertext_block(struct atmel_tdes_dev *dd) static void atmel_tdes_finish_req(struct atmel_tdes_dev *dd, int err) { struct skcipher_request *req = dd->req; + struct atmel_tdes_reqctx *rctx = skcipher_request_ctx(req); clk_disable_unprepare(dd->iclk); dd->flags &= ~TDES_FLAGS_BUSY; - atmel_tdes_set_iv_as_last_ciphertext_block(dd); + if ((rctx->mode & TDES_FLAGS_OPMODE_MASK) != TDES_FLAGS_ECB) + atmel_tdes_set_iv_as_last_ciphertext_block(dd); req->base.complete(&req->base, err); } @@ -727,7 +729,8 @@ static int atmel_tdes_crypt(struct skcipher_request *req, unsigned long mode) rctx->mode = mode; - if (!(mode & TDES_FLAGS_ENCRYPT) && req->src == req->dst) { + if ((mode & TDES_FLAGS_OPMODE_MASK) != TDES_FLAGS_ECB && + !(mode & TDES_FLAGS_ENCRYPT) && req->src == req->dst) { unsigned int ivsize = crypto_skcipher_ivsize(skcipher); if (req->cryptlen >= ivsize) -- 2.20.1