蜂鸟E203系列——Linux开发工具
Vivado安装
vivado是运行工程的工具,所以必须安装

后台回复【vivado2017】可获取vivado 2017.4 | 后台回复【vivado2020】可获取vitis 2020.1
- 安装命令:打开一个终端,然后找到vivado下面的路径,执行如下命令
sudo ./xsetup
安装步骤跟windows系统下一样,将license复制进行破解,如果是vitis 2020版本,则无需解压。
- 安装JTAG驱动:在安装目录下,找到
vivado/2017.4/data/xicom/cable_drivers/lin64/install_drivers
切记:此时不要插入JTAG cable,然后执行如下指令即可安装驱动
sudo ./install_drivers
- 设置环境变量
- 在终端中,打开.bashrc文件
sudo gedit .bashrc
- 在该文件末端,添加:
source /opt/Xilinx/Vivado/2017.4/settings64.sh
- 关闭终端,并在你想创建vivado工程的目录下,右键打开终端,然后执行
vivado
iverilog安装
Icarus Verilog是一个轻量、免费、开源的Verilog编译器,基于C++实现,开发者是 Stephen Williams ,遵循 GNU GPL license 许可证,安装文件中已经包含 GTKWave支持Verilog/VHDL文件的编译和仿真,命令行操作方式,类似gcc编译器,通过testbench文件可以生成对应的仿真波形数据文件,通过自带的GTKWave可以查看仿真波形图,支持将Verilog转换为VHDL文件。

- 安装iverilog
后台回复【iverilog】可获取iverilog安装包
在有网的情况下也可以直接执行如下指令进行安装
sudo apt-get install iverilog
- 参考链接
iverilog官网:http://iverilog.icarus.com/
iverilog源码:https://github.com/steveicarus/iverilog
Icarus Verilog的工作原理:http://exasic.com/article/index.php?md=e-06
Icarus Verilog 实战:https://www.cnblogs.com/whik/p/11980103.html
Icarus Verilog + GTKWave Guide :chrome-extension://ibllepbpahcoppkjjllbabhnigcbffpi/http://inf-server.inf.uth.gr/~konstadel/resources/Icarus_Verilog_GTKWave_guide.pdf
gtkwave 安装
GTKWave是一个使用GTK的WAV文件波形查看工具,支持Verilog VCD/EVCD文件格式。
后台回复【gtkwave】可获取gtkwave安装包
- 安装gtkwave
sudo apt-get install gtkwave
- 参考链接
gtkwave 源码:https://github.com/gtkwave/gtkwave
安装iverilog_gtkwave实例
使用清华镜像站

安装 gtkwave
sudo apt-get install gtkwave

查看version

安装iverilog
sudo apt-get install iverilog
查看版本
iverilog -v

仿真实战
编译
iverilog -o wave test.v tb_test.v
生成波形文件
vvp -n wave -lxt2
打开波形文件
gtkwave testwave.vcd
生成文件如下

仿真结果

