Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp3495779pxb; Mon, 30 Aug 2021 03:52:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzfX7h+TSkvQyM8+utW7tXlBFbHdLQBvnk2nRE+UM+lDG71/rsyARS1erhTxwHYblTGhUHs X-Received: by 2002:a05:6602:cf:: with SMTP id z15mr3399699ioe.4.1630320733694; Mon, 30 Aug 2021 03:52:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630320733; cv=none; d=google.com; s=arc-20160816; b=lLsHUnltEmXp6jc9WiwDM8nJmZdSf9dkNtTCkCGOX/ZiJ1/2NBpuXTFGHwcKHOs7rr 69FRIJYbaZK3LYiaorUdao+kP4/x9nPcPKs5GX1nQEUFnn0XkvY44V056TraeF0aePjG chZZESJuonv7c2scAHOpjougLDRAQJ9szhbImtwlG7wgV6Zulf0vkmMSjm0LHOARjrdp vl7FWRVnvLN4HfpQ5NSkrZtHnsslGF/hj7CGtnlLDgVxHq0iook/jt9UZfSbdj17Y9lb gfZpFWTnJzWmv99vwioiSs2MszAYppawJ8Ycox2dgm8WKg7IV7+/YKu2vILJJpSZqOUk o1bg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date; bh=SuLZ2Z1dLVcWYV5AQRU+z4L9Ivr0shxW1qmMRLcoipA=; b=x0PuuQFJuUaqfcu1NnjZ4BQthtNEEhEbRgUiM1mMIRggc885UIe8patL+KBRPl/qAh JVWmSL/18w04JeKWGmwOgz2870FWPhgGyV6Kl6FmCnpSgvG1otgaa+7wtApxzzpQlvDz ZwqCb4YrSAHgJCoNsSSKvhObGw3EexzJHe8gnmhB2a7LLgTJgANoKpvOLhosL0yNZ7TO V68eg4hfMsxFJvSy98nL2AgG0qPIXAJckrMm6rZFgba36798nmEHIhsOaTn2iUHmm0y7 tBlLmZtzXL+151dbWfavJOdA3vJncBOR6J7FC1RXl8/2/S9INP/0puztH4KuOEXI1jaS Q6pQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t1si14195945jao.24.2021.08.30.03.52.02; Mon, 30 Aug 2021 03:52:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236371AbhH3KwJ (ORCPT + 99 others); Mon, 30 Aug 2021 06:52:09 -0400 Received: from mail.kernel.org ([198.145.29.99]:46016 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236324AbhH3KwJ (ORCPT ); Mon, 30 Aug 2021 06:52:09 -0400 Received: from jic23-huawei (cpc108967-cmbg20-2-0-cust86.5-4.cable.virginm.net [81.101.6.87]) (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 E387F610D1; Mon, 30 Aug 2021 10:51:13 +0000 (UTC) Date: Mon, 30 Aug 2021 11:54:25 +0100 From: Jonathan Cameron To: Miquel Raynal Cc: Lars-Peter Clausen , Thomas Petazzoni , linux-iio@vger.kernel.org, Subject: Re: [PATCH 16/16] iio: adc: max1027: Enable software triggers to be used without IRQ Message-ID: <20210830115425.3fdb31b9@jic23-huawei> In-Reply-To: <20210818111139.330636-17-miquel.raynal@bootlin.com> References: <20210818111139.330636-1-miquel.raynal@bootlin.com> <20210818111139.330636-17-miquel.raynal@bootlin.com> X-Mailer: Claws Mail 4.0.0 (GTK+ 3.24.30; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 18 Aug 2021 13:11:39 +0200 Miquel Raynal wrote: > Software triggers do not need a device IRQ to work. As opposed to > hardware triggers which need it to yield the data to the IIO core, > software triggers run a dedicated thread which does all the tasks on > their behalf. Then, the end of conversion status may either come from an > interrupt or from a sufficient enough extra delay. IRQs are not > mandatory so move the triggered buffer setup out of the IRQ condition. I'd stop referring to software triggers in these descriptions. This could just as easily be about enabling a different hardware trigger such as a gpio trigger or indeed on a dataready trigger provided by an entirely different device. Otherwise the logic is correct. Good to get this more flexible support into the driver. If we can make it a tiny bit more flexible by enabling use of the cnvst trigger to drive this 'and' other drivers that would be even better and conform more closely to the normal way an IIO driver work. The validate_device / validate_trigger callbacks are often about making it easier to bring a device driver up in the first place, so it's great to see them go away in later improvements like this. (note I'm not saying there aren't complex cases where we can't remove them though!) Jonathan > > Signed-off-by: Miquel Raynal > --- > drivers/iio/adc/max1027.c | 20 +++++++++++--------- > 1 file changed, 11 insertions(+), 9 deletions(-) > > diff --git a/drivers/iio/adc/max1027.c b/drivers/iio/adc/max1027.c > index bb437e43adaf..e767437a578e 100644 > --- a/drivers/iio/adc/max1027.c > +++ b/drivers/iio/adc/max1027.c > @@ -567,16 +567,18 @@ static int max1027_probe(struct spi_device *spi) > if (!st->buffer) > return -ENOMEM; > > + /* Enable triggered buffers */ > + ret = devm_iio_triggered_buffer_setup(&spi->dev, indio_dev, > + &iio_pollfunc_store_time, > + &max1027_trigger_handler, > + NULL); > + if (ret < 0) { > + dev_err(&indio_dev->dev, "Failed to setup buffer\n"); > + return ret; > + } > + > + /* If there is an EOC interrupt, enable the hardware trigger (cnvst) */ > if (spi->irq) { > - ret = devm_iio_triggered_buffer_setup(&spi->dev, indio_dev, > - &iio_pollfunc_store_time, > - &max1027_trigger_handler, > - NULL); > - if (ret < 0) { > - dev_err(&indio_dev->dev, "Failed to setup buffer\n"); > - return ret; > - } > - > st->trig = devm_iio_trigger_alloc(&spi->dev, "%s-trigger", > indio_dev->name); > if (st->trig == NULL) {