module SunComu_2( output reg pin98_te3, output reg pin99_te4, output reg pin100_te5, input wire pin103_te6, input wire rst ); reg [3:0] counter; reg clk1; //学号NRZ序列及CMI解码序列时钟 480kbps reg clk2; //CMI编码序列时钟 960kbps always@(posedge pin103_te6 or negedge rst) //counter从0到15循环 begin if(!rst) counter <= 4'b0; else if(counter == 4'b1111) begin counter <= 4'b0; end else if(pin103_te6) begin counter <= counter+1; end end //clk1 16分频 always@(posedge pin103_te6 or negedge rst) begin if(!rst) clk1 <= 0; else if(counter[3] == 0) begin clk1 <= 1'b0; end else if(counter[3] == 1) begin clk1 <= 1'b1; end end //clk2 8分频 always@(posedge pin103_te6 or negedge rst) begin if(!rst) clk2 <= 0; else if(counter[2] == 0) begin clk2 <= 1'b0; end else if(counter[2] == 1) begin clk2 <= 1'b1; end end //输出15位学号NRZ码 后四位0032 变为100000 reg [3:0] num; if(counter[3] == 0) // cmi_ceded 输出CMI编码 reg flag0 = 1'b0; always@(posedge clk2) begin flag0 <= flag0 + 1; if(flag0 == 1) pin99_te4 <= cmi_reg[0]; else if(flag0 == 0) pin99_te4<=cmi_reg[1]; end //cmi_decoded 输出CMI解码 always@(posedge clk2) begin if(cmi_reg == 2'b10) pin100_te5<=0; else if(cmi_reg==2'b00 || cmi_reg==2'b11) pin100_te5<=1; end endmodule 请添加注释
时间: 2024-02-07 08:02:01 浏览: 103
Python2中的raw_input() 与 input()
这是一个 Verilog 模块 SunComu_2,主要实现了以下功能:
- 输出三个时钟信号 pin98_te3、pin99_te4、pin100_te5。
- 输入一个时钟信号 pin103_te6 和一个复位信号 rst。
- 实现从 0 到 15 循环的计数器。
- 实现两个时钟信号 clk1 和 clk2,分别为 pin103_te6 的 16 分频和 8 分频信号。
- 输出 15 位的学号 NRZ 码,其中后四位 0032 变为 100000。
- 输出 CMI 编码和 CMI 解码信号。
注释如下:
```
module SunComu_2(
output reg pin98_te3, // 输出时钟信号
output reg pin99_te4,
output reg pin100_te5,
input wire pin103_te6, // 输入时钟信号和复位信号
input wire rst
);
reg [3:0] counter; // 从 0 到 15 循环的计数器
reg clk1; // pin103_te6 的 16 分频信号
reg clk2; // pin103_te6 的 8 分频信号
always@(posedge pin103_te6 or negedge rst) begin
if(!rst) counter <= 4'b0; // 复位计数器
else if(counter == 4'b1111) begin
counter <= 4'b0; // 计数器从 15 回到 0
end else if(pin103_te6) begin
counter <= counter+1; // 计数器加 1
end
end
// clk1 为 pin103_te6 的 16 分频信号
always@(posedge pin103_te6 or negedge rst) begin
if(!rst) clk1 <= 0; // 复位 clk1
else if(counter[3] == 0) begin
clk1 <= 1'b0; // 16 分频时钟的低电平信号
end else if(counter[3] == 1) begin
clk1 <= 1'b1; // 16 分频时钟的高电平信号
end
end
// clk2 为 pin103_te6 的 8 分频信号
always@(posedge pin103_te6 or negedge rst) begin
if(!rst) clk2 <= 0; // 复位 clk2
else if(counter[2] == 0) begin
clk2 <= 1'b0; // 8 分频时钟的低电平信号
end else if(counter[2] == 1) begin
clk2 <= 1'b1; // 8 分频时钟的高电平信号
end
end
// 输出 15 位的学号 NRZ 码,其中后四位 0032 变为 100000
reg [3:0] num;
if(counter[3] == 0) begin
// CMI 编码
reg flag0 = 1'b0;
always@(posedge clk2) begin
flag0 <= flag0 + 1;
if(flag0 == 1) pin99_te4 <= cmi_reg[0];
else if(flag0 == 0) pin99_te4 <= cmi_reg[1];
end
// CMI 解码
always@(posedge clk2) begin
if(cmi_reg == 2'b10) pin100_te5 <= 0;
else if(cmi_reg == 2'b00 || cmi_reg == 2'b11) pin100_te5 <= 1;
end
end
endmodule
```
阅读全文