Received: by 2002:a17:90a:88:0:0:0:0 with SMTP id a8csp31591pja; Fri, 22 Nov 2019 03:04:30 -0800 (PST) X-Google-Smtp-Source: APXvYqyF+Vruc8ZTHon0sh0TpIlnIb0lANdpygI6wxHUVtztvsU6O1llwAcAx2j7VgTIW5e5EbiD X-Received: by 2002:a50:9b10:: with SMTP id o16mr306264edi.117.1574420669840; Fri, 22 Nov 2019 03:04:29 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574420669; cv=none; d=google.com; s=arc-20160816; b=Ir6rOXHBxgsO4kmMSSNeT8WEpj8r3mznG4LNRioLagamHCyg0U22ZipLlDzeuMTN0O gyl1joMCj83ReKZAOjhHchoRroTLgHf/qTqJNyE/Gij4HGWv60RC18oKhUcLMS1/PgIp TpP0LMssIPNUcQT50j/NwDv9UZRiUqAr4nFaqDrZSAj3evkrNNkshmZYsReZc1LJOzyR eWxulKOUlgxyU+wMxgMY6+UC2ZMv6KHyr2vu+EkNtYuPuWAWNuTuP84vFGqpnlE2VKqF KjFSNp8KTFY2FPCcZhvGZQsGyoZArbHod0s3NhZHTihVZlEblVv27LcQ0KkAaENZ288W w5Xg== 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=bMqRwotVKcJ2xq7adxKcpvIj8OS2NfIkowBsLmd16bQ=; b=Onekp5nLfQ6YYts4hb+3k0Cflr2urf5izx2tI5Y1UF+d1NyVK3lqPiXQ+vcSWP22k4 v2HEHcSZ2O/uTbUPebOPdYYpkTh9InAXICdfLKDiSDmtPoozlcBQUBIgL4uqesGkWdjb cZovJiJ6+wAjMrhXPnxELpCXF2XGwOEGw9ZPp7M44S8evFIG1N4cARDS2ujPNpa4krev s81NSQcDoYnXqzPkBrNdZyDZSmtvpdes/g02t8UHgJsXRP6nJFMiAMsnEfkpHP102/dF ow5Dd8S2hfcIkOgxF4wfDYOYN3ZiUPEL0fJYp3aeA9/Jh0Dhu/Zt+eP96zv+yKJa6tUo CyfA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=kSGYFz4E; 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 l15si1163166ejd.187.2019.11.22.03.04.05; Fri, 22 Nov 2019 03:04:29 -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=kSGYFz4E; 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 S1731309AbfKVLCc (ORCPT + 99 others); Fri, 22 Nov 2019 06:02:32 -0500 Received: from mail.kernel.org ([198.145.29.99]:55944 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730373AbfKVLCY (ORCPT ); Fri, 22 Nov 2019 06:02:24 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (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 EBED1207DD; Fri, 22 Nov 2019 11:02:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1574420543; bh=JlvttV+ytTpJjDcou2x+3Ji1QNx3Gd14PbB1YenipxA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=kSGYFz4EtjeBRcMhAMNqP9mWkDJvUTiu52yNDL3kv76VQKrajVjuuiM2OfEV15wBQ e3X3X0WDAsWFQslj4QUDwOpY7CMQ9VyyVRXaj4Squ1gnPjEpgCGA8YNO5RWIH7OJ2D C+wdADfq8Q6I9EStRz0/l8QkwrM8CMkQJ2zDub4Y= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Radu Solea , Franck LENORMAND , Leonard Crestez , Herbert Xu , Sasha Levin Subject: [PATCH 4.19 142/220] crypto: mxs-dcp - Fix AES issues Date: Fri, 22 Nov 2019 11:28:27 +0100 Message-Id: <20191122100922.993710960@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191122100912.732983531@linuxfoundation.org> References: <20191122100912.732983531@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: Radu Solea [ Upstream commit fadd7a6e616b89c7f4f7bfa7b824f290bab32c3c ] The DCP driver does not obey cryptlen, when doing android CTS this results in passing to hardware input stream lengths which are not multiple of block size. Add a check to prevent future erroneous stream lengths from reaching the hardware and adjust the scatterlist walking code to obey cryptlen. Also properly copy-out the IV for chaining. Signed-off-by: Radu Solea Signed-off-by: Franck LENORMAND Signed-off-by: Leonard Crestez Signed-off-by: Herbert Xu Signed-off-by: Sasha Levin --- drivers/crypto/mxs-dcp.c | 33 +++++++++++++++++++++++++++++++-- 1 file changed, 31 insertions(+), 2 deletions(-) diff --git a/drivers/crypto/mxs-dcp.c b/drivers/crypto/mxs-dcp.c index 3425ccc012168..b926098f70ffd 100644 --- a/drivers/crypto/mxs-dcp.c +++ b/drivers/crypto/mxs-dcp.c @@ -225,6 +225,12 @@ static int mxs_dcp_run_aes(struct dcp_async_ctx *actx, dma_addr_t dst_phys = dma_map_single(sdcp->dev, sdcp->coh->aes_out_buf, DCP_BUF_SZ, DMA_FROM_DEVICE); + if (actx->fill % AES_BLOCK_SIZE) { + dev_err(sdcp->dev, "Invalid block size!\n"); + ret = -EINVAL; + goto aes_done_run; + } + /* Fill in the DMA descriptor. */ desc->control0 = MXS_DCP_CONTROL0_DECR_SEMAPHORE | MXS_DCP_CONTROL0_INTERRUPT | @@ -254,6 +260,7 @@ static int mxs_dcp_run_aes(struct dcp_async_ctx *actx, ret = mxs_dcp_start_dma(actx); +aes_done_run: dma_unmap_single(sdcp->dev, key_phys, 2 * AES_KEYSIZE_128, DMA_TO_DEVICE); dma_unmap_single(sdcp->dev, src_phys, DCP_BUF_SZ, DMA_TO_DEVICE); @@ -280,13 +287,15 @@ static int mxs_dcp_aes_block_crypt(struct crypto_async_request *arq) uint8_t *out_tmp, *src_buf, *dst_buf = NULL; uint32_t dst_off = 0; + uint32_t last_out_len = 0; uint8_t *key = sdcp->coh->aes_key; int ret = 0; int split = 0; - unsigned int i, len, clen, rem = 0; + unsigned int i, len, clen, rem = 0, tlen = 0; int init = 0; + bool limit_hit = false; actx->fill = 0; @@ -305,6 +314,11 @@ static int mxs_dcp_aes_block_crypt(struct crypto_async_request *arq) for_each_sg(req->src, src, nents, i) { src_buf = sg_virt(src); len = sg_dma_len(src); + tlen += len; + limit_hit = tlen > req->nbytes; + + if (limit_hit) + len = req->nbytes - (tlen - len); do { if (actx->fill + len > out_off) @@ -321,13 +335,15 @@ static int mxs_dcp_aes_block_crypt(struct crypto_async_request *arq) * If we filled the buffer or this is the last SG, * submit the buffer. */ - if (actx->fill == out_off || sg_is_last(src)) { + if (actx->fill == out_off || sg_is_last(src) || + limit_hit) { ret = mxs_dcp_run_aes(actx, req, init); if (ret) return ret; init = 0; out_tmp = out_buf; + last_out_len = actx->fill; while (dst && actx->fill) { if (!split) { dst_buf = sg_virt(dst); @@ -350,6 +366,19 @@ static int mxs_dcp_aes_block_crypt(struct crypto_async_request *arq) } } } while (len); + + if (limit_hit) + break; + } + + /* Copy the IV for CBC for chaining */ + if (!rctx->ecb) { + if (rctx->enc) + memcpy(req->info, out_buf+(last_out_len-AES_BLOCK_SIZE), + AES_BLOCK_SIZE); + else + memcpy(req->info, in_buf+(last_out_len-AES_BLOCK_SIZE), + AES_BLOCK_SIZE); } return ret; -- 2.20.1