ns3中调试程序------命令行、gdb和logging系统

1、在调试代码时候,一直没有弄明白NS_LOG中的各种函数是如何使用的,甚至现在运行程序只知道,./waf –run,至于输出调试信息,现在真的是没有弄明白,不利于代码的理解和调试。

2、通过命令行,改变实验变量,观察实验结果,./waf --run "sb" --command-template="%s --help"
会出现程序参数和一般参数
比如修改distance(default=50),./waf --run "sb" --command-template="%s --distance=200",会明显实验结果在distance=200时,收发数据包为0,distance距离导致收发双方不能正常通信。
这种通过命令行的方法,只会改变一次运行结果,不会改变文件中的值,下次运行时,distance仍然=50,对于观察实验结果来说,很方便,尤其是把每次改变结果值,写成脚本,运行很方便
3、gdb调试,个人认为比较笨拙,不过在eclipse没安装成功,这也是一个小调试的方法。
./waf --run "sb" --command-template="gdb %s",进入到gdb调试环境中,l,break,r,finish,next,进行调试。

4、NS3中的logging系统,功能也很强大,只是现在使用很少,记录各模块中的输出信息,对调试的执行有帮助。
在程序中”wifi-example-sim.cc”发现,使用了”NS_LOG_COMPONENT_DEFINE”和”NS_LOG_INFO”以及”NS_LOG_ERROR”这3种形式的函数;
比如,我想在运行程序”wifi-example-sim.cc”时,输出NS_LOG_INFO函数中的信息,首先找到NS_LOG_COMPONENT_DEFINE("WiFiDistanceExperiment"),之后通过命令行
$ export NS_LOG=WiFiDistanceExperiment=info
$ ./waf --run "sb"
观察程序运行情况;
因为该程序,”NS_LOG_ERROR”未执行到,所以,没有信息输出。
5、
$ export NS_LOG=WiFiDistanceExperiment=all:WiFiDistanceApps=all
$ ./waf --run "sb"
可以看到”wifi-example-sim.cc”和”wifi-example-apps.cc”中的NS_LOG信息,便于理解程序运行。
分析程序,从main函数运行,“Create traffic source & sink”之后,创建对象,调用WiFiDistanceApps::Sender和WiFiDistanceApps::Receiver(使用了NS_LOG_FUNCTION_NOARGS,输出函数的名字,这应该只在静态函数中使用;大多数成员函数应该使用NS_LOG_FUNCTION()),之后开始Simulator::Run()

6、如果显示函数前缀,$ export 'NS_LOG=WiFiDistanceExperiment=all|prefix_func|prefix_time:WiFiDistanceApps=all|prefix_func|prefix_time'
$ ./waf --run "sb"

可以得到很详细的函数调用,以及函数调用的时间,有时候也是一种负担,因为太详细,终端不容易观察,可以输出到文本文件中查看$ ./waf --run "sb" >&sb.txt可以通过$ gedit sb.txt查看输出信息。
7、为了方便,经常定义

bool verbose=false;
WifiHelper wifi;
if(verbose)
{
wifi.EnableLogComponents();
}//turn on all wifi logging

8、同样也可以定义:

