热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linux内核dmesg,linux內核調試kmsg,dmesg

dmesg為我們多用,mandmesg告知dmesg用來顯示和管理kernelringbuffer,那麼後者為何物,以及dmesg顯示何類

dmesg為我們多用,man dmesg告知dmesg用來顯示和管理kernel ring buffer,那麼後者為何物,以及dmesg顯示何類信息,是本文待闡述的內容。

documentation/trace/ring-buffer-design.txt包含了詳細的設計方案(看來documentation下的內容應是後續查找tutor的首選), 其中細節不是目前所需,但看起來卻是是設計無鎖(lockless)日誌系統的絕佳參考資料。

ring buffer(rb)和kernel ring buffer(krb)是不同的東西,前者泛指一類buffer設計方案,後者特指Linux內核使用的ring buffer。

rb有兩種模式:

1、producer/consumer模式:如果生產的太多,沒有來得及消費,「倉庫」佔滿了,那麼就暫停生產--這種模式可能會丟失最近的事件記錄。

2、overwrite模式:生產者填滿「倉庫」的時候,它仍然繼續生產,並覆蓋最舊的事件記錄--這種模式可能會丟失最舊的事件記錄。

kernel日誌(如printk的數據)視情況發往不同的地方:

- 如果klogd和syslogd都在運行,kernel messages被寫到/var/log/messages的末尾(或者syslogd配置給定的地方),此時和級別無關,所有級別日誌信息都寫入。

- 如果klogd沒有運行,消息不會發往用戶空間(不會寫messages文件?),除非顯式讀取/proc/kmsg(一般通過kmsg)。

讀取krb的首選方案是dmesg,dmesg其實是通過系統調用syslog去讀取的。

1./proc/kmsg

在程序開發過程中,LOG是廣泛使用的用來記錄程序執行過程的機制,它既可以用於程序調試,也可以用於產品運營中的事件記錄。在Android系統中,提供了簡單、便利的LOG機制,開發人員可以方便地使用。在這一篇文章中,我們簡單介紹在Android驅動LOG的使用和查看方法。

Android內核是基於Linux Kerne 2.36的,因此,Linux Kernel的LOG機制同樣適合於Android內核,它就是有名的printk,與C語言的printf齊名。與printf類似,printk提供格式化輸入功能,同時,它也具有所有LOG機制的特點--提供日誌級別過慮功能。

printk()有一個控制日誌級別的字段,如果該字段的日記級別高於console默認的日誌級別那麼才會打印出來(數值越小日誌級別越高,分為從 0-7共計8個日誌級別)。

printk提供了8種日誌級別():

#define KERN_EMERG  "<0>"

#define KERN_ALERT  "<1>"

#define KERN_CRIT   "<2>"

#deinfe KERN_ERR    "<3>"

#deinfe KERN_WARNING    "<4>"

#deinfe KERN_NOTICE "<5>"

#deinfe KERN_INFO   "<6>"

#deinfe KERN_DEBUG  "<7>"

printk的使用方法&#xff1a;

printk(KERN_ALERT"This is the log printed by printk in linux kernel space.");

KERN_ALERT表示日誌級別&#xff0c;後面緊跟著要格式化字符串。

有一種簡單的改變當前終端的日誌級別的方法:#echo 8 > /proc/sys/kernel/printk。理論上這樣printk就能輸出到終端了。

在Android系統中&#xff0c;printk輸出的日誌信息保存在/proc/kmsg中&#xff0c;使用查看命令&#xff1a;

adb shell cat /proc/kmsg  | grep "alarm" //grep "alarm"表示只抓取alarm的信息

或者&#xff1a;

USER-NAME&#64;MACHINE-NAME:~/Android$ adb shell

root&#64;android :/ # cat  /proc/kmsg | grep "alarm" //grep "alarm"表示只抓取alarm的信息

直接查看/proc/kmsg時讀取了緩衝區中的數據後&#xff0c;將緩衝區中的數據刪除

2.dmesg

今天想要調試android系統&#xff0c;串口debug沒接出來&#xff0c;最後想嘗試一直打印dmesg的方法&#xff0c;修改循環緩衝區的大小&#xff0c;打完dmesg後自動清空。

小記錄下&#xff0c;希望能幫到需要的人&#xff1a;

dmesg 在不刷新緩衝區的情況下獲得緩衝區的內容&#xff0c;並將內容返回給stdout。

dmesg -c 打印dmesg後清空循環緩衝區

dmesg -s 64 設置dmesg循環緩衝區大小為64



推荐阅读
  • C#设计模式之八装饰模式(Decorator Pattern)【结构型】
    一、引言今天我们要讲【结构型】设计模式的第三个模式,该模式是【装饰模式】,英文名称:DecoratorPattern。我第一次看到这个名称想到的是另外一个词语“装修”,我就说说我对“装修”的理 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • imx6ull开发板驱动MT7601U无线网卡的方法和步骤详解
    本文详细介绍了在imx6ull开发板上驱动MT7601U无线网卡的方法和步骤。首先介绍了开发环境和硬件平台,然后说明了MT7601U驱动已经集成在linux内核的linux-4.x.x/drivers/net/wireless/mediatek/mt7601u文件中。接着介绍了移植mt7601u驱动的过程,包括编译内核和配置设备驱动。最后,列举了关键词和相关信息供读者参考。 ... [详细]
  • 成功安装Sabayon Linux在thinkpad X60上的经验分享
    本文分享了作者在国庆期间在thinkpad X60上成功安装Sabayon Linux的经验。通过修改CHOST和执行emerge命令,作者顺利完成了安装过程。Sabayon Linux是一个基于Gentoo Linux的发行版,可以将电脑快速转变为一个功能强大的系统。除了作为一个live DVD使用外,Sabayon Linux还可以被安装在硬盘上,方便用户使用。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • 本文介绍了贝叶斯垃圾邮件分类的机器学习代码,代码来源于https://www.cnblogs.com/huangyc/p/10327209.html,并对代码进行了简介。朴素贝叶斯分类器训练函数包括求p(Ci)和基于词汇表的p(w|Ci)。 ... [详细]
  • 本文介绍了在Ubuntu 11.10 x64环境下安装Android开发环境的步骤,并提供了解决常见问题的方法。其中包括安装Eclipse的ADT插件、解决缺少GEF插件的问题以及解决无法找到'userdata.img'文件的问题。此外,还提供了相关插件和系统镜像的下载链接。 ... [详细]
  • 本文介绍了利用ARMA模型对平稳非白噪声序列进行建模的步骤及代码实现。首先对观察值序列进行样本自相关系数和样本偏自相关系数的计算,然后根据这些系数的性质选择适当的ARMA模型进行拟合,并估计模型中的位置参数。接着进行模型的有效性检验,如果不通过则重新选择模型再拟合,如果通过则进行模型优化。最后利用拟合模型预测序列的未来走势。文章还介绍了绘制时序图、平稳性检验、白噪声检验、确定ARMA阶数和预测未来走势的代码实现。 ... [详细]
  • Mono为何能跨平台
    概念JIT编译(JITcompilation),运行时需要代码时,将Microsoft中间语言(MSIL)转换为机器码的编译。CLR(CommonLa ... [详细]
  • 原文地址http://balau82.wordpress.com/2010/02/28/hello-world-for-bare-metal-arm-using-qemu/最开始时 ... [详细]
  • uboot与linux驱动1.uboot本身是裸机程序(1)在裸机中本来是没有驱动概念的(狭义的驱动概念是指在操作系统中用来具体操控硬 ... [详细]
  • 开发板:FL2440内核:linux3.0无线网卡:RT3070RT3070的工作模式分为STA(station)模式、SoftAP(AccessPoint)模式两种。STA ... [详细]
  • P113:集成日志组件 logback 2彩色日志
    第二步,将控制台的日志改成彩色日志,便于查看修改logback.xml文件。 ... [详细]
  • 学习mybatis的基础知识:mybatis入门教程(二)
    2019独角兽企业重金招聘Python工程师标准2.3MyBatisprintsql在log4j.properties配置文件中添加如下配置,让mybatis打 ... [详细]
author-avatar
也曾悲摧过_192
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有