MIT6.S081的gdb调试方法

如何使用gdb调试MIT6.S081

在做MIT6.S081实验的时候我们可能会用到gdb来调试程序。那么具体方法是什么呢?

1.配置环境

首先根据官方指南配置好MIT6.S081,具体可见:MIT6.S081实验环境搭建

配置好环境后,

在命令行中输入命令:

复制代码
sudo make qemu-gdb

应该会出现

另开一个终端,输入命令

复制代码
gdb-multiarch

应该会出现

没出现也没关系,如果提示没有gdb-multiarch,使用命令安装就行

复制代码
sudo apt-get install gdb-multiarch

如果启动gdb-multiarch的提示信息没有

复制代码
The target architecture is assumed to be riscv:rv64

那么(每次)启动后需要输入

复制代码
set architecture riscv:rv64

2.连接qemu-gdb

在上面我们输入了sudo make qemu-gdb之后,出现的信息里面有

这个就是我们要连接的端口,根据这个端口,在gdb-multiarch中输入

复制代码
target remote localhost:25000

会出现

这个时候就连接上了

3.加载可执行文件进行调试

使用命令

复制代码
file user/_xxx

来加载可执行文件,例如 file user/_sleep(注意有下划线)

这个时候可以开始打断点了,例如

复制代码
b main

然后多次输入c继续执行

输入到原来的终端应该会有变化

在这里就要输入我们程序的参数了,第一个参数是程序的名字,后面的参数视具体情况而定,例如sleep应该有一个表示多少时间的参数:

此后就可以继续调试了

总之gdb-multiarch的调试方法和gdb类似。

相关推荐
轻松Ai享生活10 小时前
5 节课深入学习Linux Cgroups
linux
christine-rr11 小时前
linux常用命令(4)——压缩命令
linux·服务器·redis
三坛海会大神55511 小时前
LVS与Keepalived详解(二)LVS负载均衡实现实操
linux·负载均衡·lvs
東雪蓮☆11 小时前
深入理解 LVS-DR 模式与 Keepalived 高可用集群
linux·运维·服务器·lvs
qq_2642208911 小时前
LVS负载均衡群集和LVS+Keepalived群集
运维·负载均衡·lvs
乌萨奇也要立志学C++12 小时前
【Linux】进程概念(二):进程查看与 fork 初探
linux·运维·服务器
雨落Liy12 小时前
Nginx 从入门到进阶:反向代理、负载均衡与高性能实战指南
运维·nginx·负载均衡
Yyyy48212 小时前
Nginx负载均衡集群实验步骤
运维·nginx·负载均衡
绿箭柠檬茶13 小时前
Ubuntu 服务器配置转发网络访问
服务器·网络·ubuntu
獭.獭.13 小时前
Linux -- 信号【上】
linux·运维·服务器