树莓派点亮FPGA小灯

树莓派点亮FPGA小灯

引言:

​ 本次实验的目的是通过树莓派和FPGA之间的串口通信,控制FPGA开发板上的小灯。实验将展示如何使用树莓派发送特定的字符信号,通过串口传输至FPGA,并在FPGA上实现逻辑解析,以点亮指定的小灯。这不仅验证了树莓派与FPGA之间的通信能力,也展示了数字逻辑设计在实际应用中的灵活性。

希望你在本次学习过后,能够有一定的收获!!!

推荐歌曲—雨爱-杨丞琳

​ 冲啊!!!! ٩(͡๏̯͡๏)۶ ٩(͡๏̯͡๏)۶ ٩(͡๏̯͡๏)۶

文章目录

  • 树莓派点亮FPGA小灯
    • 一、任务介绍
    • 二、树莓派介绍
      • 一、树莓派
      • 二、树莓派图片
    • 三、实验流程
      • 1、树莓派设置
      • 2、FPGA相关
    • 四、实验效果
    • 五、实验总结

一、任务介绍

  1. 了解树莓派的相关内容
  2. 实现树莓派与FPGA开发板之间的通信
  3. 使用树莓派点亮FPGA开发板上面的小灯

二、树莓派介绍

一、树莓派

a.简介:树莓派(Raspbreey Pi,RPi),慈善组织“Raspberry Pi 基金会”开发,为学生计算机编程教育而设计,基于Linux系统的单片机系统。随Windows 10 IoT的发布,有可以用运行Windows的树莓派。只有信用卡大小,却有视频、音频等功能。

c. 硬件:是一款基于ARM的微型电脑主板

内存硬盘:SD/MicroSD卡

四类接口:有1/2/4个USB接口;

一个10/100 以太网接口(A型没有网口);

视频模拟信号的电视输出接口;

和HDMI高清视频输出接口。

可连接键盘、鼠标和网线.,具备所有PC的基本功能只需接通电视机和键盘,就能执行如电子表格、文字处理、玩游戏、播放高清视频等诸多功能。Raspberry Pi B款只提供电脑板,无内存、电源、键盘、机箱或连线。

d.语言:树莓派基金会提供了基于ARM的Debian和Arch Linux的发行版供大众下载。还计划提供支持Python作为主要编程语言,支持Java、BBC BASIC (通过 RISC OS 映像或者Linux的"Brandy Basic"克隆)、C 和Perl等编程语言。

e. 发展以及应用(亚博官网摘)

img

二、树莓派图片

a.板子图片(亚博官网摘)

img

b.树莓派3b与树莓派3b+参数对比:

img

b.树莓派3b+引脚图:

img

三、实验流程

1、树莓派设置

  1. 首先确认波特率设置正确,是否为115200。(当然,其他波特率也可以的,不过代码得改一下
  2. 向microSD卡中烧录树莓派官方的镜像后,先不要急着把它插入树莓派中。
  3. 在电脑上打开microSD卡,按如下方式修改config.txt和cmdline.txt这两个文件,在config.txt文件中附加
dtoverlay=pi3-miniuart-bt

在电脑里直接打开比在树莓派里打开要好操作,不用获取权限
然后把cmdline.txt中的内容换成

dwc_otg.lpm_enable=0 console=tty1 console=serial0,115200 root=/dev/mmcblk0p2 rootfstype=ext4 elevator=deadline fsck.repair=yes rootwait

修改完成之后,我们打开树莓派

进入到树莓派的命令行当中进行如下操作
在命令行中输入如下命令

sudo chmod 777 /dev/ttyAMA0
这里要先获取权限,否则后面代码会报错

接着进入python3中,输入如下代码,这里一定一定要注意,不要安装serial库!!!因为这个是安装好的,再安装会提示serial中无Serial!

树莓派发送数据代码

import serial
import time
ser = serial.Serial('/dev/ttyAMA0',115200)while ser.isOpen() :ser.write(b"A") # 点亮第一个小灯time.sleep(1)ser.write(b"B") # 点亮第二个小灯time.sleep(1)

2、FPGA相关

led.v

module led (input  clk,input  rst_n,input  tx,output reg[7:0] led
);wire [7:0] dout;wire dout_vld;uart_rx uart_rx_inst (.clk (clk),.rst_n (rst_n),.din    (tx),.dout(dout),.dout_vld    (dout_vld));always @(posedge clk or negedge rst_n) beginif(!rst_n) beginled <= 8'b0;endelse if (dout_vld) beginif (dout == 8'h41) beginled <= 8'b0000_0001;endelse if (dout == 8'h42) beginled <= 8'b0000_0010;endelse if (dout == 8'h43) beginled <= 8'b0000_0100;endelse if (dout == 8'h44) beginled <= 8'b0000_1000;endelse if (dout == 8'h45) beginled <= 8'b0001_0000;endelse if (dout == 8'h46) beginled <= 8'b0010_0000;endelse if (dout == 8'h47) beginled <= 8'b0100_0000;endelse beginled <= led;endendend    endmodule

