Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp2451509pxb; Sat, 25 Sep 2021 07:41:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJztpPPBc7q0b52MZs+Ojkgpv/BBQeVZ7HC8t63Sm7y/l/DqYBvXmU9qdTI5yOcuPJ6UZ+xY X-Received: by 2002:a05:6402:2061:: with SMTP id bd1mr11705172edb.186.1632580871102; Sat, 25 Sep 2021 07:41:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632580871; cv=none; d=google.com; s=arc-20160816; b=fmFsHijuSblZ/KTSQ3ajviisy4oG5FIs71Gp4HbJsvyNDDJgiHnFUXjEwpcAmR9kCa +ebq9Q7H8KdM9m9SfeQCmINcIkMdKBX7dWd39PF9+NIEKEDYeHoqslYl79hO6fuB3UC9 2SUcx+Xv60LAhHUs0Fpp53t9kCHvp1usnJ6CcuWssYj/3NTw3CsxjktWkGcMOar/2Sws J7zDTrDrVTIpz+p7To3c3r+SzwSVEuKcSw4SEbgXBwj4OWiJmk5ERFR2D7phiTb7UTmm 60pMEHRPrlqrLS/gN6QUQ1ZVXoM3lRAp7DfVVVKQFB5mCtNe89X5Jq3kLeQetuMtSIYV 4iFQ== 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=W1zbeSCxjgP1/jT5S3s117AtmvfhaZUZJn5dXQVOMPs=; b=0EwaDsvleOUa2vDcNwfvfij8cI7LFULEKJQgRHzr7Y5+2+ieZpmH0wSzCll86eIcZt eIfvPBDNmGD4Sw2oLArWCHlTjJ2tZBXW1e2UhMokEfkRgpilylP3Pamn+0Ds8sRT0Q+O L17wFZQ26AVEVHz0IMbO0IUxlz/2MPMYpqipKEu+guz+KjKg8tKNpCZEf5VfWJ5R3Dbj gIyg54oaxi8wNAEqzHqayrpZ2cnb93ZZVo0ZxoRGCgaTk3wMMnRL2we4rfDzV67LEmVV PX0szzWoaMAXS5xXyc5fA/qT/aovwaLLtJp2wK3qlIakvHrqOZn7Xyr0AyPyVyRO1kio EA1Q== 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 x13si14458734edl.539.2021.09.25.07.40.46; Sat, 25 Sep 2021 07:41:11 -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 S1343746AbhIYOk7 (ORCPT + 99 others); Sat, 25 Sep 2021 10:40:59 -0400 Received: from mail.kernel.org ([198.145.29.99]:34942 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234538AbhIYOk6 (ORCPT ); Sat, 25 Sep 2021 10:40:58 -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 0C93F61041; Sat, 25 Sep 2021 14:39:21 +0000 (UTC) Date: Sat, 25 Sep 2021 15:43:10 +0100 From: Jonathan Cameron To: Andriy Tryshnivskyy Cc: jbhayana@google.com, lars@metafoo.de, linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org, Vasyl.Vavrychuk@opensynergy.com Subject: Re: [PATCH 1/1] iio/scmi: Add reading "raw" attribute. Message-ID: <20210925154310.2f31c032@jic23-huawei> In-Reply-To: <20210922065235.12891-2-andriy.tryshnivskyy@opensynergy.com> References: <20210922065235.12891-1-andriy.tryshnivskyy@opensynergy.com> <20210922065235.12891-2-andriy.tryshnivskyy@opensynergy.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, 22 Sep 2021 09:52:35 +0300 Andriy Tryshnivskyy wrote: > Add IIO_CHAN_INFO_RAW to the mask and implement corresponding > reading "raw" attribute in scmi_iio_read_raw. > > Signed-off-by: Andriy Tryshnivskyy Hi Andriy, A few comments inline. I don't haven't looked closely at whether the scmi side of things is correct though so will rely on Jyoti for that. Thanks, Jonathan > --- > drivers/iio/common/scmi_sensors/scmi_iio.c | 38 +++++++++++++++++++++- > 1 file changed, 37 insertions(+), 1 deletion(-) > > diff --git a/drivers/iio/common/scmi_sensors/scmi_iio.c b/drivers/iio/common/scmi_sensors/scmi_iio.c > index 7cf2bf282cef..b88780a25796 100644 > --- a/drivers/iio/common/scmi_sensors/scmi_iio.c > +++ b/drivers/iio/common/scmi_sensors/scmi_iio.c > @@ -286,6 +286,9 @@ static int scmi_iio_read_raw(struct iio_dev *iio_dev, > struct scmi_iio_priv *sensor = iio_priv(iio_dev); > s8 scale; > int ret; > + int err; > + u32 sensor_config; > + struct scmi_sensor_reading readings[SCMI_IIO_NUM_OF_AXIS]; > > switch (mask) { > case IIO_CHAN_INFO_SCALE: > @@ -300,6 +303,38 @@ static int scmi_iio_read_raw(struct iio_dev *iio_dev, > case IIO_CHAN_INFO_SAMP_FREQ: > ret = scmi_iio_get_odr_val(iio_dev, val, val2); > return ret ? ret : IIO_VAL_INT_PLUS_MICRO; > + case IIO_CHAN_INFO_RAW: > + sensor_config = FIELD_PREP(SCMI_SENS_CFG_SENSOR_ENABLED_MASK, > + SCMI_SENS_CFG_SENSOR_ENABLE); > + err = sensor->handle->sensor_ops->config_set( > + sensor->handle, sensor->sensor_info->id, sensor_config); > + if (err) > + dev_err(&iio_dev->dev, > + "Error in enabling sensor %s err %d", > + sensor->sensor_info->name, err); Don't try to carry on if you got an error. Unless something very odd has gone on that should mean the sensor isn't not enabled so nothing else will work. If this returns and error just return it here. > + > + err = sensor->handle->sensor_ops->reading_get_timestamped( > + sensor->handle, sensor->sensor_info->id, > + sensor->sensor_info->num_axis, > + (struct scmi_sensor_reading *)&readings); Why do we need the cast? Also, this should probably just be readings unless I'm missing something rather than the address of readings. That will pass the address of the first element which is likely to be what you want. > + if (err) { > + dev_err(&iio_dev->dev, > + "Error in reading raw attribute for sensor %s err %d", > + sensor->sensor_info->name, err); > + return err; > + } > + > + sensor_config = FIELD_PREP(SCMI_SENS_CFG_SENSOR_ENABLED_MASK, > + SCMI_SENS_CFG_SENSOR_DISABLE); > + err = sensor->handle->sensor_ops->config_set( > + sensor->handle, sensor->sensor_info->id, sensor_config); > + if (err) > + dev_err(&iio_dev->dev, > + "Error in enabling sensor %s err %d", > + sensor->sensor_info->name, err); As above, this indicates something has gone wrong and we should tell userspace that in preference to trying to get one last value out. > + /* Use 32-bit value, since practically there is no need in 64 bits */ > + *val = (u32)readings[ch->scan_index].value; We should check it fits and if doesn't return an error rather than pretending all was fine. > + return IIO_VAL_INT; > default: > return -EINVAL; > } > @@ -381,7 +416,8 @@ static void scmi_iio_set_data_channel(struct iio_chan_spec *iio_chan, > iio_chan->type = type; > iio_chan->modified = 1; > iio_chan->channel2 = mod; > - iio_chan->info_mask_separate = BIT(IIO_CHAN_INFO_SCALE); > + iio_chan->info_mask_separate = > + BIT(IIO_CHAN_INFO_SCALE) | BIT(IIO_CHAN_INFO_RAW); > iio_chan->info_mask_shared_by_type = BIT(IIO_CHAN_INFO_SAMP_FREQ); > iio_chan->info_mask_shared_by_type_available = > BIT(IIO_CHAN_INFO_SAMP_FREQ);