Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp294273imb; Fri, 1 Mar 2019 00:25:34 -0800 (PST) X-Google-Smtp-Source: APXvYqxnIzJqhKQA7Zt3KrLs01cZe0fMynICHbnGPL6fIrCDTqPbtkUE5R6Qqcb1J4linMHSzhXm X-Received: by 2002:a17:902:9001:: with SMTP id a1mr460339plp.96.1551428734589; Fri, 01 Mar 2019 00:25:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551428734; cv=none; d=google.com; s=arc-20160816; b=oeCy/XZqqKsmMc+ahme8ZDMj+rCftL5Xh4vh2BVhHDPCNRQd6ONvJur/03k7uiFGkc e85BGVNr+gh9tHVioHwhiCk8rVKEof3WuvHkfA5nPQJdApjuRknbygxXdNQ/cgDXWbH7 1CYss61UmVFWnLpXtXWIP9w5u3AySs/Oooj0DaYRGkyUXwQocrLCrTeor3xhujo2VRkQ QqhKPlhPmdqrxWZ03cJRhE6Jqqo72JmTytxPhazm/LCy4rL8F9F2RiLDqUVkleUZCnDa kvbMuI32xym2GKDHkPsMQoaCR/6qjAB11YaHDQV53TH5cv8exUDCDN0iAlR735RVmdA3 Tlxw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=hZg6I2ivxgQoN6bPBaT+VVJ438Ps34FWL8t6tuMEcvE=; b=cW7hJ0nb5hjT7TSJzm47aKQQrbjw5zkVw4RUx714LemrxTEFjyQopeCIWQFYl3YACb z6phSPGu9yf0GKxXanKBzt/L0Vsj7gOk0VhbAw7LnVIHCH87WyZV9/9vDM+R1EinDOZa Yw1uZ1fnq1qIhdmuLQQlvrsnQmMB/CzQKTh9L8bCZ+/ALz+rzwtVeqCQ4S+k642YNXWP pJkSNj/1r4esMpIKHPASdCwn6OtTEa/n/OcV17sjpYhPscn9EOvsIktTH09kAD6hAxt+ J+9lMY19ksfaYj0smBpdOLGfjrWR5vk9nO9hl2vNuEMjrPj3v5jq3mFPfhTvdpCJ1PYk ytfQ== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e3si19616187pfi.223.2019.03.01.00.25.18; Fri, 01 Mar 2019 00:25:34 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731669AbfCAIVj (ORCPT + 99 others); Fri, 1 Mar 2019 03:21:39 -0500 Received: from mga18.intel.com ([134.134.136.126]:19903 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727755AbfCAIVj (ORCPT ); Fri, 1 Mar 2019 03:21:39 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga004.fm.intel.com ([10.253.24.48]) by orsmga106.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 01 Mar 2019 00:21:38 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,426,1544515200"; d="scan'208";a="148331971" Received: from rajeev-desktop.iind.intel.com ([10.223.84.39]) by fmsmga004.fm.intel.com with ESMTP; 01 Mar 2019 00:21:36 -0800 From: Rushikesh S Kadam To: lee.jones@linaro.org, bleung@chromium.org, enric.balletbo@collabora.com, groeck@chromium.org Cc: linux-kernel@vger.kernel.org, rushikesh.s.kadam@intel.com, gwendal@google.com, jettrink@chromium.org, andriy.shevchenko@intel.com Subject: [PATCH v3] mfd: cros_ec: instantiate properly CrOS ISH MCU device Date: Fri, 1 Mar 2019 13:50:54 +0530 Message-Id: <1551428454-596-1-git-send-email-rushikesh.s.kadam@intel.com> X-Mailer: git-send-email 1.9.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Integrated Sensor Hub (ISH) is also a MCU running EC having feature bit EC_FEATURE_ISH. Instantiate it as a special CrOS EC device with device name 'cros_ish'. Signed-off-by: Rushikesh S Kadam --- v3 - Dropped "Intel" in commments in cros_ec header file. CrOS EC ISH device is a generic ISH. This was missed earlier. v2 - Addressed review comments to term the CrOS EC device as a generic Integrated Sensor Hub. v1 - Initial version. drivers/mfd/cros_ec_dev.c | 13 +++++++++++++ include/linux/mfd/cros_ec.h | 1 + include/linux/mfd/cros_ec_commands.h | 2 ++ 3 files changed, 16 insertions(+) diff --git a/drivers/mfd/cros_ec_dev.c b/drivers/mfd/cros_ec_dev.c index 2d0fee4..46963c2 100644 --- a/drivers/mfd/cros_ec_dev.c +++ b/drivers/mfd/cros_ec_dev.c @@ -415,6 +415,19 @@ static int ec_device_probe(struct platform_device *pdev) cdev_init(&ec->cdev, &fops); /* + * Check whether this is actually an Integrated Sensor Hub (ISH) + * rather than an EC. + */ + if (cros_ec_check_features(ec, EC_FEATURE_ISH)) { + dev_info(dev, "CrOS ISH MCU detected.\n"); + /* + * Help userspace differentiating ECs from ISH MCU, + * regardless of the probing order. + */ + ec_platform->ec_name = CROS_EC_DEV_ISH_NAME; + } + + /* * Add the class device * Link to the character device for creating the /dev entry * in devtmpfs. diff --git a/include/linux/mfd/cros_ec.h b/include/linux/mfd/cros_ec.h index de8b588..00c5765 100644 --- a/include/linux/mfd/cros_ec.h +++ b/include/linux/mfd/cros_ec.h @@ -24,6 +24,7 @@ #define CROS_EC_DEV_NAME "cros_ec" #define CROS_EC_DEV_PD_NAME "cros_pd" +#define CROS_EC_DEV_ISH_NAME "cros_ish" /* * The EC is unresponsive for a time after a reboot command. Add a diff --git a/include/linux/mfd/cros_ec_commands.h b/include/linux/mfd/cros_ec_commands.h index fc91082..43bee4f 100644 --- a/include/linux/mfd/cros_ec_commands.h +++ b/include/linux/mfd/cros_ec_commands.h @@ -856,6 +856,8 @@ enum ec_feature_code { EC_FEATURE_RTC = 27, /* EC supports CEC commands */ EC_FEATURE_CEC = 35, + /* The MCU is an Integrated Sensor Hub */ + EC_FEATURE_ISH = 40, }; #define EC_FEATURE_MASK_0(event_code) (1UL << (event_code % 32)) -- 1.9.1