gdb 调试 RISC-V
优秀的产品需要有高效的调试手段,RISC-V的工具链中提供GDB。 使得切换到RISCV后,底软和内核工程师的工作效率不受损害。
我们使用一个有趣的程序来尝试gdb调试的效果。源文件 rot13.c 和 链接描述文件spike.lds如下
rot13.c 中,通过变量wait的值,控制程序进入不同阶段:
阶段1: 程序因为 0 == wait, 停留在一个死循环里面。在后面的gdb调试中,我们可以看到通过修改变量wait的值,控制程序进入下一个阶段。
阶段2: 程序执行简单的“解密”运算,将初始化的“密文”解析为“明文”。在gdb中,我们将看到RISC-V demo 作者想告诉我们的信息。
阶段3: 程序结束。
/* file name: rot13.c */
char text[] = "Vafgehpgvba frgf jnag gb or serr!";
// Don't use the stack, because sp isn't set up.
volatile int wait = 1;
int main()
{
while (wait)
;
// Doesn't actually go on the stack, because there are lots of GPRs.
int i = 0;
while (text[i]) {
char lower = text[i] | 32;
if (lower >= 'a' && lower <= 'm')
text[i] += 13;
else if (lower > 'm' && lower <= 'z')
text[i] -= 13;
i++;
}
done:
while (!wait)
;
}
/* spike.lds */
OUTPUT_ARCH( "riscv" )
SECTIONS
{
. = 0x10010000;
.text : { *(.text) }
.data : { *(.data) }
}
1.Build
源码Build 命令如下
$ riscv64-unknown-elf-gcc -g -Og -o rot13-64.o -c rot13.c
$ riscv64-unknown-elf-gcc -g -Og -T spike.lds -nostartfiles -o rot13-64 rot13-64.o
2.调试
2.1 在spike(riscv-isa-sim)上运行程序rot13-64,在9824端口打开调试通道。
2.2 使用openocd 创建一个gdb调试的server, 通过9824端口连接到spike上的riscv实例,并在3333端口等待gdb的连接。
/*spike.cfg*/
interface remote_bitbang
remote_bitbang_host localhost
remote_bitbang_port 9824
set _CHIPNAME riscv
jtag newtap $_CHIPNAME cpu -irlen 5 -expected-id 0x10e31913
set _TARGETNAME $_CHIPNAME.cpu
target create $_TARGETNAME riscv -chain-position $_TARGETNAME
gdb_report_data_abort enable
init
halt
2.3 使用配套的riscv gdb工具进行调试。最终我们得到了demo 作者告诉我们的秘密
“Instrcution sets want to be free!”