x393  1.0
FPGAcodeforElphelNC393camera
system_defines.vh
Go to the documentation of this file.
1 /*!
2  * @file system_defines.vh
3  * @date 2015-02-28
4  * @author Andrey Filippov
5  *
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.
9  *
10  * @copyright Copyright (c) 2015 Elphel, Inc.
11  *
12  * <b>License:</b>
13  *
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.
18  *
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.
23  *
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/> .
26  *
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.
39  */
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
47 
48 // Parameters from x393_sata project
49  `define USE_DRP
50  `define ALIGN_CLOCKS
51 // `define STRAIGHT_XCLK
52  `define USE_DATASCOPE
53 // `define DATASCOPE_INCOMING_RAW
54  `define PRELOAD_BRAMS
55 // `define AHCI_SATA 1
56 // `define DEBUG_ELASTIC
57 // End of parameters from x393_sata project
58 
59  `define PRELOAD_BRAMS
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
64 // `define USE_PCLK2X
65 // `define USE_XCLK2X
66  `define REVERSE_LANES 1
67  `define DEBUG_RING 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
72  `define sg25 1
73 // `define sg15E 1
74 // `define sg187E 1
75  `define den4096Mb 1
76 
77  `define MCLK_VCO_MULT 16
78 // `define MCLK_VCO_MULT 18
79 // `define MCLK_VCO_MULT 20
80 
81  `define MEMBRIDGE_DEBUG_WRITE 1
82 // Enviroment-dependent options
83  `ifdef IVERILOG
84  `define SIMULATION
85  `define OPEN_SOURCE_ONLY
86  `endif
87 
88  `ifdef COCOTB
89  `define SIMULATION
90  `define OPEN_SOURCE_ONLY
91  `endif
92 
93  `ifdef CVC
94  `define SIMULATION
95  `define OPEN_SOURCE_ONLY
96  `endif // CVC
97 
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
101  `undef INFER_LATCHES
102  // define when using CDC - it does not support them
103  `undef IGNORE_ATTR
104 //`define MEMBRIDGE_DEBUG_READ 1
105  `define use200Mhz 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
113 
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
120 
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
127 
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
134 
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
141 
142  // chn 5 is disabled
143  `undef def_enable_mem_chn5
144 
145  // chn 6 is disabled
146  `undef def_enable_mem_chn6
147 
148  // chn 7 is disabled
149  `undef def_enable_mem_chn7
150 
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
157 
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
164 
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
171 
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
178 
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
185 
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
192 
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
199 
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
206 `endif
207