| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * ACPI fan device IDs are shared between the fan driver and the device power
- * management code.
- *
- * Add new device IDs before the generic ACPI fan one.
- */
- #ifndef _ACPI_FAN_H_
- #define _ACPI_FAN_H_
- #include <linux/kconfig.h>
- #include <linux/limits.h>
- #define ACPI_FAN_DEVICE_IDS \
- {"INT3404", }, /* Fan */ \
- {"INTC1044", }, /* Fan for Tiger Lake generation */ \
- {"INTC1048", }, /* Fan for Alder Lake generation */ \
- {"INTC1063", }, /* Fan for Meteor Lake generation */ \
- {"INTC106A", }, /* Fan for Lunar Lake generation */ \
- {"INTC10A2", }, /* Fan for Raptor Lake generation */ \
- {"INTC10D6", }, /* Fan for Panther Lake generation */ \
- {"INTC10FE", }, /* Fan for Wildcat Lake generation */ \
- {"INTC10F5", }, /* Fan for Nova Lake generation */ \
- {"PNP0C0B", } /* Generic ACPI fan */
- #define ACPI_FPS_NAME_LEN 20
- struct acpi_fan_fps {
- u64 control;
- u64 trip_point;
- u64 speed;
- u64 noise_level;
- u64 power;
- char name[ACPI_FPS_NAME_LEN];
- struct device_attribute dev_attr;
- };
- struct acpi_fan_fif {
- u8 revision;
- u8 fine_grain_ctrl;
- u8 step_size;
- u8 low_speed_notification;
- };
- struct acpi_fan_fst {
- u64 revision;
- u64 control;
- u64 speed;
- };
- struct acpi_fan {
- acpi_handle handle;
- bool acpi4;
- bool has_fst;
- struct acpi_fan_fif fif;
- struct acpi_fan_fps *fps;
- int fps_count;
- /* A value of 0 means that trippoint-related functions are not supported */
- u32 fan_trip_granularity;
- #if IS_REACHABLE(CONFIG_HWMON)
- struct device *hdev;
- #endif
- struct thermal_cooling_device *cdev;
- struct device_attribute fst_speed;
- struct device_attribute fine_grain_control;
- };
- /**
- * acpi_fan_speed_valid - Check if fan speed value is valid
- * @speeed: Speed value returned by the ACPI firmware
- *
- * Check if the fan speed value returned by the ACPI firmware is valid. This function is
- * necessary as ACPI firmware implementations can return 0xFFFFFFFF to signal that the
- * ACPI fan does not support speed reporting. Additionally, some buggy ACPI firmware
- * implementations return a value larger than the 32-bit integer value defined by
- * the ACPI specification when using placeholder values. Such invalid values are also
- * detected by this function.
- *
- * Returns: True if the fan speed value is valid, false otherwise.
- */
- static inline bool acpi_fan_speed_valid(u64 speed)
- {
- return speed < U32_MAX;
- }
- /**
- * acpi_fan_power_valid - Check if fan power value is valid
- * @power: Power value returned by the ACPI firmware
- *
- * Check if the fan power value returned by the ACPI firmware is valid.
- * See acpi_fan_speed_valid() for details.
- *
- * Returns: True if the fan power value is valid, false otherwise.
- */
- static inline bool acpi_fan_power_valid(u64 power)
- {
- return power < U32_MAX;
- }
- int acpi_fan_get_fst(acpi_handle handle, struct acpi_fan_fst *fst);
- int acpi_fan_create_attributes(struct acpi_device *device);
- void acpi_fan_delete_attributes(struct acpi_device *device);
- #if IS_REACHABLE(CONFIG_HWMON)
- int devm_acpi_fan_create_hwmon(struct device *dev);
- void acpi_fan_notify_hwmon(struct device *dev);
- #else
- static inline int devm_acpi_fan_create_hwmon(struct device *dev) { return 0; };
- static inline void acpi_fan_notify_hwmon(struct device *dev) { };
- #endif
- #endif
|