Received: by 2002:ac0:b08d:0:0:0:0:0 with SMTP id l13csp3276082imc; Sun, 24 Feb 2019 01:15:06 -0800 (PST) X-Google-Smtp-Source: AHgI3Iaz5WWKcVTdgEVrGViwl5goX0WshgC155ipUio9nvPbzcbYLUfAHw2OSvyMzhlmRclxeG1s X-Received: by 2002:a63:4f61:: with SMTP id p33mr12290843pgl.303.1550999706877; Sun, 24 Feb 2019 01:15:06 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550999706; cv=none; d=google.com; s=arc-20160816; b=qoJ8s8FYBpl4PIoMEO6erpWtHBNLIhyfh4GYcQwr+SdTLTZ9cX6JwVGQTVLMRQXEQJ b0AyHntGnk6D+Pz707rQ7ED19+cWl7+d+TyXyKcuUNfIFXw9pJle9OPQ+6gAaWDwXZcB oWHXUC/YNybYGgcWqhV2jrTd/UbSXDao5pCxRDsbklg6gqw4IxnwYcEYljy4AM2zdT1H dpOzOggi/KXXID++uBTZQ8efkmwgfmSpl3MfOTLysRDjpVY5TGpJy4hRyaZ7G8STYX0p KCeyYbivFqXOeqbj2eh9Ah2KIdogv/92Rgb2cgAV5xyGUUXno5ZART2rmiWwWRIQS5ZL pZmg== 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=lPt0r0fKBoAN0VyqTNTpI1uP9sskFsOVejaqfmdzrQM=; b=f/VFqEHN+xy6gM7ypSMixseJ2kKQeuCe6TBt1CKwNEK5sCEfJM55jQlQe2eRgR6oDg OVhbcW9XMyv+VJzNmvp9PiNUXn6SeMfJWxzmaQRSzlHJNbGBJmUHEaBjbz1oQ5/rkm+v 1fF9Lcqz9OW/FXJxcuG8BfX1GINEaNJyFfaAjQ6PKNMUzPLziZUB9pK0/81ybUQIkGsN bYrG12SxeTE6seNxl6FwgvU1kAGZaW3LhjhPCfFcgmW5BN33Mlcwb9iKoFYll4/nmKj8 sllhNnO232liZT+szbjih0ysuK5lnTJlfJahdDru+QsVaHyTsMTG8776bWF5jm78QVSU kP2A== 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 o188si5715298pga.297.2019.02.24.01.14.50; Sun, 24 Feb 2019 01:15:06 -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 S1728188AbfBXJOb (ORCPT + 99 others); Sun, 24 Feb 2019 04:14:31 -0500 Received: from mga02.intel.com ([134.134.136.20]:8519 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728120AbfBXJOb (ORCPT ); Sun, 24 Feb 2019 04:14:31 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by orsmga101.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 24 Feb 2019 01:14:30 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,407,1544515200"; d="scan'208";a="135863164" Received: from rajeev-desktop.iind.intel.com ([10.223.84.39]) by FMSMGA003.fm.intel.com with ESMTP; 24 Feb 2019 01:14:28 -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] cros_ec: instantiate properly Intel ISH MCU device Date: Sun, 24 Feb 2019 14:43:49 +0530 Message-Id: <1550999629-31791-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 Intel 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 --- drivers/mfd/cros_ec_dev.c | 10 ++++++++++ include/linux/mfd/cros_ec.h | 1 + include/linux/mfd/cros_ec_commands.h | 2 ++ 3 files changed, 13 insertions(+) diff --git a/drivers/mfd/cros_ec_dev.c b/drivers/mfd/cros_ec_dev.c index 2d0fee4..be499b8 100644 --- a/drivers/mfd/cros_ec_dev.c +++ b/drivers/mfd/cros_ec_dev.c @@ -414,6 +414,16 @@ static int ec_device_probe(struct platform_device *pdev) device_initialize(&ec->class_dev); cdev_init(&ec->cdev, &fops); + /* check whether this is actually a Intel ISH rather than an EC */ + if (cros_ec_check_features(ec, EC_FEATURE_ISH)) { + dev_info(dev, "Intel 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 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..9276c3c 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 Intel Integrated Sensor Hub */ + EC_FEATURE_ISH = 40, }; #define EC_FEATURE_MASK_0(event_code) (1UL << (event_code % 32)) -- 1.9.1