2 * @file system_defines.vh
4 * @author Andrey Filippov
6 * @brief Preprocessor macros definitions to be included in the project
7 * These defines specify overall configuration of the system, set type
8 * of the sensor interface and more.
10 * @copyright Copyright (c) 2015 Elphel, Inc.
14 * system_defines.vh is free software; you can redistribute it and/or modify
15 * it under the terms of the GNU General Public License as published by
16 * the Free Software Foundation, either version 3 of the License, or
17 * (at your option) any later version.
19 * system_defines.vh is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
24 * You should have received a copy of the GNU General Public License
25 * along with this program. If not, see <http://www.gnu.org/licenses/> .
27 * Additional permission under GNU GPL version 3 section 7:
28 * If you modify this Program, or any covered work, by linking or combining it
29 * with independent modules provided by the FPGA vendor only (this permission
30 * does not extend to any 3-rd party modules, "soft cores" or macros) under
31 * different license terms solely for the purpose of generating binary "bitstream"
32 * files and/or simulating the code, the copyright holders of this Program give
33 * you the right to distribute the covered work without those independent modules
34 * as long as the source code for them is available from the FPGA vendor free of
35 * charge, and there is no dependence on any encrypted modules for simulating of
36 * the combined code. This permission applies to you if the distributed code
37 * contains all the components and scripts required to completely simulate it
38 * with at least one of the Free Software programs.
40 // This file may be used to define same pre-processor macros to be included into each parsed file
41 `ifndef SYSTEM_DEFINES
42 `define SYSTEM_DEFINES
43 // TODO: Later compare instantiate/infer
44 `define INSTANTIATE_DSP48E1
45 `define DEBUG_DCT1D // undefine after debugging is over
46 // `define USE_OLD_DCT
48 // Parameters from x393_sata project
51 // `define STRAIGHT_XCLK
53 // `define DATASCOPE_INCOMING_RAW
55 // `define AHCI_SATA 1
56 // `define DEBUG_ELASTIC
57 // End of parameters from x393_sata project
60 `define DISPLAY_COMPRESSED_DATA
61 // if HISPI is not defined, parallel sensor interface is used for all channels
62 `define HISPI /*************** CHANGE here and x393_hispi/x393_parallel in bitstream tool settings ****************/
63 // `define USE_OLD_XDCT393
66 `define REVERSE_LANES 1
68 `define USE_HARD_CURPARAMS // Adjustment of actual hardware may break simulation
69 // `define DEBUG_SENS_MEM_PAGES 1
70 // `define MCLK_VCO_MULT 16
71 // DDR3 memory speed grade and density
77 `define MCLK_VCO_MULT 16
78 // `define MCLK_VCO_MULT 18
79 // `define MCLK_VCO_MULT 20
81 `define MEMBRIDGE_DEBUG_WRITE 1
82 // Enviroment-dependent options
85 `define OPEN_SOURCE_ONLY
90 `define OPEN_SOURCE_ONLY
95 `define OPEN_SOURCE_ONLY
98 // will not use simultaneous reset in shift registers, just and input data with ~rst
99 `define SHREG_SEQUENTIAL_RESET 1
100 // synthesis does to recognize global clock as G input of the primitive latch
102 // define when using CDC - it does not support them
104 //`define MEMBRIDGE_DEBUG_READ 1
106 `define USE_CMD_ENCOD_TILED_32_RD 1
107 // chn 0 is read from memory and write to memory
108 `define def_enable_mem_chn0
109 `define def_read_mem_chn0
110 `define def_write_mem_chn0
111 `undef def_scanline_chn0
112 `undef def_tiled_chn0
114 // chn 1 is scanline r+w
115 `define def_enable_mem_chn1
116 `define def_read_mem_chn1
117 `define def_write_mem_chn1
118 `define def_scanline_chn1
119 `undef def_tiled_chn1
121 // chn 2 is tiled r+w
122 `define def_enable_mem_chn2
123 `define def_read_mem_chn2
124 `define def_write_mem_chn2
125 `undef def_scanline_chn2
126 `define def_tiled_chn2
128 // chn 3 is scanline r+w (reuse later)
129 `define def_enable_mem_chn3
130 `define def_read_mem_chn3
131 `define def_write_mem_chn3
132 `define def_scanline_chn3
133 `undef def_tiled_chn3
135 // chn 4 is tiled r+w (reuse later)
136 `define def_enable_mem_chn4
137 `define def_read_mem_chn4
138 `define def_write_mem_chn4
139 `undef def_scanline_chn4
140 `define def_tiled_chn4
143 `undef def_enable_mem_chn5
146 `undef def_enable_mem_chn6
149 `undef def_enable_mem_chn7
151 // chn 8 is scanline w (sensor channel 0)
152 `define def_enable_mem_chn8
153 `undef def_read_mem_chn8
154 `define def_write_mem_chn8
155 `define def_scanline_chn8
156 `undef def_tiled_chn8
158 // chn 9 is scanline w (sensor channel 1)
159 `define def_enable_mem_chn9
160 `undef def_read_mem_chn9
161 `define def_write_mem_chn9
162 `define def_scanline_chn9
163 `undef def_tiled_chn9
165 // chn 10 is scanline w (sensor channel 2)
166 `define def_enable_mem_chn10
167 `undef def_read_mem_chn10
168 `define def_write_mem_chn10
169 `define def_scanline_chn10
170 `undef def_tiled_chn10
172 // chn 11 is scanline w (sensor channel 3)
173 `define def_enable_mem_chn11
174 `undef def_read_mem_chn11
175 `define def_write_mem_chn11
176 `define def_scanline_chn11
177 `undef def_tiled_chn11
179 // chn 12 is tiled read (compressor channel 0)
180 `define def_enable_mem_chn12
181 `define def_read_mem_chn12
182 `undef def_write_mem_chn12
183 `undef def_scanline_chn12
184 `define def_tiled_chn12
186 // chn 12 is tiled read (compressor channel 1)
187 `define def_enable_mem_chn13
188 `define def_read_mem_chn13
189 `undef def_write_mem_chn13
190 `undef def_scanline_chn13
191 `define def_tiled_chn13
193 // chn 12 is tiled read (compressor channel 2)
194 `define def_enable_mem_chn14
195 `define def_read_mem_chn14
196 `undef def_write_mem_chn14
197 `undef def_scanline_chn14
198 `define def_tiled_chn14
200 // chn 12 is tiled read (compressor channel 3)
201 `define def_enable_mem_chn15
202 `define def_read_mem_chn15
203 `undef def_write_mem_chn15
204 `undef def_scanline_chn15
205 `define def_tiled_chn15