Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp249766ybe; Wed, 18 Sep 2019 16:33:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqyYyduw4kDUA5dy8TfGdewox7skWFhc1Vk2Q+6ptcBa8S9qURvAvjtbRyf+iSV+eHEa5jE9 X-Received: by 2002:a17:906:490e:: with SMTP id b14mr10125133ejq.293.1568849597992; Wed, 18 Sep 2019 16:33:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1568849597; cv=none; d=google.com; s=arc-20160816; b=CzytIt9H1lQeMKLryoKLLsADyhFAJhIcbjnkV6GzkGarWPj6FPG9lvXcZEVg8L7Gc0 h9F06ec8kzY68uHGkL29uxqvBAD+E09gynVKkx0XDBpbNd9D7Yd1iHjn92hOQNmh1N6S mpHEg+/UeB2oA4e+CokZUWu/tPHzLj1Z4VG1MdlATUZ8LtgPeHDZH9lsQbRbKvkjgple ndWGHMO7Gsgq/4hQTuWL6uhnnDq5ABrNXGM8ZW5BcImUEExqj5S1iutwE6RuO78+Qnmi N0oz7HP6/pBgeUcjKw3dRKKt9c1K8iAemzfDqwTawDuuWQVNEhSlLLsYxu+R7M6n8ys/ GewA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=W7dgmGEb7jiXcDVOoTR3Y60qv1W+YIvlHIEXooqB17k=; b=DCDQpjalI9Wlv/sCkkhdo4Ox63M+5T2zvyKHOyBFHZUSVBmSw0ub5R9ryGck/IenMU zmRL3qoWcB3WaoamXlhSEB4vyDUAhT/k7s79tL3E4RApslbiV9/MNJuxkcjLWqgwuaRe sbNEj5cNb2WLzNzZsN1UMUsDvA2qi4vSJ1pMGRtVXYUJXNqY1zh0299Ud9Bmb+paDfuj aIz41rGZqvQn7JqrpZErMQOYPj1SSymxRPg789tmKMZdrwCO2+LYZtXx9Kt1fi+db3ST 16wdO6Q3jv8tg8v2jvtPXUgUqGU3NjfoxjYQybA1vevLOwjRBavsdxLLxz6DyuagGjSi COGw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=Nfn4vYYm; 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=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id pj21si3681157ejb.64.2019.09.18.16.32.54; Wed, 18 Sep 2019 16:33:17 -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=@chromium.org header.s=google header.b=Nfn4vYYm; 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=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388124AbfIRVpM (ORCPT + 99 others); Wed, 18 Sep 2019 17:45:12 -0400 Received: from mail-oi1-f193.google.com ([209.85.167.193]:46788 "EHLO mail-oi1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388087AbfIRVpL (ORCPT ); Wed, 18 Sep 2019 17:45:11 -0400 Received: by mail-oi1-f193.google.com with SMTP id k25so875180oiw.13 for ; Wed, 18 Sep 2019 14:45:10 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=W7dgmGEb7jiXcDVOoTR3Y60qv1W+YIvlHIEXooqB17k=; b=Nfn4vYYmqahbw5bImjcKKNhaG/umEZbk35DywdJMi8vFUMvoVbQL06VrdNGdNwpJAM q0TyWW1phTEmA+8WxooalcEWilGfeV+b9QN/Vpnw2mR3wcVegp0T2KS7FqygdQ9Sjc8+ MIY/jDimM/1cJvKeEfud3N1KUM+igqZtQJBUg= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=W7dgmGEb7jiXcDVOoTR3Y60qv1W+YIvlHIEXooqB17k=; b=p7z0PsvnQoIdB3sbEV0Ta2nSQJ7kQGDXVKLXL+vseU4nKCdI3ZZcN8dkxwD2qjhYjN 4Vm/eivWgjXZZKPrrlaQTd9nyk/h6I49xyJbglaizbT4zREGjlY2y2eWYoPrxmAqJ4yP kROEfC4ctRWjHZAavl+YnF9RSR+wAyQ+0a8h+HBGPie38vs9SNaV7aQXLLqArPUUTy5i fHOFkjWgPBG4LEKnl0dq8Cldko2ugpdeD2a+f30tBR79oHPaWcU/sxBZfCuG1kvzKpee RX0qt5pWwgmwwkBchDMEf38Exd2npqMbDWzIVbJnaPDl1GWgcUm4lexx6gHuZDhwYdrz Gd7Q== X-Gm-Message-State: APjAAAXpw4N22cydcG78ozeW7/AgmebaO2pXhMKazbdQp9irRmk4bnsu RpXTRuwCjEduekYWq/A9x6WPgCB480g= X-Received: by 2002:aca:b902:: with SMTP id j2mr18474oif.169.1568843110117; Wed, 18 Sep 2019 14:45:10 -0700 (PDT) Received: from mail-oi1-f178.google.com (mail-oi1-f178.google.com. [209.85.167.178]) by smtp.gmail.com with ESMTPSA id t207sm2210887oif.11.2019.09.18.14.45.08 for (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 18 Sep 2019 14:45:09 -0700 (PDT) Received: by mail-oi1-f178.google.com with SMTP id k20so971087oih.3 for ; Wed, 18 Sep 2019 14:45:08 -0700 (PDT) X-Received: by 2002:aca:da87:: with SMTP id r129mr19681oig.177.1568843108323; Wed, 18 Sep 2019 14:45:08 -0700 (PDT) MIME-Version: 1.0 References: <20190918204316.237342-1-campello@chromium.org> In-Reply-To: <20190918204316.237342-1-campello@chromium.org> From: Nick Crews Date: Wed, 18 Sep 2019 15:44:57 -0600 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH v4] platform/chrome: wilco_ec: Add debugfs test_event file To: Daniel Campello Cc: LKML , Enric Balletbo i Serra , Benson Leung , Alexandre Belloni , Duncan Laurie Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Assuming that the Kbuild bot doesn't get mad about the format string now, LGTM. Thanks Daniel! Reviewed-by: Nick Crews On Wed, Sep 18, 2019 at 2:43 PM Daniel Campello wrote: > > This change introduces a new debugfs file 'test_event' that when written > to causes the EC to generate a test event. > > Signed-off-by: Daniel Campello > --- > Changes for v2: > - Cleaned up and added comments. > - Renamed and updated function signature from write_to_mailbox to > send_ec_cmd. > Changes for v3: > - Switched NULL format string to empty format string > - Renamed val parameter on send_ec_cmd to out_val > Changes for v4: > - Provided a format string to avoid -Wformat-zero-length warning > > drivers/platform/chrome/wilco_ec/debugfs.c | 46 +++++++++++++++++----- > 1 file changed, 36 insertions(+), 10 deletions(-) > > diff --git a/drivers/platform/chrome/wilco_ec/debugfs.c b/drivers/platform/chrome/wilco_ec/debugfs.c > index 8d65a1e2f1a3..ba86c38421ff 100644 > --- a/drivers/platform/chrome/wilco_ec/debugfs.c > +++ b/drivers/platform/chrome/wilco_ec/debugfs.c > @@ -160,29 +160,29 @@ static const struct file_operations fops_raw = { > > #define CMD_KB_CHROME 0x88 > #define SUB_CMD_H1_GPIO 0x0A > +#define SUB_CMD_TEST_EVENT 0x0B > > -struct h1_gpio_status_request { > +struct ec_request { > u8 cmd; /* Always CMD_KB_CHROME */ > u8 reserved; > - u8 sub_cmd; /* Always SUB_CMD_H1_GPIO */ > + u8 sub_cmd; > } __packed; > > -struct hi_gpio_status_response { > +struct ec_response { > u8 status; /* 0 if allowed */ > - u8 val; /* BIT(0)=ENTRY_TO_FACT_MODE, BIT(1)=SPI_CHROME_SEL */ > + u8 val; > } __packed; > > -static int h1_gpio_get(void *arg, u64 *val) > +static int send_ec_cmd(struct wilco_ec_device *ec, u8 sub_cmd, u8 *out_val) > { > - struct wilco_ec_device *ec = arg; > - struct h1_gpio_status_request rq; > - struct hi_gpio_status_response rs; > + struct ec_request rq; > + struct ec_response rs; > struct wilco_ec_message msg; > int ret; > > memset(&rq, 0, sizeof(rq)); > rq.cmd = CMD_KB_CHROME; > - rq.sub_cmd = SUB_CMD_H1_GPIO; > + rq.sub_cmd = sub_cmd; > > memset(&msg, 0, sizeof(msg)); > msg.type = WILCO_EC_MSG_LEGACY; > @@ -196,13 +196,37 @@ static int h1_gpio_get(void *arg, u64 *val) > if (rs.status) > return -EIO; > > - *val = rs.val; > + *out_val = rs.val; > > return 0; > } > +/** > + * h1_gpio_get() - Gets h1 gpio status. > + * @arg: The wilco EC device. > + * @val: BIT(0)=ENTRY_TO_FACT_MODE, BIT(1)=SPI_CHROME_SEL > + */ > +static int h1_gpio_get(void *arg, u64 *val) > +{ > + return send_ec_cmd(arg, SUB_CMD_H1_GPIO, (u8 *)val); > +} > > DEFINE_DEBUGFS_ATTRIBUTE(fops_h1_gpio, h1_gpio_get, NULL, "0x%02llx\n"); > > +/** > + * test_event_set() - Sends command to EC to cause an EC test event. > + * @arg: The wilco EC device. > + * @val: unused. > + */ > +static int test_event_set(void *arg, u64 val) > +{ > + u8 ret; > + > + return send_ec_cmd(arg, SUB_CMD_TEST_EVENT, &ret); > +} > + > +/* Format is unused since it is only required for get method which is NULL */ > +DEFINE_DEBUGFS_ATTRIBUTE(fops_test_event, NULL, test_event_set, "%llu\n"); > + > /** > * wilco_ec_debugfs_probe() - Create the debugfs node > * @pdev: The platform device, probably created in core.c > @@ -226,6 +250,8 @@ static int wilco_ec_debugfs_probe(struct platform_device *pdev) > debugfs_create_file("raw", 0644, debug_info->dir, NULL, &fops_raw); > debugfs_create_file("h1_gpio", 0444, debug_info->dir, ec, > &fops_h1_gpio); > + debugfs_create_file("test_event", 0200, debug_info->dir, ec, > + &fops_test_event); > > return 0; > } > -- > 2.23.0.237.gc6a4ce50a0-goog >