Como encontrar o tamanho do cache L2 no Linux?

33

Eu queria saber como encontrar o tamanho do cache L2 no Linux ...

para o tamanho do cache L1, estou fazendo o seguinte

pico /proc/cpuinfo

e quanto ao tamanho do cache L2?

Ciro Santilli adicionou uma nova foto
fonte

Respostas:

29

cat /sys/devices/system/cpu/cpu0/cache/index2/size

ou cheque dmidecode

ou use lshw

Dakshina Dasari
fonte
27

EDIT 3 : Heh, desculpe, apenas faça sudo dmidecode -t cachee ele mostrará as informações de cache da sua CPU. Para saber em que seção você está olhando (L1 ou L2), observe a Configuration:linha. Você quer Configuration: Enabled, Not Socketed, Level 2.

Jorge Israel Peña
fonte
17

Você deve verificar a seguinte ferramenta . Ele fornece as informações mais precisas de todas as ferramentas que eu tentei. Esta é a saída da versão da linha de comandos:

~$ lstopo-no-graphics
Machine (7984MB)
  Socket L#0
    L2 L#0 (4096KB)
      L1d L#0 (32KB) + L1i L#0 (32KB) + Core L#0 + PU L#0 (P#0)
      L1d L#1 (32KB) + L1i L#1 (32KB) + Core L#1 + PU L#1 (P#1)
    L2 L#1 (4096KB)
      L1d L#2 (32KB) + L1i L#2 (32KB) + Core L#2 + PU L#2 (P#2)
      L1d L#3 (32KB) + L1i L#3 (32KB) + Core L#3 + PU L#3 (P#3)

E esta é a interface gráfica:insira a descrição da imagem aqui

zloster
fonte
9

Basta usar: lscpu

Saída de amostra:

$ lscpu 
Architecture:          x86_64
CPU op-mode(s):        32-bit, 64-bit
Byte Order:            Little Endian
CPU(s):                4
On-line CPU(s) list:   0-3
Thread(s) per core:    1
Core(s) per socket:    4
Socket(s):             1
NUMA node(s):          1
Vendor ID:             GenuineIntel
CPU family:            6
Model:                 42
Stepping:              7
CPU MHz:               3401.000
BogoMIPS:              6784.57
Virtualization:        VT-x
L1d cache:             32K
L1i cache:             32K
L2 cache:              256K
L3 cache:              8192K
NUMA node0 CPU(s):     0-3
user1846476
fonte
lscpunão é preciso em algumas CPUs com configuração exótica. Por exemplo, a CPU da minha resposta fornece o seguinte (omitiu algumas informações): Família de CPUs: 6 Modelo: 15 Etapa: 11 CPU MHz: 1866.742 BogoMIPS: 3733.48 Virtualização: VT-x L1d cache: 32K L1i cache: 32K L2 cache: 32K L2 cache: 4096K NUMA node0 CPU (s): 0-3 A CPU é Xeon L5320 com 8 MB L2 total.
Zloster
5

getconf

getconf -a | grep CACHE

dá:

LEVEL1_ICACHE_SIZE                 32768
LEVEL1_ICACHE_ASSOC                8
LEVEL1_ICACHE_LINESIZE             64
LEVEL1_DCACHE_SIZE                 32768
LEVEL1_DCACHE_ASSOC                8
LEVEL1_DCACHE_LINESIZE             64
LEVEL2_CACHE_SIZE                  262144
LEVEL2_CACHE_ASSOC                 8
LEVEL2_CACHE_LINESIZE              64
LEVEL3_CACHE_SIZE                  20971520
LEVEL3_CACHE_ASSOC                 20
LEVEL3_CACHE_LINESIZE              64
LEVEL4_CACHE_SIZE                  0
LEVEL4_CACHE_ASSOC                 0
LEVEL4_CACHE_LINESIZE              0

Ou para um único nível:

getconf LEVEL2_CACHE_SIZE

O legal dessa interface é que ela é apenas um invólucro em torno do POSIX sysconf função C (argumentos de cache são extensões não POSIX) e, portanto, pode ser usada também a partir do código C.

Testado no Ubuntu 16.04.

instrução CPUID x86

A instrução CPUID x86 também oferece informações de cache e pode ser acessada diretamente pelo usuário: https://en.wikipedia.org/wiki/CPUID

O glibc parece usar esse método para x86. Não confirmei pela etapa depuração / rastreamento de instruções, mas a fonte do 2.28 sysdeps/x86/cacheinfo.cfaz isso:

__cpuid (2, eax, ebx, ecx, edx);

TODO criar um exemplo C mínimo, preguiçoso agora, perguntou em: https://stackoverflow.com/questions/14283171/how-to-receive-l1-l2-l3-cache-size-using-cpuid-instruction-in-x86

O ARM também possui um mecanismo definido pela arquitetura para encontrar tamanhos de cache por meio de registradores como o CCSIDR (Registro de ID de Tamanho de Cache); consulte o Manual do Programador do ARMv8 11.6 "Descoberta de cache" para obter uma visão geral.

Ciro Santilli adicionou uma nova foto
fonte
4

dmesg | grep cache mostrará suas informações relacionadas a L1 e L2.

charlatão quixote
fonte
Ou dmesg (ou dmesg.boot) e procure o modelo da CPU. Então pesquise no google.
Hennes