Jak znaleźć rozmiar pamięci podręcznej L2 w systemie Linux?

33

Chciałem wiedzieć, jak znaleźć rozmiar pamięci podręcznej L2 w systemie Linux ...

dla rozmiaru pamięci podręcznej L1 wykonuję następujące czynności

pico /proc/cpuinfo

co z wielkością pamięci podręcznej L2?

Ciro Santilli
źródło

Odpowiedzi:

29

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

lub sprawdź dmidecode

albo użyj lshw

Dakshina Dasari
źródło
27

EDYCJA 3 : Heh, przepraszam, po prostu zrób, sudo dmidecode -t cachea pokaże ci informacje o pamięci podręcznej twojego procesora. Aby powiedzieć, na którą sekcję patrzysz (L1 lub L2), spójrz na Configuration:linię. Chcesz Configuration: Enabled, Not Socketed, Level 2.

Jorge Israel Peña
źródło
17

Powinieneś sprawdzić następujące narzędzie . Podaje najdokładniejsze informacje ze wszystkich narzędzi, których wypróbowałem. Oto dane wyjściowe wersji wiersza poleceń:

~$ 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)

A to jest interfejs graficzny:wprowadź opis zdjęcia tutaj

zloster
źródło
9

Wystarczy użyć: lscpu

Przykładowe dane wyjściowe:

$ 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
użytkownik1846476
źródło
lscpunie jest dokładny na niektórych procesorach o egzotycznej konfiguracji. Na przykład procesor z mojej odpowiedzi podaje (pominięto niektóre informacje): Rodzina procesorów: 6 Model: 15 Stepowanie: 11 Procesor MHz: 1866.742 BogoMIPS: 3733.48 Wirtualizacja: Pamięć podręczna VT-x L1d: 32 KB Pamięć podręczna L1i: 32 KB Pamięć podręczna L2: 4096 KB Węzeł NUMA 0 Procesory: 0-3 Procesor to Xeon L5320 z 8 MB L2 łącznie.
zloster
5

getconf

getconf -a | grep CACHE

daje:

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

Lub dla jednego poziomu:

getconf LEVEL2_CACHE_SIZE

Fajną rzeczą w tym interfejsie jest to, że jest on tylko opakowaniem wokół funkcji POSIX sysconfC (argumenty pamięci podręcznej to rozszerzenia inne niż POSIX), więc można go również używać z kodu C.

Testowane w Ubuntu 16.04.

Instrukcja CPUID x86

Instrukcja CPUID x86 oferuje również informacje o pamięci podręcznej i może być bezpośrednio dostępna dla użytkownika: https://en.wikipedia.org/wiki/CPUID

glibc wydaje się używać tej metody dla x86. Nie potwierdziłem debugowania krokowego / śledzenia instrukcji, ale źródło 2.28 sysdeps/x86/cacheinfo.crobi to:

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

TODO stwórz minimalny przykład C, leniwy teraz, zadany na stronie : https://stackoverflow.com/questions/14283171/how-to-receive-l1-l2-l3-cache-size-using-cpuid-instruction-in-x86

ARM ma również zdefiniowany przez architekturę mechanizm znajdowania rozmiarów pamięci podręcznej przez rejestry, takie jak Rejestr ID rozmiaru pamięci podręcznej (CCSIDR), zobacz przegląd ARMv8 dla programistów 11.6 „ Wykrywanie pamięci podręcznej”.

Ciro Santilli
źródło
4

dmesg | grep cache pokaże informacje związane z L1 i L2.

quack quixote
źródło
Lub dmesg (lub dmesg.boot) i wyszukaj model procesora. Następnie google w tym.
Hennes,