使用dev_dbg调试

首先内核要使能两个配置才可以使用。一般内核都是打开的。

CONFIG_DEBUG_FS=y
CONFIG_DYNAMIC_DEBUG=y

当编译选项CONFIG_DYNAMIC_DEBUG打开的时候,在编译阶段,kernel会把所有使用dev_dbg()的信息记录在一个table中,这些信息我们可以从/sys/kernel/debug/dynamic_debug/control解析出来:

[root@localhost ~]# cat /sys/kernel/debug/dynamic_debug/control | grep infiniband
drivers/infiniband/core/uverbs_cmd.c:730 [ib_uverbs]ib_uverbs_reg_mr =_ "ODP support not available\012"
drivers/infiniband/core/umem_odp.c:458 [ib_uverbs]ib_umem_odp_map_dma_and_lock =_ "ib_umem_odp_map_dma_single_page failed with error %d\012"
drivers/infiniband/core/umem_odp.c:449 [ib_uverbs]ib_umem_odp_map_dma_and_lock =_ "%s: un-expected hmm_order %d, page_shift %d\012"
drivers/infiniband/core/verbs.c:2071 [ib_core]ib_reg_user_mr =_ "ODP support not available\012"
drivers/infiniband/core/cache.c:626 [ib_core]_ib_cache_gid_del =p "%s: can't delete gid %pI6 error=%d\012"
drivers/infiniband/core/cache.c:391 [ib_core]del_gid =p "%s port=%d index=%d gid %pI6\012"
drivers/infiniband/core/cache.c:328 [ib_core]store_gid_entry =p "%s port=%d index=%d gid %pI6\012"
drivers/infiniband/core/cache.c:244 [ib_core]free_gid_entry_locked =p "%s port=%d index=%d gid %pI6\012"
drivers/infiniband/core/mad.c:366 [ib_core]ib_register_mad_agent =_ "%s: QP %d not supported\012"
drivers/infiniband/core/mad.c:356 [ib_core]ib_register_mad_agent =_ "%s: Invalid port %d\012"
drivers/infiniband/core/mad.c:340 [ib_core]ib_register_mad_agent =_ "%s: Invalid GS QP type: class 0x%x\012"
drivers/infiniband/core/mad.c:330 [ib_core]ib_register_mad_agent =_ "%s: Invalid SM QP type: class 0x%x\012"
drivers/infiniband/core/mad.c:317 [ib_core]ib_register_mad_agent =_ "%s: RMPP version for non-RMPP class 0x%x\012"
drivers/infiniband/core/mad.c:308 [ib_core]ib_register_mad_agent =_ "%s: No OUI specified for class 0x%x\012"
drivers/infiniband/core/mad.c:297 [ib_core]ib_register_mad_agent =_ "%s: Invalid Mgmt Class 0\012"
drivers/infiniband/core/mad.c:287 [ib_core]ib_register_mad_agent =_ "%s: Invalid Mgmt Class 0x%x\012"
drivers/infiniband/core/mad.c:275 [ib_core]ib_register_mad_agent =_ "%s: no recv_handler\012"
drivers/infiniband/core/mad.c:270 [ib_core]ib_register_mad_agent =_ "%s: invalid Class Version %u\012"
drivers/infiniband/core/mad.c:260 [ib_core]ib_register_mad_agent =_ "%s: invalid RMPP Version %u\012"
drivers/infiniband/core/mad.c:253 [ib_core]ib_register_mad_agent =_ "%s: invalid QP Type %d\012"
drivers/infiniband/core/ib_core_uverbs.c:328 [ib_core]rdma_user_mmap_entry_insert_range =_ "mmap: pgoff[%#lx] npages[%#x] inserted\012"
drivers/infiniband/core/ib_core_uverbs.c:196 [ib_core]rdma_user_mmap_entry_free =_ "mmap: pgoff[%#lx] npages[%#zx] removed\012"
drivers/infiniband/core/ib_core_uverbs.c:141 [ib_core]rdma_user_mmap_entry_get_pgoff =_ "mmap: pgoff[%#lx] npages[%#zx] returned\012"

比如我们想打开rdma设备gid管理的相关日志。

打开整个文件的dev_dbg使用file关键字:

