当前位置:网站首页>SOC_ SD_ CMD_ FSM
SOC_ SD_ CMD_ FSM
2022-07-05 07:07:00 【Eight four one one】
Catalog
1. State machine flow chart
- CMD_STATE_STOP: In my spare time
- CMD_STATE_WAIT_SEND: Waiting to be sent
- CMD_STATE_SEND: In sending
- CMD_STATE_WAIT_RECEIVE: Waiting to receive
- CMD_STATE_RECEIVE: Receiving
2. Interface description
- Clock reset soft reset
- There are two response types ,R2 The response is long in_longresponse, Others are in_response
- Drive the state machine to work in_command_ready The signal
- sd The data signal from the card in_sd_dat And command signals in_sd_cmd
- Send and receive signals to two younger brother modules has_send_bit、has_receive_bit And the current state of the state machine current_state
- Give back sd Card response feedback signal end_command、end_command_and_response、response_timeout
input in_sd_clk;
input in_soft_reset;
input hrst_n;
//sd if
input in_longresponse;
input in_response;
input in_command_ready;
//sd bus (sd card)
input [3:0] in_sd_dat;
input in_sd_cmd;
// Give two younger brother modules
output [2:0] current_state;
output [5:0] has_send_bit;
output [7:0] has_receive_bit;
// return sd if
output end_command;
output end_command_and_response;
output response_timeout;
3. Response digit selection
- Long response R2 yes 136bit, The short response is 48bit
assign need_to_receive_bit = in_longresponse ? 8'd136 : 8'd47; // Use to compare with has received bits
4. Three stage state machine
① The first paragraph describes sub state migration , The default state is CMD_STATE_STOP
always @(posedge in_sd_clk or negedge hrst_n) begin
if(!hrst_n)
current_state <= `CMD_STATE_STOP;
else if (!in_soft_reset)
current_state <= `CMD_STATE_STOP;
else
current_state <= next_state;
end
② The second segment of the state machine , Describe state transition with combinatorial logic , Complete the corresponding transition according to the above state transition diagram
always @(*) begin
case (current_state)
`CMD_STATE_STOP:
if (in_command_ready)
next_state = `CMD_STATE_WAIT_SEND;
else
next_state = current_state;
`CMD_STATE_WAIT_SEND:
if (in_sd_dat[0])
next_state = `CMD_STATE_SEND;
else
next_state = current_state;
`CMD_STATE_SEND:
if (has_send_bit != 47)
next_state = `CMD_STATE_SEND;
else if (!in_response)
next_state = `CMD_STATE_STOP;
else
next_state = `CMD_STATE_WAIT_RECEIVE;
`CMD_SEND_WAITE_RECEIVE:
if(resp_time == 7'b0111111)
next_state = `CMD_STATE_STOP;
else if (!in_sd_cmd)
next_state = `CMD_STATE_RECEIVE;
else
next_state = `CMD_SEND_WAITE_RECEIVE;
`CMD_STATE_RECEIVE:
if(has_receive_bit == (need_to_receive_bit - 1))
next_state = `CMD_STATE_STOP;
else
next_state = `CMD_STATE_RECEIVE;
default: next_state = `CMD_STATE_STOP;
endcase
end
③ The third segment of the state machine , Describe what actions each State performs , It mainly includes the assignment of the following signals
- has_send_bit: Sent bit Count
- receive_bit_counter_en: receive bit Counter enable
- resp_time_counter_en: Wait for the timeout counter to enable
- end_command_and_response: The signal of the end of the whole cycle of the responding command
- end_command: Unresponsive command end signal of the whole cycle
- response_timeout: Wait for the timeout signal
always @(*) begin
case (current_state)
`CMD_STATE_STOP:
begin
has_send_bit = 1'b0;
receive_bit_counter_en = 1'b0;
resp_time_counter_en = 1'b0;
end_command_and_response = 1'b0;
end_command = 1'b0;
response_timeout =1'b0;
end
`CMD_STATE_WAIT_SEND:
begin
has_send_bit = 1'b0;
receive_bit_counter_en = 1'b0;
resp_time_counter_en = 1'b0;
end_command_and_response = 1'b0;
end_command = 1'b0;
response_timeout =1'b0;
end
`CMD_STATE_SEND:
begin
receive_bit_counter_en = 1'b0;
resp_time_counter_en = 1'b0;
end_command_and_response = 1'b0;
end_command = 1'b0;
response_timeout =1'b0;
if (has_send_bit !=47)
begin
send_bit_counter_en = 1'b1;
next_state = `CMD_STATE_SEND;
end
else
begin
if(!in_response)
begin
next_state = `CMD_STATE_STOP;
send_bit_counter_en = 1'b0 ;
end_command_and_response= 1'b1;
end_command = 1'b1;
end
else
begin
next_state =`CMD_STATE_WAIT_RECEIVE;
send_bit_counter_en = 1'b0;
end_command = 1'b1 ;
end
end
end
`CMD_SEND_WAITE_RECEIVE:
begin
end_command = 1'b1;
send_bit_counter_en = 1'b0;
receive_bit_counter_en = 1'b0;
resp_time_counter_en = 1'b0;
end_command_and_response = 1'b0;
response_timeout =1'b0;
if(resp_time == 7'b0111111)
response_timeout = 1'b1;
else if (!in_sd_cmd)
resp_time_counter_en = 1'b0;
else
resp_time_counter_en = 1'b1;
end
`CMD_STATE_RECEIVE:
begin
send_bit_counter_en = 1'b0;
resp_time_counter_en = 1'b0;
end_command = 1'b1;
end_command_and_response = 1'b0;
response_timeout = 1'b0;
if(has_receive_bit == (need_to_receive_bit - 1))
begin
end_command_and_response = 1'b1;
receive_bit_counter_en = 1'b0;
end
else
receive_bit_counter_en = 1'b1;
end
default:
begin
has_send_bit = 1'b0;
receive_bit_counter_en = 1'b0;
resp_time_counter_en = 1'b0;
end_command_and_response = 1'b0;
end_command = 1'b0;
response_timeout =1'b0;
end
endcase
end
5. Corresponding 3 A counter
- Send count
- Receive count
- Timeout count
always @(posedge in_sd_clk or negedge hrst_n) begin
if(!hrst_n)
has_send_bit <= 6'b0;
else if(!in_soft_reset)
has_send_bit <= 6'b0;
else
begin
if(has_send_bit == 47)
has_send_bit <= 6'b0;
else if (send_bit_counter_en == 1'b1)
has_send_bit <= has_send_bit + 1;
end
end
always @(posedge in_sd_clk or negedge hrst_n) begin
if(!hrst_n)
has_receive_bit <= 8'b0;
else if (!in_soft_reset)
has_receive_bit <= 8'b0;
else begin
if(has_receive_bit == (need_to_receive_bit - 1))
has_receive_bit <= 8'b0;
else if (receive_bit_counter_en == 1'b1)
has_receive_bit <= has_receive_bit + 1;
end
end
always @(posedge in_sd_clk or negedge hrst_n) begin
if(!hrst_n)
resp_time <= 7'b0;
else if (!in_soft_reset)
resp_time <= 7'b0;
else if( current_state == `CMD_STATE_RECEIVE)
resp_time <= 7'b0;
else if (resp_time == 63)
resp_time <= 7'b0;
else if (resp_time_counter_en == 1'b1)
resp_time <= resp_time + 1;
end
边栏推荐
- The problem of Chinese garbled code in the vscode output box can be solved once for life
- All English in the code
- 扫盲-以太网MII接口类型大全-MII、RMII、SMII、GMII、RGMII、SGMII、XGMII、XAUI、RXAUI
- Use the Paping tool to detect TCP port connectivity
- docker安装mysql并使用navicat连接
- [software testing] 06 -- basic process of software testing
- npm install -g/--save/--save-dev的区别
- 6-3 find the table length of the linked table
- 基于FPGA的一维卷积神经网络CNN的实现(八)激活层实现
- Special training of C language array
猜你喜欢
【软件测试】02 -- 软件缺陷管理
Ros2 - workspace (V)
数学分析_笔记_第8章:重积分
Marvell 88E1515 PHY loopback模式测试
. Net core stepping on the pit practice
Mutual transformation between two-dimensional array and sparse array (sparse matrix)
在本地搭建一个微服务集群环境,学习自动化部署
Rehabilitation type force deduction brush question notes D2
[software testing] 02 -- software defect management
A brief introduction to heading/pitch/roll and omega/phi/kappa
随机推荐
ROS2——Service服务(九)
Database mysql all
An article was opened to test the real situation of outsourcing companies
全局变量和静态变量的初始化
程序中的负数存储及类型转换
【软件测试】05 -- 软件测试的原则
ROS2——安装ROS2(三)
Written examination notes
【软件测试】02 -- 软件缺陷管理
小米笔试真题一
乐鑫面试流程
Rehabilitation type force deduction brush question notes D2
[tf] Unknown: Failed to get convolution algorithm. This is probably because cuDNN failed to initial
Binary search (half search)
Marvell 88E1515 PHY loopback模式测试
Qt项目中的日志库log4qt使用
Now there are HTML files and MVC made with vs (connected to the database). How can they be connected?
Use the Paping tool to detect TCP port connectivity
U-boot initialization and workflow analysis
你心目中的数据分析 Top 1 选 Pandas 还是选 SQL?