修改Linux内核的printk缓冲区(log缓冲区)大小
来源:互联网 发布:淘宝商家信用卡手续费 编辑:程序博客网 时间:2024/05/18 06:28
我们可以用printk打印kernel的日志信息(即log信息),根据时间戳可以判断内核新打印的log会覆盖掉以前打印的log。原因是内核用环形缓冲区存放打印的log信息。那么如何增大缓冲区的大小呢?
我们看kernel/printk.c的代码
- #define LOG_ALIGN __alignof__(struct printk_log)
- #define __LOG_BUF_LEN (1 << CONFIG_LOG_BUF_SHIFT)
- static char __log_buf[__LOG_BUF_LEN] __aligned(LOG_ALIGN);
- static char *log_buf = __log_buf;
- static u32 log_buf_len = __LOG_BUF_LEN;
正是__LOG_BUF_LEN这个宏设置了环形缓冲区的大小,那么__LOG_BUF_LEN的大小是多少呢?是由1 << CONFIG_LOG_BUF_SHIFT(即2的CONFIG_LOG_BUF_SHIFT次幂)来决定的,那么CONFIG_LOG_BUF_SHIFT这个配置项又是在哪里定义呢?
在init/Kconfig里定义
- config LOG_BUF_SHIFT
- int "Kernel log buffer size (16 => 64KB, 17 => 128KB)"
- range 12 21
- default 17
- depends on PRINTK
- help
- Select the minimal kernel log buffer size as a power of 2.
- The final size is affected by LOG_CPU_MAX_BUF_SHIFT config
- parameter, see below. Any higher size also might be forced
- by "log_buf_len" boot parameter.
- Examples:
- 17 => 128 KB
- 16 => 64 KB
- 15 => 32 KB
- 14 => 16 KB
- 13 => 8 KB
- 12 => 4 KB
可见CONFIG_LOG_BUF_SHIFT是一个内核配置项。它的大小可以配置为12~21,也就是说环形缓冲区的大小可以配置为4 KB - 2MB。内核(3.18内核)默认是17,即缓冲区的大小为2^17(131072)B。
所以要想增大或者减小环形缓冲区的大小,只需要在内核的配置文件里(对于arm架构为arch/arm/configs/xxx或者arch/arm64/configs/xxx)添加CONFIG_LOG_BUF_SHIFT=XX 即可修改环形缓冲区的大小。
阅读全文
0 0
- 修改Linux内核的printk缓冲区(log缓冲区)大小
- 修改Linux内核的printk缓冲区(log缓冲区)大小
- 修改Linux内核的printk缓冲区(log缓冲区)大小
- socket对应的内核缓冲区(发送,接收)的大小
- linux内核环形缓冲区
- linux设置套接字缓冲区的大小
- linux设置套接字缓冲区的大小
- linux设置套接字缓冲区的大小
- linux设置套接字缓冲区的大小
- 【Linux】tcp缓冲区大小的默认值、最大值
- 缓冲区大小的问题
- 获取缓冲区的大小
- 内核缓冲区的管理
- log缓冲区
- linux socket 缓冲区默认大小
- linux 默认socket 缓冲区大小
- linux socket 缓冲区默认大小
- linux socket 缓冲区默认大小
- PAT-L1-005. 考试座位号
- Vulkan
- Docker build errors
- Nodejs使用Express构建Web项目,使用html文件代替jade模板
- SurfaceView 和 GLSurfaceView
- 修改Linux内核的printk缓冲区(log缓冲区)大小
- xilinx小实验——vivado纯逻辑编程第一个demo
- SurfaceTexture
- TextureView
- 游戏循环
- [Python爬虫]Scrapy配合Selenium和PhantomJS爬取动态网页
- web安全学习笔记
- 新手上路系列11:网络编程基础知识与服务器搭建
- 疯狂Java笔记之常见java集合的实现细节