使用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:

相关推荐
2301_8035545244 分钟前
Linux里面的文件描述符和windows里面的句柄
linux·运维·服务器
星马梦缘1 小时前
如何切换window-ubuntu双系统【方案一】
linux·ubuntu·双系统
idolao1 小时前
CentOS 7 安装 jakarta-tomcat-connectors-jk2-src-current.tar.gz 详细步骤(解压、编译、配置)
linux·centos·tomcat
时空自由民.2 小时前
蓝牙协议栈介绍
linux·网络·单片机
KnowSafe2 小时前
证书自动化解决方案哪家更可靠?
运维·服务器·安全·https·自动化·ssl
日取其半万世不竭2 小时前
用云服务器搭建 Nextcloud,告别网盘限速和隐私泄露
运维·服务器
zh路西法2 小时前
【RDKX5多摄像头模型推理】USB带宽限制与ROS2话题零拷贝转发
linux·c++·python·深度学习
计算机安禾3 小时前
【Linux从入门到精通】第47篇:SystemTap与eBPF——Linux内核观测的显微镜
java·linux·前端
wanhengidc3 小时前
可持续性 云手机运行
运维·服务器·网络·安全·智能手机