uart_rx.v

module uart_rx (input clk,input rst_n,input din,  // pc 发送给 FPGA 的数据output reg[7:0] dout,  // 发送给 tx 让他串行的传输出去output reg dout_vld    // 当这一次 8bit 接收完成 再传递给tx
);parameter BAUD = 5207;  // 使用波特率 115200 发送1 bit 需要的时钟周期reg din_r0; // 同步到时钟上升沿 reg din_r1; // 打拍 延时一个时钟周期 wire nedge; // 下降沿reg flag;  // 计数器计数标志 下降沿到来之后开始计数 传输数据完成停止计数reg [8:0] data; // 寄存 数据always @(posedge clk or negedge rst_n) beginif (!rst_n) begin din_r0<= 1; din_r1<=1;    endelse begin din_r0<= din; din_r1<= din_r0;   endendassign nedge = din_r1 && !din_r0; // 下降沿//  计数一个bit发送需要的时钟周期reg [20:0] cnt_bsp; wire add_cnt_bsp; wire end_cnt_bsp; always @(posedge clk or negedge rst_n) beginif (!rst_n)     cnt_bsp <= 0;else if (add_cnt_bsp)if (end_cnt_bsp)    cnt_bsp <= 0;else                cnt_bsp <= cnt_bsp + 1; else cnt_bsp <= cnt_bsp;endassign add_cnt_bsp = flag;assign end_cnt_bsp = add_cnt_bsp && (cnt_bsp == BAUD - 1);// 计数当前到了哪一 bitreg [3:0] cnt_bit;          wire add_cnt_bit;wire end_cnt_bit;always @(posedge clk or negedge rst_n)beginif (!rst_n)     cnt_bit <= 0;else if (add_cnt_bit)if (end_cnt_bit)    cnt_bit <= 0;else                cnt_bit <= cnt_bit + 1;else cnt_bit <= cnt_bit;endassign add_cnt_bit = end_cnt_bsp;assign end_cnt_bit = add_cnt_bit && (cnt_bit == 8); // 起始位 1bit 数据位 8bit always @(posedge clk or negedge rst_n) beginif (!rst_n) flag <= 0;else if(nedge) flag <= 1;else if(end_cnt_bit) flag <= 0;else flag <= flag;endalways @(posedge clk or negedge rst_n) beginif(!rst_n) data <=0;else if(cnt_bsp == BAUD>>1 && flag) data[cnt_bit] <= din; // 串并转换 LSBelse data <= data; endalways @(posedge clk or negedge rst_n) beginif(!rst_n) begindout <= 8'b0;dout_vld <= 0;endelse if(end_cnt_bit)begindout <= data[8:1]; // 第0位起始位 被舍去 dout_vld <= 1;endelse begindout <= dout;dout_vld <= 0;endendendmodule

FPGA引脚图

在这里插入图片描述

四、实验效果

在这里插入图片描述

五、实验总结

实验成果

本次实验成功实现了通过树莓派与FPGA之间的串口通信控制FPGA开发板上的小灯。实验中,树莓派作为上位机,通过发送特定的字符信号,点亮了FPGA板上的LED灯。这验证了树莓派与FPGA之间的通信能力,并且展示了数字逻辑设计在实际应用中的实用性和灵活性。

技术要点

  • 串口通信:实验中使用了树莓派的串口功能来与FPGA进行数据交换,这是实现控制的关键技术点。
  • 信号解析:FPGA端的逻辑设计能够正确解析树莓派发送的信号,这是实现特定功能的基础。
  • 硬件连接:确保树莓派与FPGA之间的物理连接正确无误,包括串口线和电源连接。

遇到的问题及解决方案

  • 串口通信不稳定:在实验过程中,遇到了串口通信不稳定的问题,通过调整波特率和检查串口线路解决了这一问题。
  • FPGA逻辑设计错误:在FPGA逻辑设计中出现了解析信号错误的问题,通过反复检查和调试逻辑电路得到了解决。

实验心得

通过本次实验,我们不仅学习了树莓派和FPGA的基本知识,还掌握了它们之间的通信方法。实验过程中遇到的问题和挑战提高了我们解决实际问题的能力。此外,实验也加深了我们对数字逻辑设计和微控制器编程的理解。

最后感谢大佬友情链接:

  • 树莓派3B+串口通信(超详细简单版)_树莓派3b串口通信-CSDN博客
  • 树莓派3B+ 引脚图说明_树莓派3b+引脚图-CSDN博客
  • 树莓派介绍&树莓派3代B+型开发板_树莓派开发板-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/692222.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[240512] x-cmd 发布 v0.3.6: (se,wkp,ddgo...)x( kimi,gemini,gpt...)

