Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp6111806ybl; Sun, 22 Dec 2019 23:41:23 -0800 (PST) X-Google-Smtp-Source: APXvYqz/I7fk9O8kZoUB7Yt6OS2V1zSrraBGGXf22+iUsmIVjVslU8RPrr/yVzTVcwkfotb858f3 X-Received: by 2002:a9d:3d0a:: with SMTP id a10mr27851337otc.327.1577086883738; Sun, 22 Dec 2019 23:41:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1577086883; cv=none; d=google.com; s=arc-20160816; b=byiW/oCFlrGOB2E4ZhZXv5zx8Mj43s8s54XxEto1rvlq/uZvPEnu8M5Nj2v/UzGhEz EZB+5vFv0kxYgAybukXj6okwgT/0N+Qy/x18J3zbyeIsvKOc90LcAYpb6keMdGFpNjLO x3/sROS1pk+ku4GYr5naS+q2P6zG7ql8zlroIorzWQlCBsi3As1C10LqNV/Kr9skG2xP B0d+jSHoJnN4e2ES+ab4njvwotMCEwehe50kOK7dk9KT32z/KYghKf2UvOn++8vYdDgI 9bZd1aTYE8VbKQuQSUjx9/Y/xvG36FlLLjTsKpfAl+WWt1uTHddYNzeWyHSe4MS/azMp Vv6w== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:references:cc:to:from:subject; bh=sxDfrFGvjcufdgEaaYZk2KJbCiGDdXsj5qA9/mXlsAQ=; b=EiVhsrNiWP0LphqY8CaCSzS3yK1r7Oh8uOgXyCfcTD4wzEEXKBgPsWlecUeyOqiiO/ og6pmVxPzu4lQovL3rkJecZRJriMOdikqsc8j6dQ2PWRO+Kt/hwyedlXxq3pwbBx4Lwh eW+AsuEQijY3U7vUM2dqg2SwA3e+q4vKwDzyhUR9IwHw8OMp0hxFX7J9I8pQC6hEHQ/1 bI9viXw+mg2CcPZQNAPO/NUpQRh91gD6YYpEZBBdVQ6hXxlP02wByESkrBD5E6qG+Kl9 LT8M9VAuORODrh6ywvv7sIgV/T++CdYOhg3JlOv21fQ2seXDz4xtIqn2CQw82UBbWIMF Pj4g== 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=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y198si9424332oia.163.2019.12.22.23.41.12; Sun, 22 Dec 2019 23:41:23 -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=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726266AbfLWHkL (ORCPT + 99 others); Mon, 23 Dec 2019 02:40:11 -0500 Received: from bhuna.collabora.co.uk ([46.235.227.227]:56788 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725901AbfLWHkL (ORCPT ); Mon, 23 Dec 2019 02:40:11 -0500 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: eballetbo) with ESMTPSA id C8B1A28D34E Subject: Re: [PATCH v4 1/2] platform: chrome: Add cros-usbpd-notify driver From: Enric Balletbo i Serra To: Prashant Malani , groeck@chromium.org, bleung@chromium.org, lee.jones@linaro.org Cc: linux-kernel@vger.kernel.org, Jon Flatley , Gwendal Grignou References: <20191220193843.47182-1-pmalani@chromium.org> <9bcb4671-f421-c639-f8c8-a02f62bfc7ee@collabora.com> Message-ID: Date: Mon, 23 Dec 2019 08:40:05 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.3.0 MIME-Version: 1.0 In-Reply-To: <9bcb4671-f421-c639-f8c8-a02f62bfc7ee@collabora.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Prashant, On 23/12/19 8:18, Enric Balletbo i Serra wrote: > Hi Prashant, > > On 20/12/19 20:38, Prashant Malani wrote: >> From: Jon Flatley >> >> ChromiumOS uses ACPI device with HID "GOOG0003" for power delivery >> related events. The existing cros-usbpd-charger driver relies on these >> events without ever actually receiving them on ACPI platforms. This is >> because in the ChromeOS kernel trees, the GOOG0003 device is owned by an >> ACPI driver that offers firmware updates to USB-C chargers. >> >> Introduce a new platform driver under cros-ec, the ChromeOS embedded >> controller, that handles these PD events and dispatches them >> appropriately over a notifier chain to all drivers that use them. >> >> On non-ACPI platforms, the driver gets instantiated for ECs which >> support the EC_FEATURE_USB_PD feature bit, and on such platforms, the >> notification events will get delivered using the MKBP event handling >> mechanism. >> >> Co-Developed-by: Prashant Malani >> Reviewed-by: Gwendal Grignou >> Signed-off-by: Jon Flatley >> Signed-off-by: Prashant Malani > > For my own reference: > > Acked-for-chrome-by: Enric Balletbo i Serra > Sorry, too much rush acking this patch, here applies the same comment as patch 2 >> --- >> >> Changes in v4(pmalani@chromium.org): >> - No code changes, but added new version so that versioning is >> consistent with the next patch in the series. >> >> Changes in v3 (pmalani@chromium.org): >> - Renamed driver and files from "cros_ec_pd_notify" to >> "cros_usbpd_notify" to be more consistent with other naming. >> - Moved the change to include cros-usbpd-notify in the charger MFD into >> a separate follow-on patch. >> >> Changes in v2 (pmalani@chromium.org): >> - Removed dependency on DT entry; instead, we will instantiate the >> driver on detecting EC_FEATURE_USB_PD for non-ACPI platforms. >> - Modified the cros-ec-pd-notify device to be an mfd_cell under >> usbpdcharger for non-ACPI platforms. Altered the platform_probe() call >> to derive the cros EC structs appropriately. >> - Replaced "usbpd_notify" with "pd_notify" in functions and structures. >> - Addressed comments from upstream maintainer. >> >> drivers/platform/chrome/Kconfig | 9 ++ >> drivers/platform/chrome/Makefile | 1 + >> drivers/platform/chrome/cros_usbpd_notify.c | 151 ++++++++++++++++++ >> .../linux/platform_data/cros_usbpd_notify.h | 17 ++ >> 4 files changed, 178 insertions(+) >> create mode 100644 drivers/platform/chrome/cros_usbpd_notify.c >> create mode 100644 include/linux/platform_data/cros_usbpd_notify.h >> >> diff --git a/drivers/platform/chrome/Kconfig b/drivers/platform/chrome/Kconfig >> index 5f57282a28da0..3a8a98f2fb4d1 100644 >> --- a/drivers/platform/chrome/Kconfig >> +++ b/drivers/platform/chrome/Kconfig >> @@ -226,6 +226,15 @@ config CROS_USBPD_LOGGER >> To compile this driver as a module, choose M here: the >> module will be called cros_usbpd_logger. >> >> +config CROS_USBPD_NOTIFY >> + tristate "ChromeOS Type-C power delivery event notifier" >> + depends on CROS_EC >> + help >> + If you say Y here, you get support for Type-C PD event notifications >> + from the ChromeOS EC. On ACPI platorms this driver will bind to the >> + GOOG0003 ACPI device, and on non-ACPI platforms this driver will get >> + initialized on ECs which support the feature EC_FEATURE_USB_PD. >> + >> source "drivers/platform/chrome/wilco_ec/Kconfig" >> >> endif # CHROMEOS_PLATFORMS >> diff --git a/drivers/platform/chrome/Makefile b/drivers/platform/chrome/Makefile >> index aacd5920d8a18..f6465f8ef0b5e 100644 >> --- a/drivers/platform/chrome/Makefile >> +++ b/drivers/platform/chrome/Makefile >> @@ -22,5 +22,6 @@ obj-$(CONFIG_CROS_EC_DEBUGFS) += cros_ec_debugfs.o >> obj-$(CONFIG_CROS_EC_SENSORHUB) += cros_ec_sensorhub.o >> obj-$(CONFIG_CROS_EC_SYSFS) += cros_ec_sysfs.o >> obj-$(CONFIG_CROS_USBPD_LOGGER) += cros_usbpd_logger.o >> +obj-$(CONFIG_CROS_USBPD_NOTIFY) += cros_usbpd_notify.o >> >> obj-$(CONFIG_WILCO_EC) += wilco_ec/ >> diff --git a/drivers/platform/chrome/cros_usbpd_notify.c b/drivers/platform/chrome/cros_usbpd_notify.c >> new file mode 100644 >> index 0000000000000..05a7db834d2e0 >> --- /dev/null >> +++ b/drivers/platform/chrome/cros_usbpd_notify.c >> @@ -0,0 +1,151 @@ >> +// SPDX-License-Identifier: GPL-2.0-only >> +/* >> + * Copyright 2019 Google LLC >> + * >> + * This driver serves as the receiver of cros_ec PD host events. >> + */ >> + >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> +#include >> + >> +#define DRV_NAME "cros-usbpd-notify" >> +#define ACPI_DRV_NAME "GOOG0003" >> + >> +static BLOCKING_NOTIFIER_HEAD(cros_usbpd_notifier_list); >> + >> +/** >> + * cros_usbpd_register_notify - Register a notifier callback for PD events. >> + * @nb: Notifier block pointer to register >> + * >> + * On ACPI platforms this corresponds to host events on the ECPD >> + * "GOOG0003" ACPI device. On non-ACPI platforms this will filter mkbp events >> + * for USB PD events. >> + * >> + * Return: 0 on success or negative error code. >> + */ >> +int cros_usbpd_register_notify(struct notifier_block *nb) >> +{ >> + return blocking_notifier_chain_register( >> + &cros_usbpd_notifier_list, nb); >> +} >> +EXPORT_SYMBOL_GPL(cros_usbpd_register_notify); >> + >> + >> +/** >> + * cros_usbpd_unregister_notify - Unregister notifier callback for PD events. >> + * @nb: Notifier block pointer to unregister >> + * >> + * Unregister a notifier callback that was previously registered with >> + * cros_usbpd_register_notify(). >> + */ >> +void cros_usbpd_unregister_notify(struct notifier_block *nb) >> +{ >> + blocking_notifier_chain_unregister(&cros_usbpd_notifier_list, nb); >> +} >> +EXPORT_SYMBOL_GPL(cros_usbpd_unregister_notify); >> + >> +#ifdef CONFIG_ACPI >> + For arm64 will follow this path, and this is not what we want, right? >> +static int cros_usbpd_notify_add_acpi(struct acpi_device *adev) >> +{ >> + return 0; >> +} >> + >> +static void cros_usbpd_notify_acpi(struct acpi_device *adev, u32 event) >> +{ >> + blocking_notifier_call_chain(&cros_usbpd_notifier_list, event, NULL); >> +} >> + >> +static const struct acpi_device_id cros_usbpd_notify_acpi_device_ids[] = { >> + { ACPI_DRV_NAME, 0 }, >> + { } >> +}; >> +MODULE_DEVICE_TABLE(acpi, cros_usbpd_acpi_device_ids); >> + >> +static struct acpi_driver cros_usbpd_notify_driver = { >> + .name = DRV_NAME, >> + .class = DRV_NAME, >> + .ids = cros_usbpd_notify_acpi_device_ids, >> + .ops = { >> + .add = cros_usbpd_notify_add_acpi, >> + .notify = cros_usbpd_notify_acpi, >> + }, >> +}; >> +module_acpi_driver(cros_usbpd_notify_driver); >> + >> +#else /* CONFIG_ACPI */ >> + >> +static int cros_usbpd_notify_plat(struct notifier_block *nb, >> + unsigned long queued_during_suspend, void *data) >> +{ >> + struct cros_ec_device *ec_dev = (struct cros_ec_device *)data; >> + u32 host_event = cros_ec_get_host_event(ec_dev); >> + >> + if (!host_event) >> + return NOTIFY_BAD; >> + >> + if (host_event & EC_HOST_EVENT_MASK(EC_HOST_EVENT_PD_MCU)) { >> + blocking_notifier_call_chain(&cros_usbpd_notifier_list, >> + host_event, NULL); >> + return NOTIFY_OK; >> + } >> + return NOTIFY_DONE; >> +} >> + >> +static int cros_usbpd_notify_probe_plat(struct platform_device *pdev) >> +{ >> + struct device *dev = &pdev->dev; >> + struct cros_ec_dev *ecdev = dev_get_drvdata(dev->parent); >> + struct notifier_block *nb; >> + int ret; >> + >> + nb = devm_kzalloc(dev, sizeof(*nb), GFP_KERNEL); >> + if (!nb) >> + return -ENOMEM; >> + >> + nb->notifier_call = cros_usbpd_notify_plat; >> + dev_set_drvdata(dev, nb); >> + >> + ret = blocking_notifier_chain_register(&ecdev->ec_dev->event_notifier, >> + nb); >> + if (ret < 0) { >> + dev_err(dev, "Failed to register notifier\n"); >> + return ret; >> + } >> + >> + return 0; >> +} >> + >> +static int cros_usbpd_notify_remove_plat(struct platform_device *pdev) >> +{ >> + struct device *dev = &pdev->dev; >> + struct cros_ec_dev *ecdev = dev_get_drvdata(dev->parent); >> + struct notifier_block *nb = >> + (struct notifier_block *)dev_get_drvdata(dev); >> + >> + blocking_notifier_chain_unregister(&ecdev->ec_dev->event_notifier, >> + nb); >> + >> + return 0; >> +} >> + >> +static struct platform_driver cros_usbpd_notify_driver = { >> + .driver = { >> + .name = DRV_NAME, >> + }, >> + .probe = cros_usbpd_notify_probe_plat, >> + .remove = cros_usbpd_notify_remove_plat, >> +}; >> +module_platform_driver(cros_usbpd_notify_driver); >> + >> +#endif /* CONFIG_ACPI */ >> + >> +MODULE_LICENSE("GPL"); >> +MODULE_DESCRIPTION("ChromeOS power delivery notifier device"); >> +MODULE_AUTHOR("Jon Flatley "); >> +MODULE_ALIAS("platform:" DRV_NAME); >> diff --git a/include/linux/platform_data/cros_usbpd_notify.h b/include/linux/platform_data/cros_usbpd_notify.h >> new file mode 100644 >> index 0000000000000..cd7c7bebf18da >> --- /dev/null >> +++ b/include/linux/platform_data/cros_usbpd_notify.h >> @@ -0,0 +1,17 @@ >> +// SPDX-License-Identifier: GPL-2.0-only >> +/* >> + * ChromeOS EC Power Delivery Notifier Driver >> + * >> + * Copyright 2019 Google LLC >> + */ >> + >> +#ifndef __LINUX_PLATFORM_DATA_CROS_USBPD_NOTIFY_H >> +#define __LINUX_PLATFORM_DATA_CROS_USBPD_NOTIFY_H >> + >> +#include >> + >> +int cros_usbpd_register_notify(struct notifier_block *nb); >> + >> +void cros_usbpd_unregister_notify(struct notifier_block *nb); >> + >> +#endif /* __LINUX_PLATFORM_DATA_CROS_USBPD_NOTIFY_H */ >>