使用printk对SPI子系统全过程的追踪

替换编译内核:

在内核目录下执行:

make mrproper

make 100ask_imx6ull_defconfig

在加载配置后才能打开内核界面修改内核设置,之后再编译内核

make zImage -j4

make dtbs

cp arch/arm/boot/zImage ~/nfs_rootfs

cp arch/arm/boot/dts/100ask_imx6ull-14x14.dtb ~/nfs_rootfs

make modules #编译内核里标记为<M>的驱动/功能

sudo apt install tree #安装一个查看目录结构的工具

make ARCH=arm INSTALL_MOD_PATH=/home/book/nfs_rootfs modules_install

ARCH=arm 要编译的是 ARM 架构,

INSTALL_MOD_PATH指定模块安装路径,

modules_install把刚刚编译好的 .ko 驱动模块,安装到前面指定的路径

就是选择模块编译后的保存路径

cd /home/book/nfs_rootfs

adb push zImage /boot

adb push 100ask_imx6ull-14x14.dtb /boot

adb push lib/modules /lib # modules 目录下保存执行完 make modules 生成的.ko文件。

将驱动编译成模块:

cd 源码目录

make menuconfig #打开图形化配置

1.驱动类选项会用< >

< > 空括号表示完全关闭,这个驱动不编译。

<M> 标记M表示单独编译成模块,单独编译成.ko文件。

< * >星号表示编译进内核。

2.一般系统类开关选项用[ ]

\] = 功能彻底关闭、禁用 \[\*\] = 功能强制开启、编译进内核 `3.---` 灰色横杠 这个选项被其他功能强制依赖,你无权手动修改。

永久更改环境变量:

路径: ~/.bashrc

添加以下内容

source ~/.bashrc #在编译内核前要重载环境变量否则会出现编译成x86架构,导致开发板不能正常启动。

file arch/arm/boot/zImage #检查内核镜像,防止编译成x86架构替换到开发板导致启动失败。

动态调试:

单独开启某个文件的官方调试信息。若没有打开开关,执行dmesg就只会显示自己添加的打印信息。

make menuconfig #必须打开下面这两个内核配置才能看到 pr_debug 的输出。

开启这几个文件的调试打印

echo "file drivers/base/bus.c +p" > /sys/kernel/debug/dynamic_debug/control

echo "file drivers/base/core.c +p" > /sys/kernel/debug/dynamic_debug/control

echo "file drivers/base/driver.c +p" > /sys/kernel/debug/dynamic_debug/control

echo "file drivers/base/class.c +p" > /sys/kernel/debug/dynamic_debug/control

关闭这几个文件的调试打印

echo "file drivers/base/bus.c -p" > /sys/kernel/debug/dynamic_debug/control

echo "file drivers/base/core.c -p" >> /sys/kernel/debug/dynamic_debug/control

echo "file drivers/base/class.c -p" >> /sys/kernel/debug/dynamic_debug/control

echo "file drivers/base/driver.c -p" >> /sys/kernel/debug/dynamic_debug/control

关闭所有文件的调试输出

echo "clear" > /sys/kernel/debug/dynamic_debug/control

左边第一个 7 代表 console_loglevel;(主要修改这个数)

左边第二个 7 代表 default_message_loglevel;

左边第三个 1 代表 minimum_console_loglevel;

左边第四个 7 代表 default_console_loglevel;

echo 4 > /proc/sys/kernel/printk #将控制台级别设为4

message等级必须高于控制台规定等级才能打印输出。
printk("%s %s %d, spi_imx->clk_per = %p\n", FILE, FUNCTION, LINE, spi_imx->clk_per);

没有写日志等级,就使用 /proc/sys/kernel/printk 中的 default_message_loglevel

printk log:

相关推荐
~黄夫人~3 分钟前
零基础速通|Windows&Linux 常用命令行对照表大全
linux·运维·windows·笔记·备忘录·整理表格
benjiangliu7 分钟前
LINUX系统-17-EXT系列文件系统(二)
linux·运维·服务器
杨云龙UP8 分钟前
Linux 根分区被日志吃满?一次 58G Broker 日志清理实战_2026-05-20
linux·运维·服务器·数据库·hdfs·apache
ㄣ知冷煖★36 分钟前
统一网关架构实践:从 Token 鉴权到路由、策略与凭证池转发全链路解析
java·服务器·架构
叶半欲缺38 分钟前
Linux通过lvm扩容根目录
linux·运维·服务器
utf8mb4安全女神1 小时前
Linux网络服务
linux·运维·服务器
vortex52 小时前
Linux PAM 配置详解:从原理到实战,彻底阻断非授权提权
java·linux·服务器
ZPC82102 小时前
Linux Preempt-RT 实时内核 ** 抖动(Jitter)** 完整测试方法
linux·运维·服务器
2501_920047032 小时前
openclaw在ubuntu系统的安装
linux·运维·ubuntu·openclaw
呉師傅2 小时前
UPS滴滴告警!如何测量UPS电池内阻【UPS学习】
运维·服务器·网络·学习·电脑