Re: [PATCH] ACPI / DPTF: Add DPTF battery participant driver

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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!



[Index of Archives]     [Linux IBM ACPI]     [Linux Power Management]     [Linux Kernel]     [Linux Laptop]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]     [Linux Resources]

  Powered by Linux