Verilog编码未如预期执行。

huangapple go评论59阅读模式
英文:

Verilog Coding Not Performing as Expected

问题

使用Verilog编写并对Upduino v3.1进行编码。设置一个PLL模块,使用其输出时钟来递增一个计数器,直到达到2000,并切换输出LED。以下是代码:

module main_pll(REFERENCECLK, PLLOUTCORE, LED);

input REFERENCECLK;  
output PLLOUTCORE;
output wire LED;

wire pllout;
reg [15:0] counter;
reg temp;

pllG pllmpd(.ref_clk_i(REFERENCECLK), .rst_n_i(), .outcore_o(PLLOUTCORE), .outglobal_o());

assign pllout = PLLOUTCORE;
assign LED = temp;
initial temp <= 1'b0;
initial counter <= 16'b0;

always @(posedge pllout) begin
    counter <= counter + 1;
    if (counter == 2000) begin
        counter <= 16'b0;
        temp <= ~temp;
    end
end

endmodule

输出LED不会切换,不清楚问题可能是什么。

请问您能帮助我理解我做错了什么吗?

谢谢,
Gus

英文:

new using Verilog and coding the Upduino v3.1. Set a PLL module, using its output clock to increment a counter until it reaches 2000, and toggle the output LED. This is code:

module main_pll(REFERENCECLK, PLLOUTCORE, LED);

input REFERENCECLK;  
output PLLOUTCORE;
output wire LED;

wire pllout;
reg [15:0] counter;
reg temp;

pllG pllmpd(.ref_clk_i(REFERENCECLK), .rst_n_i(), .outcore_o(PLLOUTCORE),.outglobal_o());

assign pllout = PLLOUTCORE;
assign LED = temp;
initial temp &lt;= 1&#39;b0;
initial counter &lt;= 16`b0;

always @(posedge pllout) begin
	counter &lt;= counter + 1;
	if (counter == 2000) begin
		counter &lt;= 0;
		temp &lt;= ~temp;
	end
end

endmodule

The output LED doesn't toggle and not clear what the issue could be.

Can you please help me understanding what I am doing wrong?

Thanks,
Gus

答案1

得分: 1

ice40会将所有寄存器设置为零,并将未连接的端口连接到GND(1'b0)。因此,如果未传递任何内容给rst_n_i,PLL将不会启动。以下代码在ice40UP5K-B-EVN上进行了测试:

module main(	
	input	wire	REFERENCECLK,//12 MHz clock on pin 35 (GPLL_IN/PCLKT0_1)
	output	wire	PLLOUTCORE, // pin 28
	output	reg		LED // will blink with ~3 Hz, mapped to pin 40 (RGB1=green LED)
	);

	reg [21:0] counter;// ice40 set everything to zero as default

	always @(posedge PLLOUTCORE)
	begin
		counter <= counter + 1;
		LED 	<= counter ? LED : ~LED;
	end
		
	testpll pllmpd(
		.ref_clk_i(REFERENCECLK),
		.rst_n_i(1'b1), //this is important, else the nrst will be held at 0
		.outcore_o(PLLOUTCORE), // 24 MHz out
		.outglobal_o()
		);

endmodule
英文:

ice40 sets all registers to zero and IIRC unconnected port to GND (1'b0). Thus, the PLL will not start if nothing is passed to rst_n_i. The following code was tested on an ice40UP5K-B-EVN:

module main(	
	input	wire	REFERENCECLK,//12 MHz clock on pin 35 (GPLL_IN/PCLKT0_1)
	output	wire	PLLOUTCORE, // pin 28
	output	reg		LED // will blink with ~3 Hz, mapped to pin 40 (RGB1=green LED)
	);

reg [21:0] counter;// ice40 set everything to zero as default

always @(posedge PLLOUTCORE)
begin
	counter &lt;= counter + 1;
	LED 	&lt;= counter ? LED : ~LED;
end
	
testpll pllmpd(
	.ref_clk_i(REFERENCECLK),
	.rst_n_i(1&#39;b1), //this is important, else the nrst will be held at 0
	.outcore_o(PLLOUTCORE), // 24 MHz out
	.outglobal_o()
	);

endmodule

huangapple
  • 本文由 发表于 2023年7月18日 00:21:36
  • 转载请务必保留本文链接:https://go.coder-hub.com/76706393.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定