FPGA硬件工程师Verilog面试题
Posted 嵌入式基地
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了FPGA硬件工程师Verilog面试题相关的知识,希望对你有一定的参考价值。
✅作者简介:大家好我是:嵌入式基地,是一名嵌入式工程师,希望一起努力,一起进步!
📃个人主页:嵌入式基地
🔥系列专栏:FPGA Verilog 习题专栏
💬网上关于嵌入式的面试练习网站很少,这里给大家推荐一款Verilog 在线刷题神器,从基础到大厂面试题👉点击跳转刷题网站进行注册学习
微信公众号:嵌入式基地
FPGA硬件工程师Verilog面试题(五)
习题一:输入序列连续的序列检测
描述
- 请编写一个序列检测模块,检测输入信号a是否满足01110001序列,当信号满足该序列,给出指示信号match。
模块的接口信号图如下:
-
模块的时序图如下:
-
请使用Verilog HDL实现以上功能,并编写testbench验证模块的功能
输入描述
- clk:系统时钟信号
- rst_n:异步复位信号,低电平有效
- a:单比特信号,待检测的数据
输出描述
- match:当输入信号a满足目标序列,该信号为1,其余时刻该信号为0
代码实现
`timescale 1ns/1ns
module sequence_detect(
input clk,
input rst_n,
input a,
output reg match
);
reg [7:0] a_tem;
always @(posedge clk or negedge rst_n)
if (!rst_n)
begin
match <= 1'b0;
end
else if (a_tem == 8'b0111_0001)
begin
match <= 1'b1;
end
else
begin
match <= 1'b0;
end
always @(posedge clk or negedge rst_n)
if (!rst_n)
begin
a_tem <= 8'b0;
end
else
begin
a_tem <= a_tem[6:0],a;
end
endmodule
习题二:含有无关项的序列检测
描述
-
请编写一个序列检测模块,检测输入信号a是否满足011XXX110序列(长度为9位数据,前三位是011,后三位是110,中间三位不做要求),当信号满足该序列,给出指示信号match。
-
程序的接口信号图如下:
-
程序的功能时序图如下:
-
请使用Verilog HDL实现以上功能,并编写testbench验证模块的功能。 要求代码简洁,功能完整。
输入描述
- clk:系统时钟信号
- rst_n:异步复位信号,低电平有效
- a:单比特信号,待检测的数据
输出描述
- match:当输入信号a满足目标序列,该信号为1,其余时刻该信号为0
代码实现
`timescale 1ns/1ns
module sequence_detect(
input clk,
input rst_n,
input a,
output match
);
reg [8:0] a_tem;
reg match_f;
reg match_b;
always @(posedge clk or negedge rst_n)
if (!rst_n)
begin
match_f <= 1'b0;
end
else if (a_tem[8:6] == 3'b011)
begin
match_f <= 1'b1;
end
else
begin
match_f <= 1'b0;
end
always @(posedge clk or negedge rst_n)
if (!rst_n)
begin
match_b <= 1'b0;
end
else if (a_tem[2:0] == 3'b110)
begin
match_b <= 1'b1;
end
else
begin
match_b <= 1'b0;
end
always @(posedge clk or negedge rst_n)
if (!rst_n)
begin
a_tem <= 9'b0;
end
else
begin
a_tem <= a_tem[7:0],a;
end
assign match = match_b && match_f;
endmodule
习题三:不重叠序列检测
描述
-
请编写一个序列检测模块,检测输入信号(a)是否满足011100序列, 要求以每六个输入为一组,不检测重复序列,例如第一位数据不符合,则不考虑后五位。一直到第七位数据即下一组信号的第一位开始检测。当信号满足该序列,给出指示信号match。当不满足时给出指示信号not_match。
-
模块的接口信号图如下:
-
模块的时序图如下:
-
请使用Verilog HDL实现以上功能,要求使用状态机实现,画出状态转化图。并编写testbench验证模块的功能。
输入描述
- clk:系统时钟信号
- rst_n:异步复位信号,低电平有效
- a:单比特信号,待检测的数据
输出描述
- match:当输入信号a满足目标序列,该信号为1,其余时刻该信号为0
- not_match:当输入信号a不满足目标序列,该信号为1,其余时刻该信号为0
代码实现
`timescale 1ns/1ns
module sequence_detect(
input clk,
input rst_n,
input data,
output reg match,
output reg not_match
);
parameter ZERO=0, ONE=1, TWO=2, THREE=3, FOUR=4, FIVE=5, SIX=6, FAIL=7;
reg [2:0] state, nstate;
reg [2:0] cnt;
always@(posedge clk or negedge rst_n) begin
if(~rst_n)
cnt <= 0;
else
cnt <= cnt==6? 1: cnt+1;
end
always@(posedge clk or negedge rst_n) begin
if(~rst_n)
state <= ZERO;
else
state <= nstate;
end
always@(*) begin
if(~rst_n)
nstate = ZERO;
else
case(state)
ZERO : nstate = data? FAIL : ONE;
ONE : nstate = data? TWO : FAIL;
TWO : nstate = data? THREE: FAIL;
THREE: nstate = data? FOUR : FAIL;
FOUR : nstate = data? FAIL : FIVE;
FIVE : nstate = data? FAIL : SIX;
SIX : nstate = data? FAIL : ONE;
FAIL : nstate = cnt==6&&data==0? ONE: FAIL;
default: nstate = ZERO;
endcase
end
always@(*) begin
if(~rst_n) begin
match = 0;
not_match = 0;
end
else begin
match = cnt==6&&state==SIX;
not_match = cnt==6&&state==FAIL;
end
end
endmodule
习题四:输入序列不连续的序列检测
描述
-
请编写一个序列检测模块,输入信号端口为data,表示数据有效的指示信号端口为data_valid。当data_valid信号为高时,表示此刻的输入信号data有效,参与序列检测;当data_valid为低时,data无效,抛弃该时刻的输入。当输入序列的有效信号满足0110时,拉高序列匹配信号match。
-
模块的接口信号图如下:
-
模块的时序图如下:
-
请使用状态机实现以上功能,画出状态转移图并使用Verilog HDL编写代码实现以上功能,并编写testbench验证模块的功能.
输入描述
- clk:系统时钟信号
- rst_n:异步复位信号,低电平有效
- data:单比特信号,待检测的数据
- data_valid:输入信号有效标志,当该信号为1时,表示输入信号有效
输出描述
- match:当输入信号data满足目标序列,该信号为1,其余时刻该信号为0
代码实现
`timescale 1ns/1ns
module sequence_detect(
input clk,
input rst_n,
input data,
input data_valid,
output reg match
);
reg [3:0] data_r;
always@(posedge clk or negedge rst_n) begin
if(~rst_n)
data_r <= 4'b0;
else
data_r <= data_valid? data_r[2:0], data: data_r;
end
always@(posedge clk or negedge rst_n) begin
if(~rst_n)
match <= 0;
else
match <= data_r[2:0]==3'b011 && data==1'b0 && data_valid;
end
// always@(posedge clk or negedge rst_n) begin
// if(~rst_n)
// match <= 0;
// else
// match <= data_r==4'b0110;
// end
endmodule
结束语
你想要的牛客都有,各种大厂面试真题在等你哦!快快通过下方链接注册加入刷题大军吧!
💬刷题神器,从基础到大厂面试题👉点击跳转刷题网站
以上是关于FPGA硬件工程师Verilog面试题的主要内容,如果未能解决你的问题,请参考以下文章