Я хотел знать, как найти размер кэша L2 в Linux ...
для размера кэша L1 я делаю следующее
pico /proc/cpuinfo
как насчет размера кеша L2?
cat /sys/devices/system/cpu/cpu0/cache/index2/size
или проверьте dmidecode
или используйте lshw
РЕДАКТИРОВАТЬ 3: Хех, извините, просто выполните sudo dmidecode -t cache и он покажет вам информацию о кеше вашего процессора. Чтобы узнать, на какой раздел вы смотрите (L1 или L2), посмотрите строку Configuration: . Требуется Configuration: Enabled, Not Socketed, Level 2 .
Вы должны проверить следующий инструмент. Это дает наиболее точную информацию из всех инструментов, которые я пробовал. Это вывод версии командной строки:
~$ 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)
И это графический интерфейс:
Просто используйте: lscpu
Образец вывода:
$ 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
dmesg | grep cache покажет информацию о L1 и L2. 
getconf
getconf -a | grep CACHE
дает:
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
Или для одного уровня:
getconf LEVEL2_CACHE_SIZE
Крутая вещь в этом интерфейсе состоит в том, что он является просто оболочкой для функции C POSIX sysconf (аргументы кэша не являются расширениями POSIX), и поэтому его можно использовать и из кода C.
Проверено в Ubuntu 16.04.
инструкция CPUID x86
Инструкция CPUID x86 также предлагает информацию о кеше, и доступ к ней может быть получен непосредственно пользователем: https://en.wikipedia.org/wiki/CPUID
Glibc, похоже, использует этот метод для x86. Я не подтвердил пошаговую отладку / трассировку инструкций, но источник для 2.28 sysdeps/x86/cacheinfo.c делает это:
__cpuid (2, eax, ebx, ecx, edx);
TODO создать минимальный пример C, ленивый сейчас, по адресу: https://stackoverflow.com/questions/14283171/how-to-receive-l1-l2-l3-cache-size-using-cpuid-instruction-in-x86
В ARM также есть механизм, определяемый архитектурой для определения размеров кэша через регистры, такие как регистр идентификатора размера кэша (CCSIDR), см. Руководство для программистов ARMv8 11.6 "Обнаружение кэша".