echo -n "file drivers/infiniband/core/cache.c +p" > /mnt/debug/dynamic_debug/control

打开一个函数的dev_dbg开关,使用func关键字:

echo -n "func del_gid -p" > /sys/kernel/debug/dynamic_debug/control

关闭日志,则使用-p:

echo -n "file drivers/infiniband/core/cache.c -p" > /mnt/debug/dynamic_debug/control

在/sys/kernel/debug/dynamic_debug/control的输出中,我们上面的操作都会体现出来。如果函数后面是“=p”,则说明开关打开。如果是“=_”,则说明开关关闭。

使能开关后,日志必须通过dmesg查看,前面会带有设备名称作为前缀:

与printk不同的是printk会打印到串口输出,但dev_dbg不会。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/28912.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android 一个manifest 可以有 多个 hal 吗 ?

是的,在Android系统中,一个manifest文件理论上可以声明多个HAL(Hardware Abstraction Layer,硬件抽象层)实现。这意味着,如果你的应用或模块需要与多种不同的硬件组件交互,你可以在同一个manife…

xftp无法删除目录

遇到很奇怪的事, 我通过xftp软件删除服务器上的一个文件夹,但是怎么都删除不掉,而且在xftp上看到的是存在两个同名的文件夹,真的是完全同名(仅通过xftp上看)。然后我觉得好奇怪,就在终端上使用l…

谷歌发布Infini-Transformer模型—无限注意力机制长度,超越极限

Transformer 是一种基于自注意力机制的深度学习模型,最初应用于自然语言处理领域,现已扩展到图像、音频等多个领域。与传统的循环神经网络 (RNN) 不同,Transformer 不依赖于顺序数据处理,能够并行计算,从而显著提高效率…

关注开源大模型,深度学习+人工智能领域热门项目

