【Arduino&Quartus】在小脚丫STEP CYC10上安装PulseRain Reindeer并在软核上运行基础功能

【Arduino&Quartus】在小脚丫STEP CYC10上安装PulseRain Reindeer并在软核上运行基础功能

一、将Reindeer软核下载到STEP CYC10

(一)下载PulseRain Reindeer软核

c 复制代码
git clone https://github.com/PulseRain/Reindeer_Step.git

可通过TurtoiseGit使用此命令下载软核到电脑,或直接在Github中下载压缩包都可。

(二)配置Reindeer软核到开发板

在你的文件存放位置,使用Quartus打开~\Reindeer_Step\build\par\step_cyc10中的step_cyc10.qpf文件,千万不要编译就只是打开就行。

1.将sof文件转换为jic文件

因为sof文件是下载到FPGA的SRAM,掉电会丢失,在CYC10上板载了一块SPI Flash,我们可以将sof文件转换为jic文件,通过JTAG下载到Flash中,每次上电时FPGA会将配置数据读取到SRAM中运行。

①打开File中的Convert ......

②随后按如下配置

其中点击Flash Loader添加10CL016Y时需要点击Add Device,而SOF Data则需要点击Add File,其中的File则是在~\Reindeer_Step-master\build\par\step_cyc10\output_files目录下的step_cyc10.sof文件,添加进去即可。

最后点击生成即可,不过可能下载下来的output里面就有jic文件。

2.将jic文件下载到FPGA中

打开后可能不是jic文件,则需要删除sof,再将jic文件添加进来,添加后界面如图所示,需要勾选上在Start

  • 注意需要将Mirco USB查到FPGA的上面那个口,Quartus才能识别到USB,上面那个是供电+编程,下面那个是供电+串口
    具体可看下图:

    如果下载完后,如我上面那个图一样,报success,则下载成功。

二、Arduino编写流水灯并下载到开发板中运行

(一)Arduino中安装板卡支持包

打开Arduino IDE,打开 文件------首选项------附加开发板管理器网址,添加如下链接: https://github.com/PulseRain/Arduino_RISCV_IDE/raw/master/package_pulserain.com_index.json

点击确定,确定后如果报错,下载失败,则需要配置代理网络

此处需要个人发挥自己的能力,恕不详述。

下载成功之后,打开 工具------开发板------开发板管理器,在搜索框中输入REINDEER,安装PACKAGE。

下载安装完成后在板卡管理器中有STEP CYC10 Board这个选项

(二)编写流水灯

在Arduino中编写好程序,以下是流水灯

c 复制代码
volatile uint8_t* const R_GPIO = (uint8_t*)0x20000018;
 
#define P0  (R_GPIO[0])
#define P1  (R_GPIO[1])
#define P2  (R_GPIO[2])
#define P3  (R_GPIO[3])
 
int kkk[1*1024]={999, 1000, 10001, 1898, 8888};
 
void setup() {
  // put your setup code here, to run once:
   Serial.print(" ===================="); 
   P3 = 0xAA;
   delay (1000);
 
}
 
int t = 0;
 
uint32_t i = 0;
uint8_t led_position = 0;
 
void loop() {
 
 Serial.print (i);
 i = (i + 1) %(1024);
 Serial.print(" ===================="); 
 kkk [i] = kkk [i] + i;
 Serial.print (kkk[i]);
 Serial.println (" ");
 delay (600);
 led_position = (led_position + 1) % 8;
 
 P3 = ~(1 << led_position);
}
  • 此处小脚丫STEP社区中的代码中:R_GPIO应为REG_GPIO,不过可能因为Arduino更新后,REG_GPIO这个变量名被使用了,所以我改为了R_GPIO

(三)上传程序

随后点击上传按钮→,软件会对程序编译后下载到板子

随后可见FPGA板子,LED灯流水亮灭。

三、总结

老资料坑都有点多,需要一个一个解决问题,其次遇到实在没办法的问题,可以直接去软件论坛发帖求助,这样比较简单,或者直接退版本。

四、引用

在小脚丫FPGA板上玩转开源农场(FARM)FPGA+Arduino+RISC-V+Make

相关推荐
怪小庄吖12 小时前
翻译:How do I reset my FPGA?
经验分享·嵌入式硬件·fpga开发·硬件架构·硬件工程·信息与通信·信号处理
海涛高软1 天前
FPGA同步复位和异步复位
fpga开发
FakeOccupational2 天前
fpga系列 HDL:verilog 常见错误与注意事项 quartus13 bug 初始失效 reg *** = 1;
fpga开发·bug
zxfeng~2 天前
AG32 FPGA 的 Block RAM 资源:M9K 使用
fpga开发·ag32
whik11942 天前
FPGA 开发工作需求明确:关键要点与实践方法
fpga开发
whik11942 天前
FPGA开发中的团队协作:构建高效协同的关键路径
fpga开发
南棱笑笑生2 天前
20250117在Ubuntu20.04.6下使用灵思FPGA的刷机工具efinity刷机
fpga开发
我爱C编程2 天前
基于FPGA的BPSK+costas环实现,包含testbench,分析不同信噪比对costas环性能影响
fpga开发·verilog·锁相环·bpsk·costas环
移知3 天前
备战春招—数字IC、FPGA笔试题(2)
fpga开发·数字ic
楠了个难3 天前
以太网实战AD采集上传上位机——FPGA学习笔记27
笔记·学习·fpga开发