Там какой-либо путь состоит в том, чтобы знать размер L1, L2, кэша L3 и RAM в Linux?

Для нахождения системного типа Unix имя хоста, версия ядра, и т.д. выполняет эту команду:

uname -a
22
28.09.2016, 23:08
5 ответов

, Если вы имеете установленный lshw:

$ sudo lshw -C memory

Пример

$ sudo lshw -C memory
...
  *-cache:0
       description: L1 cache
       physical id: a
       slot: Internal L1 Cache
       size: 32KiB
       capacity: 32KiB
       capabilities: asynchronous internal write-through data
  *-cache:1
       description: L2 cache
       physical id: b
       slot: Internal L2 Cache
       size: 256KiB
       capacity: 256KiB
       capabilities: burst internal write-through unified
  *-cache:2
       description: L3 cache
       physical id: c
       slot: Internal L3 Cache
       size: 3MiB
       capacity: 8MiB
       capabilities: burst internal write-back
  *-memory
       description: System Memory
       physical id: 2a
       slot: System board or motherboard
       size: 8GiB
     *-bank:0
          description: SODIMM DDR3 Synchronous 1334 MHz (0.7 ns)
          product: M471B5273CH0-CH9
          vendor: Samsung
          physical id: 0
          serial: 67010644
          slot: DIMM 1
          size: 4GiB
          width: 64 bits
          clock: 1334MHz (0.7ns)
     *-bank:1
          description: SODIMM DDR3 Synchronous 1334 MHz (0.7 ns)
          product: 16JTF51264HZ-1G4H1
          vendor: Micron Technology
          physical id: 1
          serial: 3749C127
          slot: DIMM 2
          size: 4GiB
          width: 64 bits
          clock: 1334MHz (0.7ns)
24
27.01.2020, 19:42

Вы можете попробовать эту команду.

$sudo dmidecode -t cache

Пример

$ sudo dmidecode -t cache | grep -iE "leve|installed"
    Configuration: Enabled, Socketed, Level 1
    Installed Size: 32 kB
    Installed SRAM Type: Asynchronous
    Configuration: Enabled, Socketed, Level 2
    Installed Size: 256 kB
    Installed SRAM Type: Burst
    Configuration: Enabled, Socketed, Level 3
    Installed Size: 3072 kB
    Installed SRAM Type: Burst

Чтобы увидеть ОЗУ просто добавить дополнительный выключатель -T-MEMORY .

$ sudo dmidecode -t cache -t memory

Ссылки

3
27.01.2020, 19:42

LSCPU

Если вы заботитесь только о размерах, попробуйте LSCPU из Util-Linux .

Пример

$ 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:    2
Core(s) per socket:    2
Socket(s):             1
NUMA node(s):          1
Vendor ID:             GenuineIntel
CPU family:            6
Model:                 37
Model name:            Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz
Stepping:              5
CPU MHz:               1199.000
BogoMIPS:              5319.88
Virtualization:        VT-x
L1d cache:             32K
L1i cache:             32K
L2 cache:              256K
L3 cache:              3072K
NUMA node0 CPU(s):     0-3

X86INFO

Также должно быть пакет / команда, называемая x86info. Предполагая, что у вас есть I386 / X86_64, X86INFO -C должен обеспечить более подробную информацию о кешах.

Пример

$ x86info -c
x86info v1.30.  Dave Jones 2001-2011
Feedback to <davej@redhat.com>.

Found 4 identical CPUs
Extended Family: 0 Extended Model: 2 Family: 6 Model: 37 Stepping: 5
Type: 0 (Original OEM)
CPU Model (x86info's best guess): Core i7 (Nehalem) [Clarkdale/Arrandale]
Processor name string (BIOS programmed): Intel(R) Core(TM) i5 CPU       M 560  @ 2.67GHz

Cache info
 L1 Instruction cache: 32KB, 4-way associative. 64 byte line size.
 L1 Data cache: 32KB, 8-way associative. 64 byte line size.
 L2 (MLC): 256KB, 8-way associative. 64 byte line size.
TLB info
 Instruction TLB: 2MB or 4MB pages, fully associative, 7 entries
 Instruction TLB: 4K pages, 4-way associative, 64 entries.
 Data TLB: 4KB or 4MB pages, fully associative, 32 entries.
 Data TLB: 4KB pages, 4-way associative, 64 entries
 Data TLB: 4K pages, 4-way associative, 512 entries.
 Data TLB: 4KB or 4MB pages, fully associative, 32 entries.
 Data TLB: 4KB pages, 4-way associative, 64 entries
 64 byte prefetching.
 Data TLB: 4K pages, 4-way associative, 512 entries.
Found unknown cache descriptors: dd 
Total processor threads: 4
This system has 1 dual-core processor with hyper-threading (2 threads per core) running at an estimated 2.65GHz
19
27.01.2020, 19:42

cpuid

Другой вариант - программа cpuid . Он использует инструкции CPUID и не требует root. Он также может работать через cpuid модуль ядра Linux.

cache and TLB information (2):
   0x59: data TLB: 4K pages, 16 entries
   0xba: data TLB: 4K pages, 4-way, 64 entries
   0x4f: instruction TLB: 4K pages, 32 entries
   0xc0: data TLB: 4K & 4M pages, 4-way, 8 entries
   0x80: L2 cache: 512K, 8-way, 64 byte lines
   0x30: L1 cache: 32K, 8-way, 64 byte lines
   0x0e: L1 data cache: 24K, 6-way, 64 byte lines

Обратите внимание, что на обычных потребительских ЦП кэш L1 и L2 используется для каждого ядра, а кэш L3 используется всеми ядрами.

2
27.01.2020, 19:42

getconf

getconf -a | grep CACHE

da:

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 para un solo nivel:

getconf LEVEL2_CACHE_SIZE

Lo bueno de esta interfaz es que es solo un envoltorio alrededor de los argumentos de caché de la función POSIX sysconfC (que no son -extensiones POSIX ), por lo que se puede usar desde el código C como bien:

long l2 = sysconf(_SC_LEVEL2_CACHE_SIZE);

Probado en Ubuntu 16.04.

instrucción CPUID x86

La instrucción CPUID x86 también ofrece información de caché, y el usuario puede acceder directamente a ella:https://en.wikipedia.org/wiki/CPUID

glibc parece usar ese método para x86. No lo he confirmado mediante la depuración por pasos/seguimiento de instrucciones, pero la fuente para 2.28sysdeps/x86/cacheinfo.clo hace:

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

TODO crear un ejemplo de C mínimo, perezoso ahora, preguntado en:https://stackoverflow.com/questions/14283171/how-to-receive-l1-l2-l3-cache-size-using-cpuid-instruction-in-x86

ARM también tiene una arquitectura -mecanismo definido para encontrar tamaños de caché a través de registros como el Registro de ID de tamaño de caché (CCSIDR ), consulte el Manual de programadores de ARMv8 11.6 "Descubrimiento de caché " para una descripción general.

Tamaño de memoria

Algunos métodos:

free
cat /proc/meminfo
sysinfo()

bibliografía:

10
27.01.2020, 19:42

Теги

Похожие вопросы