
在ARM架构的Linux系统上,glibc6是一种重要的C标准库,它为程序员提供了大量的标准C函数。但是在使用过程中也常常会出现一些问题,例如程序运行异常、段错误等。这时就需要借助一些调试工具来找出问题所在,本文将介绍一些常用的。
1. gdb
gdb是GNU调试器的简称,是一种强大的调试工具。它可以对程序进行单步跟踪、打印变量的值、修改程序的状态等功能,帮助程序员定位程序中的错误。
使用gdb调试程序的流程大致如下:
1)编译程序时加上-g参数,生成可调试的程序:
$ gcc -g -o program program.c
2)启动gdb:
$ gdb program
3)设置断点:
(gdb) break mn
4)运行程序:
(gdb) run
5)执行单步调试:
(gdb) next
6)打印变量的值:
(gdb) print var
7)修改变量的值:
(gdb) set var=10
8)退出gdb:
(gdb) quit
除了以上基本用法外,gdb还可以对内存进行调试、生成程序的核心转储文件等。
2. valgrind
valgrind是一款常用的内存调试工具,可以检测内存泄露、越界访问等问题。它可以运行在ARM架构的Linux系统上,但需要安装valgrind for ARM。
使用valgrind调试程序的流程大致如下:
1)安装valgrind for ARM:
$ sudo apt-get install valgrind-arm-linux
2)编译程序时不用加-g参数:
$ gcc -o program program.c
3)启动valgrind:
$ valgrind –tool=memcheck –leak-check=yes ./program
4)查看内存信息:
==12345== Memcheck, a memory error detector
==12345== Copyright (C) 2023-2023, and GNU GPL’d, by Julian Seward et al.
==12345== Using Valgrind-3.13.0.SVN and LibVEX; rerun with -h for copyright info
==12345== Command: ./program
==12345==
Hello, world!
==12345==
==12345== HEAP SUMMARY:
==12345== in use at exit: 0 bytes in 0 blocks
==12345== total heap usage: 1 allocs, 1 frees, 1,024 bytes allocated
==12345==
==12345== All heap blocks were freed — no leaks are possible
==12345==
==12345== For counts of detected and suppressed errors, rerun with: -v
==12345== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)
5)退出valgrind:
==12345==
==12345== HEAP SUMMARY:
==12345== in use at exit: 0 bytes in 0 blocks
==12345== total heap usage: 1 allocs, 1 frees, 1,024 bytes allocated
==12345==
==12345== All heap blocks were freed — no leaks are possible
==12345==
==12345== For counts of detected and suppressed errors, rerun with: -v
==12345== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)
$
valgrind还有其他的工具,例如helgrind可以检测多线程程序中的数据竞争问题,不过与ARM架构的Linux下的glibc6调试工具关联不大,这里不再深入介绍。
3. strace
strace是一款系统调用跟踪工具,可以输出程序运行过程中调用的系统调用。通过使用strace,程序员可以了解程序的运行情况,找出程序中的问题。
使用strace调试程序的流程大致如下:
1)编译程序:
$ gcc -o program program.c
2)启动strace:
$ strace ./program
3)运行程序:
execve(“./program”, [“./program”], []) = 0
brk(NULL) = 0x55a08fb3c000
access(“/etc/ld.so.nohwcap”, F_OK) = -1 ENOENT (No such file or directory)
access(“/etc/ld.so.preload”, R_OK) = -1 ENOENT (No such file or directory)
openat(AT_FDCWD, “/etc/ld.so.cache”, O_RDON|O_CLOEXEC) = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=78687, …}) = 0
mmap(NULL, 78687, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7f36c9fb2023
close(3) = 0
……
4)查看程序调用的系统调用:
openat(AT_FDCWD, “/etc/ld.so.cache”, O_RDON|O_CLOEXEC) = 3
close(3) = 0
access(“/etc/ld.so.nohwcap”, F_OK) = -1 ENOENT (No such file or directory)
access(“/etc/ld.so.preload”, R_OK) = -1 ENOENT (No such file or directory)
openat(AT_FDCWD, “/lib/aarch64-linux-gnu/libc.so.6”, O_RDON|O_CLOEXEC) = 3
read(3, “\177ELF\2\1\1\3\0\0\0\0\0\0\0\0\3\0(\0\1\0\0\0D.\2\0\0\0\0\0″…, 832) = 832
lseek(3, 4294971392, SEEK_SET) = -1 ESPIPE (Illegal seek)
……
5)退出strace:
$ exit_group(0) = ?
+++ exited with 0 +++
strace还可以输出文件读写情况、网络通信情况等,方便程序员进行问题定位。
本文介绍了一些常用的,包括gdb、valgrind和strace。这些工具提供了不同的调试方式,程序员可以根据需要选择合适的工具。在程序开发过程中,遇到问题时,调试工具是很好的助手,使用调试工具可以提高程序员的调试效率,缩短问题定位的时间。
相关问题拓展阅读:
- PVE内核在ARM64下安装及编译
- arm嵌入式linux系统开发详解怎么样
PVE内核在ARM64下安装及编译
以下命令在Linux root下进行
1.apt-getinstall gnupg2 wget –y
2.加入Proxmox 软逗山早件包源
wget -qO –
| sudo apt-key add echo “deb
buster pve-no-subscription ” | sudotee /etc/apt/sources.list.d/buster-pvetest.list
3.apt-getupdate
4.安装编译环境
apt-get install build-essentialasciidoc binutils bzip2 gawk gettext git libncurses5-dev libz-dev patch unzipzlib1g-dev libc6-dev subversion flex uglifyjs p7zip p7zip-full mtp libssl-devtexinfo libglib2.0-dev xmlto qemu-utils upx libelf-dev autoconf automakelibtool autopoint device-tree-compiler screen
apt-get install python3-dev python3-sphinx lintian bc bison libdw-devlibiberty-dev libnuma-dev libslang2-dev lz4 rsync libpve-common-perl dh-make docbook5-xml
若山雀是出现libncurses5-dev安装依赖错误,用aptitude安装即可解决
5. Git pve内核源码
git
6. 修改Makefile文件
23行内容 KERNEL_ARCH=x86和之后 修改成如下图所示:
7. 在pve-kernel/debian/rules.d文件目录下生成文件arm64.mk,内容如下
KERNEL_BUILD_ARCH= arm64
KERNEL_HEADER_ARCH = $(KERNEL_BUILD_ARCH)
KERNEL_BUILD_IMAGE = Image
KERNEL_IMAGE_PATH =arch/$(KERNEL_BUILD_ARCH)/boot/${KERNEL_BUILD_IMAGE}
KERNEL_INSTALL_FILE= vmlinuz
8. 修改pve-kernel/debian/rules文件,将rysnc中的tools修改成source,修改结果如下图所示
9. Make all
10.最终编译成功后会生唯橡成四个文件包,使用dpkg -i命令安装四个deb包,即可完成pve内核的安装。
linux-tools-{KERNEL_VER}_arm64.deb
linux-tools-5.0-dbgsym_{KERNEL_VER}_arm64.deb
pve-headers-{KERNEL_VER}_arm64.deb
pve-kernel-{KERNEL_VER}_arm64.deb
arm嵌入式linux系统开发详解怎么样
嵌入式系统是目前更流行的计算机应用技碰橡术之一。《ARM嵌入式Linux系统开发详解》由浅入深地讲解基于ARM体系结构的嵌入式
Linux系统开发,内容包括嵌入式系统的基本概念、应用领域等基础知识;ARM处理器的体系结构和功能特点;Linux系统内核结构和移植方法、
Bootloader功能和移笑并旁植;Linux应用程序开发,包括如何操作文件、管理内存、访问串口、多线程和多进程技术,并且剖析了应用程序的结构和工作
流程;Linux系统设备驱动程序开发,包括如何编写内核模块、驱动程序分类和功能特点,并且给出了网络设备驱动、Flash设备驱动和USB设备驱动的
实例分析。
《ARM嵌入式Linux系统开发详解》附带1张DVD光盘,内容为专门为《ARM嵌入式Linux系统开发详解》录制的9小时视频、《ARM嵌入式Linux系统开发详解》涉及的源代码、Ubuntu安装光盘的镜像文件和另外赠送的35小时Linux专题学习视频。
《ARM嵌入式Linux系统开发详解》适合广大从事嵌入式Linux系统开发人员、对嵌入式Linux系统开发有兴趣的计算蔽清机爱好者,以及大中专院校学生阅读。
关于arm linux libc6 dbg的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
香港服务器首选树叶云,2H2G首月10元开通。
树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/208081.html<