标题:开源大模型  项目名称:开源大模型  项目地址:[https://gitcode.com/2noise/ChatTTS ](https://gitcode.com/2noise/ChatTTS%E3%80%82)  随着开源程序的发展,越来越多的程序员开始关注并加入开源大模型的行列。对于开源…

javascript截取video视频第一帧作为封面方案

写在前边:因为项目是用vue.js框架实现,所以以下代码是vue.js语法。 首先,看一下Dom元素 ~~~awk <video@loadeddata="createPreImg($event)" // loadeddata事件表示media中的首帧已经加载class="content-video":src="item.videoUrl" // 视…

Havoc工具

Team端 客户端 打开后需要生成监听器和agent 监听 生成payload 最后上线 HTTPS流量 HTTP流量 心跳

力扣454题解:四数相加(java实现简易)

力扣454题解&#xff1a;四数相加 引言 LeetCode是一个流行的在线判题平台&#xff0c;它提供了大量的算法题目供程序员练习和挑战。第454题“四数相加II”是一个中等难度的题目&#xff0c;要求找出所有两数之和等于特定值的四元组。本文将详细介绍如何使用Java解决这个问题…

代码随想录打卡第十二天补

代码随想录打卡第十二天补 第五章 栈和队列 part2 150. 逆波兰表达式求值 本题不难&#xff0c;但第一次做的话&#xff0c;会很难想到&#xff0c;所以先看视频&#xff0c;了解思路再去做题 题目链接/文章讲解/视频讲解&#xff1a;https://programmercarl.com/0150.%E9%8…

【ARMv8/ARMv9 硬件加速系列 3.3 -- SVE LD2D 和 ST2D 使用介绍】

文章目录 SVE 多向量操作LD2D(加载)LD2D 操作说明LD2D 使用举例ST2D(存储)ST2D 使用举例ST2D 存储示例代码ld2d 和 st2d 小结SVE 多向量操作 在ARMv8/9的SVE (Scalable Vector Extension) 指令集中,st2d和ld2d指令用于向量化的存储和加载操作,具体地,它们允许同时对两个…

Mysql中常用的sql语句(适合萌新学习)

本人在学习mysql的过程中&#xff0c;踩过很多坑&#xff0c;走过很多弯路&#xff0c;这是我个人总结的一些常用的知识点&#xff0c;希望可以对大家有所帮助&#xff0c;与君共勉&#xff01; 1.查看 查看行&#xff1a; select * from <tables>; sel…

物联边缘网关如何助力工厂实现智能化生产?以某智能制造工厂为例-天拓四方

随着工业4.0的深入推进&#xff0c;智能制造工厂成为了工业发展的重要方向。在这个背景下&#xff0c;物联边缘网关以其独特的优势在智能制造工厂中发挥着越来越重要的作用。以下将通过一个具体的智能制造工厂应用案例&#xff0c;来阐述物联边缘网关如何助力工厂实现智能化生产…

超级签名源码/超级签/ios分发/签名端本地linux服务器完成签名

该系统完全在linux下运行&#xff0c;不存在使用第三方收费工具&#xff0c;市面上很多系统都是使用的是第三方收费系统&#xff0c;例如&#xff1a;某心签名工具&#xff0c;某测侠等&#xff0c;不开源而且需要每年交费&#xff0c;这种系统只是在这些工具的基础上套了一层壳…

服务器添加TLS域名证书核子之PKCS编解码

PKCS PKCS(Public Key Cryptography Standards)是一系列的标准,用于定义在公钥密码体系中涉及的一些基本结构和算法。PKCS#1 和 PKCS#8 是两个不同的标准,分别定义了不同的公钥私钥编码和封装格式。 PKCS#1 和PKCS#8区别 PKCS#1 PKCS#1 定义了一种用于RSA算法的公钥和私…

java文件传输小工具 java17+springboot3+thymeleaf

背景 在和同事工作中经常需要传输文件&#xff0c;但是公网传输太慢&#xff0c;业务方不是计算机专业直接用命令行沟通麻烦。 本小工具通过页面可视化方便用户使用&#xff0c;端口9090&#xff0c;启动默认展示当前登陆本机用户的桌面。 代码开源&#xff1a; https://git…

522. 最长特殊序列 II

题目 给定字符串列表 strs &#xff0c;返回其中最长的特殊序列的长度。如果最长特殊序列不存在&#xff0c;返回 -1。 特殊序列定义如下&#xff1a;该序列为某字符串独有的子序列&#xff08;即不能是其他字符串的子序列&#xff09;。 字符串 s 的子序列可以通过删去字符…

支付宝对于内容的渴求,似乎一直都没有停止过

无论是业已搁浅的圈子&#xff0c;还是后来的蚂蚁财富号&#xff0c;抑或是现在拿出10亿现金扶持创作者&#xff0c;无一不是这样一种渴求的外在体现。 6月12日&#xff0c;支付宝在内容开放日宣布投入10亿元现金、百亿流量加码扶持内容创作者&#xff0c;还将引入价值1亿元资…

antd的表格组件错乱问题

环境 react&#xff1a;17.0.2 antd&#xff1a;3.26.20 问题 表格头列宽度和表格体列宽度不一致&#xff0c;表格错乱 解决 针对这个问题官方github仓库里面有专门的issues https://github.com/ant-design/ant-design/issues/13825 里面给出了几种解决方案&#xff1a…

【C#】项目中添加png文件时,设置其“生成操作”(Build Action)属性

在C#项目中&#xff0c;当添加图像文件&#xff08;如PNG文件&#xff09;时&#xff0c;可以设置其“生成操作”&#xff08;Build Action&#xff09;属性&#xff0c;这个属性决定了编译器如何处理这些文件。 以下是几个常见的生成操作选项及其含义&#xff1a; Resource: …

C++类对象模型、类对象的存储方式、this指针、this指针的引出、this指针的特性、C语言和C++实现Stack的对比等的介绍。

文章目录 前言一、C类对象模型1. 类对象的存储方式2. 结构体内存对齐规则 二、this指针1. this指针的引出2. this指针的特性3. C语言和C实现Stack的对比 总结 前言 C类对象模型、类对象的存储方式、this指针、this指针的引出、this指针的特性、C语言和C实现Stack的对比等的介绍…

2024中国应急(消防)品牌巡展成都站成功召开!

汇聚品牌力量&#xff0c;共同相聚成都。6月14日&#xff0c;由中国安全产业协会指导&#xff0c;中国安全产业协会应急创新分会、应急救援产业网联合主办&#xff0c;四川省消防协会协办的“一切为了安全”2024年中国应急(消防)品牌巡展-成都站成功举办。该巡展旨在展示中国应…