From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753950AbbCCG5d (ORCPT ); Tue, 3 Mar 2015 01:57:33 -0500 Received: from mail.windriver.com ([147.11.1.11]:57443 "EHLO mail.windriver.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752441AbbCCG5b (ORCPT ); Tue, 3 Mar 2015 01:57:31 -0500 Message-ID: <54F55B52.60006@windriver.com> Date: Tue, 3 Mar 2015 14:57:22 +0800 From: yjin User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:24.0) Gecko/20100101 Thunderbird/24.6.0 MIME-Version: 1.0 To: =?UTF-8?B?SG9yaWEgR2VhbnTEgw==?= , , CC: , , , , , , Subject: Re: [PATCH 3/4] crypto: caamhash: add two missed dma_mapping_error References: <1425103234-31129-1-git-send-email-yanjiang.jin@windriver.com> <1425103234-31129-3-git-send-email-yanjiang.jin@windriver.com> <54F44F4C.8050604@freescale.com> In-Reply-To: <54F44F4C.8050604@freescale.com> Content-Type: text/plain; charset="UTF-8"; format=flowed Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2015年03月02日 19:53, Horia Geantă wrote: > On 2/28/2015 8:00 AM, yanjiang.jin@windriver.com wrote: >> From: Yanjiang Jin >> >> Add two missed dma_mapping_error() after dma_map_single(). >> >> Signed-off-by: Yanjiang Jin >> --- >> drivers/crypto/caam/caamhash.c | 8 ++++++++ >> 1 file changed, 8 insertions(+) >> >> diff --git a/drivers/crypto/caam/caamhash.c b/drivers/crypto/caam/caamhash.c >> index f347ab7..f6ad322 100644 >> --- a/drivers/crypto/caam/caamhash.c >> +++ b/drivers/crypto/caam/caamhash.c >> @@ -160,6 +160,10 @@ static inline dma_addr_t map_seq_out_ptr_result(u32 *desc, struct device *jrdev, >> dma_addr_t dst_dma; >> >> dst_dma = dma_map_single(jrdev, result, digestsize, DMA_FROM_DEVICE); >> + if (dma_mapping_error(jrdev, dst_dma)) { >> + dev_err(jrdev, "unable to map dst dma\n"); >> + return -ENOMEM; >> + } >> append_seq_out_ptr(desc, dst_dma, digestsize, 0); >> >> return dst_dma; > Value returned by map_seq_out_ptr_result() - dst_dma - is always fed to > dma_mapping_error(). > Note that using an invalid dst_dma in append_seq_out_ptr() doesn't break > anything, so it's ok to check dst_dma later. > >> @@ -173,6 +177,10 @@ static inline dma_addr_t buf_map_to_sec4_sg(struct device *jrdev, >> dma_addr_t buf_dma; >> >> buf_dma = dma_map_single(jrdev, buf, buflen, DMA_TO_DEVICE); >> + if (dma_mapping_error(jrdev, buf_dma)) { >> + dev_err(jrdev, "unable to map buf dma\n"); >> + return 0; >> + } >> dma_to_sec4_sg_one(sec4_sg, buf_dma, buflen, 0); >> >> return buf_dma; >> > These functions are expected to return dma_addr_t, not an error code. > If dma_mapping_error() is needed within their scope, the return type > will have to change. And return value will need to be checked by their > callers. > System run well without the above changes, so abandoned this patch in V2. Will do more test in the future. Thanks! Yanjiang > >