]> www.infradead.org Git - users/hch/misc.git/commitdiff
cpufreq: ondemand: Update the efficient idle check for Intel extended Families
authorSohil Mehta <sohil.mehta@intel.com>
Mon, 8 Sep 2025 23:06:55 +0000 (16:06 -0700)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Wed, 10 Sep 2025 10:25:08 +0000 (12:25 +0200)
IO time is considered busy by default for modern Intel processors. The
current check covers recent Family 6 models but excludes the brand new
Families 18 and 19.

According to Arjan van de Ven, the model check was mainly due to a lack
of testing on systems before INTEL_CORE2_MEROM. He suggests considering
all Intel processors as having an efficient idle.

Extend the IO busy classification to all Intel processors starting with
Family 6, including Family 15 (Pentium 4s) and upcoming Families 18/19.

Use an x86 VFM check and move the function to the header file to avoid
using arch-specific #ifdefs in the C file.

Signed-off-by: Sohil Mehta <sohil.mehta@intel.com>
Link: https://patch.msgid.link/20250908230655.2562440-1-sohil.mehta@intel.com
[ rjw: Added empty line after #include ]
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/cpufreq/cpufreq_ondemand.c
drivers/cpufreq/cpufreq_ondemand.h

index 0e65d37c923113afcc772b5d29372fb65d1fc75b..a6ecc203f7b7f37d32f4e44fb6eaa81ec7e481b5 100644 (file)
@@ -29,29 +29,6 @@ static struct od_ops od_ops;
 
 static unsigned int default_powersave_bias;
 
-/*
- * Not all CPUs want IO time to be accounted as busy; this depends on how
- * efficient idling at a higher frequency/voltage is.
- * Pavel Machek says this is not so for various generations of AMD and old
- * Intel systems.
- * Mike Chan (android.com) claims this is also not true for ARM.
- * Because of this, whitelist specific known (series) of CPUs by default, and
- * leave all others up to the user.
- */
-static int should_io_be_busy(void)
-{
-#if defined(CONFIG_X86)
-       /*
-        * For Intel, Core 2 (model 15) and later have an efficient idle.
-        */
-       if (boot_cpu_data.x86_vendor == X86_VENDOR_INTEL &&
-                       boot_cpu_data.x86 == 6 &&
-                       boot_cpu_data.x86_model >= 15)
-               return 1;
-#endif
-       return 0;
-}
-
 /*
  * Find right freq to be set now with powersave_bias on.
  * Returns the freq_hi to be used right now and will set freq_hi_delay_us,
@@ -377,7 +354,7 @@ static int od_init(struct dbs_data *dbs_data)
        dbs_data->sampling_down_factor = DEF_SAMPLING_DOWN_FACTOR;
        dbs_data->ignore_nice_load = 0;
        tuners->powersave_bias = default_powersave_bias;
-       dbs_data->io_is_busy = should_io_be_busy();
+       dbs_data->io_is_busy = od_should_io_be_busy();
 
        dbs_data->tuners = tuners;
        return 0;
index 1af8e5c4b86fd08553f6d0238529e07fc2629f32..2ca8f1aaf2e348e65b1cd95ea5934ff85101bd2c 100644 (file)
@@ -24,3 +24,26 @@ static inline struct od_policy_dbs_info *to_dbs_info(struct policy_dbs_info *pol
 struct od_dbs_tuners {
        unsigned int powersave_bias;
 };
+
+#ifdef CONFIG_X86
+#include <asm/cpu_device_id.h>
+
+/*
+ * Not all CPUs want IO time to be accounted as busy; this depends on
+ * how efficient idling at a higher frequency/voltage is.
+ *
+ * Pavel Machek says this is not so for various generations of AMD and
+ * old Intel systems. Mike Chan (android.com) claims this is also not
+ * true for ARM.
+ *
+ * Because of this, select a known series of Intel CPUs (Family 6 and
+ * later) by default, and leave all others up to the user.
+ */
+static inline bool od_should_io_be_busy(void)
+{
+       return (boot_cpu_data.x86_vendor == X86_VENDOR_INTEL &&
+               boot_cpu_data.x86_vfm >= INTEL_PENTIUM_PRO);
+}
+#else
+static inline bool od_should_io_be_busy(void) { return false; }
+#endif