- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在编写一些代码,需要我手动操作一段代码的上下文,然后切换到它,而不是使用 makecontext。由于断言失败,我的测试程序在一行上失败,所以我尝试使用 GDB 来确定结果并查看该部分失败的原因,但是,当我使用 GDB v7.4.1 运行它时,它由于 null 而出现段错误地址在前面的代码部分。
上下文切换的结果如下:程序的指令指针指向一个函数的开头,该函数接受两个参数,一个指向另一个函数的指针和一些参数。 (函数将参数传递给函数指针,然后将上下文切换回来)。
我隔离了导致此问题的代码区域,这是围绕它的代码的结果。
245 setcontext(runQueue->front->currContext);
(gdb) print runQueue->front->currContext->uc_mcontext.gregs[REG_RIP]
$1 = 420391
(gdb) print runQueue->front->currContext->uc_mcontext.gregs[REG_RSP]
$2 = 1077936128
(gdb) print runQueue->front->currContext->uc_mcontext.gregs[REG_RDI]
$3 = 4199321
(gdb) print runQueue->front->currContext->uc_mcontext.gregs[REG_RSI]
$4 = 10
这就在上下文切换之前。我检查了寄存器以验证程序切换到的上下文的值是否正确,并且它们符合预期(REG_RIP:4203091 == 0x402253,REG_RSP:1077936128 == 0x40400000,REG_RDI:4199321 == 0x401399 和 REG_RSI : 0xa == 10)
进入上下文切换并跟随它脱离上下文的变化后,结果是这样的:
thread_func(function=0, arg=0x0) at thread.c:51
51 {
(gdb) info registers rip
rip 0x402253 0x402253 <thread_func>
(gdb) info registers rsp
rsp 0x40400000 0x40400000
(gdb) info registers rdi
rdi 0x401399 4199321
(gdb) info registers rsi
rsi 0xa 10
寄存器的值没有改变,但是 GDB 没有正确传入参数,程序试图使用 0 值,并且程序段错误访问空指针。
有什么办法可以解决这个问题或绕过这个问题吗?
最佳答案
The values of the registers are unchanged, but the arguments are not passed in correctly by GDB, the program attempts to utilize the 0 values, and the program segmentation faults for accessing a null pointer.
您对正在发生的事情的解释极有可能是不正确的。
特别是,您声称 NULL 取消引用的发生似乎主要是基于此:
thread_func(function=0, arg=0x0) at thread.c:51
其中 function 和 arg 的值应分别为 0x401399
和 0xa
。
但是,您的函数有序言,并且您在序言执行之前停止了。 GDB 向您显示当前包含在内存位置的值,这些位置将包含序言之后的参数,但您尚未将它们存储在那里。尝试 stepi
过去的序言(过去的指令 mov %rsi,-0x20(%rbp)
),你会观察到 function
和 arg
神奇地获取正确的值。
如果您的程序稍后因 NULL 指针取消引用而崩溃,那是因为其他原因。
附言在设置 %rsp
时,您违反了 ABI 要求:x86_84 要求在每个函数内部,%rsp
是 16 字节对齐的。这意味着进入任何函数%rsp&0xF == 8
(你有%rsp&0xF == 0
)。这很可能会在以后导致崩溃,尤其是当您使用任何 SSE2 指令时。
您可以通过将 %rsp
设置为 mmap_addr+8
或通过使用 -mstackrealign< 编译
.thread.c
来解决此问题
关于c - GDB 影响 setcontext 结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26220744/
假设我定义了一个 new gdb command其中包括别名。 import gdb import string class PrettyPrintString (gdb.Command):
是否可以使用 gdb 的 if 或 while 条件来测试 gdb 命令是否成功(而不是查询程序值或变量)? 现在为了清楚起见,我谈论的是 gdb 内置命令(即当您在 gdb 中键入 help 时出现
我只是使用 gdb 逐行逐行执行代码,以了解它是如何工作的以及它在做什么。我第一次这样做时效果很好,但现在下一个命令无法正常工作。有时它前进,有时它倒退。这没有意义。每次我这样做似乎都是相同的模式。下
我怎样才能运行类似 gdb -e path/to/exe -ex 'run --argnamae argvalue' 的东西? 让我们假设在过去一两年内有一个最新版本的 gfb。 Gdb 运行并打印响
我正在使用 gdb 调试程序,并且我想要命令的输出 $(perl -e 'print "A"x20') 作为我的论点。我怎样才能做到这一点?这样,论点将非常灵活。 最佳答案 您可以使用 run 命令,
我在 linux 上使用 gdb 版本 7.5.1,并试图使用诸如 $_memeq 之类的便利功能只是发现它显然不存在: Undefined command: "$_memeq". Try "help
我有: 正在运行的剥离二进制文件 总局 未剥离的二进制文件 我可以连接到运行剥离的二进制文件 (gdp -p PID)。如何将未剥离二进制文件中的符号提供给连接到正在运行的进程的 gdb? 最佳答案
我偶然发现了gdb的自动显示功能,该功能非常强大且方便。打电话后 (gdb) display/i $pc (gdb) display $rax 监视的值将在每个步骤后自动显示: (gdb) si 0x
我知道 Linux 等现代操作系统并不总是在应用程序最初链接的同一地址执行应用程序。但是,当调试器开始四处查看时,它需要知道原始链接地址和最终执行地址之间的关系。 GDB如何计算偏移量? 澄清:我不是
我想知道是否有可能从GDB本身获取已调试应用程序已打开但未关闭的文件/目录的列表? 当前,我设置了一个断点,然后使用lsof这样的外部程序来检查打开的文件。 但是这种方法确实很烦人。 环境:Debia
我想执行非常简单的命令 print var1, var2, var3, var4 在 gdb 中不时检查变量的值。 我不想使用显示,因为它会扰乱我的 View 。 我该如何做到这一点?现在我能做的就是
这个问题已经有答案了: gdb scripting: execute commands at selected breakpoint (1 个回答) 已关闭 8 年前。 我需要检查一个变量以确定它是否
在命令行下,我知道使用 echo $?给我退出代码。在gdb中,我使用“r”来运行程序,程序终止,那么gdb是如何得到这个退出码的呢? gdb 里面有什么命令吗? 谢谢! 最佳答案 当程序退出时,gd
我遇到了核心,无法从中获取回溯。我有两个问题。 我可以从以下位置找出导致崩溃的行或崩溃发生的位置吗列出命令输出? 否则如何处理。我应该将 heuristic-fence-post 设置为多少才能得到一
调试时加断点,运行bt可以看到栈帧。 通过运行信息寄存器选择帧时,可以看到特定帧上的寄存器值。 例如,考虑在第 5 帧设置断点。当断点被击中时,进入第 3 帧,可以看到查看寄存器值。 在第 5 帧设置
gdb 如何打印结构?来自 zengr 在 how does gdb work? 引用的“GDB 内部”文档看起来 GDB 使用 BFD 库从一个或多个符号表加载符号。如果是这种情况,gdb 怎么知道
我只是使用 gdb 逐行逐行执行代码,以了解它是如何工作的以及它在做什么。我第一次这样做时效果很好,但现在下一个命令无法正常工作。有时它前进,有时它倒退。这没有意义。每次我这样做似乎都是相同的模式。下
当我执行以下命令时,我得到不同的 function() 地址 (gdb) 中断函数() function() 0x804834a 处的断点 1。 (gdb) 打印函数() function() 0x8
我已经安装了 (OSX Mojave 10.14.6.) Eclipse CDT 和 GNU MCU Eclipse plugin最后 GNU Tools for ARM .我的目标是使用 GDB (
我必须对文件(main 和 functions)进行 cpp,然后让它们构建一个 exe 文件(代码)和两个目标文件(main.o 和 functions.o)。 如何从 gdb 命令行调试特定文件“
我是一名优秀的程序员,十分优秀!