Como visualizo o tamanho do cache da minha CPU usando a linha de comando?
Quero ver informações sobre o cache L1, L2 e L3.
Além disso, seria possível enviar apenas informações no cache, para que todas as outras informações sejam filtradas?
Como visualizo o tamanho do cache da minha CPU usando a linha de comando?
Quero ver informações sobre o cache L1, L2 e L3.
Além disso, seria possível enviar apenas informações no cache, para que todas as outras informações sejam filtradas?
Respostas:
lscpu
fornecerá as informações que você está procurando.
lscpu | grep "cache"
para filtrar apenas informações de cache. Isso resultará em algo como:
L1d cache: 32K
L1i cache: 32K
L2 cache: 256K
L3 cache: 3072K
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 interessante dessa interface é que ela é apenas um invólucro da sysconf
funçã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.c
faz isso:
__cpuid (2, eax, ebx, ecx, edx);
O TODO cria 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 registros 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.