1 package require ::quartus::project
3 set need_to_close_project 0
6 # Check that the right project is open
7 if {[is_project_open]} {
8 if {[string compare $quartus(project) "de1_cyclone"]} {
9 puts "Project de1_cyclone is not open"
10 set make_assignments 0
13 # Only open if not already open
14 if {[project_exists de1_cyclone]} {
15 project_open -revision de1_cyclone de1_cyclone
17 project_new -revision de1_cyclone de1_cyclone
19 set need_to_close_project 1
23 if {$make_assignments} {
24 set_global_assignment -name FAMILY "Cyclone II"
25 set_global_assignment -name DEVICE EP2C20F484C7
26 set_global_assignment -name EDA_SIMULATION_TOOL "ModelSim (VHDL)"
27 set_global_assignment -name EDA_OUTPUT_DATA_FORMAT VHDL -section_id eda_simulation
28 set_global_assignment -name USE_GENERATED_PHYSICAL_CONSTRAINTS OFF -section_id eda_blast_fpga
29 set_global_assignment -name MISC_FILE "de1_cyclone.dpf"
30 set_global_assignment -name STRATIX_DEVICE_IO_STANDARD "3.3-V LVTTL"
31 set_global_assignment -name RESERVE_ALL_UNUSED_PINS "AS INPUT TRI-STATED WITH WEAK PULL-UP"
32 set_global_assignment -name RESERVE_ASDO_AFTER_CONFIGURATION "AS INPUT TRI-STATED"
34 set_global_assignment -name TOP_LEVEL_ENTITY core_top
35 set_global_assignment -name VHDL_FILE ../src/core_top.vhd
36 set_global_assignment -name VHDL_FILE ../src/mem_pkg.vhd
37 set_global_assignment -name VHDL_FILE ../src/rom.vhd
38 set_global_assignment -name VHDL_FILE ../src/rom_b.vhd
39 set_global_assignment -name VHDL_FILE ../src/r_w_ram.vhd
40 set_global_assignment -name VHDL_FILE ../src/r_w_ram_b.vhd
41 set_global_assignment -name VHDL_FILE ../src/r2_w_ram.vhd
42 set_global_assignment -name VHDL_FILE ../src/r2_w_ram_b.vhd
43 set_global_assignment -name VHDL_FILE ../src/common_pkg.vhd
44 set_global_assignment -name VHDL_FILE ../src/core_pkg.vhd
45 set_global_assignment -name VHDL_FILE ../src/fetch_stage.vhd
46 set_global_assignment -name VHDL_FILE ../src/fetch_stage_b.vhd
47 set_global_assignment -name VHDL_FILE ../src/decoder.vhd
48 set_global_assignment -name VHDL_FILE ../src/decoder_b.vhd
49 set_global_assignment -name VHDL_FILE ../src/decode_stage.vhd
50 set_global_assignment -name VHDL_FILE ../src/decode_stage_b.vhd
52 set_global_assignment -name VHDL_FILE ../src/extension_pkg.vhd
53 set_global_assignment -name VHDL_FILE ../src/extension_uart_pkg.vhd
54 set_global_assignment -name VHDL_FILE ../src/extension_uart.vhd
55 set_global_assignment -name VHDL_FILE ../src/extension_uart_b.vhd
56 set_global_assignment -name VHDL_FILE ../src/rs232_tx.vhd
57 set_global_assignment -name VHDL_FILE ../src/rs232_tx_arc.vhd
58 set_global_assignment -name VHDL_FILE ../src/rs232_rx.vhd
59 set_global_assignment -name VHDL_FILE ../src/rs232_rx_arc.vhd
60 set_global_assignment -name VHDL_FILE ../src/extension_7seg_pkg.vhd
61 set_global_assignment -name VHDL_FILE ../src/extension_7seg.vhd
62 set_global_assignment -name VHDL_FILE ../src/extension_7seg_b.vhd
64 set_global_assignment -name VHDL_FILE ../src/alu_pkg.vhd
66 set_global_assignment -name VHDL_FILE ../src/extension_pkg.vhd
67 # set_global_assignment -name VHDL_FILE ../src/gpm_pkg.vhd
68 set_global_assignment -name VHDL_FILE ../src/extension_pkg.vhd
69 set_global_assignment -name VHDL_FILE ../src/extension.vhd
70 set_global_assignment -name VHDL_FILE ../src/extension_b.vhd
72 set_global_assignment -name VHDL_FILE ../src/exec_op.vhd
73 set_global_assignment -name VHDL_FILE ../src/exec_op/add_op_b.vhd
74 set_global_assignment -name VHDL_FILE ../src/exec_op/and_op_b.vhd
75 set_global_assignment -name VHDL_FILE ../src/exec_op/or_op_b.vhd
76 set_global_assignment -name VHDL_FILE ../src/exec_op/xor_op_b.vhd
77 set_global_assignment -name VHDL_FILE ../src/exec_op/shift_op_b.vhd
79 set_global_assignment -name VHDL_FILE ../src/alu.vhd
80 set_global_assignment -name VHDL_FILE ../src/alu_b.vhd
82 # set_global_assignment -name VHDL_FILE ../src/gpm.vhd
83 # set_global_assignment -name VHDL_FILE ../src/gpm_b.vhd
85 set_global_assignment -name VHDL_FILE ../src/execute_stage.vhd
86 set_global_assignment -name VHDL_FILE ../src/execute_stage_b.vhd
89 set_global_assignment -name VHDL_FILE ../src/writeback_stage.vhd
90 set_global_assignment -name VHDL_FILE ../src/writeback_stage_b.vhd
93 set_location_assignment PIN_L1 -to sys_clk
94 set_location_assignment PIN_R22 -to sys_res
95 set_location_assignment PIN_G12 -to bus_tx
96 set_location_assignment PIN_F14 -to bus_rx
98 set_location_assignment PIN_J2 -to sseg0[0]
99 set_location_assignment PIN_J1 -to sseg0[1]
100 set_location_assignment PIN_H2 -to sseg0[2]
101 set_location_assignment PIN_H1 -to sseg0[3]
102 set_location_assignment PIN_F2 -to sseg0[4]
103 set_location_assignment PIN_F1 -to sseg0[5]
104 set_location_assignment PIN_E2 -to sseg0[6]
106 set_location_assignment PIN_E1 -to sseg1[0]
107 set_location_assignment PIN_H6 -to sseg1[1]
108 set_location_assignment PIN_H5 -to sseg1[2]
109 set_location_assignment PIN_H4 -to sseg1[3]
110 set_location_assignment PIN_G3 -to sseg1[4]
111 set_location_assignment PIN_D2 -to sseg1[5]
112 set_location_assignment PIN_D1 -to sseg1[6]
114 set_location_assignment PIN_G5 -to sseg2[0]
115 set_location_assignment PIN_G6 -to sseg2[1]
116 set_location_assignment PIN_C2 -to sseg2[2]
117 set_location_assignment PIN_C1 -to sseg2[3]
118 set_location_assignment PIN_E3 -to sseg2[4]
119 set_location_assignment PIN_E4 -to sseg2[5]
120 set_location_assignment PIN_D3 -to sseg2[6]
122 set_location_assignment PIN_F4 -to sseg3[0]
123 set_location_assignment PIN_D5 -to sseg3[1]
124 set_location_assignment PIN_D6 -to sseg3[2]
125 set_location_assignment PIN_J4 -to sseg3[3]
126 set_location_assignment PIN_L8 -to sseg3[4]
127 set_location_assignment PIN_F3 -to sseg3[5]
128 set_location_assignment PIN_D4 -to sseg3[6]
131 set_global_assignment -name FMAX_REQUIREMENT "80.00 MHz" -section_id sys_clk
132 set_instance_assignment -name CLOCK_SETTINGS sys_clk -to sys_clk
134 set_global_assignment -name LL_ROOT_REGION ON -section_id "Root Region"
135 set_global_assignment -name LL_MEMBER_STATE LOCKED -section_id "Root Region"
136 set_global_assignment -name PARTITION_NETLIST_TYPE SOURCE -section_id Top
137 set_global_assignment -name PARTITION_COLOR 16764057 -section_id Top
138 set_instance_assignment -name PARTITION_HIERARCHY root_partition -to | -section_id Top
144 if {$need_to_close_project} {