Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp3230877ybi; Sun, 14 Jul 2019 09:21:39 -0700 (PDT) X-Google-Smtp-Source: APXvYqzfwNxfc/vX/rq3CSMBJTSFkA9ZrImM0BWoj6xfSOyWOz2NjcwlZ6InXaeSl8sUBLUKS/QH X-Received: by 2002:a63:f401:: with SMTP id g1mr22988613pgi.314.1563121299442; Sun, 14 Jul 2019 09:21:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563121299; cv=none; d=google.com; s=arc-20160816; b=QJ7w5D4cykoIPsBK7x2tR0Q7M3I2vLmmLQgvg9OFedEIpd1PcaiPHAuBs/KFUn7j0G dAoWVSp4HuaCWjWd4FrPdg+i6OE443pgVfzTQwQWabzS++hxzeHrJBSbZqTIzsBOyF2A B+hwwLXukVl2SZ5M9Qc5Dc15b4AAhazh6Er4e7jytqqDaMgf78CmNbPdCP0l30/dZRVJ VbwOFng8Yy+Zl74ldbjHS2cZ1ae2rzSOTHF/teBXf6Uk1BHhGq/Vux3uaPaFgMD82vsj 8eGyVyAMoI0FCpXf05mTGwVFoIsVc9NY3xpRU10W2ZNQiQa27EvmSVJIaQWfy+RmNknj jraQ== 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 :references:in-reply-to:message-id:subject:cc:to:from:date :dkim-signature; bh=JQ0zkb3zpM26nIbQQrdZ1sFJU+Npw1tioM68RGobxQg=; b=W1rszDnnA4/DGZxrLBVhvozbpeca++MoSMWH0B8NfavcjFfQanBqj/Pjq5/3S0eoUc 6j8w7Qo0UK453Bd7Q7JvTkIJ+zCmlAs2qif+5nXb+do8YmSKGXFr/KHvj6YBAwSU3i5s BL16eGQ0ErSzCqWHLwTgwdaDX4UNd1vO9OsxSfPYdQhcmniCIAa+y1jdaMac6nGUUeQj vble3xW4Q1o5srHxbG6c1JOohVOj30IuUdJ8POTi9W8mojIGarMSaMtM9QH5vzqpa8qK KIvbBaZ0DsTolAYFUre9BuRwM+UXoXHIX2qPps671+7waSojVoGWk82OxKOQyoSOCll/ Izbw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=a4lyDsOc; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h8si12701637plt.16.2019.07.14.09.21.22; Sun, 14 Jul 2019 09:21:39 -0700 (PDT) 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=@kernel.org header.s=default header.b=a4lyDsOc; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728396AbfGNQTm (ORCPT + 99 others); Sun, 14 Jul 2019 12:19:42 -0400 Received: from mail.kernel.org ([198.145.29.99]:52104 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728106AbfGNQTm (ORCPT ); Sun, 14 Jul 2019 12:19:42 -0400 Received: from archlinux (cpc149474-cmbg20-2-0-cust94.5-4.cable.virginm.net [82.4.196.95]) (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 78C9F20C01; Sun, 14 Jul 2019 16:19:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1563121180; bh=TVxBVjOA00hKVNaSlq096EK5GPPxbdmRVnbjXDeVNMY=; h=Date:From:To:Cc:Subject:In-Reply-To:References:From; b=a4lyDsOcgUrk5m4ywtq75dKQlLM4Txs3PNUtH93f7vVqH1Gaj807jiz4oxH5cCwv7 LE30ZTsz/kaiqkANkKrddFXirvSf9pX5C9cIW8nY/GBcgGOXpP52Oz02uWa4cwcQ6a YW7Kvup9f1Ic+Lho8yJhE2Qh8qlZeQZZLOkL9x5I= Date: Sun, 14 Jul 2019 17:19:35 +0100 From: Jonathan Cameron To: Fabien Lahoudere Cc: gwendal@chromium.org, egranata@chromium.org, kernel@collabora.com, Nick Vaccaro , Hartmut Knaack , Lars-Peter Clausen , Peter Meerwald-Stadler , Benson Leung , Enric Balletbo i Serra , Guenter Roeck , linux-iio@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v4 1/1] iio: common: cros_ec_sensors: determine protocol version Message-ID: <20190714171935.6a67cfb2@archlinux> In-Reply-To: <3fc3e1e606bc1e5478fca0888f9c005df6e52745.1562056868.git.fabien.lahoudere@collabora.com> References: <3fc3e1e606bc1e5478fca0888f9c005df6e52745.1562056868.git.fabien.lahoudere@collabora.com> X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2 Jul 2019 10:49:38 +0200 Fabien Lahoudere wrote: > This patch adds a function to determine which version of the > protocol is used to communicate with EC. > > Signed-off-by: Fabien Lahoudere > Signed-off-by: Nick Vaccaro > Reviewed-by: Gwendal Grignou > Tested-by: Gwendal Grignou > Acked-by: Enric Balletbo i Serra There are so many different series flying around for this driver that I have given up trying to figure out if I should be picking some of them up. I'll ack them on the assumption they'll all go together, but feel free to ping me if you want me to pick some of them up through IIO. Acked-by: Jonathan Cameron Thanks, Jonathan > --- > .../cros_ec_sensors/cros_ec_sensors_core.c | 36 ++++++++++++++++++- > 1 file changed, 35 insertions(+), 1 deletion(-) > > diff --git a/drivers/iio/common/cros_ec_sensors/cros_ec_sensors_core.c b/drivers/iio/common/cros_ec_sensors/cros_ec_sensors_core.c > index 130362ca421b..81111af8a167 100644 > --- a/drivers/iio/common/cros_ec_sensors/cros_ec_sensors_core.c > +++ b/drivers/iio/common/cros_ec_sensors/cros_ec_sensors_core.c > @@ -25,6 +25,31 @@ static char *cros_ec_loc[] = { > [MOTIONSENSE_LOC_MAX] = "unknown", > }; > > +static int cros_ec_get_host_cmd_version_mask(struct cros_ec_device *ec_dev, > + u16 cmd_offset, u16 cmd, u32 *mask) > +{ > + int ret; > + struct { > + struct cros_ec_command msg; > + union { > + struct ec_params_get_cmd_versions params; > + struct ec_response_get_cmd_versions resp; > + }; > + } __packed buf = { > + .msg = { > + .command = EC_CMD_GET_CMD_VERSIONS + cmd_offset, > + .insize = sizeof(struct ec_response_get_cmd_versions), > + .outsize = sizeof(struct ec_params_get_cmd_versions) > + }, > + .params = {.cmd = cmd} > + }; > + > + ret = cros_ec_cmd_xfer_status(ec_dev, &buf.msg); > + if (ret >= 0) > + *mask = buf.resp.version_mask; > + return ret; > +} > + > int cros_ec_sensors_core_init(struct platform_device *pdev, > struct iio_dev *indio_dev, > bool physical_device) > @@ -33,6 +58,8 @@ int cros_ec_sensors_core_init(struct platform_device *pdev, > struct cros_ec_sensors_core_state *state = iio_priv(indio_dev); > struct cros_ec_dev *ec = dev_get_drvdata(pdev->dev.parent); > struct cros_ec_sensor_platform *sensor_platform = dev_get_platdata(dev); > + u32 ver_mask; > + int ret; > > platform_set_drvdata(pdev, indio_dev); > > @@ -47,8 +74,15 @@ int cros_ec_sensors_core_init(struct platform_device *pdev, > > mutex_init(&state->cmd_lock); > > + ret = cros_ec_get_host_cmd_version_mask(state->ec, > + ec->cmd_offset, > + EC_CMD_MOTION_SENSE_CMD, > + &ver_mask); > + if (ret < 0) > + return ret; > + > /* Set up the host command structure. */ > - state->msg->version = 2; > + state->msg->version = fls(ver_mask) - 1; > state->msg->command = EC_CMD_MOTION_SENSE_CMD + ec->cmd_offset; > state->msg->outsize = sizeof(struct ec_params_motion_sense); >