专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
FPGA
新手,跪求spi串口程序
2019-07-15 23:07
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
FPGA
8058
16
1774
新手,真心求助。
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
16条回答
Heng_Ji
2019-07-17 10:59
module spi_receiver
(
//global clock
input clk,
input rst_n,
//mcu spi interface
input spi_cs, //Chip select enable, default:L
input spi_sck , //Data transfer clock
input spi_mosi, //Master output and slave input
// output spi_miso, //Master input and slave output
//user interface
output reg rxd_flag,
output reg [7:0] rxd_data
);
//-------------------------------------
//mcu data sync to fpga
reg spi_cs_r0, spi_cs_r1;
reg spi_sck_r0, spi_sck_r1; //fsmc default 0; 8080 default 1; spi default 0;
reg spi_mosi_r0, spi_mosi_r1;
always@(posedge clk or negedge rst_n)
begin
if(!rst_n)
begin
spi_cs_r0 <= 1; spi_cs_r1 <= 1; //chip select enable
spi_sck_r0 <= 0; spi_sck_r1 <= 0; //data transfer clock
spi_mosi_r0 <= 0; spi_mosi_r1 <= 0; //Master output and slave input
end
else
begin
spi_cs_r0 <= spi_cs; spi_cs_r1 <= spi_cs_r0;
spi_sck_r0 <= spi_sck; spi_sck_r1 <= spi_sck_r0;
spi_mosi_r0 <= spi_mosi; spi_mosi_r1 <= spi_mosi_r0;
end
end
wire mcu_cs = spi_cs_r1;
wire mcu_data = spi_mosi_r1;
wire mcu_read_flag = (~spi_sck_r1 & spi_sck_r0) ? 1'b1 : 1'b0; //posedge of sck
wire mcu_read_done = (~spi_cs_r1 & spi_cs_r0) ? 1'b1 : 1'b0; //posedge of cs
//-------------------------------------
//sample signal, receive data
reg [3:0] rxd_cnt;
reg [7:0] rxd_data_r;
always@(posedge clk or negedge rst_n)
begin
if(!rst_n)
begin
rxd_cnt <= 0;
rxd_data_r <= 0;
end
else if(mcu_cs == 1'b0)
begin
if(mcu_read_flag) //posedge of sck
begin
rxd_data_r[3'd7 - rxd_cnt[2:0]] <= mcu_data;
rxd_cnt <= rxd_cnt + 1'b1; //0-7-8
end
else
begin
rxd_cnt <= rxd_cnt;
rxd_data_r <= rxd_data_r;
end
end
else
begin
rxd_cnt <= 0;
rxd_data_r <= rxd_data_r;
end
end
//-------------------------------------------------
//output spi receive data and receive flag
always@(posedge clk or negedge rst_n)
begin
if(!rst_n)
begin
rxd_flag <= 0;
rxd_data <= 0;
end
else if(mcu_read_done)
begin
rxd_flag <= 1'b1;
rxd_data <= rxd_data_r;
end
else
begin
rxd_flag <= 0;
rxd_data <= rxd_data;
end
end
endmodule
复制代码
加载中...
查看其它16个回答
一周热门
更多
>
相关问题
如何用FPGA驱动LCD屏?
5 个回答
请教一下各位专家如何用FPGA做eDP接口?
6 个回答
FPGA CH7301c DVI(显示器数字接口)没有数字输出
7 个回答
100颗FPGA的板子,开开眼界
6 个回答
求教自制最小系统版
10 个回答
相关文章
嵌入式领域,FPGA的串口通信接口设计,VHDL编程,altera平台
0个评论
Xilinx的FPGA开发工具——ISE开发流程
0个评论
基于FPGA的详细设计流程
0个评论
干货分享,FPGA硬件系统的设计技巧
0个评论
一种通过FPGA对AD9558时钟管理芯片进行配置的方法
0个评论
×
关闭
采纳回答
向帮助了您的知道网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
FPGA
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
×
付费偷看金额在0.1-10元之间
确定
×
关闭
您已邀请
0
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
- module spi_receiver
- (
- //global clock
- input clk,
- input rst_n,
-
- //mcu spi interface
- input spi_cs, //Chip select enable, default:L
- input spi_sck , //Data transfer clock
- input spi_mosi, //Master output and slave input
- // output spi_miso, //Master input and slave output
- //user interface
- output reg rxd_flag,
- output reg [7:0] rxd_data
- );
- //-------------------------------------
- //mcu data sync to fpga
- reg spi_cs_r0, spi_cs_r1;
- reg spi_sck_r0, spi_sck_r1; //fsmc default 0; 8080 default 1; spi default 0;
- reg spi_mosi_r0, spi_mosi_r1;
- always@(posedge clk or negedge rst_n)
- begin
- if(!rst_n)
- begin
- spi_cs_r0 <= 1; spi_cs_r1 <= 1; //chip select enable
- spi_sck_r0 <= 0; spi_sck_r1 <= 0; //data transfer clock
- spi_mosi_r0 <= 0; spi_mosi_r1 <= 0; //Master output and slave input
- end
- else
- begin
- spi_cs_r0 <= spi_cs; spi_cs_r1 <= spi_cs_r0;
- spi_sck_r0 <= spi_sck; spi_sck_r1 <= spi_sck_r0;
- spi_mosi_r0 <= spi_mosi; spi_mosi_r1 <= spi_mosi_r0;
- end
- end
- wire mcu_cs = spi_cs_r1;
- wire mcu_data = spi_mosi_r1;
- wire mcu_read_flag = (~spi_sck_r1 & spi_sck_r0) ? 1'b1 : 1'b0; //posedge of sck
- wire mcu_read_done = (~spi_cs_r1 & spi_cs_r0) ? 1'b1 : 1'b0; //posedge of cs
- //-------------------------------------
- //sample signal, receive data
- reg [3:0] rxd_cnt;
- reg [7:0] rxd_data_r;
- always@(posedge clk or negedge rst_n)
- begin
- if(!rst_n)
- begin
- rxd_cnt <= 0;
- rxd_data_r <= 0;
- end
- else if(mcu_cs == 1'b0)
- begin
- if(mcu_read_flag) //posedge of sck
- begin
- rxd_data_r[3'd7 - rxd_cnt[2:0]] <= mcu_data;
- rxd_cnt <= rxd_cnt + 1'b1; //0-7-8
- end
- else
- begin
- rxd_cnt <= rxd_cnt;
- rxd_data_r <= rxd_data_r;
- end
- end
- else
- begin
- rxd_cnt <= 0;
- rxd_data_r <= rxd_data_r;
- end
- end
- //-------------------------------------------------
- //output spi receive data and receive flag
- always@(posedge clk or negedge rst_n)
- begin
- if(!rst_n)
- begin
- rxd_flag <= 0;
- rxd_data <= 0;
- end
- else if(mcu_read_done)
- begin
- rxd_flag <= 1'b1;
- rxd_data <= rxd_data_r;
- end
- else
- begin
- rxd_flag <= 0;
- rxd_data <= rxd_data;
- end
- end
- endmodule
复制代码一周热门 更多>