专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
FPGA
新手,跪求spi串口程序
2019-07-15 23:07
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
FPGA
8059
16
1774
新手,真心求助。
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
16条回答
Heng_Ji
2019-07-17 12:07
module spi_transfer
(
//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 reg spi_miso, //Master input and slave output
//user interface
input txd_en, //Transfer enable
input [7:0] txd_data, //Transfer data
output reg txd_flag //Transfer complete signal
);
//-------------------------------------
//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 1;
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
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;
end
end
wire mcu_cs = spi_cs_r1;
wire mcu_write_flag = (spi_sck_r1 & ~spi_sck_r0) ? 1'b1 : 1'b0; //nededge of sck
wire mcu_write_done = (~spi_cs_r1 & spi_cs_r0) ? 1'b1 : 1'b0; //posedge of cs
//-------------------------------------
//shift signal, transfer data
localparam SPI_MISO_DEFAULT = 1'b1;
localparam T_IDLE = 1'b0; //test the flag to transfer data
localparam T_SEND = 1'b1; //spi transfer data
reg [1:0] txd_state;
reg [3:0] txd_cnt;
always@(posedge clk or negedge rst_n)
begin
if(!rst_n)
begin
spi_miso <= SPI_MISO_DEFAULT;
txd_cnt <= 0;
txd_state <= 0;
end
else
begin
case(txd_state)
T_IDLE: //test the flag to transfer data
begin
spi_miso <= SPI_MISO_DEFAULT;
txd_cnt <= 0;
if(txd_en)
txd_state <= T_SEND;
else
txd_state <= T_IDLE;
end
T_SEND: //spi transfer data
begin
if(mcu_write_done == 1'b1)
txd_state <= T_IDLE;
else
txd_state <= T_SEND;
if(mcu_cs == 1'b0)
begin
if(mcu_write_flag) //spi sck negedge
begin
spi_miso <= txd_data[3'd7 - txd_cnt[2:0]];
txd_cnt <= txd_cnt + 1'b1;
end
else
begin
spi_miso <= spi_miso;
txd_cnt <= txd_cnt;
end
end
else
begin
spi_miso <= SPI_MISO_DEFAULT;
txd_cnt <= 0;
end
end
endcase
end
end
//-------------------------------------------------
//output spi transfer flag
always@(posedge clk or negedge rst_n)
begin
if(!rst_n)
txd_flag <= 0;
else
txd_flag <= mcu_write_done;
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_transfer
- (
- //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 reg spi_miso, //Master input and slave output
- //user interface
- input txd_en, //Transfer enable
- input [7:0] txd_data, //Transfer data
- output reg txd_flag //Transfer complete signal
- );
- //-------------------------------------
- //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 1;
- 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
- 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;
- end
- end
- wire mcu_cs = spi_cs_r1;
- wire mcu_write_flag = (spi_sck_r1 & ~spi_sck_r0) ? 1'b1 : 1'b0; //nededge of sck
- wire mcu_write_done = (~spi_cs_r1 & spi_cs_r0) ? 1'b1 : 1'b0; //posedge of cs
- //-------------------------------------
- //shift signal, transfer data
- localparam SPI_MISO_DEFAULT = 1'b1;
- localparam T_IDLE = 1'b0; //test the flag to transfer data
- localparam T_SEND = 1'b1; //spi transfer data
- reg [1:0] txd_state;
- reg [3:0] txd_cnt;
- always@(posedge clk or negedge rst_n)
- begin
- if(!rst_n)
- begin
- spi_miso <= SPI_MISO_DEFAULT;
- txd_cnt <= 0;
- txd_state <= 0;
- end
- else
- begin
- case(txd_state)
- T_IDLE: //test the flag to transfer data
- begin
- spi_miso <= SPI_MISO_DEFAULT;
- txd_cnt <= 0;
- if(txd_en)
- txd_state <= T_SEND;
- else
- txd_state <= T_IDLE;
- end
- T_SEND: //spi transfer data
- begin
- if(mcu_write_done == 1'b1)
- txd_state <= T_IDLE;
- else
- txd_state <= T_SEND;
-
- if(mcu_cs == 1'b0)
- begin
- if(mcu_write_flag) //spi sck negedge
- begin
- spi_miso <= txd_data[3'd7 - txd_cnt[2:0]];
- txd_cnt <= txd_cnt + 1'b1;
- end
- else
- begin
- spi_miso <= spi_miso;
- txd_cnt <= txd_cnt;
- end
- end
- else
- begin
- spi_miso <= SPI_MISO_DEFAULT;
- txd_cnt <= 0;
- end
- end
- endcase
- end
- end
- //-------------------------------------------------
- //output spi transfer flag
- always@(posedge clk or negedge rst_n)
- begin
- if(!rst_n)
- txd_flag <= 0;
- else
- txd_flag <= mcu_write_done;
- end
- endmodule
复制代码一周热门 更多>