目录 x-cmd 发布 v0.3.6新增了 jina 模块新增了 ddgo 模块新增了 se 模块wkp 模块新增了 writer 模块cosmo 模块 x-cmd 发布 v0.3.6 本次版本的最新引入的功能都是目的为了进一步探索 LLM 的使用。 本版本的改进分为两类&#xff1a;资讯类模块&#xff08;Wikipedia&#xf…

李廉洋:5.12黄金原油下周一行情分析,必看策略。

黄金消息面分析&#xff1a;美国4月份潜在通胀可能出现6个月来的首次放缓&#xff0c;在一系列意外上涨之后&#xff0c;物价压力有望再次开始缓解。核心CPI预计环比上涨0.3%&#xff0c;此前三个月的涨幅均为0.4%&#xff0c;同比预计将上涨3.6%&#xff0c;尽管这一增幅将是三…

rust开发web服务器框架,github排名对比

Rocket Star最多的框架 github仓库地址&#xff1a;GitHub - rwf2/Rocket: A web framework for Rust. Rocket 是一个针对 Rust 的异步 Web 框架&#xff0c;重点关注可用性、安全性、可扩展性和速度。 Axum 异步运行时 githuh仓库地址&#xff1a;GitHub - tokio-rs/axum: …

能源效率:未来可持续发展的全球当务之急

当前全球正面临着严重的能源与气候危机&#xff0c;能源消耗不断增长导致环境污染、气候变化等问题日益严重。在这一背景下&#xff0c;提高能源效率成为了当务之急。今天&#xff0c;我们来简要探讨一下能源效率在全球可持续发展中的重要性&#xff0c;重点关注建筑物能源效率…

C语言——文件相关操作补充

一、文件读取结束的判定 当我们使用例如fgetc、fgets、fscanf、fread等函数来读取文件内容时&#xff0c;我们可能遇到需要判断文件读取的结束&#xff0c;一般情况下都是通过这些函数的返回值来判断文件读取是否结束。 1、fgetc 返回读取的字符的ASCII值&#xff0c;如果读…

微信授权登录02-移动端

目录 ## 前言 1.准备工作 1.1 网站域名 1.2 微信公众号 2.授权登录开发 2.1 前端开发 2.1.1 调起微信授权页面 ## 调起微信授权页面效果图 2.1.2 用户允许授权后回调处理 2.2 后端开发 2.2.1 根据code查询用户信息 2.2.2 自动注册登录 ## 后记 ## 前言 上一篇写…

使用Flask构建POST请求的Web应用

文章目录 准备工作创建路由处理POST请求创建表单页面运行应用结论 在Web开发中&#xff0c;处理POST请求是一项常见任务&#xff0c;特别是在构建表单提交、用户注册和数据提交等功能时。Flask是一个简单而强大的Python Web框架&#xff0c;它提供了方便的工具来处理HTTP请求&a…

bash tab 补全报错 bash: syntax error near unexpected token `(‘

使用 vim 编辑文件时&#xff0c;敲下 vim xxx 后&#xff0c;再键入 tab 键报进行补全报错 bash: syntax error near unexpected token (. 打开 bash 的命令执行详情 set -v 定位到具体的代码&#xff1a; 显然&#xff0c;代码位于 bash 补全的逻辑当中。 定位代码具体的…

大学生体质测试|基于Springboot+vue的大学生体质测试管理系统设计与实现(源码+数据库+文档)

大学生体质测试管理系统 目录 基于Springboot&#xff0b;vue的大学生体质测试管理系统设计与实现 一、前言 二、系统设计 三、系统功能设计 1系统功能模块 2管理员功能模块 3用户功能模块 4教师功能模块 四、数据库设计 五、核心代码 六、论文参考 七、最新计算…

Nios-II编程入门实验

文章目录 一 Verilog实现流水灯二 Nios实现流水灯2.1 创建项目2.2 SOPC添加模块2.3 SOPC输入输出连接2.4 Generate2.5 软件部分2.6 运行结果 三 Verilog实现串口3.1 代码3.2 引脚3.3 效果 四 Nios2实现串口4.1 sopc硬件设计4.2 top文件4.3 软件代码4.4 实现效果 五 参考资料六 …

java入门-面向对象的三大特性

面向对象三大特性 封装 什么是封装 封装 是将代码及其处理的数据绑定在一起的一种编程机制&#xff0c;该机制保证了程序和数据都不受外部干扰且不被误用。 封装的作用 访问控制符 方法传参-值传递 传参类型是基本类型 程序案例&#xff1a; public static void main(St…