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!”