-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathArriaVADCEthernet_top.sdc
134 lines (109 loc) · 7.33 KB
/
ArriaVADCEthernet_top.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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
post_message -type info "Entering Nios_CPU_top.sdc"
source src/commentOutSDCFile.sdc
#checkQuartusVersion "Version 12.0 Build 178 05/31/2012 SJ Full Version"
commentOutSDCFile "Nios_CPU_qsys/synthesis/submodules/altera_eth_tse_mac.sdc"
#Info: Reading SDC File: 'Nios_CPU_qsys/synthesis/submodules/Nios_CPU_qsys_tse_mac_constraints.sdc'
#
# Start by getting all of the PLL related clocks declared
#
derive_pll_clocks -create_base_clocks
#
# these are the input clocks to the FPGA
#
set altera_reserved_tck { altera_reserved_tck }
#set clkin_50_fpga { clkin_50_fpga }
create_clock -period 20.00 -name clkin_50 [ get_ports clkin_50 ]
create_clock -period 20.00 -name clkin_50_adc [ get_ports clkin_50_adc ]
#
# these are the generated clocks from jtag and plls that we care about
#
#set ddrlo_sysclk_125 { Nios_CPU_qsys_inst|ddr2_lo_latency_128m|s5gx100g_fpga_bup_qsys_inst_ddr2_lo_latency_128m_controller_phy_inst|s5gx100g_fpga_bup_qsys_inst_ddr2_lo_latency_128m_phy_inst|s5gx100g_fpga_bup_qsys_inst_ddr2_lo_latency_128m_phy_alt_mem_phy_inst|clk|pll|altpll_component|auto_generated|pll1|clk[1] }
#set ddrlo_auxhalf_62p5 { Nios_CPU_qsys_inst|ddr2_lo_latency_128m|s5gx100g_fpga_bup_qsys_inst_ddr2_lo_latency_128m_controller_phy_inst|s5gx100g_fpga_bup_qsys_inst_ddr2_lo_latency_128m_phy_inst|s5gx100g_fpga_bup_qsys_inst_ddr2_lo_latency_128m_phy_alt_mem_phy_inst|clk|pll|altpll_component|auto_generated|pll1|clk[0] }
set enet_pll_125 { u0|enet_pll|altera_pll_i|general[0].gpll~PLL_OUTPUT_COUNTER|divclk }
set enet_pll_25 { u0|enet_pll|altera_pll_i|general[1].gpll~PLL_OUTPUT_COUNTER|divclk }
set enet_pll_2p5 { u0|enet_pll|altera_pll_i|general[2].gpll~PLL_OUTPUT_COUNTER|divclk }
set enet_reset { u0|enet_pll|altera_pll_i|general[2].gpll~PLL_OUTPUT_COUNTER|divclk }
set enet_locked { u0|enet_pll|altera_pll_i|general[2].gpll~PLL_OUTPUT_COUNTER|divclk }
#
# constrain the Ethernet RGMII interface, the order of these source statements is specific
#
source src/rgmii_clocks.sdc
source src/rgmii_input.sdc
source src/rgmii_output.sdc
#
# some clock uncertainty is required
#
derive_clock_uncertainty
#
# Create false paths between clock domains that are not fully constrained by the IP that makes these paths.
# Ideally we should not have to do this, however, these paths must be cut to meet timing and in most cases
# the IP should be accounting for synchronization between these paths.
# The risk of a global cut like these is that if the IP is not synchronizing properly between the two domains
# then you have significant problems with the design. Ideally the IP should synchronize it's clock crossing
# paths and create constraints to cut those paths so we don't have to perform a global cut like this.
#
set_clock_groups \
-exclusive \
-group [get_clocks {tx_clk_125 tx_clk_25 tx_clk_2p5}] \
-group [get_clocks enet_rx_clk] \
-group [get_clocks clkin_50]
#
# these are clock crossing paths from our global reset generator which should be cut
#
#set_false_path -from [get_keepers *reset_counter*resetn_out] -to *
#set_false_path -from * -to [get_keepers *bit_synchronizer*p1]
#
# this is the locked output from the Ethernet PLL in the design, it can be cut
#
#set_false_path -from {Nios_CPU_qsys_inst:Nios_CPU_qsys_inst|enet_pll:the_enet_pll|count_done} -to *
#
# this is for the IRQ signals that come from the slow peripheral clock domain to the linux cpu
#
#set_false_path -from * -to [get_keepers *irq_from_sa_clock_crossing_linux_cpu_data_master\|data_in_d1]
#
# These are the constraints out of the TSE MAC SDC file that are relevant to us.
# The TSE MAC SDC file should be commented out by this script.
#
set_multicycle_path -setup 5 -from [ get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_tx_min_ff:U_TXFF|altera_tse_altsyncram_dpm_fifo:U_RTSM|altsyncram*] -to [ get_registers *]
set_multicycle_path -setup 5 -from [ get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_tx_min_ff:U_TXFF|altera_tse_retransmit_cntl:U_RETR|*] -to [ get_registers *]
set_multicycle_path -setup 5 -from [ get_registers *] -to [ get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_tx_min_ff:U_TXFF|altera_tse_retransmit_cntl:U_RETR|*]
set_multicycle_path -hold 5 -from [ get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_tx_min_ff:U_TXFF|altera_tse_altsyncram_dpm_fifo:U_RTSM|altsyncram*] -to [ get_registers *]
set_multicycle_path -hold 5 -from [ get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_tx_min_ff:U_TXFF|altera_tse_retransmit_cntl:U_RETR|*] -to [ get_registers *]
set_multicycle_path -hold 5 -from [ get_registers *] -to [ get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_tx_min_ff:U_TXFF|altera_tse_retransmit_cntl:U_RETR|*]
set_max_delay 7 -from [get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_tx_min_ff:U_TXFF|dout_reg_sft*] -to [get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_top_1geth:U_GETH|altera_tse_mac_tx:U_TX|*]
set_max_delay 7 -from [get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_tx_min_ff:U_TXFF|eop_sft*] -to [get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_top_1geth:U_GETH|altera_tse_mac_tx:U_TX|*]
set_max_delay 7 -from [get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_tx_min_ff:U_TXFF|sop_reg*] -to [get_registers *|altera_tse_top_w_fifo:U_MAC|altera_tse_top_1geth:U_GETH|altera_tse_mac_tx:U_TX|*]
#
# The following constraints are for miscelaneous input and output pins in the
# design that are not constrained elsewhere.
#
# cpu_resetn
set_input_delay -clock [ get_clocks clkin_50 ] 10 [ get_ports {cpu_resetn} ]
#set_input_delay -clock [ get_clocks clkin_50 ] 10 [ get_ports {max_cpu_resetn} ]
set_false_path -from [get_ports cpu_resetn] -to *
set_false_path -from * -to [get_ports flash_resetn]
# Ethernet MDIO interface
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {enet_mdc} ]
set_input_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {enet_mdio} ]
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {enet_mdio} ]
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {enet_resetn} ]
# flash interface
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {fm_a[*]} ]
set_input_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {fm_d[*]} ]
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {fm_d[*]} ]
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {flash_cen[*]} ]
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {flash_oen} ]
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {flash_resetn} ]
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {flash_wen} ]
# jtag interface
set_input_delay -clock [ get_clocks $altera_reserved_tck ] 10 [ get_ports altera_reserved_tms ]
set_input_delay -clock [ get_clocks $altera_reserved_tck ] 10 [ get_ports altera_reserved_tdi ]
set_output_delay -clock [ get_clocks $altera_reserved_tck ] 10 [ get_ports altera_reserved_tdo ]
# user pb, dipsw and led
#set_input_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {user_pb[*]} ]
#set_input_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {user_dipsw[*]} ]
#set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {user_led[*]} ]
set_output_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {lcd_*} ]
set_input_delay -clock [ get_clocks clkin_50 ] 2 [ get_ports {lcd_data[*]} ]
set_false_path -from * -to [get_ports {lcd_*}]
set_false_path -from [get_ports {lcd_data[*]}] -to *