Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1958414ybl; Thu, 9 Jan 2020 04:38:02 -0800 (PST) X-Google-Smtp-Source: APXvYqzg2DrxQMEDJRpMOy4ZZ3raz44U1clCoXPa15AJudBvGM6Jh9AKjr+1u5TOh6/Kxu5d9sQ3 X-Received: by 2002:a05:6830:1481:: with SMTP id s1mr8358422otq.66.1578573482552; Thu, 09 Jan 2020 04:38:02 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578573482; cv=none; d=google.com; s=arc-20160816; b=vygVx6gbYgWrNegsXQyaRH2D3zKwWZaNQew+QCRiN5KWbhfAbhVUjNvx2vmG/NTMIm yhThbidlN51ukpG1LxbqYtC/q0RRbjKbyROtzoA8LcNn3XXsaW4QqdHanqg53y7ZghKW /Zg2PeJVc32XMFjXJ/T1rAzKJ4vOjKKzLXqzF2Dud2aVbd3jxsFR1O1R+2htY8ZX3fcq 9GczB4bF5GFp3KozqmZ7vUxWceDVu+wdwc0j39nBE68jVy614MiA/8E9UUQnMec5vSs/ F6oHsmbIDz34aDwXKuAd/tqBZogn5Zak5iOG4VB4EZ5SegZ7eMi967VJz2OHCapVZ+NH KgTA== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=AxZf/fSBlfXNNSHtuKJsnMXKc0gcBZunFQ/GUTcU0Ew=; b=Zz9f0vVg0gB2ArGsjimxQFVd/g2LNE4n7ZZyYGCEBVKFcwrMqt8wyhlanPnHd6N7PI uU+XoqbhSHEw2NfNSk+mY8Xn/PQP3LGjwV3gcJcw3eed5cUI+p4ExQgX3pFImnxewrDN xYsV7Z4PRcXEvxWr3wscFsKiAPCFdd4MYuLqw/ZS8mNDbTbTLqz4VrBQL89gPkL4J7DJ Esr3ICVQx9M//SCaffdfOQF523SIrkU2cKJ5kPNpK5nV3k4okRqpnNofGuzQJ+0nsmAy YmvoDYUJcnTf6jbklOotT4AWc57jFlfK8MYuufUqZidE1HX3NFmkx/Rt4YoalrwzsrbP k7Dw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@st.com header.s=STMicroelectronics header.b=ep1riYVk; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=st.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i15si4010669otk.120.2020.01.09.04.37.50; Thu, 09 Jan 2020 04:38: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=@st.com header.s=STMicroelectronics header.b=ep1riYVk; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=st.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729894AbgAIL3S (ORCPT + 99 others); Thu, 9 Jan 2020 06:29:18 -0500 Received: from mx07-00178001.pphosted.com ([62.209.51.94]:43340 "EHLO mx07-00178001.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728588AbgAIL3S (ORCPT ); Thu, 9 Jan 2020 06:29:18 -0500 Received: from pps.filterd (m0046668.ppops.net [127.0.0.1]) by mx07-00178001.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 009BRq95008261; Thu, 9 Jan 2020 12:29:04 +0100 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=st.com; h=subject : to : cc : references : from : message-id : date : mime-version : in-reply-to : content-type : content-transfer-encoding; s=STMicroelectronics; bh=AxZf/fSBlfXNNSHtuKJsnMXKc0gcBZunFQ/GUTcU0Ew=; b=ep1riYVkRMeQ3qB2A0qZ8bop9cK6cH8vvv7E1zMY9T6YA3Hn3JfBAxrJSpJLH3tGHwPL fQFRaln2+8YEOlYL+jXAdPhJcm/Swamw5RlBEwjkNupNnRR0CC//xVqz8xUdOxKxnC+9 /09w8DgaLVyqnle3tOVjPJn5FdFgyYwChDCE4YIP2YII9K1pEI5ZC1a8pOnK9RixVRYp PtF2MRdD2/MVzuTC0OEctrc0HLYkkIA05mg4IH7wNzpqUXeVQjrVMEuVfCmwbc3u46gf 0JX7j0jOlNvNofm7Vur4V+MWzFqkGDARt73RIbbetII6NQZ/W5SGgPOv8u3ADPsJvFJz Ow== Received: from beta.dmz-eu.st.com (beta.dmz-eu.st.com [164.129.1.35]) by mx07-00178001.pphosted.com with ESMTP id 2xakm5sb53-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 09 Jan 2020 12:29:04 +0100 Received: from euls16034.sgp.st.com (euls16034.sgp.st.com [10.75.44.20]) by beta.dmz-eu.st.com (STMicroelectronics) with ESMTP id F1AFD10002A; Thu, 9 Jan 2020 12:29:02 +0100 (CET) Received: from Webmail-eu.st.com (sfhdag5node3.st.com [10.75.127.15]) by euls16034.sgp.st.com (STMicroelectronics) with ESMTP id DEE692A4D79; Thu, 9 Jan 2020 12:29:02 +0100 (CET) Received: from [10.48.0.71] (10.75.127.44) by SFHDAG5NODE3.st.com (10.75.127.15) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Thu, 9 Jan 2020 12:29:02 +0100 Subject: Re: [PATCH v2] iio: adc: stm32-dfsdm: Use dma_request_chan() instead dma_request_slave_channel() To: Peter Ujfalusi , , , CC: , , , , , Olivier MOYSAN References: <20200107114532.6697-1-peter.ujfalusi@ti.com> <4c0b7e3e-cd98-860a-e931-c216f1bc6e7a@ti.com> From: Fabrice Gasnier Message-ID: <698d9dec-4486-f70a-b8e0-dfd6b4bb907f@st.com> Date: Thu, 9 Jan 2020 12:29:01 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.9.0 MIME-Version: 1.0 In-Reply-To: <4c0b7e3e-cd98-860a-e931-c216f1bc6e7a@ti.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 8bit X-Originating-IP: [10.75.127.44] X-ClientProxiedBy: SFHDAG2NODE2.st.com (10.75.127.5) To SFHDAG5NODE3.st.com (10.75.127.15) X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.138,18.0.572 definitions=2020-01-09_02:2020-01-09,2020-01-09 signatures=0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 1/9/20 11:32 AM, Peter Ujfalusi wrote: > > > On 09/01/2020 11.13, Fabrice Gasnier wrote: >> On 1/7/20 12:45 PM, Peter Ujfalusi wrote: >>> dma_request_slave_channel() is a wrapper on top of dma_request_chan() >>> eating up the error code. >>> >>> By using dma_request_chan() directly the driver can support deferred >>> probing against DMA. >>> >>> Signed-off-by: Peter Ujfalusi >>> --- >>> Hi, >>> >>> Changes since v1: >>> - Fall back to IRQ mode for ADC only in case of ENODEV >> >> Hi Peter, >> >> Thanks for the patch, >> >> Please find a minor comment here after. Apart from that, you can add my: >> >> Acked-by: Fabrice Gasnier >> >> >>> >>> Regards, >>> Peter >>> >>> drivers/iio/adc/stm32-dfsdm-adc.c | 21 +++++++++++++++++---- >>> 1 file changed, 17 insertions(+), 4 deletions(-) >>> >>> diff --git a/drivers/iio/adc/stm32-dfsdm-adc.c b/drivers/iio/adc/stm32-dfsdm-adc.c >>> index e493242c266e..74a2211bdff4 100644 >>> --- a/drivers/iio/adc/stm32-dfsdm-adc.c >>> +++ b/drivers/iio/adc/stm32-dfsdm-adc.c >>> @@ -1383,9 +1383,13 @@ static int stm32_dfsdm_dma_request(struct iio_dev *indio_dev) >>> { >>> struct stm32_dfsdm_adc *adc = iio_priv(indio_dev); >>> >>> - adc->dma_chan = dma_request_slave_channel(&indio_dev->dev, "rx"); >>> - if (!adc->dma_chan) >>> - return -EINVAL; >>> + adc->dma_chan = dma_request_chan(&indio_dev->dev, "rx"); >>> + if (IS_ERR(adc->dma_chan)) { >>> + int ret = PTR_ERR(adc->dma_chan); >>> + >>> + adc->dma_chan = NULL; >>> + return ret; >> >> You may "return PTR_ERR(adc->dma_chan);" directly here. > > I don't make decision here on behalf of the adc path on to go forward w/ > or w/o DMA support and if we go ahead the stm32_dfsdm_dma_release() > needs the dma_chan to be NULL in case we don't use DMA. > > It is much cleaner to set dma_chan to NULL here than doing it in other > paths. Hi Peter, Sorry I wasn't clear enough. I agree with you. I was suggesting only, talking about the 'ret' variable. It may be removed to spare a few lines :-). if (IS_ERR(adc->dma_chan)) { adc->dma_chan = NULL; return PTR_ERR(adc->dma_chan); } I'm okay both ways. > >> >> Best Regards, >> Fabrice >> >>> + } >>> >>> adc->rx_buf = dma_alloc_coherent(adc->dma_chan->device->dev, >>> DFSDM_DMA_BUFFER_SIZE, >>> @@ -1509,7 +1513,16 @@ static int stm32_dfsdm_adc_init(struct iio_dev *indio_dev) >>> init_completion(&adc->completion); >>> >>> /* Optionally request DMA */ >>> - if (stm32_dfsdm_dma_request(indio_dev)) { >>> + ret = stm32_dfsdm_dma_request(indio_dev); >>> + if (ret) { >>> + if (ret != -ENODEV) { >>> + if (ret != -EPROBE_DEFER) >>> + dev_err(&indio_dev->dev, >>> + "DMA channel request failed with %d\n", >>> + ret); >>> + return ret; >>> + } >>> + >>> dev_dbg(&indio_dev->dev, "No DMA support\n"); >>> return 0; >>> } >>> > > - Péter > > Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. > Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki >