Received: by 2002:a17:90a:88:0:0:0:0 with SMTP id a8csp55429pja; Fri, 22 Nov 2019 03:23:02 -0800 (PST) X-Google-Smtp-Source: APXvYqycCgHIWhvimEKIt8ePbOQ2L+edOAY79pRBUPs+kXT2hQ+NUL1WRBWiqRu5B3sMSJLSz5W8 X-Received: by 2002:a50:e619:: with SMTP id y25mr408387edm.204.1574421782177; Fri, 22 Nov 2019 03:23:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574421782; cv=none; d=google.com; s=arc-20160816; b=kR4KMgcfsgd7SuvAe6XwRwwfNIdh1tLFG0j1sLhRcSZIAjRMf2A+gpk0zA8z8+5BTX ofEZIfYtyC4Z6GN6KZhf7mPzZ3mxVVBrvMFfeWxiR628Bb+1lJAs651doS1pORG1HTxg /0gUG+Pxm/IZt+GTtWqkxXd2TW7X++EO6WM9y7HEHhSxjYWin07kANtcN8Hh65GhfuAz F0qIQeY2Nq8vGjhmzlgDi+/sjDVBjvcK81mZ6aPHITO97sX70msQigU+hT13TEWXiaSK s3xo73Fs3eMLGmZjeJCUPVLRkaT74MpGRzgFgaKQzCQl/xJJo6ghb10yBOpD1UQ1ZmPe nJlw== 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=owWaUUIZgDGbfMZwoiYqnIG98nnj8aFezf+OKvHecjM=; b=p+Q/Z7kVmSkEJOI2tCnFhtoYuey6LSCIwjmR4JTIV3DOQOS24PNIQGsGN8f9/A1HdM lNo9TDoRS1ZWIaGkeJL1bPw3x1CcMOQKdPALqbvmRBaT3CZYTTRG+WwNxR9GJ8aMPX3+ VOlk3HCyOYMt5rLfh3YBOzrc+HmJiqbXu/eKxon32gmJJBKP4ImBjzhfS8gfjZD2EZVl 7NYyEbfX1Vh6ky06e2p4bCYF/z0ieCNMerv2KQcftNNAPtEdkaz7Vf6PijvOG5EMWUgb /23n6ELrhwBjcte+MlgC4wmr1o0ocyh8Qhjrw6UKT6ddvJkriyHPZr3OgdHimFz5WhQT Usrg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=INUepQjL; 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 y5si3873072ejw.281.2019.11.22.03.22.37; Fri, 22 Nov 2019 03:23:02 -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=INUepQjL; 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 S1729845AbfKVKsI (ORCPT + 99 others); Fri, 22 Nov 2019 05:48:08 -0500 Received: from mail.kernel.org ([198.145.29.99]:56488 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727804AbfKVKsG (ORCPT ); Fri, 22 Nov 2019 05:48:06 -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 1A0D6205C9; Fri, 22 Nov 2019 10:48:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1574419685; bh=zzrMT65p4aIG+QXYsqjFqm0EsZZulY+2S2RkW/+FWLs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=INUepQjLstZz5iTeWiz2kNFcjcKKZOzuhYN+U0Kr7RTM3g6WgmoPPEMd5ucMnDx6w /BT4IOz4xbl2qTlcCagkMUCeegU+xOO59vXx8MAVWDrcvMswNPtyGR+8GGnWx6eTV/ oEAqRLy3aM7Muw1i0RuSmoHyLfN/tY8Iew79jnd8= 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.9 196/222] crypto: mxs-dcp - Fix AES issues Date: Fri, 22 Nov 2019 11:28:56 +0100 Message-Id: <20191122100916.384289765@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191122100830.874290814@linuxfoundation.org> References: <20191122100830.874290814@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 7483adf120084..b4bd34429cc14 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