Esiste un modo per conoscere le dimensioni di cache L1, L2, L3 e RAM in Ubuntu?


Risposte:


12

Informazioni sulla CPU

Usa il 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

Le informazioni elencate sono per core della CPU.

Informazioni sulla memoria

C'è il comando gratuito (-h fornisce risultati in forma leggibile dall'uomo, ovvero GiB anziché byte):

$ 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

Questo ti darà le informazioni sulla tua cache. Socket Designation ti dirà a quale cache viene fatto riferimento nella sezione.

sudo dmidecode -t cache

Per la RAM ci sono un paio di cose da guardare, ma meminfo dovrebbe farlo. Ho usato grep qui per mostrare solo totale / libero, ma potresti usare less o cat per vedere tutto. Mostra molte più informazioni sulla dimensione e sull'utilizzo della memoria rispetto alla sola dimensione.

grep Mem /proc/meminfo

1

Basato sulla risposta di jkabrams con il seguente comando e il filtro "cache" da esso, ogni elemento cache che ti è stato mostrato.

lscpu | grep cache

e RAM:

free -h

Per ulteriori informazioni su RAM, processi e così via, puoi usare htop sulla tua distribuzione. Installalo così su 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

O per un singolo livello:

getconf LEVEL2_CACHE_SIZE

La cosa interessante di questa interfaccia è che è solo un wrapper per la sysconffunzione POSIX C (gli argomenti della cache sono estensioni non POSIX) e quindi può essere utilizzato anche dal codice C.

Testato in Ubuntu 16.04.

istruzione CPUID x86

L'istruzione CPUID x86 offre anche informazioni sulla cache e può essere letta direttamente dall'utenteland: https://en.wikipedia.org/wiki/CPUID

sembra che glibc usi quel metodo per x86. Non ho confermato dal debugging / traccia delle istruzioni, ma il sorgente per 2.28 lo sysdeps/x86/cacheinfo.cfa:

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

TODO crea un esempio C minimo, pigro ora, richiesto a: /programming/14283171/how-to-receive-l1-l2-l3-cache-size-using-cpuid-instruction-in-x86

ARM ha anche un meccanismo definito dall'architettura per trovare le dimensioni della cache attraverso registri come il registro ID dimensioni cache (CCSIDR), vedere il Manuale dei programmatori ARMv8 11.6 " Rilevamento della cache" per una panoramica.

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.