struct xe_hwmon_thermal_info temp;
};
+static inline int prepare_power_limit_param2(const struct xe_hwmon *hwmon)
+{
+ if (hwmon->boot_power_limit_read) {
+ if (hwmon->xe->info.platform >= XE_CRESCENTISLAND)
+ return READ_PL_ACCEPTED;
+ else
+ return READ_PL_FROM_PCODE;
+ } else {
+ return READ_PL_FROM_FW;
+ }
+}
+
static int xe_hwmon_pcode_read_power_limit(const struct xe_hwmon *hwmon, u32 attr, int channel,
u32 *uval)
{
(channel == CHANNEL_CARD) ?
READ_PSYSGPU_POWER_LIMIT :
READ_PACKAGE_POWER_LIMIT,
- hwmon->boot_power_limit_read ?
- READ_PL_FROM_PCODE : READ_PL_FROM_FW),
- &val0, &val1);
+ prepare_power_limit_param2(hwmon)), &val0, &val1);
if (ret) {
drm_dbg(&hwmon->xe->drm, "read failed ch %d val0 0x%08x, val1 0x%08x, ret %d\n",
(channel == CHANNEL_CARD) ?
READ_PSYSGPU_POWER_LIMIT :
READ_PACKAGE_POWER_LIMIT,
- hwmon->boot_power_limit_read ?
- READ_PL_FROM_PCODE : READ_PL_FROM_FW),
- &val0, &val1);
-
+ prepare_power_limit_param2(hwmon)), &val0, &val1);
if (ret)
drm_dbg(&hwmon->xe->drm, "read failed ch %d val0 0x%08x, val1 0x%08x, ret %d\n",
channel, val0, val1, ret);
#define WRITE_PSYSGPU_POWER_LIMIT 0x7
#define READ_PACKAGE_POWER_LIMIT 0x8
#define WRITE_PACKAGE_POWER_LIMIT 0x9
-#define READ_PL_FROM_FW 0x1
#define READ_PL_FROM_PCODE 0x0
+#define READ_PL_FROM_FW 0x1
+#define READ_PL_ACCEPTED 0x2
#define PCODE_THERMAL_INFO 0x25
#define READ_THERMAL_LIMITS 0x0