通过命令行查看 CPU 缓存的大小?

Tel*_*Why 13 command-line cache cpu system-info cpuinfo

如何使用命令行查看 CPU 缓存的大小?

我想查看有关 L1、L2 和 L3 缓存的信息。

另外,是否可以输出有关缓存的信息,以便过滤掉所有其他信息?

小智 15

lscpu 将提供您正在寻找的信息。

lscpu | grep "cache"仅过滤掉缓存信息。这将导致类似:

L1d cache:             32K
L1i cache:             32K
L2 cache:              256K
L3 cache:              3072K
Run Code Online (Sandbox Code Playgroud)


Cir*_*郝海东 5

系统文件系统

for d in /sys/devices/system/cpu/cpu0/cache/index*;
  do tail -c+1 $d/{level,type,size}
  echo
done
Run Code Online (Sandbox Code Playgroud)

给出:

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

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 C 函数的包装器sysconf(缓存参数是非 POSIX 扩展),因此它也可以在 C 代码中使用:

long l2 = sysconf(_SC_LEVEL2_CACHE_SIZE);
Run Code Online (Sandbox Code Playgroud)

在 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 示例,现在很懒,询问于:/sf/ask/999822001/

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