x393  1.0
FPGAcodeforElphelNC393camera
x393_parameters.vh
Go to the documentation of this file.
1 /*!
2  * @file x393_parameters.vh
3  * @date 2015-02-07
4  * @author Andrey Filippov
5  *
6  * @brief Parameters for the x393 (simulation and implementation)
7  *
8  * @copyright Copyright (c) 2015 Elphel, Inc.
9  *
10  * <b>License:</b>
11  *
12  * x393_parameters.vh is free software; you can redistribute it and/or modify
13  * it under the terms of the GNU General Public License as published by
14  * the Free Software Foundation, either version 3 of the License, or
15  * (at your option) any later version.
16  *
17  * x393_parameters.vh is distributed in the hope that it will be useful,
18  * but WITHOUT ANY WARRANTY; without even the implied warranty of
19  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20  * GNU General Public License for more details.
21  *
22  * You should have received a copy of the GNU General Public License
23  * along with this program. If not, see <http://www.gnu.org/licenses/> .
24  *
25  * Additional permission under GNU GPL version 3 section 7:
26  * If you modify this Program, or any covered work, by linking or combining it
27  * with independent modules provided by the FPGA vendor only (this permission
28  * does not extend to any 3-rd party modules, "soft cores" or macros) under
29  * different license terms solely for the purpose of generating binary "bitstream"
30  * files and/or simulating the code, the copyright holders of this Program give
31  * you the right to distribute the covered work without those independent modules
32  * as long as the source code for them is available from the FPGA vendor free of
33  * charge, and there is no dependence on any encrypted modules for simulating of
34  * the combined code. This permission applies to you if the distributed code
35  * contains all the components and scripts required to completely simulate it
36  * with at least one of the Free Software programs.
37  */
38  parameter MCONTR_WR_MASK = 'h3c00, // AXI write address mask for the 1Kx32 buffers command sequence memory
39  parameter MCONTR_RD_MASK = 'h3c00, // AXI read address mask to generate busy
40 
41  parameter CONTROL_ADDR = 'h0000, // AXI write address of control write registers
42  parameter CONTROL_ADDR_MASK = 'h3800, // AXI write mask of control registers
43  parameter CONTROL_RBACK_ADDR = 'h0000, // AXI read address of control registers readback
44  parameter CONTROL_RBACK_ADDR_MASK = 'h3800, // AXI mask of control registers readback addresses
45  parameter CONTROL_RBACK_DEPTH= 11, // 10 - 1xbram, 11 - 2xbram
46 
47 
48  parameter STATUS_ADDR = 'h0800, // AXI read address of status read registers
49  parameter STATUS_ADDR_MASK = 'h3c00, // AXI write address of status registers
50 
51  parameter MCONTR_CMD_WR_ADDR = 'h0c00, // AXI write to command sequence memory
52 
53  parameter MCONTR_BUF0_RD_ADDR = 'h1000, // AXI read address from buffer 0 (PS sequence, memory read) (was 'h400)
54  parameter MCONTR_BUF0_WR_ADDR = 'h1000, // AXI write address to buffer 0 (PS sequence, memory write) (was 'h400)
55  // MCONTR_BUF[2-4]_* - temporary, will be removed in the futire
56  parameter MCONTR_BUF2_RD_ADDR = 'h1400, // AXI read address from buffer 2 (PL sequence, tiles, memory read)
57  parameter MCONTR_BUF2_WR_ADDR = 'h1400, // AXI write address to buffer 2 (PL sequence, tiles, memory write)
58  parameter MCONTR_BUF3_RD_ADDR = 'h1800, // AXI read address from buffer 3 (PL sequence, scanline, memory read)
59  parameter MCONTR_BUF3_WR_ADDR = 'h1800, // AXI write address to buffer 3 (PL sequence, scanline, memory write)
60  parameter MCONTR_BUF4_RD_ADDR = 'h1c00, // AXI read address from buffer 4 (PL sequence, tiles, memory read)
61  parameter MCONTR_BUF4_WR_ADDR = 'h1c00, // AXI write address to buffer 4 (PL sequence, tiles, memory write)
62 
63 
64  parameter AXI_WR_ADDR_BITS = 14,
65  parameter AXI_RD_ADDR_BITS = 14,
66  parameter STATUS_DEPTH= 8, // 256 cells, maybe just 16..64 are enough?
67 
68 //command interface parameters
69  parameter DLY_LD = 'h080, // address to generate delay load
70  parameter DLY_LD_MASK = 'h780, // address mask to generate delay load
71 //0x1000..103f - 0- bit data (set/reset)
72  parameter MCONTR_PHY_0BIT_ADDR = 'h020, // address to set sequnecer channel and run (4 LSB-s - channel)
73  parameter MCONTR_PHY_0BIT_ADDR_MASK = 'h7f0, // address mask to generate sequencer channel/run
74 // 0x1020 - DLY_SET // 0 bits -set pre-programmed delays
75 // 0x1024..1025 - CMDA_EN // 0 bits - enable/disable command/address outputs
76 // 0x1026..1027 - SDRST_ACT // 0 bits - enable/disable active-low reset signal to DDR3 memory
77 // 0x1028..1029 - CKE_EN // 0 bits - enable/disable CKE signal to memory
78 // 0x102a..102b - DCI_RST // 0 bits - enable/disable CKE signal to memory
79 // 0x102c..102d - DLY_RST // 0 bits - enable/disable CKE signal to memory
80  parameter MCONTR_PHY_0BIT_DLY_SET = 'h0, // set pre-programmed delays
81  parameter MCONTR_PHY_0BIT_CMDA_EN = 'h4, // enable/disable command/address outputs
82  parameter MCONTR_PHY_0BIT_SDRST_ACT = 'h6, // enable/disable active-low reset signal to DDR3 memory
83  parameter MCONTR_PHY_0BIT_CKE_EN = 'h8, // enable/disable CKE signal to memory
84  parameter MCONTR_PHY_0BIT_DCI_RST = 'ha, // enable/disable CKE signal to memory
85  parameter MCONTR_PHY_0BIT_DLY_RST = 'hc, // enable/disable CKE signal to memory
86 //0x1030..1037 - 0-bit memory cotroller (set/reset)
87  parameter MCONTR_TOP_0BIT_ADDR = 'h030, // address to turn on/off memory controller features
88  parameter MCONTR_TOP_0BIT_ADDR_MASK = 'h7f8, // address mask to generate sequencer channel/run
89 // 0x1030..1031 - MCONTR_EN // 0 bits, disable/enable memory controller
90 // 0x1032..1033 - REFRESH_EN // 0 bits, disable/enable memory refresh
91 // 0x1034..1037 - reserved
92  parameter MCONTR_TOP_0BIT_MCONTR_EN = 'h0, // disable/enable memory controller
93  parameter MCONTR_TOP_0BIT_REFRESH_EN = 'h2, // disable/enable command/address outputs
94 //0x1040..107f - 16-bit data
95 // 0x1040..104f - RUN_CHN // address to set sequncer channel and run (4 LSB-s - channel) - bits?
96 // parameter RUN_CHN_REL = 'h040, // address to set sequnecer channel and run (4 LSB-s - channel)
97 // parameter RUN_CHN_REL_MASK = 'h7f0, // address mask to generate sequencer channel/run
98 // 0x1050..1057: MCONTR_PHY16
99  parameter MCONTR_PHY_16BIT_ADDR = 'h050, // address to set sequnecer channel and run (4 LSB-s - channel)
100  parameter MCONTR_PHY_16BIT_ADDR_MASK = 'h7f8, // address mask to generate sequencer channel/run
101 // 0x1050 - PATTERNS // 16 bits
102 // 0x1051 - PATTERNS_TRI // 16-bit address to set DQM and DQS tristate on/off patterns {dqs_off,dqs_on, dq_off,dq_on} - 4 bits each
103 // 0x1052 - WBUF_DELAY // 4 bits - extra delay (in mclk cycles) to add to write buffer enable (DDR3 read data)
104 // 0x1053 - EXTRA_REL // 1 bit - set extra parameters (currently just inv_clk_div)
105 // 0x1054 - STATUS_CNTRL // 8 bits - write to status control
106  parameter MCONTR_PHY_16BIT_PATTERNS = 'h0, // set DQM and DQS patterns (16'h0055)
107  parameter MCONTR_PHY_16BIT_PATTERNS_TRI = 'h1, // 16-bit address to set DQM and DQS tristate on/off patterns {dqs_off,dqs_on, dq_off,dq_on} - 4 bits each
108  parameter MCONTR_PHY_16BIT_WBUF_DELAY = 'h2, // 4? bits - extra delay (in mclk cycles) to add to write buffer enable (DDR3 read data)
109  parameter MCONTR_PHY_16BIT_EXTRA = 'h3, // ? bits - set extra parameters (currently just inv_clk_div)
110  parameter MCONTR_PHY_STATUS_CNTRL = 'h4, // write to status control (8-bit)
111 
112 //0x1060..106f: arbiter priority data
113  parameter MCONTR_ARBIT_ADDR = 'h060, // Address to set channel priorities
114  parameter MCONTR_ARBIT_ADDR_MASK = 'h7f0, // Address mask to set channel priorities
115 //0x1070..1077 - 16-bit top memory controller:
116  parameter MCONTR_TOP_16BIT_ADDR = 'h070, // address to set mcontr top control registers
117  parameter MCONTR_TOP_16BIT_ADDR_MASK = 'h7f8, // address mask to set mcontr top control registers
118 // 0x1070 - MCONTR_CHN_EN // 16 bits per-channel enable (want/need requests)
119 // 0x1071 - REFRESH_PERIOD // 8-bit refresh period
120 // 0x1072 - REFRESH_ADDRESS // 10 bits
121 // 0x1073 - STATUS_CNTRL // 8 bits - write to status control (and debug?)
122  parameter MCONTR_TOP_16BIT_CHN_EN = 'h0, // 16 bits per-channel enable (want/need requests)
123  parameter MCONTR_TOP_16BIT_REFRESH_PERIOD = 'h1, // 8-bit refresh period
124  parameter MCONTR_TOP_16BIT_REFRESH_ADDRESS= 'h2, // 10 bits refresh address in the sequencer (PL) memory
125  parameter MCONTR_TOP_16BIT_STATUS_CNTRL= 'h3, // 8 bits - write to status control (and debug?)
126 
127 // Status read address
128  parameter MCONTR_PHY_STATUS_REG_ADDR= 'h0, // 8 or less bits: status register address to use for memory controller phy
129  parameter MCONTR_TOP_STATUS_REG_ADDR= 'h1, // 8 or less bits: status register address to use for memory controller
130 
131 
132  parameter CHNBUF_READ_LATENCY = 2, //1, // external channel buffer extra read latency ( 0 - data available next cycle after re (but prev. data))
133 
134  parameter DFLT_DQS_PATTERN= 8'haa, // TODO: make work for the simulator too 8'h55,
135  parameter DFLT_DQM_PATTERN= 8'h00, // 8'h00
136  parameter DFLT_DQ_TRI_ON_PATTERN= 4'h7, // DQ tri-state control word, first when enabling output
137  parameter DFLT_DQ_TRI_OFF_PATTERN= 4'he, // DQ tri-state control word, first after disabling output
138  parameter DFLT_DQS_TRI_ON_PATTERN= 4'h3, // DQS tri-state control word, first when enabling output
139  parameter DFLT_DQS_TRI_OFF_PATTERN=4'hc, // DQS tri-state control word, first after disabling output
140  parameter DFLT_WBUF_DELAY= 4'h9, // TODO: Find the reason - simulation needs 8, target - 9
141  parameter DFLT_INV_CLK_DIV= 1'b0,
142 
143  parameter DFLT_CHN_EN= 16'h0, // channel mask to be enabled at reset
144  parameter DFLT_REFRESH_ADDR= 10'h0, // refresh sequence address in command memory
145  parameter DFLT_REFRESH_PERIOD= 8'h0, // default 8-bit refresh period (scale?)
146  parameter ADDRESS_NUMBER= 15,
147  parameter COLADDR_NUMBER= 10,
148  parameter PHASE_WIDTH = 8,
149  parameter SLEW_DQ = "SLOW",
150  parameter SLEW_DQS = "SLOW",
151  parameter SLEW_CMDA = "SLOW",
152  parameter SLEW_CLK = "SLOW",
153  parameter IBUF_LOW_PWR = "TRUE",
154 `ifdef use200Mhz
155  parameter real REFCLK_FREQUENCY = 200.0, // 300.0,
156  parameter HIGH_PERFORMANCE_MODE = "FALSE",
157  parameter CLKIN_PERIOD = 20, // 10, //ns >1.25, 600<Fvco<1200 // Hardware 150MHz , change to | 6.667
158 `ifdef MCLK_VCO_MULT
159  parameter CLKFBOUT_MULT = `MCLK_VCO_MULT ,
160 `else
161  parameter CLKFBOUT_MULT = 16, // 8, // Fvco=Fclkin*CLKFBOUT_MULT_F/DIVCLK_DIVIDE, Fout=Fvco/CLKOUT#_DIVIDE | 16
162 `endif
163 `else
164  parameter real REFCLK_FREQUENCY = 300.0,
165  parameter HIGH_PERFORMANCE_MODE = "FALSE",
166  parameter CLKIN_PERIOD = 10, //ns >1.25, 600<Fvco<1200
167  parameter CLKFBOUT_MULT = 8, // Fvco=Fclkin*CLKFBOUT_MULT_F/DIVCLK_DIVIDE, Fout=Fvco/CLKOUT#_DIVIDE
168 `endif
169  parameter DIVCLK_DIVIDE= 1,
170  parameter CLKFBOUT_USE_FINE_PS= 0, //1, // 0 - old, 1 - new
171  parameter CLKFBOUT_PHASE = 0.000,
172  parameter SDCLK_PHASE = 0.000,
173  parameter CLK_PHASE = 0.000, //11.25, /// 0.000,
174  parameter CLK_DIV_PHASE = 0.000,
175  parameter MCLK_PHASE = 90.000, //78.75, // 90.000,
176  parameter REF_JITTER1 = 0.010,
177  parameter SS_EN = "FALSE",
178  parameter SS_MODE = "CENTER_HIGH",
179  parameter SS_MOD_PERIOD = 10000,
180  parameter CMD_PAUSE_BITS= 10,
181  parameter CMD_DONE_BIT= 10,
182 
183  parameter NUM_CYCLES_LOW_BIT= 'h6, // decode addresses [NUM_CYCLES_LOW_BIT+:4] into command a/d length
184 // TODO: put actual data
185  parameter NUM_CYCLES_00 = 2, // 2-cycle 000.003f
186  parameter NUM_CYCLES_01 = 4, // 4-cycle 040.007f
187  parameter NUM_CYCLES_02 = 3, // 3-cycle 080.00bf
188  parameter NUM_CYCLES_03 = 3, // 3-cycle 0c0.00ff
189  parameter NUM_CYCLES_04 = 6, // 6-cycle 100.013f
190  parameter NUM_CYCLES_05 = 6, // 6-cycle 140.017f
191  parameter NUM_CYCLES_06 = 4, // 4-cycle 180.01bf
192  parameter NUM_CYCLES_07 = 4, // 4-cycle 1c0.01ff
193  parameter NUM_CYCLES_08 = 6, // 6-cycle 200.023f
194  parameter NUM_CYCLES_09 = 6, //
195  parameter NUM_CYCLES_10 = 6, //
196  parameter NUM_CYCLES_11 = 6, //
197  parameter NUM_CYCLES_12 = 6, //
198  parameter NUM_CYCLES_13 = 5, // 5-cycle - not yet used
199  parameter NUM_CYCLES_14 = 6, // 6-cycle - not yet used
200  parameter NUM_CYCLES_15 = 9, // single-cycle
201  parameter NUM_CYCLES_16 = 6, //
202  parameter NUM_CYCLES_17 = 6, //
203  parameter NUM_CYCLES_18 = 6, //
204  parameter NUM_CYCLES_19 = 6, //
205  parameter NUM_CYCLES_20 = 6, //
206  parameter NUM_CYCLES_21 = 6, //
207  parameter NUM_CYCLES_22 = 6, //
208  parameter NUM_CYCLES_23 = 6, //
209  parameter NUM_CYCLES_24 = 6, //
210  parameter NUM_CYCLES_25 = 6, //
211  parameter NUM_CYCLES_26 = 6, //
212  parameter NUM_CYCLES_27 = 6, //
213  parameter NUM_CYCLES_28 = 6, //
214  parameter NUM_CYCLES_29 = 6, //
215  parameter NUM_CYCLES_30 = 6, //
216  parameter NUM_CYCLES_31 = 6, //
217 
218 // parameter CMD0_ADDR = 'h0800, // AXI write to command sequence memory
219 // parameter CMD0_ADDR_MASK = 'h1800, // AXI read address mask for the command sequence memory
220  parameter MCNTRL_PS_ADDR= 'h100,
221  parameter MCNTRL_PS_MASK= 'h7e0, // both channels 0 and 1
222  parameter MCNTRL_PS_STATUS_REG_ADDR= 'h2,
223  parameter MCNTRL_PS_EN_RST= 'h0,
224  parameter MCNTRL_PS_CMD= 'h1,
225  parameter MCNTRL_PS_STATUS_CNTRL= 'h2,
226 
227  parameter NUM_XFER_BITS= 6, // number of bits to specify transfer length
228  parameter FRAME_WIDTH_BITS= 13, // Maximal frame width - 8-word (16 bytes) bursts
229  parameter FRAME_HEIGHT_BITS= 16, // Maximal frame height
230  parameter LAST_FRAME_BITS= 16, // number of bits in frame counter (before rolls over)
231  parameter MCNTRL_SCANLINE_CHN1_ADDR= 'h120,
232  parameter MCNTRL_SCANLINE_CHN3_ADDR= 'h130,
233  parameter MCNTRL_SCANLINE_MASK= 'h7f0, // both channels 0 and 1
234  parameter MCNTRL_SCANLINE_MODE= 'h0, // set mode register: {extra_pages[1:0],enable,!reset}
235  parameter MCNTRL_SCANLINE_STATUS_CNTRL= 'h1, // control status reporting
236  parameter MCNTRL_SCANLINE_STARTADDR= 'h2, // 22-bit frame start address (3 CA LSBs==0. BA==0)
237  parameter MCNTRL_SCANLINE_FRAME_SIZE= 'h3, // 22-bit frame start address increment (3 CA LSBs==0. BA==0)
238  parameter MCNTRL_SCANLINE_FRAME_LAST= 'h4, // 16-bit last frame number in the buffer
239  parameter MCNTRL_SCANLINE_FRAME_FULL_WIDTH= 'h5, // Padded line length (8-row increment), in 8-bursts (16 bytes)
240  parameter MCNTRL_SCANLINE_WINDOW_WH= 'h6, // low word - 13-bit window width (0->'h4000), high word - 16-bit frame height (0->'h10000)
241  parameter MCNTRL_SCANLINE_WINDOW_X0Y0= 'h7, // low word - 13-bit window left, high word - 16-bit window top
242  parameter MCNTRL_SCANLINE_WINDOW_STARTXY= 'h8, // low word - 13-bit start X (relative to window), high word - 16-bit start y
243  // Start XY can be used when read command to start from the middle
244  // TODO: Add number of blocks to R/W? (blocks can be different) - total length?
245  // Read back current address (for debugging)?
246  parameter MCNTRL_SCANLINE_STATUS_REG_CHN1_ADDR= 'h4,
247  parameter MCNTRL_SCANLINE_STATUS_REG_CHN3_ADDR= 'h6,
248  parameter MCNTRL_SCANLINE_PENDING_CNTR_BITS= 2, // Number of bits to count pending trasfers, currently 2 is enough, but may increase
249  // if memory controller will allow programming several sequences in advance to
250  // spread long-programming (tiled) over fast-programming (linear) requests.
251  // But that should not be too big to maintain 2-level priorities
252 
253  parameter MCNTRL_SCANLINE_FRAME_PAGE_RESET =1'b0, // reset internal page number to zero at the frame start (false - only when hard/soft reset)
254  parameter MAX_TILE_WIDTH= 6, // number of bits to specify maximal tile (width-1) (6 -> 64)
255  parameter MAX_TILE_HEIGHT= 6, // number of bits to specify maximal tile (height-1) (6 -> 64)
256  parameter MCNTRL_TILED_CHN2_ADDR= 'h140,
257  parameter MCNTRL_TILED_CHN4_ADDR= 'h150,
258  parameter MCNTRL_TILED_MASK= 'h7f0, // both channels 0 and 1
259  parameter MCNTRL_TILED_MODE= 'h0, // set mode register: {extra_pages[1:0],write_mode,enable,!reset}
260  parameter MCNTRL_TILED_STATUS_CNTRL= 'h1, // control status reporting
261  parameter MCNTRL_TILED_STARTADDR= 'h2, // 22-bit frame start address (3 CA LSBs==0. BA==0)
262  parameter MCNTRL_TILED_FRAME_SIZE= 'h3, // 22-bit frame start address increment (3 CA LSBs==0. BA==0)
263  parameter MCNTRL_TILED_FRAME_LAST= 'h4, // 16-bit last frame number in the buffer
264  parameter MCNTRL_TILED_FRAME_FULL_WIDTH='h5, // Padded line length (8-row increment), in 8-bursts (16 bytes)
265  parameter MCNTRL_TILED_WINDOW_WH= 'h6, // low word - 13-bit window width (0->'h4000), high word - 16-bit frame height (0->'h10000)
266  parameter MCNTRL_TILED_WINDOW_X0Y0= 'h7, // low word - 13-bit window left, high word - 16-bit window top
267  parameter MCNTRL_TILED_WINDOW_STARTXY= 'h8, // low word - 13-bit start X (relative to window), high word - 16-bit start y
268  // Start XY can be used when read command to start from the middle
269  // TODO: Add number of blocks to R/W? (blocks can be different) - total length?
270  // Read back current address (for debugging)?
271  parameter MCNTRL_TILED_TILE_WHS= 'h9, // low byte - 6-bit tile width in 8-bursts, second byte - tile height (0 - > 64),
272  // 3-rd byte - vertical step (to control tile vertical overlap)
273  parameter MCNTRL_TILED_STATUS_REG_CHN2_ADDR= 'h5,
274  parameter MCNTRL_TILED_STATUS_REG_CHN4_ADDR= 'h7,
275  parameter MCNTRL_TILED_PENDING_CNTR_BITS=2, // Number of bits to count pending trasfers, currently 2 is enough, but may increase
276  // if memory controller will allow programming several sequences in advance to
277  // spread long-programming (tiled) over fast-programming (linear) requests.
278  // But that should not be too big to maintain 2-level priorities
279  parameter MCNTRL_TILED_FRAME_PAGE_RESET =1'b0, // reset internal page number to zero at the frame start (false - only when hard/soft reset)
280  parameter BUFFER_DEPTH32= 10, // Block RAM buffer depth on a 32-bit port
281 
282  // bits in mode control word
283  parameter MCONTR_LINTILE_NRESET = 0, // reset if 0
284  parameter MCONTR_LINTILE_EN = 1, // enable requests
285  parameter MCONTR_LINTILE_WRITE = 2, // write to memory mode
286  parameter MCONTR_LINTILE_EXTRAPG = 3, // extra pages (over 1) needed by the client simultaneously
287  parameter MCONTR_LINTILE_EXTRAPG_BITS = 2, // number of bits to use for extra pages
288  parameter MCONTR_LINTILE_KEEP_OPEN = 5, // keep banks open (will be used only if number of rows <= 8)
289  parameter MCONTR_LINTILE_BYTE32 = 6, // use 32-byte wide columns in each tile (false - 16-byte)
290  parameter MCONTR_LINTILE_RST_FRAME = 8, // reset frame number
291  parameter MCONTR_LINTILE_SINGLE = 9, // read/write a single page
292  parameter MCONTR_LINTILE_REPEAT = 10, // read/write pages until disabled
293  parameter MCONTR_LINTILE_DIS_NEED = 11, // disable 'need' request
294  parameter MCONTR_LINTILE_SKIP_LATE = 12, // skip actual R/W operation when it is too late, advance pointers
295 
296 // Channel test module parameters
297  parameter MCNTRL_TEST01_ADDR= 'h0f0,
298  parameter MCNTRL_TEST01_MASK= 'h7f0,
299  parameter MCNTRL_TEST01_CHN1_MODE= 'h2, // set mode register for channel 5
300  parameter MCNTRL_TEST01_CHN1_STATUS_CNTRL= 'h3, // control status reporting for channel 5
301  parameter MCNTRL_TEST01_CHN2_MODE= 'h4, // set mode register for channel 2
302  parameter MCNTRL_TEST01_CHN2_STATUS_CNTRL= 'h5, // control status reporting for channel 2
303  parameter MCNTRL_TEST01_CHN3_MODE= 'h6, // set mode register for channel 3
304  parameter MCNTRL_TEST01_CHN3_STATUS_CNTRL= 'h7, // control status reporting for channel 3
305  parameter MCNTRL_TEST01_CHN4_MODE= 'h8, // set mode register for channel 4
306  parameter MCNTRL_TEST01_CHN4_STATUS_CNTRL= 'h9, // control status reporting for channel 4
307  parameter MCNTRL_TEST01_STATUS_REG_CHN1_ADDR= 'h3c, // status/readback register for channel 2
308  parameter MCNTRL_TEST01_STATUS_REG_CHN2_ADDR= 'h3d, // status/readback register for channel 3
309  parameter MCNTRL_TEST01_STATUS_REG_CHN3_ADDR= 'h3e, // status/readback register for channel 4
310  parameter MCNTRL_TEST01_STATUS_REG_CHN4_ADDR= 'h3f, // status/readback register for channel 4
311 
312  parameter MCONTR_SENS_BASE = 'h680, // .. 'h6bf
313  parameter MCONTR_SENS_INC = 'h10,
314  parameter MCONTR_CMPRS_BASE = 'h6c0, // .. 'h6ff
315  parameter MCONTR_CMPRS_INC = 'h10,
316  parameter MCONTR_SENS_STATUS_BASE = 'h28, // .. 'h2b
317  parameter MCONTR_SENS_STATUS_INC = 'h1,
318  parameter MCONTR_CMPRS_STATUS_BASE = 'h2c, // .. 'h2f
319  parameter MCONTR_CMPRS_STATUS_INC = 'h1,
320 
321 // membridge module parameters
322  parameter MEMBRIDGE_ADDR= 'h200,
323  parameter MEMBRIDGE_MASK= 'h7f0,
324  parameter MEMBRIDGE_CTRL= 'h0, // bit 0 - enable, bits[2:1]: 01 - start, 11 - start and reset address
325  parameter MEMBRIDGE_STATUS_CNTRL= 'h1,
326  parameter MEMBRIDGE_LO_ADDR64= 'h2, // low address of the system memory, in 64-bit words (<<3 to get byte address)
327  parameter MEMBRIDGE_SIZE64= 'h3, // size of the system memory range (access will roll over to lo_addr
328  parameter MEMBRIDGE_START64= 'h4, // start address relative to lo_addr
329  parameter MEMBRIDGE_LEN64= 'h5, // full length of transfer in 64-bit words
330  parameter MEMBRIDGE_WIDTH64= 'h6, // frame width in 64-bit words (partial last page in each line)
331  parameter MEMBRIDGE_MODE= 'h7, // AXI cache mode (default == 3). +0x10 - debug cache (replace data with counters)
332  parameter MEMBRIDGE_STATUS_REG= 'h3b,
333 
334  parameter RSEL= 1'b1, // late/early READ commands (to adjust timing by 1 SDCLK period)
335  parameter WSEL= 1'b0, // late/early WRITE commands (to adjust timing by 1 SDCLK period)
336 
337  parameter SENSOR_GROUP_ADDR = 'h400, // sensor registers base address
338  parameter SENSOR_BASE_INC = 'h040, // increment for sesor channel
339 
340  parameter HIST_SAXI_ADDR_REL = 'h100, // histograms control addresses (16 locations) relative to SENSOR_GROUP_ADDR
341  parameter HIST_SAXI_MODE_ADDR_REL = 'h110, // histograms mode address (1 locations) relative to SENSOR_GROUP_ADDR
342 
343 
344  parameter SENSI2C_STATUS_REG_BASE = 'h20, // 4 locations" x20, x22, x24, x26
345  parameter SENSI2C_STATUS_REG_INC = 2, // increment to the next sensor
346  parameter SENSI2C_STATUS_REG_REL = 0, // 4 locations" 'h20, 'h22, 'h24, 'h26
347  parameter SENSIO_STATUS_REG_REL = 1, // 4 locations" 'h21, 'h23, 'h25, 'h27
348  parameter SENSOR_NUM_HISTOGRAM= 1, //was 3 trying just one histogram (see utilization) 3, // number of histogram channels
349  parameter HISTOGRAM_RAM_MODE = "BUF32", // "NOBUF", // valid: "NOBUF" (32-bits, no buffering), "BUF18", "BUF32"
350  parameter SENS_NUM_SUBCHN = 3, // number of subchannels for his sensor ports (1..4)
351  parameter SENS_GAMMA_BUFFER = 0, // 1 - use "shadow" table for clean switching, 0 - single table per channel
352 
353  // parameters defining address map
354  parameter SENSOR_CTRL_RADDR = 0, // relative to SENSOR_GROUP_ADDR
355  parameter SENSOR_CTRL_ADDR_MASK = 'h7ff, //
356  // bits of the SENSOR mode register
357  parameter SENSOR_MODE_WIDTH = 10,
358  parameter SENSOR_HIST_EN_BITS = 0, // 0..3 1 - enable histogram modules, disable after processing the started frame
359  parameter SENSOR_HIST_NRST_BITS = 4, // 0 - immediately reset all histogram modules
360  parameter SENSOR_CHN_EN_BIT = 8, // 1 - this enable channel
361  parameter SENSOR_16BIT_BIT = 9, // 0 - 8 bpp mode, 1 - 16 bpp (bypass gamma). Gamma-processed data is still used for histograms
362 
363  parameter SENSI2C_CTRL_RADDR = 2, // 302..'h303
364  parameter SENSI2C_CTRL_MASK = 'h7fe,
365  // sensor_i2c_io relative control register addresses
366  parameter SENSI2C_CTRL = 'h0,
367  // Control register bits
368  parameter SENSI2C_CMD_TABLE = 29, // [29]: 1 - write to translation table (ignore any other fields), 0 - write other fields
369  parameter SENSI2C_CMD_TAND = 28, // [28]: 1 - write table address (8 bits), 0 - write table data (28 bits)
370 
371  parameter SENSI2C_CMD_RESET = 14, // [14] reset all FIFO (takes 16 clock pulses), also - stops i2c until run command
372  parameter SENSI2C_CMD_RUN = 13, // [13:12]3 - run i2c, 2 - stop i2c (needed before software i2c), 1,0 - no change to run state
373  parameter SENSI2C_CMD_RUN_PBITS = 1,
374 
375  parameter SENSI2C_CMD_SOFT_SDA = 6, // [7:6] - SDA software control: 0 - nop, 1 - low, 2 - active high, 3 - float
376  parameter SENSI2C_CMD_SOFT_SCL = 4, // [5:4] - SCL software control: 0 - nop, 1 - low, 2 - active high, 3 - float
377 
378  parameter SENSI2C_CMD_FIFO_RD = 3, // advance I2C read data FIFO by 1
379  parameter SENSI2C_CMD_ACIVE = 2, // [2] - SENSI2C_CMD_ACIVE_EARLY0, SENSI2C_CMD_ACIVE_SDA
380  parameter SENSI2C_CMD_ACIVE_EARLY0 = 1, // release SDA==0 early if next bit ==1
381  parameter SENSI2C_CMD_ACIVE_SDA = 0, // drive SDA=1 during the second half of SCL=1
382  //i2c page table bit fields
383  parameter SENSI2C_TBL_RAH = 0, // high byte of the register address
384  parameter SENSI2C_TBL_RAH_BITS = 8,
385  parameter SENSI2C_TBL_RNWREG = 8, // read register (when 0 - write register
386  parameter SENSI2C_TBL_SA = 9, // Slave address in write mode
387  parameter SENSI2C_TBL_SA_BITS = 7,
388  parameter SENSI2C_TBL_NBWR = 16, // number of bytes to write (1..10)
389  parameter SENSI2C_TBL_NBWR_BITS = 4,
390  parameter SENSI2C_TBL_NBRD = 16, // number of bytes to read (1 - 8) "0" means "8"
391  parameter SENSI2C_TBL_NBRD_BITS = 3,
392  parameter SENSI2C_TBL_NABRD = 19, // number of address bytes for read (0 - 1 byte, 1 - 2 bytes)
393  parameter SENSI2C_TBL_DLY = 20, // bit delay (number of mclk periods in 1/4 of SCL period)
394  parameter SENSI2C_TBL_DLY_BITS= 8,
395 
396 
397  parameter SENSI2C_STATUS = 'h1,
398 
399  parameter SENS_SYNC_RADDR = 'h4,
400  parameter SENS_SYNC_MASK = 'h7fc,
401  // 2 locations reserved for control/status (if they will be needed)
402  parameter SENS_SYNC_MULT = 'h2, // relative register address to write number of frames to combine in one (minus 1, '0' - each farme)
403  parameter SENS_SYNC_LATE = 'h3, // number of lines to delay late frame sync
404 
405 
406 
407  parameter SENS_GAMMA_RADDR = 'h38, // 'h38..'h3b was 4,
408  parameter SENS_GAMMA_ADDR_MASK = 'h7fc,
409  // sens_gamma registers
410  parameter SENS_GAMMA_CTRL = 'h0,
411  parameter SENS_GAMMA_ADDR_DATA = 'h1, // bit 20 ==1 - table address, bit 20==0 - table data (18 bits)
412  parameter SENS_GAMMA_HEIGHT01 = 'h2, // bits [15:0] - height minus 1 of image 0, [31:16] - height-1 of image1
413  parameter SENS_GAMMA_HEIGHT2 = 'h3, // bits [15:0] - height minus 1 of image 2 ( no need for image 3)
414  // bits of the SENS_GAMMA_CTRL mode register
415  parameter SENS_GAMMA_MODE_WIDTH = 5, // does not include trig
416  parameter SENS_GAMMA_MODE_BAYER = 0,
417  parameter SENS_GAMMA_MODE_PAGE = 2,
418  parameter SENS_GAMMA_MODE_EN = 3,
419  parameter SENS_GAMMA_MODE_REPET = 4,
420  parameter SENS_GAMMA_MODE_TRIG = 5,
421 
422 // Vignetting correction / pixel value scaling - controlled via single data word (same as in 252), some of bits [23:16]
423 // are used to select register, bits 25:24 - select sub-frame
424  parameter SENS_LENS_RADDR = 'h3c,
425  parameter SENS_LENS_ADDR_MASK = 'h7fc,
426  parameter SENS_LENS_COEFF = 'h3, // set vignetting/scale coefficients (
427  parameter SENS_LENS_AX = 'h00, // 00000...
428  parameter SENS_LENS_AX_MASK = 'hf8,
429  parameter SENS_LENS_AY = 'h08, // 00001...
430  parameter SENS_LENS_AY_MASK = 'hf8,
431  parameter SENS_LENS_C = 'h10, // 00010...
432  parameter SENS_LENS_C_MASK = 'hf8,
433  parameter SENS_LENS_BX = 'h20, // 001.....
434  parameter SENS_LENS_BX_MASK = 'he0,
435  parameter SENS_LENS_BY = 'h40, // 010.....
436  parameter SENS_LENS_BY_MASK = 'he0,
437  parameter SENS_LENS_SCALES = 'h60, // 01100...
438  parameter SENS_LENS_SCALES_MASK = 'hf8,
439  parameter SENS_LENS_FAT0_IN = 'h68, // 01101000
440  parameter SENS_LENS_FAT0_IN_MASK = 'hff,
441  parameter SENS_LENS_FAT0_OUT = 'h69, // 01101001
442  parameter SENS_LENS_FAT0_OUT_MASK = 'hff,
443  parameter SENS_LENS_POST_SCALE = 'h6a, // 01101010
444  parameter SENS_LENS_POST_SCALE_MASK = 'hff,
445 
446  parameter SENSIO_RADDR = 8, //'h408 .. 'h40f
447  parameter SENSIO_ADDR_MASK = 'h7f8,
448  // sens_parallel12 registers
449  parameter SENSIO_CTRL = 'h0,
450  // SENSIO_CTRL register bits
451  parameter SENS_CTRL_MRST = 0, // 1: 0
452  parameter SENS_CTRL_ARST = 2, // 3: 2
453  parameter SENS_CTRL_ARO = 4, // 5: 4
454  parameter SENS_CTRL_RST_MMCM = 6, // 7: 6
455 //`ifdef HISPI
456  parameter SENS_CTRL_IGNORE_EMBED =8, // 9: 8
457 //`else
458  parameter SENS_CTRL_EXT_CLK = 8, // 9: 8
459 //`endif
460  parameter SENS_CTRL_LD_DLY = 10, // 10
461 //`ifdef HISPI
462  parameter SENS_CTRL_GP0= 12, // 13:12
463  parameter SENS_CTRL_GP1= 14, // 15:14
464 //`else
465  parameter SENS_CTRL_QUADRANTS = 12, // 17:12, enable - 20
466  parameter SENS_CTRL_QUADRANTS_WIDTH = 6,
467  parameter SENS_CTRL_QUADRANTS_EN = 20, // 17:12, enable - 20 (2 bits reserved)
468 //`endif
469  parameter SENSIO_STATUS = 'h1,
470  parameter SENSIO_JTAG = 'h2,
471  // SENSIO_JTAG register bits
472  parameter SENS_JTAG_PGMEN = 8,
473  parameter SENS_JTAG_PROG = 6,
474  parameter SENS_JTAG_TCK = 4,
475  parameter SENS_JTAG_TMS = 2,
476  parameter SENS_JTAG_TDI = 0,
477 //`ifndef HISPI
478  parameter SENSIO_WIDTH = 'h3, // 1.. 2^16, 0 - use HACT
479 //`endif
480  parameter SENSIO_DELAYS = 'h4, // 'h4..'h7
481  // 4 of 8-bit delays per register
482  // sensor_i2c_io command/data write registers s (relative to SENSOR_GROUP_ADDR)
483  parameter SENSI2C_ABS_RADDR = 'h10, // 'h410..'h41f
484  parameter SENSI2C_REL_RADDR = 'h20, // 'h420..'h42f
485  parameter SENSI2C_ADDR_MASK = 'h7f0, // both for SENSI2C_ABS_ADDR and SENSI2C_REL_ADDR
486 
487  // sens_hist registers (relative to SENSOR_GROUP_ADDR)
488  parameter HISTOGRAM_RADDR0 = 'h30, //
489  parameter HISTOGRAM_RADDR1 = 'h32, //
490  parameter HISTOGRAM_RADDR2 = 'h34, //
491  parameter HISTOGRAM_RADDR3 = 'h36, //
492  parameter HISTOGRAM_ADDR_MASK = 'h7fe, // for each channel
493  // sens_hist registers
494  parameter HISTOGRAM_LEFT_TOP = 'h0,
495  parameter HISTOGRAM_WIDTH_HEIGHT = 'h1, // 1.. 2^16, 0 - use HACT
496 
497  //sensor_i2c_io other parameters
498  parameter integer SENSI2C_DRIVE= 12,
499  parameter SENSI2C_IBUF_LOW_PWR= "TRUE",
500  parameter SENSI2C_SLEW = "SLOW",
501 
502 //`ifndef HISPI
503  //sensor_fifo parameters
504  parameter SENSOR_DATA_WIDTH = 12,
505  parameter SENSOR_FIFO_2DEPTH = 4,
506  parameter [3:0] SENSOR_FIFO_DELAY = 5, // 7,
507 //`endif
508 
509  // other parameters for histogram_saxi module
510  parameter HIST_SAXI_ADDR_MASK = 'h7f0,
511  parameter HIST_SAXI_MODE_WIDTH = 8,
512  parameter HIST_SAXI_EN = 0,
513  parameter HIST_SAXI_NRESET = 1,
514  parameter HIST_CONFIRM_WRITE = 2, // wait write confirmation for each block
515  // bit 3 is not used
516  parameter HIST_SAXI_AWCACHE = 4, // ..7 Write 4'h3 there, cache mode (4 bits, default 4'h3)
517 
518  parameter HIST_SAXI_MODE_ADDR_MASK = 'h7ff,
519  parameter NUM_FRAME_BITS = 4, // number of bits use for frame number
520 
521  // Other parameters
522  parameter SENS_SYNC_FBITS = 16, // number of bits in a frame counter for linescan mode
523  parameter SENS_SYNC_LBITS = 16, // number of bits in a line counter for sof_late output (limited by eof)
524  parameter SENS_SYNC_LATE_DFLT = 15, // number of lines to delay late frame sync
525  parameter SENS_SYNC_MINBITS = 8, // number of bits to enforce minimal frame period
526  parameter SENS_SYNC_MINPER = 130, // minimal frame period (in pclk/mclk?)
527 
528 
529  // sens_parallel12 other parameters
530 
531 // parameter IODELAY_GRP ="IODELAY_SENSOR", // may need different for different channels?
532  parameter integer IDELAY_VALUE = 0,
533  parameter integer PXD_DRIVE = 12,
534  parameter PXD_IBUF_LOW_PWR = "TRUE",
535  parameter PXD_SLEW = "SLOW",
536 `ifdef use200Mhz
537  parameter real SENS_REFCLK_FREQUENCY = 300.0, // same as REFCLK_FREQUENCY
538 `else
539  parameter real SENS_REFCLK_FREQUENCY = 200.0,
540 `endif
541  parameter SENS_HIGH_PERFORMANCE_MODE = "FALSE",
542 
543 //`ifdef HISPI
544  parameter PXD_CAPACITANCE = "DONT_CARE",
545  parameter PXD_CLK_DIV = 10, // 220MHz -> 22MHz
546  parameter PXD_CLK_DIV_BITS = 4,
547 //`endif
548 
549  parameter SENS_PHASE_WIDTH= 8, // number of bits for te phase counter (depends on divisors)
550 // parameter SENS_PCLK_PERIOD = 10.000, // input period in ns, 0..100.000 - MANDATORY, resolution down to 1 ps
551  parameter SENS_BANDWIDTH = "OPTIMIZED", //"OPTIMIZED", "HIGH","LOW"
552 
553  // parameters for the sensor-synchronous clock PLL
554 `define TWEAKING_IOSTANDARD
555 `ifdef HISPI
556  parameter CLKIN_PERIOD_SENSOR = 3.000, // input period in ns, 0..100.000 - MANDATORY, resolution down to 1 ps
557  parameter CLKFBOUT_MULT_SENSOR = 3, // 330 MHz --> 990 MHz
558  parameter CLKFBOUT_PHASE_SENSOR = 0.000, // CLOCK FEEDBACK phase in degrees (3 significant digits, -360.000...+360.000)
559  parameter IPCLK_PHASE = 0.000,
560  parameter IPCLK2X_PHASE = 0.000,
561  `ifdef TWEAKING_IOSTANDARD
562  parameter PXD_IOSTANDARD = "LVCMOS25", // with 1.8 actually applied voltage
563  parameter SENSI2C_IOSTANDARD = "LVCMOS25", // with 1.8 actually applied voltage
564 // parameter PXD_IOSTANDARD = "LVCMOS18", // with 1.8 actually applied voltage
565 // parameter SENSI2C_IOSTANDARD = "LVCMOS18", // with 1.8 actually applied voltage
566  `else
567  parameter PXD_IOSTANDARD = "LVCMOS18",
568  parameter SENSI2C_IOSTANDARD = "LVCMOS18",
569  `endif
570 
571 `else
572  parameter CLKIN_PERIOD_SENSOR = 10.000, // input period in ns, 0..100.000 - MANDATORY, resolution down to 1 ps
573  parameter CLKFBOUT_MULT_SENSOR = 8, // 100 MHz --> 800 MHz
574  parameter CLKFBOUT_PHASE_SENSOR = 0.000, // CLOCK FEEDBACK phase in degrees (3 significant digits, -360.000...+360.000)
575  parameter IPCLK_PHASE = 0.000,
576  parameter IPCLK2X_PHASE = 0.000,
577  parameter PXD_IOSTANDARD = "LVCMOS25",
578  parameter SENSI2C_IOSTANDARD = "LVCMOS25",
579 
580 `endif
581 
582  `ifdef TWEAKING_IOSTANDARD
583  parameter HISPI_UNTUNED_SPLIT = "FALSE", // Very power-hungry
584  parameter HISPI_DIFF_TERM = "TRUE", // Only possible with 2.5 power LVDS, not with 1.8V "TRUE",
585 // parameter HISPI_DIFF_TERM = "FALSE", // Only possible with 2.5 power LVDS, not with 1.8V "TRUE",
586 // parameter HISPI_IOSTANDARD = "PPDS_25", // "LVDS_25", "MINI_LVDS_25", "PPDS_25", "RSDS_25"
587  parameter HISPI_IOSTANDARD = "LVDS_25", // "LVDS_25", "MINI_LVDS_25", "PPDS_25", "RSDS_25"
588  `else
589  parameter HISPI_UNTUNED_SPLIT = "FALSE", // Very power-hungry
590  parameter HISPI_DIFF_TERM = "FALSE", // Only possible with 2.5 power LVDS, not with 1.8V "TRUE",
591  parameter HISPI_IOSTANDARD = "DIFF_SSTL18_I", //"DIFF_SSTL18_II" for high current (13.4mA vs 8mA)
592  `endif
593 
594 
595 // parameter BUF_IPCLK = "BUFMR", //G", // "BUFR", // BUFR fails for both clocks for sensors1 and 3
596 // parameter BUF_IPCLK2X = "BUFMR", //G", // "BUFR",
597 
598  parameter BUF_IPCLK_SENS0 = "BUFR", // "BUFR2", //G", // "BUFR", // BUFR fails for both clocks for sensors1 and 3
599  parameter BUF_IPCLK2X_SENS0 = "BUFIO", /// "BUFR", //G", // "BUFR",
600 
601  parameter BUF_IPCLK_SENS1 = "BUFG", // "BUFR", // BUFR fails for both clocks for sensors1 and 3
602  parameter BUF_IPCLK2X_SENS1 = "BUFG", // "BUFR",
603 
604  parameter BUF_IPCLK_SENS2 = "BUFR", // "BUFR2", //G", // "BUFR", // BUFR fails for both clocks for sensors1 and 3
605  parameter BUF_IPCLK2X_SENS2 = "BUFIO", ///"BUFR", //G", // "BUFR",
606 
607  parameter BUF_IPCLK_SENS3 = "BUFG", // "BUFR2", ///"BUFG", // "BUFR", // BUFR fails for both clocks for sensors1 and 3
608  parameter BUF_IPCLK2X_SENS3 = "BUFG", // "BUFIO", ///"BUFG", // "BUFR",
609 
610  parameter SENS_DIVCLK_DIVIDE = 1, // Integer 1..106. Divides all outputs with respect to CLKIN
611  parameter SENS_REF_JITTER1 = 0.010, // Expected jitter on CLKIN1 (0.000..0.999)
612  parameter SENS_REF_JITTER2 = 0.010,
613  parameter SENS_SS_EN = "FALSE", // Enables Spread Spectrum mode
614  parameter SENS_SS_MODE = "CENTER_HIGH",//"CENTER_HIGH","CENTER_LOW","DOWN_HIGH","DOWN_LOW"
615  parameter SENS_SS_MOD_PERIOD = 10000, // integer 4000-40000 - SS modulation period in ns
616 
617 //`ifdef HISPI
618  parameter HISPI_MSB_FIRST = 0,
619  parameter HISPI_NUMLANES = 4,
620 
621  parameter HISPI_DELAY_CLK0= "TRUE",
622  parameter HISPI_DELAY_CLK1= "TRUE",
623  parameter HISPI_DELAY_CLK2= "TRUE",
624  parameter HISPI_DELAY_CLK3= "TRUE",
625  parameter HISPI_MMCM0 = "TRUE",
626  parameter HISPI_MMCM1 = "FALSE",
627  parameter HISPI_MMCM2 = "TRUE",
628  parameter HISPI_MMCM3 = "FALSE",
629  parameter HISPI_KEEP_IRST = 5, // number of cycles to keep irst on after release of prst (small number - use 1 hot)
630  parameter HISPI_WAIT_ALL_LANES = 4'h8, // number of output pixel cycles to wait after the earliest lane
631  parameter HISPI_FIFO_DEPTH = 4,
632  parameter HISPI_FIFO_START = 7,
633  parameter HISPI_CAPACITANCE = "DONT_CARE",
634  parameter HISPI_DQS_BIAS = "TRUE",
635  parameter HISPI_IBUF_DELAY_VALUE = "0",
636  parameter HISPI_IBUF_LOW_PWR = "TRUE",
637  parameter HISPI_IFD_DELAY_VALUE = "AUTO",
638 // parameter HISPI_IOSTANDARD = "PPDS_25", //"DIFF_SSTL18_II" for high current (13.4mA vs 8mA)
639 // parameter HISPI_IOSTANDARD = "DIFF_HSTL_II_18", //"DIFF_SSTL18_II" for high current (13.4mA vs 8mA)
640 //`endif DIFF_HSTL_II_18
641 
642 
643  parameter CMPRS_NUM_AFI_CHN = 1, // 2, // 1 - multiplex all 4 compressors to a single AXI_HP, 2 - split between to AXI_HP
644  parameter CMPRS_GROUP_ADDR = 'h600, // total of 'h60
645  parameter CMPRS_BASE_INC = 'h10,
646  parameter CMPRS_AFIMUX_RADDR0= 'h40, // relative to CMPRS_NUM_AFI_CHN ( 16 addr)
647  parameter CMPRS_AFIMUX_RADDR1= 'h50, // relative to CMPRS_NUM_AFI_CHN ( 16 addr)
648  parameter CMPRS_AFIMUX_MASK= 'h7f0,
649 
650  parameter CMPRS_STATUS_REG_BASE= 'h10,
651  parameter CMPRS_HIFREQ_REG_BASE= 'h14,
652  parameter CMPRS_AFIMUX_REG_ADDR0= 'h18, // Uses 4 locations
653  parameter CMPRS_AFIMUX_REG_ADDR1= 'h1c, // Uses 4 locations
654 
655  parameter CMPRS_STATUS_REG_INC= 1,
656  parameter CMPRS_HIFREQ_REG_INC= 1,
657  parameter CMPRS_MASK= 'h7f8,
658  parameter CMPRS_CONTROL_REG= 0,
659  parameter CMPRS_STATUS_CNTRL= 1,
660  parameter CMPRS_FORMAT= 2,
661  parameter CMPRS_COLOR_SATURATION= 3,
662  parameter CMPRS_CORING_MODE= 4,
663  parameter CMPRS_INTERRUPTS= 5,
664  parameter CMPRS_TABLES= 6, // 6..7
665  parameter TABLE_QUANTIZATION_INDEX = 0,
666  parameter TABLE_CORING_INDEX = 1,
667  parameter TABLE_FOCUS_INDEX = 2,
668  parameter TABLE_HUFFMAN_INDEX = 3,
669 
670 
671  // Bit-fields in compressor control word
672  parameter CMPRS_CBIT_RUN = 2, // bit # to control compressor run modes
673  parameter CMPRS_CBIT_RUN_BITS = 2, // number of bits to control compressor run modes
674  parameter CMPRS_CBIT_QBANK = 6, // bit # to control quantization table page
675  parameter CMPRS_CBIT_QBANK_BITS = 3, // number of bits to control quantization table page
676  parameter CMPRS_CBIT_DCSUB = 8, // bit # to control extracting DC components bypassing DCT
677  parameter CMPRS_CBIT_DCSUB_BITS = 1, // bit # to control extracting DC components bypassing DCT
678  parameter CMPRS_CBIT_CMODE = 13, // bit # to control compressor color modes
679  parameter CMPRS_CBIT_CMODE_BITS = 4, // number of bits to control compressor color modes
680  parameter CMPRS_CBIT_FRAMES = 15, // bit # to control compressor multi/single frame buffer modes
681  parameter CMPRS_CBIT_FRAMES_BITS = 1, // number of bits to control compressor multi/single frame buffer modes
682  parameter CMPRS_CBIT_BAYER = 20, // bit # to control compressor Bayer shift mode
683  parameter CMPRS_CBIT_BAYER_BITS = 2, // number of bits to control compressor Bayer shift mode
684  parameter CMPRS_CBIT_FOCUS = 23, // bit # to control compressor focus display mode
685  parameter CMPRS_CBIT_FOCUS_BITS = 2, // number of bits to control compressor focus display mode
686  // compressor bit-fields decode
687  parameter CMPRS_CBIT_RUN_RST = 2'h0, // reset compressor, stop immediately
688 // parameter CMPRS_CBIT_RUN_DISABLE = 2'h1, // disable compression of the new frames, finish any already started
689  parameter CMPRS_CBIT_RUN_STANDALONE = 2'h2, // enable compressor, compress single frame from memory (async)
690  parameter CMPRS_CBIT_RUN_ENABLE = 2'h3, // enable compressor, enable synchronous compression mode
691  parameter CMPRS_CBIT_CMODE_JPEG18 = 4'h0, // color 4:2:0 3x3 de-bayer core
692  parameter CMPRS_CBIT_CMODE_MONO6 = 4'h1, // mono 4:2:0 (6 blocks)
693  parameter CMPRS_CBIT_CMODE_JP46 = 4'h2, // jp4, 6 blocks, original
694  parameter CMPRS_CBIT_CMODE_JP46DC = 4'h3, // jp4, 6 blocks, dc -improved
695  parameter CMPRS_CBIT_CMODE_JPEG20 = 4'h4, // color 4:2:0 5x5 de-bayer core - not implemented
696  parameter CMPRS_CBIT_CMODE_JP4 = 4'h5, // jp4, 4 blocks
697  parameter CMPRS_CBIT_CMODE_JP4DC = 4'h6, // jp4, 4 blocks, dc-improved
698  parameter CMPRS_CBIT_CMODE_JP4DIFF = 4'h7, // jp4, 4 blocks, differential
699  parameter CMPRS_CBIT_CMODE_JP4DIFFHDR = 4'h8, // jp4, 4 blocks, differential, hdr
700  parameter CMPRS_CBIT_CMODE_JP4DIFFDIV2 = 4'h9, // jp4, 4 blocks, differential, divide by 2
701  parameter CMPRS_CBIT_CMODE_JP4DIFFHDRDIV2 = 4'ha, // jp4, 4 blocks, differential, hdr,divide by 2
702  parameter CMPRS_CBIT_CMODE_MONO1 = 4'hb, // mono JPEG (not yet implemented)
703  parameter CMPRS_CBIT_CMODE_MONO4 = 4'he, // mono, 4 blocks (but still not actual monochrome JPEG as the blocks are scanned in 2x2 macroblocks)
704 
705  parameter CMPRS_CBIT_FRAMES_SINGLE = 0, //1, // use a single-frame buffer for images
706 
707  parameter CMPRS_COLOR18 = 0, // JPEG 4:2:0 with 18x18 overlapping tiles for de-bayer
708  parameter CMPRS_COLOR20 = 1, // JPEG 4:2:0 with 18x18 overlapping tiles for de-bayer (not implemented)
709  parameter CMPRS_MONO16 = 2, // JPEG 4:2:0 with 16x16 non-overlapping tiles, color components zeroed
710  parameter CMPRS_JP4 = 3, // JP4 mode with 16x16 macroblocks
711  parameter CMPRS_JP4DIFF = 4, // JP4DIFF mode TODO: see if correct
712  parameter CMPRS_MONO8 = 7, // Regular JPEG monochrome with 8x8 macroblocks (not yet implemented)
713 
714  parameter CMPRS_FRMT_MBCM1 = 0, // bit # of number of macroblock columns minus 1 field in format word
715  parameter CMPRS_FRMT_MBCM1_BITS = 13, // number of bits in number of macroblock columns minus 1 field in format word
716  parameter CMPRS_FRMT_MBRM1 = 13, // bit # of number of macroblock rows minus 1 field in format word
717  parameter CMPRS_FRMT_MBRM1_BITS = 13, // number of bits in number of macroblock rows minus 1 field in format word
718  parameter CMPRS_FRMT_LMARG = 26, // bit # of left margin field in format word
719  parameter CMPRS_FRMT_LMARG_BITS = 5, // number of bits in left margin field in format word
720  parameter CMPRS_CSAT_CB = 0, // bit # of number of blue scale field in color saturation word
721  parameter CMPRS_CSAT_CB_BITS = 10, // number of bits in blue scale field in color saturation word
722  parameter CMPRS_CSAT_CR = 12, // bit # of number of red scale field in color saturation word
723  parameter CMPRS_CSAT_CR_BITS = 10, // number of bits in red scale field in color saturation word
724  parameter CMPRS_CORING_BITS = 3, // number of bits in coring mode
725 
726  parameter CMPRS_TIMEOUT_BITS= 12,
727  parameter CMPRS_TIMEOUT= 1000, // mclk cycles
728 
729  parameter CMPRS_AFIMUX_EN= 'h0, // enables (gl;obal and per-channel)
730  parameter CMPRS_AFIMUX_RST= 'h1, // per-channel resets
731  parameter CMPRS_AFIMUX_MODE= 'h2, // per-channel select - which register to return as status
732  parameter CMPRS_AFIMUX_STATUS_CNTRL= 'h4, // .. 'h7
733  parameter CMPRS_AFIMUX_SA_LEN= 'h8, // .. 'hf
734 
735  parameter CMPRS_AFIMUX_WIDTH = 26, // maximal for status: currently only works with 26)
736  parameter CMPRS_AFIMUX_CYCBITS = 3,
737  parameter AFI_MUX_BUF_LATENCY = 4'd2, // buffers read latency from fifo_ren* to fifo_rdata* valid : 2 if no register layers are used
738  // GPIO control : 'h700..'h701, status: 'h30
739  parameter integer GPIO_DRIVE = 12,
740  parameter GPIO_ADDR = 'h700, // .701
741  parameter GPIO_MASK = 'h7fe,
742  parameter GPIO_STATUS_REG_ADDR = 'h30, // address where status can be read out (10 GPIO inputs)
743 
744  parameter GPIO_IBUF_LOW_PWR = "TRUE",
745  parameter GPIO_IOSTANDARD = "LVCMOS15", // power is 1.5V
746  parameter GPIO_SLEW = "SLOW",
747 
748  parameter GPIO_SET_PINS = 0, // Set GPIO output state, give control for some bits to other modules
749  parameter GPIO_SET_STATUS = 1, // set status mode
750  parameter GPIO_N = 10, // number of GPIO bits to control
751  parameter GPIO_PORTEN = 24, // bit number to control port enables (up from this)
752  // Timing (rtc+camsync) parameters
753  parameter RTC_ADDR= 'h704, // 'h707
754  parameter CAMSYNC_ADDR = 'h708, // 'h70f
755  parameter RTC_STATUS_REG_ADDR = 'h31, // (1 loc) address where status can be read out (currently just sequence # and alternating bit)
756  parameter RTC_SEC_USEC_ADDR = 'h32, // ..'h33 address where seconds of the snapshot can be read (microseconds - next address)
757  parameter RTC_MASK = 'h7fc,
758  parameter CAMSYNC_MASK = 'h7f8,
759  parameter CAMSYNC_MODE = 'h0,
760  parameter CAMSYNC_TRIG_SRC = 'h1, // setup trigger source
761  parameter CAMSYNC_TRIG_DST = 'h2, // setup trigger destination line(s)
762  parameter CAMSYNC_TRIG_PERIOD = 'h3, // setup output trigger period
763  parameter CAMSYNC_TRIG_DELAY0 = 'h4, // setup input trigger delay
764  parameter CAMSYNC_TRIG_DELAY1 = 'h5, // setup input trigger delay
765  parameter CAMSYNC_TRIG_DELAY2 = 'h6, // setup input trigger delay
766  parameter CAMSYNC_TRIG_DELAY3 = 'h7, // setup input trigger delay
767 
768  parameter CAMSYNC_EN_BIT = 'h0, // enable module (0 - reset)
769  parameter CAMSYNC_SNDEN_BIT = 'h2, // enable writing ts_snd_en
770  parameter CAMSYNC_EXTERNAL_BIT = 'h4, // enable writing ts_external (0 - local timestamp in the frame header)
771  parameter CAMSYNC_TRIGGERED_BIT = 'h6, // triggered mode ( 0- async)
772  parameter CAMSYNC_MASTER_BIT = 'h9, // select a 2-bit master channel (master delay may be used as a flash delay)
773  parameter CAMSYNC_CHN_EN_BIT = 'he, // per-channel enable timestamp generation
774  parameter CAMSYNC_PRE_MAGIC = 6'b110100,
775  parameter CAMSYNC_POST_MAGIC = 6'b001101,
776 
777  parameter RTC_MHZ= 25, // RTC input clock in MHz (should be interger number)
778  parameter RTC_BITC_PREDIV = 5, // number of bits to generate 2 MHz pulses counting refclk
779  parameter RTC_SET_USEC= 0, // 20-bit number of microseconds
780  parameter RTC_SET_SEC= 1, // 32-bit full number of seconds (und actually update timer)
781  parameter RTC_SET_CORR= 2, // write correction 16-bit signed
782  parameter RTC_SET_STATUS= 3, // generate an output pulse to take a snapshot
783  // Command sequencers parameters
784  parameter CMDFRAMESEQ_ADDR_BASE= 'h780,
785  parameter CMDFRAMESEQ_ADDR_INC= 'h20,
786  parameter CMDFRAMESEQ_MASK= 'h7e0,
787  parameter CMDFRAMESEQ_DEPTH = 64, // 32/64/128
788  parameter CMDFRAMESEQ_ABS = 0,
789  parameter CMDFRAMESEQ_REL = 16,
790  parameter CMDFRAMESEQ_CTRL = 31,
791  parameter CMDFRAMESEQ_RST_BIT = 14,
792  parameter CMDFRAMESEQ_RUN_BIT = 13,
793  parameter CMDFRAMESEQ_IRQ_BIT = 0,
794 
795  parameter CMDSEQMUX_ADDR = 'h702, // only status control
796  parameter CMDSEQMUX_MASK = 'h7ff,
797  parameter CMDSEQMUX_STATUS = 'h38,
798  // Logger parameters
799  parameter LOGGER_ADDR = 'h720, //..'h721
800  parameter LOGGER_STATUS = 'h722, // .. 'h722
801  parameter LOGGER_STATUS_REG_ADDR = 'h39, // just 1 location)
802  parameter LOGGER_MASK = 'h7fe,
803  parameter LOGGER_STATUS_MASK = 'h7ff,
804 
805 // parameter LOGGER_PAGE_IMU = 0, // 'h00..'h1f - overlaps with period/duration/halfperiod/config? (was so in x353)
806  parameter LOGGER_PAGE_GPS = 1, // 'h20..'h3f
807  parameter LOGGER_PAGE_MSG = 2, // 'h40..'h5f
808  parameter LOGGER_PAGE_IMU = 3, // 'h60..'h7f - removing overlap with period/duration/halfperiod/config
809 
810  parameter LOGGER_PERIOD = 0,
811  parameter LOGGER_BIT_DURATION = 1,
812  parameter LOGGER_BIT_HALF_PERIOD = 2, //rs232 half bit period
813  parameter LOGGER_CONFIG = 3,
814 
815  parameter LOGGER_CONF_IMU = 2,
816  parameter LOGGER_CONF_IMU_BITS = 2,
817  parameter LOGGER_CONF_GPS = 7,
818  parameter LOGGER_CONF_GPS_BITS = 4,
819  parameter LOGGER_CONF_MSG = 13,
820  parameter LOGGER_CONF_MSG_BITS = 5,
821  parameter LOGGER_CONF_SYN = 18, // 15,
822  parameter LOGGER_CONF_SYN_BITS = 4, // 1,
823  parameter LOGGER_CONF_EN = 20, // 17,
824  parameter LOGGER_CONF_EN_BITS = 1,
825  parameter LOGGER_CONF_DBG = 25, // 22,
826  parameter LOGGER_CONF_DBG_BITS = 4,
827 
828  parameter MULT_SAXI_HALF_BRAM_IN = 1, // 0 - use full 36Kb BRAM for the buffer, 1 - use just half
829  parameter MULT_SAXI_WLOG = 4, // number of bits for the input data ( 3 - 8 bit, 4 - 16-bit, 5 - 32-bit
830 
831  parameter MULT_SAXI_ADDR = 'h730, // ..'h737
832  parameter MULT_SAXI_CNTRL_ADDR = 'h738, // ..'h739
833  parameter MULT_SAXI_STATUS_REG = 'h34, //..'h37 uses 4 consecutive locations
834  parameter MULT_SAXI_HALF_BRAM = 1, // 0 - use full 36Kb BRAM for the buffer, 1 - use just half
835  parameter MULT_SAXI_BSLOG0 = 4, // number of bits to represent burst size (4 - b.s. = 16, 0 - b.s = 1)
836  parameter MULT_SAXI_BSLOG1 = 4,
837  parameter MULT_SAXI_BSLOG2 = 4,
838  parameter MULT_SAXI_BSLOG3 = 4,
839  parameter MULT_SAXI_MASK = 'h7f8, // 4 address/length pairs. In bytes, but lower bits are set to 0?
840  parameter MULT_SAXI_CNTRL_MASK = 'h7fe, // mode and status - 2 locations
841  parameter MULT_SAXI_AWCACHE = 4'h3, //..7 cache mode (4 bits, default 4'h3)
842  parameter MULT_SAXI_ADV_WR = 4, // number of clock cycles before end of write to genearte adv_wr_done
843  parameter MULT_SAXI_ADV_RD = 3, // number of clock cycles before end of write to genearte adv_wr_done
844 
845  // Clock management (input, generation, buffering)
846  parameter CLK_ADDR = 'h728, // ..'h729
847  parameter CLK_MASK = 'h7fe, //
848  parameter CLK_STATUS_REG_ADDR = 'h3a, //
849  parameter CLK_CNTRL = 0,
850  parameter CLK_STATUS = 1,
851 
852 // These are needed for Python:
853 //`ifdef DEBUG_RING
854 // Debug module (read/write serial ring)
855  parameter DEBUG_ADDR = 'h710, //..'h713 // SuppressThisWarning VEditor
856  parameter DEBUG_MASK = 'h7fc,
857  parameter DEBUG_STATUS_REG_ADDR = 'hfc, // address where status can be read out // SuppressThisWarning VEditor
858  parameter DEBUG_READ_REG_ADDR = 'hfd, // read 32-bit received shifted data// SuppressThisWarning VEditor
859  parameter DEBUG_SHIFT_DATA = 'h0, // shift i/o data by 32 bits// SuppressThisWarning VEditor
860  parameter DEBUG_LOAD = 'h1, // parallel load of the distributed shift registe (both ways)// SuppressThisWarning VEditor
861  parameter DEBUG_SET_STATUS = 'h2, // program status (mode 3?)// SuppressThisWarning VEditor
862  parameter DEBUG_CMD_LATENCY = 2, // >0 extra registers in the debug_sl (distriburted in parallel)// SuppressThisWarning VEditor
863 //`endif
864  // setting system clock generated by a single PLL
865  parameter MULTICLK_IN_PERIOD = 20, // 50MHz
866  parameter MULTICLK_DIVCLK = 1, //
867  parameter MULTICLK_MULT = 24, //1200MHz
868 `ifdef use200Mhz
869  parameter MULTICLK_DIV_DLYREF = 6, // 6 - 200MHz I/O delay reference clock (4 - 300MHz)
870 `else
871  parameter MULTICLK_DIV_DLYREF = 4, // 4 - 300MHz I/O delay reference clock (6 - 200MHz)
872 `endif
873  parameter MULTICLK_DIV_AXIHP = 8, // 150 MHz for AXI HP
874 `ifdef USE_XCLK2X
875  parameter MULTICLK_DIV_XCLK = 12, // 100 MHz for compressor
876  parameter MULTICLK_DIV_XCLK2X = 6, // 200 MHz for compressor (when MULTICLK_DIV_XCLK uses 100 MHz)
877 `else
878  parameter MULTICLK_DIV_XCLK = 5, // 240 MHz for compressor (12 for 100 MHz)
879 `endif
880  parameter MULTICLK_DIV_SYNC = 12, // 100 MHz for inter-camera synchronization and time keeping
881 // Additional parameters for multi-clock PLL (phases and buffer types)
882  parameter MULTICLK_PHASE_FB = 0.0,
883  parameter MULTICLK_PHASE_DLYREF = 0.0,
884  parameter MULTICLK_BUF_DLYREF = "BUFG",
885  parameter MULTICLK_PHASE_AXIHP = 0.0,
886  parameter MULTICLK_BUF_AXIHP = "BUFG",
887  parameter MULTICLK_PHASE_XCLK = 0.0,
888  parameter MULTICLK_BUF_XCLK = "BUFG",
889 `ifdef USE_XCLK2X
890  parameter MULTICLK_PHASE_XCLK2X = 0.0,
891  parameter MULTICLK_BUF_XCLK2X = "BUFG",
892 `endif
893  parameter MULTICLK_PHASE_SYNC = 0.0,
894  parameter MULTICLK_BUF_SYNC = "BUFG",
895 
896 // parameter CLKIN_PERIOD_AXIHP = 20, //ns >1.25, 600<Fvco<1200
897 // parameter DIVCLK_DIVIDE_AXIHP = 1,
898 // parameter CLKFBOUT_MULT_AXIHP = 18, // Fvco=Fclkin*CLKFBOUT_MULT_F/DIVCLK_DIVIDE, Fout=Fvco/CLKOUT#_DIVIDE
899 // parameter CLKOUT_DIV_AXIHP = 6, // To get 150MHz for the reference clock
900 // parameter BUF_CLK1X_AXIHP = "BUFG", // "BUFG", "BUFH", "BUFR", "NONE"
901 `ifdef HISPI
902  parameter CLKIN_PERIOD_PCLK = 42, // 24MHz (actually needed is 24.4444
903  parameter DIVCLK_DIVIDE_PCLK = 1,
904  parameter CLKFBOUT_MULT_PCLK = 36, // 880 MHz
905  parameter CLKOUT_DIV_PCLK = 4, // 220 MHz
906  parameter CLKOUT_DIV_PCLK2X = 2, // 440 MHz
907 `else
908  parameter CLKIN_PERIOD_PCLK = 42, // 24MHz
909  parameter DIVCLK_DIVIDE_PCLK = 1,
910  parameter CLKFBOUT_MULT_PCLK = 40, // 960 MHz
911  parameter CLKOUT_DIV_PCLK = 10, // 96MHz
912  parameter CLKOUT_DIV_PCLK2X = 5, // 192 MHz
913 `endif
914  parameter PHASE_CLK2X_PCLK = 0.000,
915  parameter BUF_CLK1X_PCLK = "BUFG",
916  parameter BUF_CLK1X_PCLK2X = "BUFG",
917 
918 
919  parameter MEMCLK_CAPACITANCE = "DONT_CARE",
920  parameter MEMCLK_IBUF_LOW_PWR = "TRUE",
921  parameter MEMCLK_IOSTANDARD = "SSTL15",
922 
923  parameter FFCLK0_CAPACITANCE = "DONT_CARE",
924  parameter FFCLK0_DIFF_TERM = "FALSE",
925  parameter FFCLK0_IBUF_LOW_PWR = "TRUE",
926  parameter FFCLK0_IOSTANDARD = "RSDS_25",
927 
928  parameter FFCLK1_CAPACITANCE = "DONT_CARE",
929  parameter FFCLK1_DIFF_TERM = "FALSE",
930  parameter FFCLK1_IBUF_LOW_PWR = "TRUE",
931  parameter FFCLK1_IOSTANDARD = "RSDS_25"
932 
933 
934 
935 
936 
937 
938