嵌入式linux使用trace调试步骤记录

0.内核配置:
CONFIG_FUNCTION_TRACER
CONFIG_FUNCTION_GRAPH_TRACER

一、 function graph tracer的使用

1.挂载debugfs文件系统
mount -t debugfs none /sys/kernel/debug

2.进入tracing调试目录
cd /sys/kernel/debug/tracing

3.设置为function_graph功能
echo function_graph > ./current_tracer

4.添加需要跟踪的函数blk_update_request
echo ‘phytium_lpc_probe’ > ./set_graph_function

5.开启跟踪
echo 1 > ./tracing_on

6.执行自己的操作或者脚本,等待函数运行或者bug出现

7.关闭跟踪
echo 0 > ./tracing_on

8.取出log
cp ./trace ~/log.txt

优化:
1.设置函数过滤
echo vfs_open > ./set_ftrace_filter

2.设置当前进程pid过滤
echo $$ > /sys/kernel/debug/tracing/set_ftrace_pid

3.函数结束的反括号后带函数入口的注释
echo 1 > ./options/funcgraph-proc
echo 1 > ./options/funcgraph-tail

4.使能trace子进程
echo 1 > /sys/kernel/debug/tracing/options/function-fork

二、kprobe的使用

1.挂载debugfs文件系统
mount -t debugfs none /sys/kernel/debug

2.进入tracing调试目录
cd /sys/kernel/debug/tracing

3.设置配置属性获取函数传入参数和返回值

echo 'p:myprobe do_fork clone_flags=%r0 stack_start=%r1 stack_size=%r2 parent_tidptr=%r3 child_tidptr=+0($stack)' > /sys/kernel/debug/tracing/kprobe_events
echo 'r:myretprobe do_fork $retval' >> /sys/kernel/debug/tracing/kprobe_events

上面是arm的用法,下面是X86的:

echo 'p bio_add_page arg1=$arg1 arg2=$arg2' > /sys/kernel/tracing/kprobe_events

4.开启探测并触发函数调用
echo 1 > events/kprobes/myprobe/enable
echo 1 > events/kprobes/myretprobe/enable

5.执行自己的操作或者脚本,等待函数运行或者bug出现

6.取出log
cp ./trace ~/log.txt

优化:
1.激活堆栈查看函数调用关系
echo stacktrace > trace_options

2.设置过滤PID信息
echo common_pid!=512 > events/kprobes/myprobe/filter

三、 trace event的使用

1.挂载debugfs文件系统
mount -t debugfs none /sys/kernel/debug

2.进入tracing调试目录
cd /sys/kernel/debug/tracing

3.设置events跟踪开关
ehco 1 > ./events/kmem/kmalloc/enable
ehco 1 > ./events/kmem/kfree/enable

4.开启跟踪
echo 1 > ./tracing_on

5.执行自己的操作或者脚本,等待函数运行或者bug出现

6.关闭跟踪
echo 0 > ./tracing_on

7.取出log
cp ./trace ~/log.txt

优化:
1.设置内存内存过滤信息
echo bytes_alloc==4096 > ./events/kmem/kmalloc/filter

