Existe alguma maneira de saber o tamanho do cache L1, L2, L3 e RAM no ubuntu?


Respostas:


12

Informações da CPU

Use o comando lscpu :

$ lscpu
Architecture:          x86_64
CPU op-mode(s):        32-bit, 64-bit
Byte Order:            Little Endian
CPU(s):                2
On-line CPU(s) list:   0,1
Thread(s) per core:    1
Core(s) per socket:    2
Socket(s):             1
NUMA node(s):          1
Vendor ID:             GenuineIntel
CPU family:            15
Model:                 6
Stepping:              5
CPU MHz:               2400.000
BogoMIPS:              6000.33
L1d cache:             16K
L2 cache:              2048K
NUMA node0 CPU(s):     0,1

As informações listadas são por núcleo da CPU.

Informação da memória

Existe o comando livre (-h fornece resultados em forma legível por humanos, ou seja, GiB em vez de bytes):

$ free -h
             total       used       free     shared    buffers     cached
Mem:          2.0G       390M       1.6G        10M        15M       160M
-/+ buffers/cache:       215M       1.7G
Swap:         2.0G         0B       2.0G

3

Isso fornecerá suas informações de cache. A designação de soquete informará a qual cache está sendo referido na seção.

sudo dmidecode -t cache

Para a RAM, há algumas coisas a serem observadas, mas o meminfo deve fazê-lo. Eu usei grep aqui para mostrar apenas total / gratuito, mas você poderia usar menos ou gato para ver a coisa toda. Ele mostra muito mais informações sobre tamanho e uso da memória do que apenas tamanho.

grep Mem /proc/meminfo

1

Com base nos jkabrams, responda com o seguinte comando e filtrando "cache" a partir dele, cada item de cache que você mostra.

lscpu | grep cache

e RAM:

free -h

Para obter mais informações sobre RAM, processos e outros, você pode usar o htop na sua distribuição. Instale-o assim no ubuntu.

sudo apt-get install htop

0

sysfs

for d in /sys/devices/system/cpu/cpu0/cache/index*;
  do tail -c+1 $d/{level,type,size}
  echo
done

Dá:

==> /sys/devices/system/cpu/cpu0/cache/index0/level <==
1

==> /sys/devices/system/cpu/cpu0/cache/index0/type <==
Data

==> /sys/devices/system/cpu/cpu0/cache/index0/size <==
32K

==> /sys/devices/system/cpu/cpu0/cache/index1/level <==
1

==> /sys/devices/system/cpu/cpu0/cache/index1/type <==
Instruction

==> /sys/devices/system/cpu/cpu0/cache/index1/size <==
32K

==> /sys/devices/system/cpu/cpu0/cache/index2/level <==
2

==> /sys/devices/system/cpu/cpu0/cache/index2/type <==
Unified

==> /sys/devices/system/cpu/cpu0/cache/index2/size <==
256K

==> /sys/devices/system/cpu/cpu0/cache/index3/level <==
3

==> /sys/devices/system/cpu/cpu0/cache/index3/type <==
Unified

==> /sys/devices/system/cpu/cpu0/cache/index3/size <==
8192K

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 da sysconffunção POSIX 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 da 2.28 sysdeps/x86/cacheinfo.cfaz isso:

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

TODO crie um exemplo C mínimo, preguiçoso agora, solicitado em: /programming/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.

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.