O que significa “nível cpuid”?

5

Por exemplo, eu coloquei apenas a saída de um núcleo de uma máquina de 16 núcleos.

O que significa a saída por "nível cpuid" de "6"? Além disso, o que "bogomips" de "5992.10" e "clflush size" de "64" significam?

processor    :    0
vendor_id    :    GenuineIntel
cpu family   :    15
model        :    6
model name   :    Intel(R) Xeon(TM) CPU 3.00GHz
stepping     :    8
cpu MHz      :    2992.689
cache size   :    4096 KB
physical id  :    0
siblings     :    4
core id      :    0
cpu cores    :    2
fpu          :    yes
fpu_exception:    yes
cpuid level  :    6
wp           :    yes
flags        :    fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge 
                  mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 
                  ss ht tm syscall nx lm constant_tsc pni monitor ds_cpl 
                  vmx cid cx16 xtpr lahf_lm
bogomips     :    5992.10
clflush size :    64
cache_alignment:  128
address sizes:    40 bits physical, 48 bits virtual
power management:
    
por user35153 24.04.2010 / 15:28

2 respostas

3

a maioria das informações exibidas é obtida da instrução x86 'cpuid'. O 'nível' é o conjunto de opções máximo que você pode usar com segurança para interrogar o processador para obter informações.

A nota de aplicativo da Intel no link contém muitos detalhes sobre as instruções. Eu acredito que o 'nível' equivale à 'função' listada no documento.

    
por 24.04.2010 / 15:52
1

bogomips é baseado na velocidade de um conjunto muito específico de instruções em um loop, o kernel usa o valor para alguns loops de tempo. É praticamente sem sentido fora deste contexto - alguns incorretamente pensam que é uma medida da velocidade da CPU (que é neste contexto muito específico, mas não em geral).

clfush na lista de recursos refere-se à disponibilidade do recurso de liberação da linha de cache, uma instrução para informar ao cache da CPU que um determinado bloco de dados não é mais necessário ou talvez não seja mais válido (portanto, ler de outro lugar, se necessário). Eu estou supondo que o tamanho especificado em clflush size seria a granularidade com a qual esse processo pode ser controlado - ou seja, o menor bloco que pode ser liberado (provavelmente relacionado diretamente à largura da linha dos caches L1 da CPU). Isso também provavelmente não é uma coisa útil para saber, a menos que você seja um engenheiro de CPU ou tente depurar algo em um nível muito baixo.

    
por 24.04.2010 / 16:32