linux使用cpu缓存,解决方案:如何在Linux中获取CPU缓存的大小

对于运行Linux的ARM CPU(在具有Raspbian(32位)的Raspberry Pi 3B +上测试):

“Arm®Cortex®-A53MPCore处理器技术参考手册”中的章节是“高速缓存大小选择寄存器”和“高速缓存大小ID”注册,其中包括汇编程序指令。

94c9f4b7f85c4231f49d22e455461460.png

这些汇编程序指令已经可以在Linux内核头文件asm / cachetype.h中使用:set_csselr(...)和read_ccsidr(),但是无法在用户模式下调用这些函数,因此我们需要构建内核模块获取/打印值:

f84d6ca94f21d85de392f3fd6a71bbfa.png

Makefile:

e395d1b7870ce51a7860a1732dc021d7.png

obj-m += cachesize.o

all:

make -C /lib/modules/$(shell uname -r)/build M=$(PWD) modules

clean:

make -C /lib/modules/$(shell uname -r)/build M=$(PWD) clean

d65f24f5ee39b280ba1804d9072f833a.png

文件cachesize.c:

40a2c443033f618e7a4a10d0949dd208.png

#include #include #include #include MODULE_LICENSE("GPL");

MODULE_AUTHOR("Abc defg");

MODULE_DESCRIPTION("Find out ARM cache sizes");

MODULE_VERSION("0.01");

static int __init lkm_example_init(void) {

// Must run in kernel mode

// Assumptions: L1 (instructions + data), L2 (check your CPU manual)

set_csselr(0);

printk(KERN_INFO "ccsidr L1 data cache = x\n", read_ccsidr());

set_csselr(1);

printk(KERN_INFO "ccsidr L1 instruction cache = x\n", read_ccsidr());

set_csselr(2);

printk(KERN_INFO "ccsidr L2 unified = x\n", read_ccsidr());

return 0;

}

static void __exit lkm_example_exit(void) {

printk(KERN_INFO "Goodbye, World!\n");

}

module_init(lkm_example_init);

module_exit(lkm_example_exit);

然后:

make

insmode cachesize.ko

rmmod cachesize

dmesg | tail

# Compare numbers to the table "CCSIDR encodings" in the "ARM ... Technical Reference Manual"

本文来自电脑杂谈,转载请注明本文网址:

http://www.pc-fly.com/a/shoujiruanjian/article-344510-1.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值