Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp6171608rwd; Mon, 5 Jun 2023 14:16:41 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7zsVx6qg49kkzaKwF/auQavDwuN7vY1UkoyJ8yd0A6XFy5ep5F5Jt3D0fNy72Tc9XAikUv X-Received: by 2002:a17:902:e845:b0:1ad:e3a8:3c4 with SMTP id t5-20020a170902e84500b001ade3a803c4mr175277plg.4.1685999800959; Mon, 05 Jun 2023 14:16:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1685999800; cv=none; d=google.com; s=arc-20160816; b=h2ZBtLo2J5b920fEASob9RhQ+xlkXBiPwNQgvW1qdtVc8UL5dEt4y/5sZz1vj2Kyx3 BFNM6wqI/EMpHm+rmA8fg0yg2B62MJXS7KOIHOWmKiT/iZH2I8S/Gcgih11RHYcbSGq9 kj+Q6NZ+cqsfWEtXGx9LZ9NmRoAhyaW06U5+qj7gD19edG7I3dxpj/9qvqdjOFcEunp5 4aSlk8QwC+AcGzsLA/2To7fC/siTrt1nm1J8eewxbEnxgv+HlCdnixlAIDQVOl4XOdOR LC7Sy/6p11egjkQ/zdlBVMEi6/SX0tC32vhNH2yRQTVyz4iclz0BczsGKWL9Fm38u5Y5 4TqA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:organization :mime-version:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=dg/rnQ0TXbIhMngfcQgtl8t+7guiQOwuNQ9dqfdUDJQ=; b=Snf9vHlom0WXp48dlTjLnSM2trOTa5R5cJhGt4P93GAAjVJAauFuPSskZ/KoGWB2tD k+WUdiV9t6mOvn3/b/Q2rrjp40OF+xXC76XIFxp8L0yRlOtEvoN/m4+HpyCgnYLlBNCW pA2y3L7kyeLhE6PnUUYo15tbN87x4GV06mkmUxuCog0sIN8LZB/8jbGmIm9WgY+XrSJL 9Cam81Dd049EjuTRRxWi2Prv8tQyin2ylaLwvsYQ4A8Bqn+mCofm8L78XxjMdjbObDi7 7PNDoZxSdT2kCNmXjT8Bi0MPd0vdI2gFuRMuXDwkq9EvbRSojk4vaEk88SsPBmMRmBXm FQew== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b="NPDj/xkU"; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id i12-20020a17090332cc00b001b03fc03accsi6118770plr.351.2023.06.05.14.16.04; Mon, 05 Jun 2023 14:16:40 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b="NPDj/xkU"; spf=pass (google.com: domain of linux-crypto-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-crypto-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232105AbjFEVGR (ORCPT + 99 others); Mon, 5 Jun 2023 17:06:17 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37612 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229740AbjFEVGQ (ORCPT ); Mon, 5 Jun 2023 17:06:16 -0400 Received: from mga07.intel.com (mga07.intel.com [134.134.136.100]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id AC1A8F2 for ; Mon, 5 Jun 2023 14:06:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1685999175; x=1717535175; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version:content-transfer-encoding; bh=IFmmJDSy3/38+20H3hgKK+gwXE4R2MaCQitjtlOY65I=; b=NPDj/xkUBkp5mL/+Qp2YcAtMeyB+Lm88ALmuH7Vq8J72mJzurch8vQyx WaUm1OhZ/Omf1dXfaRHBzlgORJArrlgGaBmWRuZxDY7IAtFmKB2YZ3A/u oqr8YP7RUNZq0o6wRC2H92YwVl42THu4PlH/r+1alPjy+e7xq3fg9pWPG d0/j9q1yTC+ugaQ6D1Ti4jKyTzP1y5YaEOrdHYXGpq8FKWIHwCTwm1k6D XqIpTh2S1xY9eaIyuZ+iUuXfZREfqh/or+fRnHThOa2GO+eCaVyaPfDJs FhX7rTo+fbt6PDDwa94iqrD1X27sO8ZEW/dKsBqSbuow7Rlrk6nrggQW2 g==; X-IronPort-AV: E=McAfee;i="6600,9927,10732"; a="422309619" X-IronPort-AV: E=Sophos;i="6.00,218,1681196400"; d="scan'208";a="422309619" Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by orsmga105.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 05 Jun 2023 14:06:15 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10732"; a="778710826" X-IronPort-AV: E=Sophos;i="6.00,218,1681196400"; d="scan'208";a="778710826" Received: from silpixa00400314.ir.intel.com (HELO silpixa00400314.ger.corp.intel.com) ([10.237.222.175]) by fmsmga004.fm.intel.com with ESMTP; 05 Jun 2023 14:06:13 -0700 From: Giovanni Cabiddu To: herbert@gondor.apana.org.au Cc: linux-crypto@vger.kernel.org, qat-linux@intel.com, Hareshx Sankar Raj , Bolemx Sivanagaleela , Giovanni Cabiddu , Andy Shevchenko Subject: [RESEND 1/2] crypto: qat - unmap buffer before free for DH Date: Mon, 5 Jun 2023 22:06:06 +0100 Message-Id: <20230605210607.7185-2-giovanni.cabiddu@intel.com> X-Mailer: git-send-email 2.40.1 In-Reply-To: <20230605210607.7185-1-giovanni.cabiddu@intel.com> References: <20230605210607.7185-1-giovanni.cabiddu@intel.com> MIME-Version: 1.0 Organization: Intel Research and Development Ireland Ltd - Co. Reg. #308263 - Collinstown Industrial Park, Leixlip, County Kildare - Ireland Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-crypto@vger.kernel.org From: Hareshx Sankar Raj The callback function for DH frees the memory allocated for the destination buffer before unmapping it. This sequence is wrong. Change the cleanup sequence to unmap the buffer before freeing it. Fixes: 029aa4624a7f ("crypto: qat - remove dma_free_coherent() for DH") Signed-off-by: Hareshx Sankar Raj Co-developed-by: Bolemx Sivanagaleela Signed-off-by: Bolemx Sivanagaleela Reviewed-by: Giovanni Cabiddu Reviewed-by: Andy Shevchenko Signed-off-by: Giovanni Cabiddu --- drivers/crypto/intel/qat/qat_common/qat_asym_algs.c | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/drivers/crypto/intel/qat/qat_common/qat_asym_algs.c b/drivers/crypto/intel/qat/qat_common/qat_asym_algs.c index 935a7e012946..8806242469a0 100644 --- a/drivers/crypto/intel/qat/qat_common/qat_asym_algs.c +++ b/drivers/crypto/intel/qat/qat_common/qat_asym_algs.c @@ -170,15 +170,14 @@ static void qat_dh_cb(struct icp_qat_fw_pke_resp *resp) } areq->dst_len = req->ctx.dh->p_size; + dma_unmap_single(dev, req->out.dh.r, req->ctx.dh->p_size, + DMA_FROM_DEVICE); if (req->dst_align) { scatterwalk_map_and_copy(req->dst_align, areq->dst, 0, areq->dst_len, 1); kfree_sensitive(req->dst_align); } - dma_unmap_single(dev, req->out.dh.r, req->ctx.dh->p_size, - DMA_FROM_DEVICE); - dma_unmap_single(dev, req->phy_in, sizeof(struct qat_dh_input_params), DMA_TO_DEVICE); dma_unmap_single(dev, req->phy_out, -- 2.40.1