优秀的产品需要有高效的调试手段,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;