
Atualizei recentemente para o Ubuntu 22.04 LTS e vi que havia opções de energia. No entanto, o modo de desempenho não está disponível.
Não consigo obter as mesmas pontuações de desempenho e benchmark que obtenho na inicialização dupla do Windows. Eu acho que esse é o motivo.
Então eu verifiquei o governador de energia e ele diz acpi-cpufreq
. Eu verifiquei meu grub cfg e ele diz intel_pstate=enable
. Tive o mesmo problema com o Ubuntu 20.04, pensei que talvez fosse um problema com o kernle, mas mesmo com o novo kernel, ainda não está funcionando.
[ 0.062414] Kernel command line: BOOT_IMAGE=/vmlinuz-5.15.0-47-generic root=UUID=9103868b-6caf-4c46-95b9-05f6bb5b8e94 ro intel_pstate=enable quiet splash vt.handoff=7
[ 0.453038] intel_pstate: CPU model not supported
$ cat /sys/devices/system/cpu/cpu*/cpufreq/scaling_driver
acpi-cpufreq
$ uname -r
5.15.0-47-generic
$ grep -i pstate /boot/config-$(uname -r)
CONFIG_X86_INTEL_PSTATE=y
$ grep intel_pstate /boot/grub/grub.cfg
linux /vmlinuz-5.15.0-47-generic root=UUID=xxxxx ro intel_pstate=enable quiet splash $vt_handoff
$ cat /sys/devices/system/cpu/cpufreq/boost
1
$ ls /sys/devices/system/cpu/intel_pstate/
no such file or directory
$ cpufreq-info
..snip..
analyzing CPU 15:
driver: acpi-cpufreq
CPUs which run at the same hardware frequency: 15
CPUs which need to have their frequency coordinated by software: 15
maximum transition latency: 10.0 us.
hardware limits: 800 MHz - 2.30 GHz
available frequency steps: 2.30 GHz, 2.30 GHz, 2.20 GHz, 2.10 GHz, 2.00 GHz, 1.90 GHz, 1.80 GHz, 1.70 GHz, 1.50 GHz, 1.40 GHz, 1.30 GHz, 1.20 GHz, 1.10 GHz, 1000 MHz, 900 MHz, 800 MHz
available cpufreq governors: conservative, ondemand, userspace, powersave, performance, schedutil
current policy: frequency should be within 800 MHz and 2.30 GHz.
The governor "ondemand" may decide which speed to use
within this range.
current CPU frequency is 997 MHz.
cpufreq stats: 2.30 GHz:1,62%, 2.30 GHz:0,13%, 2.20 GHz:0,25%, 2.10 GHz:0,17%, 2.00 GHz:0,27%, 1.90 GHz:0,31%, 1.80 GHz:0,29%, 1.70 GHz:0,54%, 1.50 GHz:0,73%, 1.40 GHz:0,72%, 1.30 GHz:0,96%, 1.20 GHz:1,33%, 1.10 GHz:3,17%, 1000 MHz:6,38%, 900 MHz:18,62%, 800 MHz:64,50% (30660)
$ lscpu
..snip..
Model name: 11th Gen Intel(R) Core(TM) i7-11800H @ 2.30GHz
CPU family: 6
Model: 141
..snip..
Frequency boost: enabled
CPU max MHz: 2301,0000
CPU min MHz: 800,0000
BogoMIPS: 4608.00
Flags: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mc
a cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss
ht tm pbe syscall nx pdpe1gb rdtscp lm constant_tsc art
arch_perfmon pebs bts rep_good nopl xtopology nonstop_
tsc cpuid aperfmperf tsc_known_freq pni pclmulqdq dtes6
4 monitor ds_cpl vmx est tm2 ssse3 sdbg fma cx16 xtpr p
dcm pcid sse4_1 sse4_2 x2apic movbe popcnt tsc_deadline
_timer aes xsave avx f16c rdrand lahf_lm abm 3dnowprefe
tch cpuid_fault epb cat_l2 invpcid_single cdp_l2 ssbd i
brs ibpb stibp ibrs_enhanced tpr_shadow vnmi flexpriori
ty ept vpid ept_ad fsgsbase tsc_adjust bmi1 avx2 smep b
mi2 erms invpcid rdt_a avx512f avx512dq rdseed adx smap
avx512ifma clflushopt clwb intel_pt avx512cd sha_ni av
x512bw avx512vl xsaveopt xsavec xgetbv1 xsaves split_lo
ck_detect dtherm ida arat pln pts avx512vbmi umip pku o
spke avx512_vbmi2 gfni vaes vpclmulqdq avx512_vnni avx5
12_bitalg avx512_vpopcntdq rdpid movdiri movdir64b fsrm
avx512_vp2intersect md_clear flush_l1d arch_capabiliti
es
Além disso, quando procuro no Google o modelo de CPU e intel_pstate, posso ver algumas postagens no fórum com a mesma CPU e driver/governador (?) que intel_pstate, então provavelmente é compatível.
Eu queria saber quais etapas eu poderia seguir para solucionar ou corrigir esse problema? Obrigado!
ps meu dispositivo é um laptop
Responder1
Durante a inicialização você recebe a mensagem do kernel:
[ 0.453038] intel_pstate: CPU model not supported
Porque:
- O controle HWP (HardWare Pstate), também conhecido como Intel Speed Shift Technology (não deve ser confundido com Intel Speed Step), está desabilitado no BIOS.
- Parece haver um bug no código-fonte do driver de escalonamento de frequência da CPU intel_pstate que não permite o uso do driver com HWP desabilitado para a família Tiger Lake de processadores Intel e possivelmente outras famílias.
Para um teste de verificação em meu servidor de teste 20.04.4 com um Intel(R) Core(TM) i5-10600K CPU @ 4.10GHz
processador , ou Comet Lake, comentei a linha que inclui essa família no caminho sem código HWP:
doug@s19:~/kernel/linux$ git diff
diff --git a/drivers/cpufreq/intel_pstate.c b/drivers/cpufreq/intel_pstate.c
index 57cdb3679885..3cbc1abb9911 100644
--- a/drivers/cpufreq/intel_pstate.c
+++ b/drivers/cpufreq/intel_pstate.c
@@ -2414,7 +2414,7 @@ static const struct x86_cpu_id intel_pstate_cpu_ids[] = {
X86_MATCH(ATOM_GOLDMONT, core_funcs),
X86_MATCH(ATOM_GOLDMONT_PLUS, core_funcs),
X86_MATCH(SKYLAKE_X, core_funcs),
- X86_MATCH(COMETLAKE, core_funcs),
+/* X86_MATCH(COMETLAKE, core_funcs), */
X86_MATCH(ICELAKE_X, core_funcs),
{}
};
Para o kernel não modificado eu obtive:
- HWP definido como
auto
ouenabled
no BIOS resultou nointel_pstate
driver de escalonamento de frequência da CPU. - HWP definido
disabled
no BIOS resultou nointel_cpufreq
driver de escalonamento de frequência da CPU. (Observe que ointel_cpufreq
driver é apenas ointel_pstate
driver em modo passivo, que é o padrão agora quando o HWP não está disponível. Consulte tambémaqui.)
Para o kernel modificado eu obtive:
- HWP definido como
auto
ouenabled
no BIOS resultou nointel_pstate
driver de escalonamento de frequência da CPU. - HWP definido
disabled
no BIOS resultou noacpi_cpufreq
driver de escalonamento de frequência da CPU.
A lista de famílias de processadores para o ramo sem código HWP parece bastante incompleta. No caso desta questão o número do modelo é 141 ou 0X8D ou TIGERLAKE:
./arch/x86/include/asm/intel-family.h:#define INTEL_FAM6_TIGERLAKE 0x8D /* Willow Cove */
Portanto, o patch de código sugerido seria:
doug@s19:~/kernel/linux$ doug@s19:~/kernel/linux$ git diff
diff --git a/drivers/cpufreq/intel_pstate.c b/drivers/cpufreq/intel_pstate.c
index 57cdb3679885..fc3ebeb0bbe5 100644
--- a/drivers/cpufreq/intel_pstate.c
+++ b/drivers/cpufreq/intel_pstate.c
@@ -2416,6 +2416,7 @@ static const struct x86_cpu_id intel_pstate_cpu_ids[] = {
X86_MATCH(SKYLAKE_X, core_funcs),
X86_MATCH(COMETLAKE, core_funcs),
X86_MATCH(ICELAKE_X, core_funcs),
+ X86_MATCH(TIGERLAKE, core_funcs),
{}
};
MODULE_DEVICE_TABLE(x86cpu, intel_pstate_cpu_ids);
A propósito, o governador de escalonamento de frequência de CPU de desempenho está disponível para o governador de escalonamento de frequência de CPU acpi-cpufreq. Basta fazer isso:
echo performance | sudo tee /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor
E então verifique:
doug@s19:~/kernel/linux$ grep . /sys/devices/system/cpu/cpu*/cpufreq/scaling_governor
/sys/devices/system/cpu/cpu0/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu10/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu11/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu1/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu2/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu3/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu4/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu5/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu6/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu7/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu8/cpufreq/scaling_governor:performance
/sys/devices/system/cpu/cpu9/cpufreq/scaling_governor:performance