MCU JTAG安装
为了支持使用 GDB 进行交互式调试或者通过 GDB 动态下载程序到处理器中运行,需要为 FPGA 原型平台配备一个 JTAG 调试器(JTAG Debugger), E203 内核支持通过标准的 JTAG 接口对其进行调试,
参考文档:https://github.com/SI-RISCV/e200_opensource/blob/master/doc/蜂鸟E203快速上手介绍.pdf
使用“JTAG 调试器”将主机 PC 与 FPGA 开发板连接
使用如下命令查看 USB 设备的状态
lsusb // 运行该命令后会显示如下信息。
Bus 001 Device 029: ID 15ba:002a Olimex Ltd. ARM-USB-TINY-H JTAG interface
- 使用如下命令设置 udev rules 使得该 USB 设备能够被 plugdev group 所访问
sudo gedit /etc/udev/rules.d/99-openocd.rules
用 vi 打开该文件,然后添加以下内容至该文件中,然后保存退出。
SUBSYSTEM"usb", ATTR{idVendor}"15ba",
ATTR{idProduct}"002a", MODE="664", GROUP="plugdev"
SUBSYSTEM"tty", ATTRS{idVendor}"15ba",
ATTRS{idProduct}"002a", MODE="664", GROUP="plugdev"
- 使用如下命令查看该 USB 设备是否属于 plugdev group
ls /dev/ttyUSB* // 运行该命令后会显示类似如下信息。
/dev/ttyUSB0 /dev/ttyUSB1
ls -l /dev/ttyUSB1 // 运行该命令后会显示类似如下信息。
crw-rw-r-- 1 root plugdev 188, 1 Nov 28 12:53 /dev/ttyUSB1
切记:如果没有出现plugdev,则需要重启系统
- 将你自己的用户添加到 plugdev group 中
whoami
// 运行该命令能显示自己用户名,假设你的自己用户名显示为 your_user_name
// 运行如下命令将 your_user_name 添加到 plugdev group 中,比如小编的账户位anytao
sudo usermod -a -G plugdev anytao
- 确认自己的用户是否属于 plugdev group:
groups // 运行该命令后会显示类似如下信息。
... plugdev ...
只要从显示的 groups 中看到 plugdev 则意味着自己的用户属于该组,表示设置成功。
RISC-V工具链安装
参考文档:https://github.com/SI-RISCV/e200_opensource/blob/master/doc/蜂鸟E203快速上手介绍.pdf
后台回复【RISC-V Tools】可获取RISC-V Tools安装包
安装过程严格按照上述参考文档第5.2章节 《使用 HBird-E-SDK 开发和运行示例程序》即可。
蜂鸟E203系列——Linux开发工具的更多相关文章
- 蜂鸟E203系列——Linux调试(GDB+Openocd)
欲观原文,请君移步 本文基于文章<蜂鸟E203系列--利用 Hbrid-E-SDK 环境开发程序> GDB 简介 GDB(GNU Project Debugger),是 GNU 工具链中的 ...
- 蜂鸟E203系列——Linux下运行hello world例程
欲观原文,请君移步 创建程序 在 -/hbird-e-sdk-master/software 路径下创建一个"helloworld"中文件夹 在 -/hbird-e-sdk-mas ...
- Linux开发工具的使用
1. Linux开发工具的使用 Vim编译的使用 Gdb调试工具的使用 Makefile的编写 linux跟踪调试 SSH的使用 subversion的使用 1. Linux开发工具的使用 V ...
- Linux开发工具教程
今天把上个星期写的Linux开发工具相关的教程整理一下,方便阅读: 1.第一课 GCC入门: 2.第二课 GCC入门之静态库以及共享库: 3.第三课 Makefile文件的制作(上) : 4.第四课 ...
- C# 基础知识系列- 16 开发工具篇
0. 前言 这是C# 基础知识系列的最后一个内容讲解篇,下一篇是基础知识-实战篇.这一篇主要讲解一下C#程序的结构和主要编程工具. 1. 工具 工欲善其事必先利其器,在实际动手之前我们先来看看想要编写 ...
- PHPStorm.WebStrom等系列官方开发工具配置本地项目与运程服务器同步
PHPStorm.WebStrom配置本地项目与运程服务器同步 说明:PHPStorm.WebStrom等官方的系统开发工具配置本地项目与运程服务器同步的方法都基本一致没有,几乎没有什么不同之处,我们 ...
- 【Redhat系列linux防火墙工具】firewalld与iptables防火墙工具的激烈碰撞
前言 iptables与firewalld防火墙管理工具在linux发行版Redhat7系列使用较为广泛. UFW则是在linux发行版Ubuntu下进行管理防火墙的一款管理工具. 在选用防火墙工具的 ...
- Linux开发工具之Makefile(上)
二.makefile(上) 01.make工具 利用make工具可以自动完成编译工作.这些工作包括:如果修改了某几 个源文件,则只重装新编译这几个源文件:如果某个头文件被修改了,则 重新编译所有包 ...
- Linux开发工具之gcc
一.gcc入门(上) 1.gcc相关概念 gcc(GNU C Compiler)编译器,最初支持C语言,现已支持C.C++.Java.Pascal.Ada.COBOL语言等:支持多种硬件平台: ...
随机推荐
- java关键字final用法详解
final关键字在java中也是属于比较常用的一种,因此也算得上是一个比较重要的关键字,有必要对它进行深入的学习. 一.定义:用来说明最终属性,表明一个类不能派生出子类,或者成员方法不能被覆盖,或者成 ...
- Logstash下字段以及嵌套Json字段类型转换
前言 从filebeat传输到Logstash的数据,某个字段需要由string类型装换成float类型.但是不管怎么改logstash的配置文件都不生效,其实官方文档都有,但是具体细节方面的东西就得 ...
- 关于"touchstart与click同时触发"问题
点击事件可以分解成多个事件: 在移动端,手指点击一个元素,会经过:touchstart --> touchmove -> touchend --> click 由于移动设备能够同时 ...
- python中那些鲜为人知的功能特性
经常逛GitHub的可能关注一个牛叉的项目,叫 What the f*ck Python! 这个项目列出了几乎所有python中那些鲜为人知的功能特性,有些功能第一次遇见时,你会冒出 what the ...
- 解除git文件处于lock状态方法
解决办法: 去git文件夹下删除lock文件就可以
- ADB命令 使用
简介 ADB,即 Android Debug Bridge ,它是 Android 开发/测试人员不可替代的强大工具 .安卓调试桥 (Android Debug Bridge, adb),是一种可以 ...
- opencv C++极坐标变换
#include<opencv2/core/core.hpp> #include<opencv2/highgui/highgui.hpp> #include<opencv ...
- windows10安装配置WSL(Ubuntu)
windows10安装配置WSL(Ubuntu) 怎么在windows系统上用上Linux?有这么几种方法: 1. 安装双系统.这种方法的缺点是每次切换系统都需要关机.切换系统. 2. 虚拟机+Lin ...
- 如果人生也能存档——C#中的备忘录模式
大家好,老胡又和大家见面了.首先承认今天的博客有点标题党了,人生是没有存档,也没有后悔药的.有存档和后悔药的,那是游戏,不知道这是不是游戏让人格外放松的原因之一. 今天恰逢端午放假,就让我们来试着做一 ...
- Linux命令查勘进程:ps -ef |grep java
一.ps -ef |grep java 查看包含“java”的所有进程 二.涉及命令详解 ps命令将某个进程显示出来(是LINUX下最常用的也是非常强大的进程查看命令) grep命令是查找(是一种强大 ...