1、 答题记录
1.规约运算符
两两按位做运算,& | ^ 等。按位异或可以用来进行奇偶校验操作。
例如:
`timescale 1ns/1ns
//对输入的32位数据进行奇偶校验,根据sel输出校验结果(1 输出奇校验,0 输出偶校验)
module odd_sel
(
input [31:0] bus,
input sel,
output check
);
//*************code***********//
wire panduan;
wire odd;
assign panduan = ^bus; //规约运算
assign check = sel ? panduan : ~panduan ;
//*************code***********//
endmodule
2.generate for 语句
例如:
`timescale 1ns/1ns
module gen_for_module
(
input [7:0] data_in,
output [7:0] data_out
);
genvar i;
generate
for(i=0;i<=7;i=i+1)
begin : loop
assign data_out[i] = data_in[7-i];
end
endgenerate
endmodule
3.拼接赋值运算{{}}
例如:
给定五个1bit信号(a、b、c、d 和 e),生成两种25位的数据: 一种是将信号复制五次后连接起来aaaaabbbbb…,
一种是将信号连接起来复制五次成为abcdeabcde… 。比较两个25位信号,如果两个信号的同样位置的位相等,则输出1。
这道题主要是考察拼接符的灵活运用
{} 代表拼接 例如 {a,b,c,d,e} 代表将这几位拼接起来
{{ }} 代表复制 例如 {{5{a}} 代表将a 复制五次.
`timescale 1ns/1ns
module top_module
(
input a, b, c, d, e,
output [24:0] out
);
wire [24:0] res1,res2;
assign res1 = {{5{a}},{5{b}},{5{c}},{5{d}},{5{e}}};
assign res2 = {5{a,b,c,d,e}};
assign out = ~res1^res2;
endmodule
4.函数用法
例如:
用函数实现一个4bit数据大小端转换的功能。实现对两个不同的输入分别转换并输出。
`timescale 1ns/1ns
module function_mod
(
input [3:0]a,
input [3:0]b,
output [3:0]c,
output [3:0]d
);
assign c = mod(a);
assign d = mod(b);
integer i;
function [3:0] mod;
input [3:0] a;
begin
for(i=0;i<=3;i=i+1)
begin
mod[i] = a[3-i];
end
end
endfunction
endmodule