日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

修改Linux内核的printk缓冲区(log缓冲区)大小

發(fā)布時(shí)間:2025/4/16 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 修改Linux内核的printk缓冲区(log缓冲区)大小 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

點(diǎn)擊打開鏈接

我們可以用printk打印kernel的日志信息(即log信息),根據(jù)時(shí)間戳可以判斷內(nèi)核新打印的log會(huì)覆蓋掉以前打印的log。原因是內(nèi)核用環(huán)形緩沖區(qū)存放打印的log信息。那么如何增大緩沖區(qū)的大小呢? 我們看kernel/printk.c的代碼

[cpp]?view plaincopy
  • <span?style="font-family:?Arial,?Helvetica,?sans-serif;">/*?record?buffer?*/</span>??
  • [cpp]?view plaincopy
  • #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這個(gè)宏設(shè)置了環(huán)形緩沖區(qū)的大小,那么__LOG_BUF_LEN的大小是多少呢?是由1 << CONFIG_LOG_BUF_SHIFT(即2的CONFIG_LOG_BUF_SHIFT次冪)來(lái)決定的,那么CONFIG_LOG_BUF_SHIFT這個(gè)配置項(xiàng)又是在哪里定義呢?

    在init/Kconfig里定義

    [cpp]?view plaincopy
  • 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是一個(gè)內(nèi)核配置項(xiàng)。它的大小可以配置為12~21,也就是說(shuō)環(huán)形緩沖區(qū)的大小可以配置為4 KB - 2MB。內(nèi)核(3.18內(nèi)核)默認(rèn)是17,即緩沖區(qū)的大小為2^17(131072)B。

    ? ? ? 所以要想增大或者減小環(huán)形緩沖區(qū)的大小,只需要在內(nèi)核的配置文件里(對(duì)于arm架構(gòu)為arch/arm/configs/xxx或者arch/arm64/configs/xxx)添加CONFIG_LOG_BUF_SHIFT=XX 即可修改環(huán)形緩沖區(qū)的大小。


    總結(jié)

    以上是生活随笔為你收集整理的修改Linux内核的printk缓冲区(log缓冲区)大小的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。