Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp145121ybl; Tue, 7 Jan 2020 03:47:44 -0800 (PST) X-Google-Smtp-Source: APXvYqxPTfyP0XU5xsEr5hGUX5KZDQS/kcckzfsQqATmoFmwgzw7VMql1w62vTwv+T2oeP0FXe+p X-Received: by 2002:a05:6830:4ca:: with SMTP id s10mr82412554otd.268.1578397664375; Tue, 07 Jan 2020 03:47:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578397664; cv=none; d=google.com; s=arc-20160816; b=yiwpYeJDM+9Z7+qv8PSiv8XNUjUXiNdv1CsIvn+CpVOyFzefj4LxCGrZSXTw9KKkzk U2fsbyygN2ky/rw7EN4jpH1qZPtqjTootd1TkZCtfqDOKpsA6pPLH7mTOJDoVlA5sCL3 xWcbdsaLlQx55VxjoexIcI0z0XRWXQnn+JlAJ+9lV7Wkgou41YxQnmj/DO8+YMDXicc4 57IL1uZ+1uNLUKwMLqQre74KkvqI0m6oLBRn5sLwUxb91VkZnOh/qn+f3E/g3bKnPdcR av5UySMqmV5Jk2hQ/jwuDfsQ7jD6h5hTYBMWp2vUnUzDBFGyv9lL53c/91NbKjtKorWH Eueg== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=opRM3BxdJrwcWwYPbvHXI+kHoBYD6A8pkYN5zqXedA8=; b=NevJZEe1fOVrfwdElpA+BhJzVkunOFqeQ6us5B2XR+RlJwUkaUXGQVRCMmD4sWCXlB 7p6fBrZhnpr06aGrUo7/pavaJArAsg07NZhOzjpj3BCqQfJs5S3+TbrVptAZVR9Ibr8C vfFLR1sd6yUfrR5Jx0Uu7BB01u8iorToF9l7gCb7/SXN1bOR+sN4lrleVVlmCouNDy7x ExijtC4vFhGatPV4LoIiIcHDr5Eoou4/+GNQQVG0VLP+fz9jbnJ1ARhnSkqeOfuQgdsE yzlLt7gj56ra2dNMW5dnnBWVULUQ25o/oE1c3r1wsbIqV8cexX1ztp+FyWsy+beKfdFp uG7Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=XWA0M3sm; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id z25si38919215oto.211.2020.01.07.03.47.31; Tue, 07 Jan 2020 03:47:44 -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=@ti.com header.s=ti-com-17Q1 header.b=XWA0M3sm; 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=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727949AbgAGLpO (ORCPT + 99 others); Tue, 7 Jan 2020 06:45:14 -0500 Received: from lelv0143.ext.ti.com ([198.47.23.248]:56138 "EHLO lelv0143.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726690AbgAGLpO (ORCPT ); Tue, 7 Jan 2020 06:45:14 -0500 Received: from lelv0266.itg.ti.com ([10.180.67.225]) by lelv0143.ext.ti.com (8.15.2/8.15.2) with ESMTP id 007Bj55h105265; Tue, 7 Jan 2020 05:45:05 -0600 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1578397505; bh=opRM3BxdJrwcWwYPbvHXI+kHoBYD6A8pkYN5zqXedA8=; h=From:To:CC:Subject:Date; b=XWA0M3smZhELM2OjQvdUE1JdjwBZ4QVCtv7vQATPRzSyQ0VbZ6/n40c9wBjLOEram 8m+HfoR9f2iI/AFlp6X2jG0SLk/vRrs/HzQ2Ef7h+HV1nbRkE4ULZRPtLoZxg4THLE +M4e9JOZ1VOe3oRk1C6nyw0g70uFQpKo+RhDAMAs= Received: from DLEE107.ent.ti.com (dlee107.ent.ti.com [157.170.170.37]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 007Bj51m037384 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Tue, 7 Jan 2020 05:45:05 -0600 Received: from DLEE108.ent.ti.com (157.170.170.38) by DLEE107.ent.ti.com (157.170.170.37) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1847.3; Tue, 7 Jan 2020 05:45:04 -0600 Received: from lelv0327.itg.ti.com (10.180.67.183) by DLEE108.ent.ti.com (157.170.170.38) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1847.3 via Frontend Transport; Tue, 7 Jan 2020 05:45:04 -0600 Received: from feketebors.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by lelv0327.itg.ti.com (8.15.2/8.15.2) with ESMTP id 007Bj1Zv073150; Tue, 7 Jan 2020 05:45:02 -0600 From: Peter Ujfalusi To: , , , CC: , , , , Subject: [PATCH v2] iio: adc: stm32-dfsdm: Use dma_request_chan() instead dma_request_slave_channel() Date: Tue, 7 Jan 2020 13:45:32 +0200 Message-ID: <20200107114532.6697-1-peter.ujfalusi@ti.com> X-Mailer: git-send-email 2.24.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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 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; + } 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; } -- Peter Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki