lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Message-ID: <CAJZ5v0jZrW0106DR7Rk2xov--dgJsw+h7g9AGzyyrg3=_znbvQ@mail.gmail.com> Date: Mon, 27 Mar 2023 18:53:40 +0200 From: "Rafael J. Wysocki" <rafael@...nel.org> To: Ricardo Neri <ricardo.neri-calderon@...ux.intel.com> Cc: "Peter Zijlstra (Intel)" <peterz@...radead.org>, Juri Lelli <juri.lelli@...hat.com>, Vincent Guittot <vincent.guittot@...aro.org>, Ricardo Neri <ricardo.neri@...el.com>, "Ravi V. Shankar" <ravi.v.shankar@...el.com>, Ben Segall <bsegall@...gle.com>, Daniel Bristot de Oliveira <bristot@...hat.com>, Dietmar Eggemann <dietmar.eggemann@....com>, Len Brown <len.brown@...el.com>, Mel Gorman <mgorman@...e.de>, "Rafael J. Wysocki" <rafael.j.wysocki@...el.com>, Srinivas Pandruvada <srinivas.pandruvada@...ux.intel.com>, Steven Rostedt <rostedt@...dmis.org>, Tim Chen <tim.c.chen@...ux.intel.com>, Valentin Schneider <vschneid@...hat.com>, Lukasz Luba <lukasz.luba@....com>, Ionela Voinescu <ionela.voinescu@....com>, x86@...nel.org, "Joel Fernandes (Google)" <joel@...lfernandes.org>, linux-kernel@...r.kernel.org, linux-pm@...r.kernel.org, "Tim C . Chen" <tim.c.chen@...el.com> Subject: Re: [PATCH v3 17/24] thermal: intel: hfi: Enable the Intel Thread Director On Tue, Feb 7, 2023 at 6:02 AM Ricardo Neri <ricardo.neri-calderon@...ux.intel.com> wrote: > > Enable Intel Thread Director from the CPU hotplug callback: globally from > CPU0 and then enable the thread-classification hardware in each logical > processor individually. > > Also, initialize the number of classes supported. > > Let the scheduler know that it can start using IPC classes. > > Cc: Ben Segall <bsegall@...gle.com> > Cc: Daniel Bristot de Oliveira <bristot@...hat.com> > Cc: Dietmar Eggemann <dietmar.eggemann@....com> > Cc: Ionela Voinescu <ionela.voinescu@....com> > Cc: Joel Fernandes (Google) <joel@...lfernandes.org> > Cc: Len Brown <len.brown@...el.com> > Cc: Lukasz Luba <lukasz.luba@....com> > Cc: Mel Gorman <mgorman@...e.de> > Cc: Rafael J. Wysocki <rafael.j.wysocki@...el.com> > Cc: Srinivas Pandruvada <srinivas.pandruvada@...ux.intel.com> > Cc: Steven Rostedt <rostedt@...dmis.org> > Cc: Tim C. Chen <tim.c.chen@...el.com> > Cc: Valentin Schneider <vschneid@...hat.com> > Cc: x86@...nel.org > Cc: linux-pm@...r.kernel.org > Cc: linux-kernel@...r.kernel.org > Signed-off-by: Ricardo Neri <ricardo.neri-calderon@...ux.intel.com> For the changes in intel_hfi.c Acked-by: Rafael J. Wysocki <rafael.j.wysocki@...el.com> > --- > Changes since v2: > * Use the new sched_enable_ipc_classes() interface to enable the use of > IPC classes in the scheduler. > > Changes since v1: > * None > --- > arch/x86/include/asm/msr-index.h | 2 ++ > drivers/thermal/intel/intel_hfi.c | 40 +++++++++++++++++++++++++++++-- > 2 files changed, 40 insertions(+), 2 deletions(-) > > diff --git a/arch/x86/include/asm/msr-index.h b/arch/x86/include/asm/msr-index.h > index ad35355ee43e..0ea25cc9c621 100644 > --- a/arch/x86/include/asm/msr-index.h > +++ b/arch/x86/include/asm/msr-index.h > @@ -1106,6 +1106,8 @@ > /* Hardware Feedback Interface */ > #define MSR_IA32_HW_FEEDBACK_PTR 0x17d0 > #define MSR_IA32_HW_FEEDBACK_CONFIG 0x17d1 > +#define MSR_IA32_HW_FEEDBACK_THREAD_CONFIG 0x17d4 > +#define MSR_IA32_HW_FEEDBACK_CHAR 0x17d2 > > /* x2APIC locked status */ > #define MSR_IA32_XAPIC_DISABLE_STATUS 0xBD > diff --git a/drivers/thermal/intel/intel_hfi.c b/drivers/thermal/intel/intel_hfi.c > index 7ea6acce7107..35d947f47550 100644 > --- a/drivers/thermal/intel/intel_hfi.c > +++ b/drivers/thermal/intel/intel_hfi.c > @@ -48,6 +48,8 @@ > /* Hardware Feedback Interface MSR configuration bits */ > #define HW_FEEDBACK_PTR_VALID_BIT BIT(0) > #define HW_FEEDBACK_CONFIG_HFI_ENABLE_BIT BIT(0) > +#define HW_FEEDBACK_CONFIG_ITD_ENABLE_BIT BIT(1) > +#define HW_FEEDBACK_THREAD_CONFIG_ENABLE_BIT BIT(0) > > /* CPUID detection and enumeration definitions for HFI */ > > @@ -72,6 +74,15 @@ union cpuid6_edx { > u32 full; > }; > > +union cpuid6_ecx { > + struct { > + u32 dont_care0:8; > + u32 nr_classes:8; > + u32 dont_care1:16; > + } split; > + u32 full; > +}; > + > #ifdef CONFIG_IPC_CLASSES > union hfi_thread_feedback_char_msr { > struct { > @@ -506,6 +517,11 @@ void intel_hfi_online(unsigned int cpu) > > init_hfi_cpu_index(info); > > + if (cpu_feature_enabled(X86_FEATURE_ITD)) { > + msr_val = HW_FEEDBACK_THREAD_CONFIG_ENABLE_BIT; > + wrmsrl(MSR_IA32_HW_FEEDBACK_THREAD_CONFIG, msr_val); > + } > + > /* > * Now check if the HFI instance of the package/die of @cpu has been > * initialized (by checking its header). In such case, all we have to > @@ -561,8 +577,22 @@ void intel_hfi_online(unsigned int cpu) > */ > rdmsrl(MSR_IA32_HW_FEEDBACK_CONFIG, msr_val); > msr_val |= HW_FEEDBACK_CONFIG_HFI_ENABLE_BIT; > + > + if (cpu_feature_enabled(X86_FEATURE_ITD)) > + msr_val |= HW_FEEDBACK_CONFIG_ITD_ENABLE_BIT; > + > wrmsrl(MSR_IA32_HW_FEEDBACK_CONFIG, msr_val); > > + /* > + * We have all we need to support IPC classes. Task classification is > + * now working. > + * > + * All class scores are zero until after the first HFI update. That is > + * OK. The scheduler queries these scores at every load balance. > + */ > + if (cpu_feature_enabled(X86_FEATURE_ITD)) > + sched_enable_ipc_classes(); > + > unlock: > mutex_unlock(&hfi_instance_lock); > return; > @@ -640,8 +670,14 @@ static __init int hfi_parse_features(void) > */ > hfi_features.class_stride = nr_capabilities; > > - /* For now, use only one class of the HFI table */ > - hfi_features.nr_classes = 1; > + if (cpu_feature_enabled(X86_FEATURE_ITD)) { > + union cpuid6_ecx ecx; > + > + ecx.full = cpuid_ecx(CPUID_HFI_LEAF); > + hfi_features.nr_classes = ecx.split.nr_classes; > + } else { > + hfi_features.nr_classes = 1; > + } > > /* > * The header contains change indications for each supported feature. > -- > 2.25.1 >
Powered by blists - more mailing lists