Re: [PATCH] ACPI / DPTF: Add DPTF battery participant driver
From: Rafael J. Wysocki
Date: Mon May 25 2020 - 06:08:50 EST
On Fri, May 22, 2020 at 11:45 PM Srinivas Pandruvada
<srinivas.pandruvada@xxxxxxxxxxxxxxx> wrote:
>
> This driver adds support for Dynamic Platform and Thermal Framework
> battery participant device support.
>
> These attributes are presented via sysfs interface under the platform
> device for the battery participant:
> $ls /sys/bus/platform/devices/INT3532:00/dptf_battery
> current_discharge_capbility_ma
> max_platform_power_mw
> no_load_voltage_mv
> high_freq_impedance_mohm
> max_steady_state_power_mw
>
> Refer to the documentation at
> Documentation/ABI/testing/sysfs-platform-dptf
> for details.
>
> Here the implementation reuses existing dptf-power.c as the motivation and
> processing is same. It also shares one ACPI method. Here this change is
> using participant type, "PTYP" method to identify and do different
> processing. By using participant type, create/delete either "dptf_power"
> or "dptf_battery" attribute group and send notifications.
>
> The particpant type for for the battery participant is 0x0C.
>
> ACPI methods description:
>
> PMAX (Intel(R) Dynamic Tuning Platform Max Power Supplied by Battery):
> This object evaluates to the maximum platform power that can be supported
> by the battery in milli watts.
>
> PBSS (Intel(R) Dynamic Tuning Power Battery Steady State):
> This object returns the max sustained power for battery in milli watts.
>
> RBHF (Intel(R) Dynamic Tuning High Frequency Impedance):
> This object returns high frequency impedance value that can be obtained
> from battery fuel gauge.
>
> VBNL (Intel(R) Dynamic Tuning No-Load Voltage)
> This object returns battery instantaneous no-load voltage that can be
> obtained from battery fuel gauge in milli volts
>
> CMPP (Intel(R) Dynamic Tuning Current Discharge Capability)
> This object returns battery discharge current capability obtained from
> battery fuel gauge milli amps.
>
> Notifications:
>
> 0x80: PMAX change. Used to notify Intel(R)Dynamic Tuning Battery
> participant driver when the PMAX has changed by 250mw.
> 0x83: PBSS change. Used to notify Intel(R) Dynamic Tuning Battery
> participant driver when the power source has changed.
> 0x85: RBHF change. Used to notify Intel(R)Dynamic Tuning Battery
> participant driver when the RBHF has changed over a threshold by
> 5mOhm.
> 0x86: Battery Capability change. Used to notify Intel(R)Dynamic Tuning
> Battery participant driver when the battery capability has changed.
>
> Signed-off-by: Srinivas Pandruvada <srinivas.pandruvada@xxxxxxxxxxxxxxx>
> ---
> Comment
> I know this is close to merge window, so it can be differed to 5.9
> if this is a problem.
>
> Documentation/ABI/testing/sysfs-platform-dptf | 38 +++++++++
> drivers/acpi/dptf/dptf_power.c | 82 ++++++++++++++++---
> 2 files changed, 110 insertions(+), 10 deletions(-)
>
> diff --git a/Documentation/ABI/testing/sysfs-platform-dptf b/Documentation/ABI/testing/sysfs-platform-dptf
> index e83a9d208849..ef923958c750 100644
> --- a/Documentation/ABI/testing/sysfs-platform-dptf
> +++ b/Documentation/ABI/testing/sysfs-platform-dptf
> @@ -54,3 +54,41 @@ KernelVersion: v5.8
> Contact: linux-acpi@xxxxxxxxxxxxxxx
> Description:
> (WO) Confirm embedded controller about a prochot notification.
> +
> +What: /sys/bus/platform/devices/INT3532:00/dptf_battery/max_platform_power_mw
> +Date: June, 2020
> +KernelVersion: v5.8
> +Contact: linux-acpi@xxxxxxxxxxxxxxx
> +Description:
> + (RO) The maximum platform power that can be supported by the battery in milli watts.
> +
> +What: /sys/bus/platform/devices/INT3532:00/dptf_battery/max_steady_state_power_mw
> +Date: June, 2020
> +KernelVersion: v5.8
> +Contact: linux-acpi@xxxxxxxxxxxxxxx
> +Description:
> + (RO) The maximum sustained power for battery in milli watts.
> +
> +What: /sys/bus/platform/devices/INT3532:00/dptf_battery/high_freq_impedance_mohm
> +Date: June, 2020
> +KernelVersion: v5.8
> +Contact: linux-acpi@xxxxxxxxxxxxxxx
> +Description:
> + (RO) The high frequency impedance value that can be obtained from battery
> + fuel gauge in milli Ohms.
> +
> +What: /sys/bus/platform/devices/INT3532:00/dptf_battery/no_load_voltage_mv
> +Date: June, 2020
> +KernelVersion: v5.8
> +Contact: linux-acpi@xxxxxxxxxxxxxxx
> +Description:
> + (RO) The no-load voltage that can be obtained from battery fuel gauge in
> + milli volts.
> +
> +What: /sys/bus/platform/devices/INT3532:00/dptf_battery/current_discharge_capbility_ma
> +Date: June, 2020
> +KernelVersion: v5.8
> +Contact: linux-acpi@xxxxxxxxxxxxxxx
> +Description:
> + (RO) The battery discharge current capability obtained from battery fuel gauge in
> + milli Amps.
> diff --git a/drivers/acpi/dptf/dptf_power.c b/drivers/acpi/dptf/dptf_power.c
> index abe99039af74..5fab7e350db8 100644
> --- a/drivers/acpi/dptf/dptf_power.c
> +++ b/drivers/acpi/dptf/dptf_power.c
> @@ -10,13 +10,19 @@
> #include <linux/platform_device.h>
>
> /*
> - * Presentation of attributes which are defined for INT3407. They are:
> + * Presentation of attributes which are defined for INT3407 and INT3532.
> + * They are:
> * PMAX : Maximum platform powe
> * PSRC : Platform power source
> * ARTG : Adapter rating
> * CTYP : Charger type
> * PBSS : Battery steady power
> * PROP : Rest of worst case platform Power
> + * PBSS : Power Battery Steady State
> + * PBSS : Power Battery Steady State
> + * RBHF : High Frequency Impedance
> + * VBNL : Instantaneous No-Load Voltage
> + * CMPP : Current Discharge Capability
> */
> #define DPTF_POWER_SHOW(name, object) \
> static ssize_t name##_show(struct device *dev,\
> @@ -41,6 +47,10 @@ DPTF_POWER_SHOW(adapter_rating_mw, ARTG)
> DPTF_POWER_SHOW(battery_steady_power_mw, PBSS)
> DPTF_POWER_SHOW(charger_type, CTYP)
> DPTF_POWER_SHOW(rest_of_platform_power_mw, PROP)
> +DPTF_POWER_SHOW(max_steady_state_power_mw, PBSS)
> +DPTF_POWER_SHOW(high_freq_impedance_mohm, RBHF)
> +DPTF_POWER_SHOW(no_load_voltage_mv, VBNL)
> +DPTF_POWER_SHOW(current_discharge_capbility_ma, CMPP);
>
> static DEVICE_ATTR_RO(max_platform_power_mw);
> static DEVICE_ATTR_RO(platform_power_source);
> @@ -48,6 +58,10 @@ static DEVICE_ATTR_RO(adapter_rating_mw);
> static DEVICE_ATTR_RO(battery_steady_power_mw);
> static DEVICE_ATTR_RO(charger_type);
> static DEVICE_ATTR_RO(rest_of_platform_power_mw);
> +static DEVICE_ATTR_RO(max_steady_state_power_mw);
> +static DEVICE_ATTR_RO(high_freq_impedance_mohm);
> +static DEVICE_ATTR_RO(no_load_voltage_mv);
> +static DEVICE_ATTR_RO(current_discharge_capbility_ma);
>
> static ssize_t prochot_confirm_store(struct device *dev,
> struct device_attribute *attr,
> @@ -85,8 +99,38 @@ static const struct attribute_group dptf_power_attribute_group = {
> .name = "dptf_power"
> };
>
> +static struct attribute *dptf_battery_attrs[] = {
> + &dev_attr_max_platform_power_mw.attr,
> + &dev_attr_max_steady_state_power_mw.attr,
> + &dev_attr_high_freq_impedance_mohm.attr,
> + &dev_attr_no_load_voltage_mv.attr,
> + &dev_attr_current_discharge_capbility_ma.attr,
> + NULL
> +};
> +
> +static const struct attribute_group dptf_battery_attribute_group = {
> + .attrs = dptf_battery_attrs,
> + .name = "dptf_battery"
> +};
> +
> +#define MAX_POWER_CHANGED 0x80
> #define POWER_STATE_CHANGED 0x81
> +#define STEADY_STATE_POWER_CHANGED 0x83
> #define POWER_PROP_CHANGE_EVENT 0x84
> +#define IMPEDANCED_CHNGED 0x85
> +#define VOLTAGE_CURRENT_CHANGED 0x86
> +
> +static long long dptf_participant_type(acpi_handle handle)
> +{
> + unsigned long long ptype;
> + acpi_status status;
> +
> + status = acpi_evaluate_integer(handle, "PTYP", NULL, &ptype);
> + if (ACPI_FAILURE(status))
> + return -ENODEV;
> +
> + return ptype;
> +}
>
> static void dptf_power_notify(acpi_handle handle, u32 event, void *data)
> {
> @@ -100,6 +144,15 @@ static void dptf_power_notify(acpi_handle handle, u32 event, void *data)
> case POWER_PROP_CHANGE_EVENT:
> attr = "rest_of_platform_power_mw";
> break;
> + case MAX_POWER_CHANGED:
> + attr = "max_platform_power_mw";
> + break;
> + case STEADY_STATE_POWER_CHANGED:
> + attr = "max_steady_state_power_mw";
> + break;
> + case VOLTAGE_CURRENT_CHANGED:
> + attr = "no_load_voltage_mv";
> + break;
> default:
> dev_err(&pdev->dev, "Unsupported event [0x%x]\n", event);
> return;
> @@ -109,13 +162,16 @@ static void dptf_power_notify(acpi_handle handle, u32 event, void *data)
> * Notify that an attribute is changed, so that user space can read
> * again.
> */
> - sysfs_notify(&pdev->dev.kobj, "dptf_power", attr);
> + if (dptf_participant_type(handle) == 0x0CULL)
> + sysfs_notify(&pdev->dev.kobj, "dptf_battery", attr);
> + else
> + sysfs_notify(&pdev->dev.kobj, "dptf_power", attr);
> }
>
> static int dptf_power_add(struct platform_device *pdev)
> {
> + const struct attribute_group *attr_group;
> struct acpi_device *acpi_dev;
> - acpi_status status;
> unsigned long long ptype;
> int result;
>
> @@ -123,11 +179,12 @@ static int dptf_power_add(struct platform_device *pdev)
> if (!acpi_dev)
> return -ENODEV;
>
> - status = acpi_evaluate_integer(acpi_dev->handle, "PTYP", NULL, &ptype);
> - if (ACPI_FAILURE(status))
> - return -ENODEV;
> -
> - if (ptype != 0x11)
> + ptype = dptf_participant_type(acpi_dev->handle);
> + if (ptype == 0x11)
> + attr_group = &dptf_power_attribute_group;
> + else if (ptype == 0x0C)
> + attr_group = &dptf_battery_attribute_group;
> + else
> return -ENODEV;
>
> result = acpi_install_notify_handler(acpi_dev->handle,
> @@ -138,7 +195,7 @@ static int dptf_power_add(struct platform_device *pdev)
> return result;
>
> result = sysfs_create_group(&pdev->dev.kobj,
> - &dptf_power_attribute_group);
> + attr_group);
> if (result) {
> acpi_remove_notify_handler(acpi_dev->handle,
> ACPI_DEVICE_NOTIFY,
> @@ -158,13 +215,18 @@ static int dptf_power_remove(struct platform_device *pdev)
> acpi_remove_notify_handler(acpi_dev->handle,
> ACPI_DEVICE_NOTIFY,
> dptf_power_notify);
> - sysfs_remove_group(&pdev->dev.kobj, &dptf_power_attribute_group);
> +
> + if (dptf_participant_type(acpi_dev->handle) == 0x0CULL)
> + sysfs_remove_group(&pdev->dev.kobj, &dptf_battery_attribute_group);
> + else
> + sysfs_remove_group(&pdev->dev.kobj, &dptf_power_attribute_group);
>
> return 0;
> }
>
> static const struct acpi_device_id int3407_device_ids[] = {
> {"INT3407", 0},
> + {"INT3532", 0},
> {"INTC1047", 0},
> {"", 0},
> };
> --
Applied as 5.8 material under a slightly modified subject, thanks!