如何在 Linux 中找到 L2 缓存大小?

38 linux unix debian

我想知道如何在 Linux 中找到 L2 缓存大小...

对于 L1 缓存大小,我正在执行以下操作

pico /proc/cpuinfo
Run Code Online (Sandbox Code Playgroud)

L2缓存大小呢?

小智 31

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

或检查 dmidecode

或使用 lshw


Jor*_*eña 28

编辑 3:嘿,抱歉,只是这样做sudo dmidecode -t cache,它会向您显示您的 CPU 的缓存信息。要知道您正在查看哪个部分(L1 或 L2),请查看该Configuration:行。你要Configuration: Enabled, Not Socketed, Level 2


小智 19

您应该检查以下工具。它提供了我尝试过的所有工具中最准确的信息。这是命令行版本输出:

~$ 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)
Run Code Online (Sandbox Code Playgroud)

这是图形界面:在此处输入图片说明


小智 14

只需使用: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
Run Code Online (Sandbox Code Playgroud)


Cir*_*郝海东 8

getconf

getconf -a | grep CACHE
Run Code Online (Sandbox Code Playgroud)

给出:

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
Run Code Online (Sandbox Code Playgroud)

或者对于单个级别:

getconf LEVEL2_CACHE_SIZE
Run Code Online (Sandbox Code Playgroud)

这个接口很酷的一点是它只是 POSIX sysconfC 函数的一个包装器(缓存参数是非 POSIX 扩展),因此它也可以从 C 代码中使用。

在 Ubuntu 16.04 中测试。

x86 CPUID 指令

CPUID x86 指令还提供缓存信息,用户可以直接访问:https : //en.wikipedia.org/wiki/CPUID

glibc 似乎对 x86 使用该方法。我还没有通过逐步调试/指令跟踪来确认,但 2.28 的源代码是sysdeps/x86/cacheinfo.c这样做的:

__cpuid (2, eax, ebx, ecx, edx);
Run Code Online (Sandbox Code Playgroud)

TODO 创建一个最小的 C 示例,现在懒惰,在:https : //stackoverflow.com/questions/14283171/how-to-receive-l1-l2-l3-cache-size-using-cpuid-instruction-in-x86

ARM 还具有架构定义的机制,可通过缓存大小 ID 寄存器 (CCSIDR) 等寄存器查找缓存大小,有关概述,请参阅ARMv8 程序员手册11.6“缓存发现”。