Создание несимметричных часов из дифференциала на плате часов на fpg a плате VC709
Я пытаюсь использовать встроенные дифференциальные часы для моего кода verilog. Ниже приведены фрагменты моего файла verilog и ограничений. Несмотря на то, что код хорошо синтезируется, я не вижу изменения светодиодов на плате. Может кто-нибудь сказать мне, что мне здесь не хватает?
Verilog:
module leds(
input DIFF_SYS_P,
input DIFF_SYS_N,
output reg [7:0] leds=8'd0,
output clk
);
reg [31:0] count =0;
wire clk;
IBUFGDS #(
.DIFF_TERM("FALSE"),
.IBUF_LOW_PWR("TRUE"),
.IOSTANDARD("DEFAULT")
) IBUFGDS_inst (
.O(clk),
.I(DIFF_SYS_P),
.IB(DIFF_SYS_N)
);
always@(posedge clk) begin
if(count ==10) begin
leds <= 8'b10101010;
count <=count +1;
end
else begin
count<=count +1;
end
end
endmodule
Ограничения (xdc):
set_property PACKAGE_PIN G18 [get_ports DIFF_SYS_N]
set_property IOSTANDARD DIFF_SSTL15 [get_ports DIFF_SYS_N]
set_property PACKAGE_PIN H19 [get_ports DIFF_SYS_P]
set_property IOSTANDARD DIFF_SSTL15 [get_ports DIFF_SYS_P]
set_property PACKAGE_PIN AM39 [get_ports {leds[0]}]
set_property IOSTANDARD LVCMOS18 [get_ports {leds[0]}]
set_property PACKAGE_PIN AN39 [get_ports {leds[1]}]
set_property IOSTANDARD LVCMOS18 [get_ports {leds[1]}]
set_property PACKAGE_PIN AR37 [get_ports {leds[2]}]
set_property IOSTANDARD LVCMOS18 [get_ports {leds[2]}]
set_property PACKAGE_PIN AT37 [get_ports {leds[3]}]
set_property IOSTANDARD LVCMOS18 [get_ports {leds[3]}]
set_property PACKAGE_PIN AR35 [get_ports {leds[4]}]
set_property IOSTANDARD LVCMOS18 [get_ports {leds[4]}]
set_property PACKAGE_PIN AP41 [get_ports {leds[5]}]
set_property IOSTANDARD LVCMOS18 [get_ports {leds[5]}]
set_property PACKAGE_PIN AP42 [get_ports {leds[6]}]
set_property IOSTANDARD LVCMOS18 [get_ports {leds[6]}]
set_property PACKAGE_PIN AU39 [get_ports {leds[7]}]
set_property IOSTANDARD LVCMOS18 [get_ports {leds[7]}]
create_clock -period 5.000 -name DIFF_SYS_P -waveform {0.000 2.500} [get_ports DIFF_SYS_P]**
1 ответ
Во-первых, вы можете использовать IBUFGDS с IBUFG, чтобы фактически получить часы в глобальной сети синхронизации. После этого вы захотите поделить на ЛОТ больше, чем на 10, чтобы увидеть любое мигание. Я бы посоветовал подсчитать до 100 миллионов, сбросить счетчик и переключать светодиоды, а не просто устанавливать их.