-
-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathPCXT.sdc
101 lines (79 loc) · 5.88 KB
/
PCXT.sdc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
# core specific constraints
# Clocks
set CLOCK_14_318 ${topmodule}clk_14_318|q
set CLOCK_4_77 ${topmodule}clk_normal|clk_out|q
set PCLK ${topmodule}peripheral_clock|q
if {[info exists cyclonev] && ($cyclonev==1)} {
set CLOCK_CORE ${topmodule}pll|pll_inst|altera_pll_i|cyclonev_pll|counter[0].output_counter|divclk
set CLOCK_VGA_MDA ${topmodule}pllvideo|pll_inst|altera_pll_i|cyclonev_pll|counter[1].output_counter|divclk
set CLOCK_VGA_CGA ${topmodule}pllvideo|pll_inst|altera_pll_i|cyclonev_pll|counter[0].output_counter|divclk
set CLOCK_UART ${topmodule}pll|pll_inst|altera_pll_i|cyclonev_pll|counter[2].output_counter|divclk
set CLOCK_OPL ${topmodule}pllvideo|pll_inst|altera_pll_i|cyclonev_pll|counter[2].output_counter|divclk
set CLOCK_CHIP ${topmodule}pll|pll_inst|altera_pll_i|cyclonev_pll|counter[1].output_counter|divclk
create_generated_clock -name sdramclk -source [get_pins $CLOCK_CHIP] [get_ports $RAM_CLK]
} else {
set CLOCK_CORE ${topmodule}pll|altpll_component|auto_generated|pll1|clk[0]
set CLOCK_CHIP ${topmodule}pll|altpll_component|auto_generated|pll1|clk[1]
set CLOCK_UART ${topmodule}pll|altpll_component|auto_generated|pll1|clk[3]
set CLOCK_OPL ${topmodule}pll|altpll_component|auto_generated|pll1|clk[4]
set CLOCK_VGA_CGA ${topmodule}pllvideo|altpll_component|auto_generated|pll1|clk[0]
set CLOCK_VGA_MDA ${topmodule}pllvideo|altpll_component|auto_generated|pll1|clk[1]
create_generated_clock -name sdramclk -source ${topmodule}pll|altpll_component|auto_generated|pll1|clk[2] [get_ports $RAM_CLK]
}
# if {[info exists mist] && ($mist==1)} { } else { }
# Uncommenting following line gives more timing setup delays
#create_generated_clock -name clk_14_318 -source $CLOCK_VGA_CGA -divide_by 2 [get_pins $CLOCK_14_318]
create_generated_clock -name clk_4_77 -source [get_pins $CLOCK_14_318] -divide_by 3 -duty_cycle 33 [get_pins $CLOCK_4_77]
create_generated_clock -name peripheral_clock -source [get_pins $CLOCK_4_77] -divide_by 2 [get_pins $PCLK]
# SPLASH
set_false_path -to [get_registers {PCXT:guest|splash_off}]
# i2sclk moved from constrainst.sdc
create_generated_clock -name i2sclk -source $CLOCK_CHIP -divide_by 32 [get_registers {audio_top:audio_i2s|tcount[4]}]
# UART
set_false_path -from [get_clocks $CLOCK_CHIP] -to [get_clocks $CLOCK_UART]
set_false_path -from [get_clocks $CLOCK_UART] -to [get_clocks $CLOCK_CHIP]
# VIDEO
# NOTE: If the system clock and video clock are synchronous, the following description is not necessary.
set VIDEO_TO_SYSYEM_DELAY 10
set_false_path -to [get_registers [list ${topmodule}mda_mode_video_ff \
${topmodule}screen_mode_video_ff[*]]]
set_max_delay -from [get_registers ${topmodule}u_CHIPSET|u_PERIPHERALS|video_io_address[*]] \
-to [get_registers [list ${topmodule}u_CHIPSET|u_PERIPHERALS|mda_io_address_1[*] \
${topmodule}u_CHIPSET|u_PERIPHERALS|cga_io_address_1[*]]] $VIDEO_TO_SYSYEM_DELAY
set_max_delay -from [get_registers ${topmodule}u_CHIPSET|u_PERIPHERALS|video_io_data[*]] \
-to [get_registers [list ${topmodule}u_CHIPSET|u_PERIPHERALS|mda_io_data_1[*] \
${topmodule}u_CHIPSET|u_PERIPHERALS|cga_io_data_1[*]]] $VIDEO_TO_SYSYEM_DELAY
set_max_delay -from [get_registers ${topmodule}u_CHIPSET|u_PERIPHERALS|video_io_write_n] \
-to [get_registers [list ${topmodule}u_CHIPSET|u_PERIPHERALS|mda_io_write_n_1 \
${topmodule}u_CHIPSET|u_PERIPHERALS|cga_io_write_n_1]] $VIDEO_TO_SYSYEM_DELAY
set_max_delay -from [get_registers ${topmodule}u_CHIPSET|u_PERIPHERALS|video_io_read_n] \
-to [get_registers [list ${topmodule}u_CHIPSET|u_PERIPHERALS|mda_io_read_n_1 \
${topmodule}u_CHIPSET|u_PERIPHERALS|cga_io_read_n_1]] $VIDEO_TO_SYSYEM_DELAY
set_max_delay -from [get_registers ${topmodule}u_CHIPSET|u_PERIPHERALS|video_address_enable_n] \
-to [get_registers [list ${topmodule}u_CHIPSET|u_PERIPHERALS|mda_address_enable_n_1 \
${topmodule}u_CHIPSET|u_PERIPHERALS|cga_address_enable_n_1]] $VIDEO_TO_SYSYEM_DELAY
set_max_delay -to [get_registers [list ${topmodule}u_CHIPSET|u_PERIPHERALS|MDA_CRTC_DOUT_1[*] \
${topmodule}u_CHIPSET|u_PERIPHERALS|MDA_CRTC_OE_1 \
${topmodule}u_CHIPSET|u_PERIPHERALS|CGA_CRTC_DOUT_1[*] \
${topmodule}u_CHIPSET|u_PERIPHERALS|CGA_CRTC_OE_1]] $VIDEO_TO_SYSYEM_DELAY
# SDRAM
set_input_delay -clock { sdramclk } -max 6 [get_ports $RAM_IN]
set_input_delay -clock { sdramclk } -min 3 [get_ports $RAM_IN]
set_output_delay -clock { sdramclk } -max 2 [get_ports $RAM_OUT]
set_output_delay -clock { sdramclk } -min 1.5 [get_ports $RAM_OUT]
# sdramclk -> clk_chipset
set_multicycle_path -from { sdramclk } -to [get_clocks ${topmodule}pll|altpll_component|auto_generated|pll1|clk[1]] -setup -end 2
################################
# DeMiSTify constrainsts
# Clock groups
set_clock_groups -asynchronous -group [get_clocks spiclk] -group [get_clocks $CLOCK_CHIP]
set_clock_groups -asynchronous -group [get_clocks $hostclk] -group [get_clocks $CLOCK_CHIP]
set_clock_groups -asynchronous -group [get_clocks $supportclk] -group [get_clocks $CLOCK_CHIP]
set_clock_groups -asynchronous -group [get_clocks spiclk] -group [get_clocks sdramclk]
set_clock_groups -asynchronous -group [get_clocks $hostclk] -group [get_clocks sdramclk]
set_clock_groups -asynchronous -group [get_clocks $supportclk] -group [get_clocks sdramclk]
set_clock_groups -asynchronous -group [get_clocks spiclk] -group [get_clocks ${topmodule}pllvideo|*]
set_clock_groups -asynchronous -group [get_clocks ${topmodule}pll|*] -group [get_clocks ${topmodule}pllvideo|*]
# False paths
set_false_path -to ${FALSE_OUT}
set_false_path -from ${FALSE_IN}