导入NVBoard
git仓库:https://github.com/NJU-ProjectN/nvboard
按照ysyx手册的要求,初始化NVBoard项目。
由于GitHub在国外,可能会超时无响应:
解决方案是修改代理。
当前的运行环境是VM VirtualBox
虚拟机,网卡是:网络地址转换NAT
。
主机有科学上网,可以让虚拟机连接主机的代理接口。
修改或新建~/.ssh/config
:
Host github.com
HostName github.com
User git
ProxyCommand nc -X connect -x 10.161.53.236:7897 %h %p
修改上面的ip
地址端口为主机实际地址即可。
现在可以成功下载:
安装官方仓库readme
的要求,需要添加环境变量NVBOARD_HOME
指向所在的文件目录。
亲测通过ysyx
导入会自动配置。
如果没有配置,可以参照下图,在~/.bashrc
后手动追加。
进入/ysyx-workbench/nvboard/example
目录下运行make run
,而不是直接在/ysyx-workbench
下运行。
如果报错找不到/scripts/nvboard.mk
。
那可能是环境变量没有生效,需要source ~/.bashrc
。
运行结果:
创建verilator项目
- https://veripool.org/guide/latest/example_binary.html#example-create-binary-execution
双控开关
样例给的一般是.v
作为verilator
格式后缀。
文件名必须与类名相同,否则会报错:
编译语句较长,编写Makefile
文件简化操作。
本人也是初学,目前是能成功编译。
肯定会存在一些规范问题,之后边学边解决。
VSRC_DIR=./vsrc
BUILD_DIR=./build
VERILATOR_FLAGS = --binary -j 0 -Wall -I$(VSRC_DIR) --Mdir ${BUILD_DIR}
all:
@echo "Write this Makefile by your self."
sim:
$(call git_commit, "sim RTL") # DO NOT REMOVE THIS LINE!!!
#@echo "Write this Makefile by your self."
Vtop:${VSRC_DIR}/top.v
verilator ${VERILATOR_FLAGS} ./top.v
include ../Makefile
修改top.v
内容为双控开关代码:
- 搭建verilator仿真环境 | 官方文档 (oscc.cc)
补充说一下,Ctrl b z
可以全屏显示,当前分屏方案下的,活跃窗口
再按一次可以恢复分屏方案。
编译命令为:verilator -Wall --cc --exe --build main.cpp top.v
显示波形
- Verilator Pt.2: Basics of SystemVerilog verification using C++ :: It’s Embedded! (itsembedded.com)
Makefile文件内容:
- 生成可执行文件
--trace
:允许记录波形,不开启此选项在记录波形时会报错--cc
:语言是C++
--exe --build
:生成可执行文件
- 执行可执行文件
- 查看波形
main.cpp
内容:
#include <bits/stdc++.h>
#include "Vtop.h"
#include "verilated_vcd_c.h"
signed main(){
VerilatedContext* contextp = new VerilatedContext;
Vtop* top=new Vtop(contextp);
VerilatedVcdC* tfp = new VerilatedVcdC;
contextp->traceEverOn(true);
top->trace(tfp,0);
tfp->open("wave.vcd");
while(contextp->time()<100){
int a=rand()&1;
int b=rand()&1;
top->a=a;
top->b=b;
top->eval();
tfp->dump(contextp->time());
contextp->timeInc(1);
//std::cout<<t<<" "<<(int)top->a<<" "<<(int)top->b<<" "<<(int)ctop->c<<std::endl;
assert(top->c == (a ^ b));
}
tfp->close();
return 0;
}
最后必须写tfp->close();
,亲测否则不会生成波形文件。
还需要再gtkware
左侧双击才能显示波形。
接入NVBoard
刚才的文件目录结构有很多不规范之处
参照NVBoard官方仓库的样例:
csrc
:存放.cpp
文件vsrc
:存放.v
文件constr
:存放.nxdc
文件
其中constr
文件夹默认npc
下没有给出。用于绑定nvboard
引脚。
如果你创建一个不绑定任何引脚的.nxdc
文件,比如:
top=top
并仿照官方样例的main.cpp
结构,修改之前的main.cpp
:
#include <bits/stdc++.h>
#include "Vtop.h"
#include "verilated_vcd_c.h"
#include <nvboard.h>
static TOP_NAME dut;
void nvboard_bind_all_pins(TOP_NAME* top);
static void single_cycle() {
dut.clk = 0; dut.eval();
dut.clk = 1; dut.eval();
}
signed main(){
nvboard_bind_all_pins(&dut);
nvboard_init();
VerilatedContext* contextp = new VerilatedContext;
Vtop* top=new Vtop(contextp);
VerilatedVcdC* tfp = new VerilatedVcdC;
contextp->traceEverOn(true);
top->trace(tfp,0);
tfp->open("wave.vcd");
while(contextp->time()<100){
nvboard_update();
single_cycle();
}
tfp->close();
return 0;
}
把Makefile
文件抄过来,界面大概是这个样子的:
经过stfsc
,没发现官方仓库example
目录下没有办卡前端的配置项。
也就是说,这个办卡的前端是固定的,通过.nxdc
文件绑定引脚,控制显示内容。
接入双控开关
对于板载的16
个开关,期望需求是:
- 开关拨上去的时候,上方的灯是亮的
- 开关拨下去的时候,上方的灯是灭的
顶层模块是top
,led myLed
用于创建一个led
模块,并将引脚绑定。
模块间绑定之后,还需要将顶层模块与NVboard
绑定,这一部分资料较少,可以选择STFRC
阅读源码。
编辑top.nxdc
:
top=top
ledr (LD15, LD14, LD13, LD12, LD11, LD10, LD9, LD8, LD7, LD6, LD5, LD4, LD3, LD2, LD1, LD0)
sw (SW15, SW14, SW13, SW12, SW11, SW10, SW9, SW8, SW7, SW6, SW5, SW4, SW3, SW2, SW1, SW0)
左侧是ledr
和sw
的顶层模块的输入输出引脚
- 命名由开发者自定义
右侧的(LD15, ..., LD0)
是将引脚绑定到NVboard
的对应位置
- 命名在
NVboard
中写死
运行效果: