gdb的 Ctrl+c 怎么让内核给停下来

gdb的 Ctrl+c 怎么让内核给停下来,第1张

目前常用的gdb与内核的通信是基于串口的kgdboc模块来连接的,所以本文就以串口的kgdboc来讲解。文章分两个部分来解释这个问题,一部分是gdb端对ctrl+c *** 作做的一些处理,

另外一部分则是内核和KGDB对停止指令处理。1: gdb端:在Linux console程序中,ctrl+c是用来终止当前在终端窗口中运行的命令或脚本。

GDBC,头重尾稳, *** 控性强,过弯失速小,五六档略显乏力,极速没什么特色,虽然总体上比较平均, 但依然是综合实力强悍的一流战车。总之,这部车没什么缺点,极速和五六档乏力注定了不能跑湾岸,但其他图也算是理想的TA用车,对战因为有后追,极速和高档位乏力的劣势完全可以忽略,所以这个车不依赖改装,即使全原也能有不错的表现,重要的是找到适合自己手感的改装。

第三个引擎盖叫”有孔无碳“盖,就是原盖上多了通风口,硬度仅次于原盖,注重加速,弯心速快,虽然能吸弯但是反应较迟钝, *** 控性差,连续过弯精准度低,需要有好的控车技术,是对战的万金油配置。

第四个引擎盖叫”有孔有碳“,是一个舒适型的配置,加速和极速都是最快的,而且 *** 控容易,反应灵敏,但是过弯失速明显,而且是最轻的引擎盖,车头会变的很软,完全不适合对抗,因此上镜率很低,一般追求直线速度的极限才会用到。

我的GDBC一般拿来对战,改装如下:

A包——注重硬度和加速的包围,堪称对战万金油配置

有孔无碳——同样对战万金油配置

GT直翼——直翼虽然有点漂,但GDBC本身很稳,同时直翼最快的直线加速也提供了更强的爆发力。

三爪——官方其实没推荐多少适合GDBC的轮胎,也就RS,RCII和CE28N,所以选择了全车种适应性都很好的三爪,而且三爪手感确实不错。

最后,改装没有怎么样的,性能只是微调,重要的是改变手感,所以没有最好的改装,只有最适合自己的改装,像GDBC这种不依赖改装的车更是如此,所以你可以考虑考虑自己的GDBC哪方面不足,再通过改装调整,如果没什么问题,觉得这套改装适合自己,就不用换了。

Linux 下调试汇编代码既可以用 GDB、DDD 这类通用的调试器,也可以使用专门用来调试汇编代码的 ALD(Assembly Language Debugger)。

从调试的角度来看,使用 GAS 的好处是可以在生成的目标代码中包含符号表(symbol table),这样就可以使用 GDB 和 DDD 来进行源码级的调试了。要在生成的可执行程序中包含符号表,可以采用下面的方式进行编译和链接:

[xiaowp@gary code]$ as --gstabs -o hello.o hello.s

[xiaowp@gary code]$ ld -o hello hello.o

执行 as 命令时带上参数 --gstabs 可以告诉汇编器在生成的目标代码中加上符号表,同时需要注意的是,在用 ld 命令进行链接时不要加上 -s 参数,否则目标代码中的符号表在链接时将被删去。

汇编程序员通常面对的都是一些比较苛刻的软硬件环境,短小精悍的ALD可能更能符合实际的需要,因此下面主要介绍一下如何用ALD来调试汇编程序。首先在命令行方式下执行ald命令来启动调试器,该命令的参数是将要被调试的可执行程序:

[xiaowp@gary doc]$ ald hello

Assembly Language Debugger 0.1.3Copyright (C) 2000-2002 Patrick Alken

hell ELF Intel 80386 (32 bit), LSB, Executable, Version 1 (current)

Loading debugging symbols...(15 symbols loaded)

ald>

当 ALD 的提示符出现之后,用 disassemble 命令对代码段进行反汇编:

ald>disassemble -s .text

Disassembling section .text (0x08048074 - 0x08048096)

08048074 BA0F000000 mov edx, 0xf

08048079 B998900408 mov ecx, 0x8049098

0804807E BB01000000 mov ebx, 0x1

08048083 B804000000 mov eax, 0x4

08048088 CD80 int 0x80

0804808A BB00000000 mov ebx, 0x0

0804808F B801000000 mov eax, 0x1

08048094 CD80 int 0x80

上述输出信息的第一列是指令对应的地址码,利用它可以设置在程序执行时的断点:

ald>break 0x08048088

Breakpoint 1 set for 0x08048088

断点设置好后,使用 run 命令开始执行程序。ALD 在遇到断点时将自动暂停程序的运行,同时会显示所有寄存器的当前值:

ald>run

Starting program: hello

Breakpoint 1 encountered at 0x08048088

eax = 0x00000004 ebx = 0x00000001 ecx = 0x08049098 edx = 0x0000000Fesp = 0xBFFFF6C0 ebp = 0x00000000 esi = 0x00000000 edi = 0x00000000

ds = 0x0000002B es = 0x0000002B fs = 0x00000000 gs = 0x00000000

ss = 0x0000002B cs = 0x00000023 eip = 0x08048088 eflags = 0x00000246

Flags: PF ZF IF

08048088 CD80 int 0x80

如果需要对汇编代码进行单步调试,可以使用 next 命令:

ald>next

Hello, world!

eax = 0x0000000F ebx = 0x00000000 ecx = 0x08049098 edx = 0x0000000Fesp = 0xBFFFF6C0 ebp = 0x00000000 esi = 0x00000000 edi = 0x00000000

ds = 0x0000002B es = 0x0000002B fs = 0x00000000 gs = 0x00000000

ss = 0x0000002B cs = 0x00000023 eip = 0x0804808F eflags = 0x00000346

Flags: PF ZF TF IF

0804808F B801000000 mov eax, 0x1

若想获得 ALD 支持的所有调试命令的详细列表,可以使用 help 命令:

ald>help

Commands may be abbreviated.

If a blank command is entered, the last command is repeated.

Type `help <command>'' for more specific information on <command>.

General commands

attach clear continue detach disassemble

enter examine file help load

next quit register run set

step unload window write

Breakpoint related commands

break delete disable enable ignore

lbreak tbreak


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/dianzi/9035119.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-24
下一篇2023-04-24

发表评论

登录后才能评论

评论列表(0条)

    保存