我想知道如何在Linux中找到二级缓存的大小...
对于L1缓存大小,我正在执行以下操作
pico /proc/cpuinfo
L2缓存大小如何?
我想知道如何在Linux中找到二级缓存的大小...
对于L1缓存大小,我正在执行以下操作
pico /proc/cpuinfo
L2缓存大小如何?
Answers:
cat /sys/devices/system/cpu/cpu0/cache/index2/size
或检查 dmidecode
或使用 lshw
编辑3:嘿,对不起,请这样做sudo dmidecode -t cache
,它将显示您的CPU缓存信息。要告诉您要查看的是哪一部分(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
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
这个接口的优点是,它只是POSIX sysconf
C函数的包装(缓存参数是非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);
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“缓存发现”。
lscpu
在具有奇异配置的某些CPU上不准确。例如,我回答中的CPU 提供了以下信息(省略了一些信息):CPU系列:6型号:15步进:11 CPU MHz:1866.742 BogoMIPS:3733.48虚拟化:VT-x L1d高速缓存:32K L1i高速缓存:32K L2高速缓存:4096K NUMA node0 CPU:0-3 CPU是Xeon L5320,总共8MB L2。