bool tracing=false;//turn on ascii and pcap tracing;
if(tracing == true)
{
AsciiTraceHelper ascii;
YansWifiPhyHelper wifiPhy = YansWifiPhyHelper::Default();
wifiPhy.EnableAsciiAll(ascii.CreateFileStream("wifi-simple-adhoc-grid.tr"));
wifiPhy.EnablePcap("wifi-simple-adhoc-grid",devices);
NetdeviceContainer devices = wifi.Install(wifiPhy,wifiMac,c);
}
export NS_LOG=UdpEchoClientApplication=level_all
export 'NS_LOG=UdpEchoClientApplication=level_all|prefix_func:UdpEchoServerApplication=level_all|prefix_func'
export 'NS_LOG=*=level_all|prefix_func|prefix_time'
unset NS_LOG//关闭所有的NS-LOG
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 RISC-V 平台上使用 GDB 进行调试,需要先安装 RISC-V 版本的 GDB。可以通过以下命令安装: ``` sudo apt-get install gdb-multiarch ``` 安装完成后,可以使用以下命令启动 GDB: ``` riscv64-unknown-elf-gdb <executable> ``` 其 `<executable>` 是要调试的可执行文件的路径。接下来,可以使用 GDB 的各种命令进行调试。 以下是一些常用的 GDB 命令: - `break <function>`:在指定函数处设置断点。 - `break <line>`:在指定行处设置断点。 - `run <args>`:运行程序并传入参数。 - `step`:单步执行程序。 - `next`:执行下一条语句,不进入函数内部。 - `continue`:继续执行程序,直到遇到下一个断点。 - `print <variable>`:打印变量的值。 - `backtrace`:查看函数调用栈。 此外,还可以使用 `-g` 选项编译程序时生成调试信息,以便在 GDB 进行调试。例如: ``` riscv64-unknown-elf-gcc -g -o <executable> <source files> ``` ### 回答2: gdb是一个功能强大的调试工具,适用于多种不同的处理器架构,其包括risc-v。使用gdb调试risc-v程序可以帮助我们定位并解决程序的bug。 具体步骤如下: 1. 安装gdb:首先需要确保在计算机上安装了gdb。可以通过包管理器或者从gdb的官方网站上下载并安装。 2. 编译程序:在使用gdb之前,需要将C/C++程序编译为可执行文件。例如,我们可以使用risc-v的交叉编译工具链来编译程序。 3. 运行gdb:在命令行输入"gdb"命令来启动gdb调试器。 4. 加载可执行文件:在gdb输入"file <可执行文件路径>"命令来加载要调试的可执行文件。 5. 设置断点:可以使用"break <行号或函数名>"命令在程序设置断点。这将使程序暂停在指定的位置,以便进行调试。 6. 启动程序:在gdb输入"run"命令来启动程序的执行。当程序到达设置的断点时,它将暂停执行。 7. 检查程序状态:在程序暂停时,可以使用各种gdb命令来检查当前变量的值、堆栈跟踪等信息,以了解程序的当前状态。 8. 单步执行:可以使用"next"或"step"命令逐行执行程序。这将允许我们逐步跟踪程序的执行,以查找错误。 9. 查看变量值:使用"gdb"命令可以查看当前变量的值。可以为每个变量设置监视点来观察其变化。 10. 修复错误:一旦发现了bug,可以在gdb进行相应的更改或修复。然后可以重新编译程序并再次使用gdb进行调试,以确保问题已经解决。 使用gdb调试risc-v程序可以更加高效地定位问题并进行调试。通过将gdb与其他调试技术,如断言和日志输出,结合使用,可以帮助开发人员更轻松地编写和维护risc-v程序。 ### 回答3: gdb是一款强大的调试器,可用于调试RISC-V程序。以下是使用gdb调试RISC-V程序的步骤: 首先,确保已经安装了RISC-V架构的gdb工具。如果没有安装,可以通过下载源代码并手动编译安装来获取。 1. 将需要调试的RISC-V可执行文件加载到gdb。可以使用以下命令: ``` gdb <可执行文件名> ``` 2. 设置断点来在程序的特定位置断执行。使用`break`命令来设置断点。例如,要在第30行设置断点,可以使用以下命令: ``` break main.c:30 ``` 3. 启动调试会话。可以直接使用`run`命令启动程序,或者使用`start`命令以暂停的方式启动程序(这样可以在设置完断点后再启动)。 4. 当程序在断点处断时,可以使用`next`命令逐过程执行,或者使用`step`命令逐语句执行。还可以使用`continue`命令使程序继续执行直到下一个断点或程序结束。 5. 在程序执行过程,可以使用`print`命令打印变量或表达式的值。例如,要打印变量`x`的值,可以使用以下命令: ``` print x ``` 6. 若要查看当前执行的源代码行,可以使用`list`命令。 7. 将gdb作为交互式调试器使用时,还可以使用一些其他命令来查看寄存器的值、改变变量的值等。 在调试RISC-V程序时,gdb是一个非常有用的工具。它提供了一系列命令和功能,帮助我们理解程序执行的过程,查找错误并进行调试。以上是使用gdb调试RISC-V程序的基本步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值