weiqi7777

riscv elf文件中插入section

对于一个elf文件,我们可以通过readelf命令,搭配-S选项,查看该elf的section。一、源代码比如对应如下的汇编文件,文件中定义了两个section。.text.global_start_start:lbx5,0(sp)lbx6,0(sp)lbx7,0(sp)lbx8,0(sp)lbx9,0(sp)lbx10,0(sp)lbx11,0(sp).data.word0x55555555

vcs产生code coverage与function coverage

vcs仿真中,可以产生以下两类coverage:codecoveragefunctioncoverage对于codecoverage,在编译和仿真需要加额外参数。对于functioncoverage,编译和仿真不需要加额外参数。一、codecoveragecodecoverage包含以下一些coverage:linecoveragetogglecoverageconditioncove

服务器集群yum安装软件方法

在一个服务器集群中,大多数服务器是不能联网的,因此不能直接使用yum安装软件。这样的话,就造成安装软件非常麻烦。如果服务器集群中,有一台服务器可以上网。那么,可以让这台可以上网的服务器作为代理,其他不能联网的服务器,通过这台代理服务器上网,实现yum安装软

UVM中如何让一个sequence发送两个包给两个sequencer

在验证中,可能会有如下一个需求。有两个sequencer,各自需要接收一个包。但是接收的包类型不一样。期望环境只有一个sequence,该sequence,同时发送两个包,给对应的两个sequencer对于这样的需求,如何在uvm中实现了?对于这个问题,就需要用到如下知识点:virtualsequ

交互式仿真下dve和verdi中查看二维数组值

在交互式仿真中,可以通过dve工具和verdi工具,查看二维数组的值。但是不能查看稀疏数组的值。什么是稀疏数组,类似于如下定义:reg[7:0]memory[bit[63:0]]一、dve工具启动dve工具,进行交互式仿真后。首先打开需要查看二维数组的源代码,然后选择该二维数组,右键选择s

linux源码安装m4,autoconf,automake,libtool工具

linux中,会有几个常用的工具:m4autoconfautomakelibtool下面介绍下,如何在linux中,源码安装这些工具。一、安装m4-1.4.18m4源代码地址:http://mirrors.kernel.org/gnu/m4/目前,最新版本1.4.18。安装命令wgethttp://mirrors.kernel.org/gnu/m4/m4-1.4.18.tar.gz&

jenkins _curses.error setupterm could not find terminal

在使用jenkins的pipeline时,如果执行的命令中,有用到nurse库,就有如下错误信息,造成pipeline失败。_curses.error:setupterm:couldnotfindterminal使用nurse库,会在终端界面,显示字符界面。如著名的menuconfig,就是用的nurse来实现的。但是jenkins执行pipeline时

vcs回退交互式仿真

vcs联和verdi,支持回退交互式仿真。使用交互式仿真,确保如下环境变量有设置VCS_HOMEVERDI_HOMEvcs在编译的时候,要加入如下选项-lca-kdb-debug_access+all+reverse仿真的时候,在simv可执行程序后面,加入-verdi选项。./simv-verdi启动verdi之后,需要打开verdi的回退

centos6.5 安装wps linux

wps现在有linux版本,linux里面自带的soffice工具,又感觉比较挫,因此考虑在linux中安装wps工具,来操作excel和work文档。安装的linux系统为64位系统的centos6.5,因为该系统没有联网,因此是离线安装。本来以为安装很容易,其实,在安装过程中,遇到了不少坑。特此进

riscv架构printf函数传参研究

printf函数,作为一个经典的函数,经常在c程序中,被使用。printf函数和一般函数的区别在于,参数不定,因此要使用可变参数方式传参。从网上查阅的资料,得知,可变参数传参,是使用栈进行传参。将参数,压入栈中,后续使用参数,再从栈中将参数给弹出来。但是在riscv架

python3出现parser stack overflow解决方案

在使用python3的时候,执行程序,出现了如下错误:s_push:parserstackoverflows_push:parserstackoverflows_push:parserstackoverflows_push:parserstackoverflows_push:parserstackoverflow在程序里面,有使用递归算法。通过在网上查找解决办法,最终找到了解决办法。

riscv32位架构如何进行64位加减运算

在rv32架构下,一个64位变量,是要用2个寄存器保存的。在c程序中,我们是可以直接对64位变量进行加减操作的。那么rv32下,又是如何实现64位加减运算的了?下面来讨论一下。一、64位加测试程序:intmain(){int64_ta=0xbbbbbbbb;int64_tb=0xcccccccc;int64_tc=a+b;printf(

gdb no symbol in current context研究

使用gdb调试程序,当我们需要查看一个变量值,使用p变量,会提示nosymbolxxxincurrentcontext。查阅资料,得知,需要再编译的时候,加上-g选项,并且不能加-On选项,即关闭优化。但是即使使用-g选项并且关闭优化,编译程序,使用gdb调试,依然会出现上述问题。这说明了

riscv-gcc multilib研究

编译riscv工具链的时候,在configure阶段,有--enable_multilib选项,该选项会控制,生成多个仿真库。通过./configure-h,可以查看--enable_multilib选项的功能。--enable-multilibbuildbothRV32andRV64runtimelibraries[--disable-multilib]下面,就要探究以下,这个选

linux module工具安装与使用

linux中的环境变量管理,让人烦不胜烦。但是有了module这个开源的环境变量管理工具,就让linux中的环境变量管理变得容易。以下链接,是module工具的介绍:https://modules.readthedocs.io/en/latest/index.html一、安装module工具,依赖tcl工具,因此首先要安装tcl工具