ฉันอยากรู้วิธีหาขนาดแคช L2 ใน Linux ...
สำหรับขนาดแคช L1 ฉันกำลังทำสิ่งต่อไปนี้
pico /proc/cpuinfo
ขนาดแคช L2 มีขนาดเท่าใด?
ฉันอยากรู้วิธีหาขนาดแคช L2 ใน Linux ...
สำหรับขนาดแคช L1 ฉันกำลังทำสิ่งต่อไปนี้
pico /proc/cpuinfo
ขนาดแคช L2 มีขนาดเท่าใด?
คำตอบ:
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
สิ่งที่ยอดเยี่ยมเกี่ยวกับอินเทอร์เฟซนี้ก็คือมันเป็นเพียง wrapper รอบsysconf
ฟังก์ชั่นPOSIX C (อาร์กิวเมนต์แคชเป็นส่วนขยายที่ไม่ใช่ POSIX) และดังนั้นจึงสามารถใช้จากรหัส C เช่นกัน
ผ่านการทดสอบใน Ubuntu 16.04
คำสั่ง CPU86 x
คำสั่ง CPUID x86 ยังให้ข้อมูลแคชและสามารถเข้าถึงได้โดยตรงโดย userland: https://en.wikipedia.org/wiki/CPUID
glibc ดูเหมือนว่าจะใช้วิธีการนั้นสำหรับ x86 ฉันยังไม่ได้รับการยืนยันโดยการดีบักขั้นตอน / การติดตามการเรียนการสอน แต่แหล่งที่มาสำหรับ 2.28 sysdeps/x86/cacheinfo.c
ทำอย่างนั้น:
__cpuid (2, eax, ebx, ecx, edx);
สิ่งที่ต้องทำสร้างตัวอย่าง C น้อยที่สุดขี้เกียจตอนนี้ถามได้ที่: https://stackoverflow.com/questions/14283171/how-to-receive-l1-l2-l3-c3-cache-size-using-cpuid-instruction-in-x86
ARM ยังมีกลไกที่กำหนดสถาปัตยกรรมเพื่อค้นหาขนาดแคชผ่านรีจิสเตอร์เช่น Cache Size ID Register (CCSIDR) ดูคู่มือARMv8 โปรแกรมเมอร์ 11.6 "การค้นพบแคช" สำหรับภาพรวม
dmesg | grep cache
จะแสดงข้อมูลที่เกี่ยวข้องกับ L1 และ L2 ของคุณ
lscpu
ไม่แม่นยำใน CPU บางตัวที่มีการกำหนดค่าแปลกใหม่ ตัวอย่างเช่น CPU จากคำตอบของฉันให้ข้อมูลต่อไปนี้ (ละเว้นข้อมูลบางส่วน): ตระกูล CPU: 6 รุ่น: 15 ก้าว: 11 CPU MHz: 1866.742 BogoMIPS: 3733.48 การจำลองเสมือน: แคช VT-x L1d: แคช 32K L1i: 32K L2i: 40K NUMA node0 CPU: 0-3 CPU คือXeon L5320 ที่มีทั้งหมด8MB L2