1. 什么是嵌入式系统? 嵌入式系统是一种特殊的计算机系统,通常作为其他设备的一部分,它的硬件和软件是特别设计和定制的,以满足特定的功能和性能要求。 2. 嵌入式系统和桌面系统有什么区别? 嵌入式系统和桌面系统的主要区别在于它们的硬件和软件设计。嵌入式系统通常使用低功耗、小型化、低成本的处理器和外围设备,而且其软件设计通常是固定的,无法更改。桌面系统则通常使用高性能的处理器、大容量存储和内存,以及可扩展的外围设备,并且软件设计可以自由更改。 3. 嵌入式Linux是什么? 嵌入式Linux是一种特殊的Linux操作系统,它被设计用于嵌入式系统。它使用了精简版的Linux内核和用户空间工具集,以满足嵌入式系统对内存、存储和处理器性能的要求。 4. 嵌入式Linux的优点是什么? 嵌入式Linux的优点包括: - 开放源代码:嵌入式Linux是开放源代码软件,可以自由使用和修改。 - 稳定性:Linux内核在嵌入式系统中已经得到了广泛的应用和验证,具有良好的稳定性和可靠性。 - 灵活性:Linux内核和用户空间工具集可以根据需要进行裁剪和优化,以满足不同的嵌入式系统需求。 - 易于开发:Linux具有广泛的应用和开发社区,有大量的开发工具和文档可供使用。 - 可扩展性:Linux可以方便地添加新的硬件和软件模块,以扩展嵌入式系统的功能。 5. 如何在嵌入式系统中使用Linux? 在嵌入式系统中使用Linux需要进行以下步骤: - 选择合适的硬件平台,包括处理器、内存、存储和外围设备。 - 选择合适的嵌入式Linux发行版,包括内核和用户空间工具集。 - 进行系统定制和优化,包括裁剪内核和用户空间工具,以及配置系统参数。 - 开发应用程序和驱动程序,包括编译、调试和测试。 - 部署系统到目标硬件平台,包括镜像制作、烧录和启动。 - 维护和更新系统,包括升级内核和软件包,以及修复漏洞和错误。 6. 嵌入式Linux中的裁剪和优化有哪些方法? 嵌入式Linux中的裁剪和优化方法包括: - 内核裁剪:移除不需要的内核模块和功能,减小内核大小和内存占用。 - 文件系统裁剪:移除不需要的用户空间工具和库,减小文件系统大小和存储占用。 - 编译优化:使用合适的编译选项和优化方式,提高系统性能和效率。 - 硬件优化:选择合适的硬件平台和外围设备,优化系统架构和性能。 - 运行时优化:配置合适的系统参数和调整应用程序,提高系统响应和效率。 7. 嵌入式Linux中的驱动程序开发有哪些技术和工具? 嵌入式Linux中的驱动程序开发技术和工具包括: - Linux设备驱动框架:包括字符设备、块设备、网络设备、USB设备等驱动程序框架。 - 内核调试工具:包括 printk、trace、kgdb等内核调试工具,用于调试内核驱动程序。 - 内核编译工具链:包括交叉编译器、make、gcc等工具,用于编译内核驱动程序。 - 应用程序接口(API):包括系统调用、ioctl、procfs等接口,用于与内核驱动程序进行交互。 - 设备树(Device Tree):用于描述硬件平台和设备信息,用于内核驱动程序的初始化和配置。 8. 嵌入式Linux中的应用程序开发有哪些技术和工具? 嵌入式Linux中的应用程序开发技术和工具包括: - Linux开发环境:包括交叉编译器、make、gcc等开发工具,用于编译应用程序。 - 应用程序框架:包括Qt、GTK、SDL等框架,用于创建嵌入式图形界面和应用程序。 - 应用程序接口(API):包括POSIX、libc、glib等接口,用于与系统进行交互。 - 调试工具:包括GDB、strace、ltrace等工具,用于调试应用程序。 - 交叉平台支持:包括交叉编译、动态链接、静态链接等技术,用于在不同的嵌入式平台上移植应用程序。 9. 如何进行嵌入式Linux系统的调试和测试? 嵌入式Linux系统的调试和测试可以采用以下方法: - 内核调试使用 printk、trace、kgdb等内核调试工具,对内核驱动程序进行调试。 - 用户空间调试使用GDB、strace、ltrace调试工具,对应用程序进行调试。 - 性能分析:使用oprofile、perf、gprof等性能分析工具,对系统性能进行分析和优化。 - 单元测试:使用JUnit、CTest、CppUnit等单元测试框架,对驱动程序和应用程序进行单元测试。 - 集成测试:使用Selenium、Robotium等测试框架,对整个嵌入式系统进行集成测试。 - 硬件仿真:使用QEMU、Bochs等硬件仿真器,在PC上模拟嵌入式系统的运行环境,进行调试和测试。 10. 嵌入式Linux中的安全性问题有哪些? 嵌入式Linux中的安全性问题包括: - 内核漏洞:由于内核驱动程序的复杂性和漏洞,可能会导致系统被攻击或崩溃。 - 应用程序漏洞:由于应用程序的缺陷和漏洞,可能会导致系统被攻击或崩溃。 - 未经授权访问:由于系统访问控制和安全策略不当,可能会导致系统被未经授权的访问。 - 系统配置错误:由于系统配置不当,可能会导致系统被攻击或崩溃。 - 数据泄露:由于系统中的敏感数据没有得到保护,可能会导致数据泄露和损失。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小坚学Linux

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值