1 /* SPDX-License-Identifier: GPL-2.0 */
3 * Copyright (C) 2015-2017 Intel Corporation <www.intel.com>
6 #ifndef _SOCFPGA_SDRAM_ARRIA10_H_
7 #define _SOCFPGA_SDRAM_ARRIA10_H_
10 #include <linux/bitops.h>
11 int ddr_calibration_sequence(void);
13 struct socfpga_ecc_hmc {
36 u32 _pad_0x58_0x5f[2];
38 u32 _pad_0x64_0xff[39];
41 u32 _pad_0x108_0x10f[2];
54 u32 autowb_drop_cntreg;
56 u32 ecc_reg2wreccdatabus;
57 u32 ecc_rdeccdata2regbus;
58 u32 ecc_reg2rdeccdatabus;
59 u32 _pad_0x154_0x15f[3];
62 u32 _pad_0x168_0x16f[2];
69 struct socfpga_noc_ddr_scheduler {
70 u32 ddr_t_main_scheduler_id_coreid;
71 u32 ddr_t_main_scheduler_id_revisionid;
72 u32 ddr_t_main_scheduler_ddrconf;
73 u32 ddr_t_main_scheduler_ddrtiming;
74 u32 ddr_t_main_scheduler_ddrmode;
75 u32 ddr_t_main_scheduler_readlatency;
76 u32 _pad_0x20_0x34[8];
77 u32 ddr_t_main_scheduler_activate;
78 u32 ddr_t_main_scheduler_devtodev;
84 struct socfpga_noc_fw_ocram {
96 /* for master such as MPU and FPGA */
97 struct socfpga_noc_fw_ddr_mpu_fpga2sdram {
106 u32 fpga2sdram0region0addr;
107 u32 fpga2sdram0region1addr;
108 u32 fpga2sdram0region2addr;
109 u32 fpga2sdram0region3addr;
110 u32 fpga2sdram1region0addr;
111 u32 fpga2sdram1region1addr;
112 u32 fpga2sdram1region2addr;
113 u32 fpga2sdram1region3addr;
114 u32 fpga2sdram2region0addr;
115 u32 fpga2sdram2region1addr;
116 u32 fpga2sdram2region2addr;
117 u32 fpga2sdram2region3addr;
121 struct socfpga_noc_fw_ddr_l3 {
135 struct socfpga_io48_mmr {
209 #endif /*__ASSEMBLY__ */
211 #define IO48_MMR_CTRLCFG0_DB2_BURST_LENGTH_MASK 0x1F000000
212 #define IO48_MMR_CTRLCFG0_DB2_BURST_LENGTH_SHIFT 24
213 #define IO48_MMR_CTRLCFG0_DB1_BURST_LENGTH_MASK 0x00F80000
214 #define IO48_MMR_CTRLCFG0_DB1_BURST_LENGTH_SHIFT 19
215 #define IO48_MMR_CTRLCFG0_DB0_BURST_LENGTH_MASK 0x0007C000
216 #define IO48_MMR_CTRLCFG0_DB0_BURST_LENGTH_SHIFT 14
217 #define IO48_MMR_CTRLCFG0_CTRL_BURST_LENGTH_MASK 0x00003E00
218 #define IO48_MMR_CTRLCFG0_CTRL_BURST_LENGTH_SHIFT 9
219 #define IO48_MMR_CTRLCFG0_AC_POS_MASK 0x00000180
220 #define IO48_MMR_CTRLCFG0_AC_POS_SHIFT 7
221 #define IO48_MMR_CTRLCFG0_DIMM_TYPE_MASK 0x00000070
222 #define IO48_MMR_CTRLCFG0_DIM_TYPE_SHIFT 4
223 #define IO48_MMR_CTRLCFG0_MEM_TYPE_MASK 0x0000000F
224 #define IO48_MMR_CTRLCFG0_MEM_TYPE_SHIFT 0
226 #define IO48_MMR_CTRLCFG1_DBC3_ENABLE_DM BIT(30)
227 #define IO48_MMR_CTRLCFG1_DBC2_ENABLE_DM BIT(29)
228 #define IO48_MMR_CTRLCFG1_DBC1_ENABLE_DM BIT(28)
229 #define IO48_MMR_CTRLCFG1_DBC0_ENABLE_DM BIT(27)
230 #define IO48_MMR_CTRLCFG1_CTRL_ENABLE_DM BIT(26)
231 #define IO48_MMR_CTRLCFG1_DQSTRK_EN BIT(25)
232 #define IO48_MMR_CTRLCFG1_STARVE_LIMIT_MASK 0x01F80000
233 #define IO48_MMR_CTRLCFG1_STARVE_LIMIT_SHIFT 19
234 #define IO48_MMR_CTRLCFG1_REORDER_READ BIT(18)
235 #define IO48_MMR_CTRLCFG1_DBC3_REORDER_RDATA BIT(17)
236 #define IO48_MMR_CTRLCFG1_DBC2_REORDER_RDATA BIT(16)
237 #define IO48_MMR_CTRLCFG1_DBC1_REORDER_RDATA BIT(15)
238 #define IO48_MMR_CTRLCFG1_DBC0_REORDER_RDATA BIT(14)
239 #define IO48_MMR_CTRLCFG1_CTRL_REORDER_RDATA BIT(13)
240 #define IO48_MMR_CTRLCFG1_REORDER_DATA BIT(12)
241 #define IO48_MMR_CTRLCFG1_DBC3_ENABLE_ECC BIT(11)
242 #define IO48_MMR_CTRLCFG1_DBC2_ENABLE_ECC BIT(10)
243 #define IO48_MMR_CTRLCFG1_DBC1_ENABLE_ECC BIT(9)
244 #define IO48_MMR_CTRLCFG1_DBC0_ENABLE_ECC BIT(8)
245 #define IO48_MMR_CTRLCFG1_CTRL_ENABLE_ECC BIT(7)
246 #define IO48_MMR_CTRLCFG1_ADDR_ORDER_MASK 0x00000060
247 #define IO48_MMR_CTRLCFG1_ADDR_ORDER_SHIFT 5
248 #define IO48_MMR_CTRLCFG1_DBC3_BURST_LENGTH_MASK 0x0000001F
249 #define IO48_MMR_CTRLCFG1_DBC3_BURST_LENGTH_SHIFT 0
251 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_ACT_DIFF_BG_MASK 0x3F000000
252 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_ACT_DIFF_BG_SHIFT 24
253 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_ACT_DIFF_BANK_MASK 0x00FC0000
254 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_ACT_DIFF_BANK_SHIFT 18
255 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_ACT_MASK 0x0003F000
256 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_ACT_SHIFT 12
257 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_PCH_MASK 0x00000FC0
258 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_PCH_SHIFT 6
259 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_RDWR_MASK 0x0000003F
260 #define IO48_MMR_CALTIMING0_CFG_ACT_TO_RDWR_SHIFT 0
262 #define IO48_MMR_CALTIMING1_CFG_RD_TO_WR_DIFF_CHIP_MASK 0x3F000000
263 #define IO48_MMR_CALTIMING1_CFG_RD_TO_WR_DIFF_CHIP_SHIFT 24
264 #define IO48_MMR_CALTIMING1_CFG_RD_TO_WR_MASK 0x00FC0000
265 #define IO48_MMR_CALTIMING1_CFG_RD_TO_WR_SHIFT 18
266 #define IO48_MMR_CALTIMING1_CFG_RD_TO_RD_DB_MASK 0x0003F000
267 #define IO48_MMR_CALTIMING1_CFG_RD_TO_RD_DB_SHIFT 12
268 #define IO48_MMR_CALTIMING1_CFG_RD_TO_RD_DC_MASK 0x00000FC0
269 #define IO48_MMR_CALTIMING1_CFG_RD_TO_RD_DC_SHIFT 6
270 #define IO48_MMR_CALTIMING1_CFG_RD_TO_RD_MASK 0x0000003F
271 #define IO48_MMR_CALTIMING1_CFG_RD_TO_RD_SHIFT 0
273 #define IO48_MMR_CALTIMING2_CFG_WR_TO_WR_DIFF_CHIP_MASK 0x3F000000
274 #define IO48_MMR_CALTIMING2_CFG_WR_TO_WR_DIFF_CHIP_SHIFT 24
275 #define IO48_MMR_CALTIMING2_CFG_WR_TO_WR_MASK 0x00FC0000
276 #define IO48_MMR_CALTIMING2_CFG_WR_TO_WR_SHIFT 18
277 #define IO48_MMR_CALTIMING2_CFG_RD_TO_AP_VALID_MASK 0x0003F000
278 #define IO48_MMR_CALTIMING2_CFG_RD_TO_AP_VALID_SHIFT 12
279 #define IO48_MMR_CALTIMING2_CFG_RD_TO_PCH_MASK 0x00000FC0
280 #define IO48_MMR_CALTIMING2_CFG_RD_TO_PCH_SHIFT 6
281 #define IO48_MMR_CALTIMING2_CFG_RD_TO_WR_DIFF_BG_MASK 0x0000003F
282 #define IO48_MMR_CALTIMING2_CFG_RD_TO_WR_DIFF_BG_SHIFT 0
284 #define IO48_MMR_CALTIMING3_CFG_WR_TO_PCH_MASK 0x3F000000
285 #define IO48_MMR_CALTIMING3_CFG_WR_TO_PCH_SHIFT 24
286 #define IO48_MMR_CALTIMING3_CFG_WR_TO_RD_DIFF_BG_MASK 0x00FC0000
287 #define IO48_MMR_CALTIMING3_CFG_WR_TO_RD_DIFF_BG_SHIFT 18
288 #define IO48_MMR_CALTIMING3_CFG_WR_TO_RD_DIFF_CHIP_MASK 0x0003F000
289 #define IO48_MMR_CALTIMING3_CFG_WR_TO_RD_DIFF_CHIP_SHIFT 12
290 #define IO48_MMR_CALTIMING3_CFG_WR_TO_RD_MASK 0x00000FC0
291 #define IO48_MMR_CALTIMING3_CFG_WR_TO_RD_SHIFT 6
292 #define IO48_MMR_CALTIMING3_CFG_WR_TO_WR_DIFF_BG_MASK 0x0000003F
293 #define IO48_MMR_CALTIMING3_CFG_WR_TO_WR_DIFF_BG_SHIFT 0
295 #define IO48_MMR_CALTIMING4_CFG_PDN_TO_VALID_MASK 0xFC000000
296 #define IO48_MMR_CALTIMING4_CFG_PDN_TO_VALID_SHIFT 26
297 #define IO48_MMR_CALTIMING4_CFG_ARF_TO_VALID_MASK 0x03FC0000
298 #define IO48_MMR_CALTIMING4_CFG_ARF_TO_VALID_SHIFT 18
299 #define IO48_MMR_CALTIMING4_CFG_PCH_ALL_TO_VALID_MASK 0x0003F000
300 #define IO48_MMR_CALTIMING4_CFG_PCH_ALL_TO_VALID_SHIFT 12
301 #define IO48_MMR_CALTIMING4_CFG_PCH_TO_VALID_MASK 0x00000FC0
302 #define IO48_MMR_CALTIMING4_CFG_PCH_TO_VALID_SHIFT 6
303 #define IO48_MMR_CALTIMING4_CFG_WR_AP_TO_VALID_MASK 0x0000003F
304 #define IO48_MMR_CALTIMING4_CFG_WR_AP_TO_VALID_SHIFT 0
306 #define IO48_MMR_CALTIMING9_CFG_WR_4_ACT_TO_ACT_MASK 0x000000FF
307 #define IO48_MMR_CALTIMING9_CFG_WR_4_ACT_TO_ACT_SHIFT 0
309 #define IO48_MMR_DRAMADDRW_CFG_CS_ADDR_WIDTH_MASK 0x00070000
310 #define IO48_MMR_DRAMADDRW_CFG_CS_ADDR_WIDTH_SHIFT 16
311 #define IO48_MMR_DRAMADDRW_CFG_BANK_GROUP_ADDR_WIDTH_MASK 0x0000C000
312 #define IO48_MMR_DRAMADDRW_CFG_BANK_GROUP_ADDR_WIDTH_SHIFT 14
313 #define IO48_MMR_DRAMADDRW_CFG_BANK_ADDR_WIDTH_MASK 0x00003C00
314 #define IO48_MMR_DRAMADDRW_CFG_BANK_ADDR_WIDTH_SHIFT 10
315 #define IO48_MMR_DRAMADDRW_CFG_ROW_ADDR_WIDTH_MASK 0x000003E0
316 #define IO48_MMR_DRAMADDRW_CFG_ROW_ADDR_WIDTH_SHIFT 5
317 #define IO48_MMR_DRAMADDRW_CFG_COL_ADDR_WIDTH_MASK 0x0000001F
318 #define IO48_MMR_DRAMADDRW_CFG_COL_ADDR_WIDTH_SHIFT 0
320 #define ALT_ECC_HMC_OCP_DDRIOCTRL_IO_SIZE_MSK 0x00000003
322 #define ALT_ECC_HMC_OCP_INTSTAT_SERRPENA_SET_MSK BIT(0)
323 #define ALT_ECC_HMC_OCP_INTSTAT_DERRPENA_SET_MSK BIT(1)
324 #define ALT_ECC_HMC_OCP_ERRINTEN_SERRINTEN_SET_MSK BIT(0)
325 #define ALT_ECC_HMC_OCP_ERRINTEN_DERRINTEN_SET_MSK BIT(1)
326 #define ALT_ECC_HMC_OCP_INTMOD_INTONCMP_SET_MSK BIT(16)
327 #define ALT_ECC_HMC_OCP_ECCCTL_AWB_CNT_RST_SET_MSK BIT(16)
328 #define ALT_ECC_HMC_OCP_ECCCTL_CNT_RST_SET_MSK BIT(8)
329 #define ALT_ECC_HMC_OCP_ECCCTL_ECC_EN_SET_MSK BIT(0)
330 #define ALT_ECC_HMC_OCP_ECCCTL2_RMW_EN_SET_MSK BIT(8)
331 #define ALT_ECC_HMC_OCP_ECCCTL2_AWB_EN_SET_MSK BIT(0)
333 #define ALT_ECC_HMC_OCP_SERRCNTREG_VALUE 8
335 #define ALT_NOC_MPU_DDR_T_SCHED_DDRTIMING_ACTTOACT_LSB 0
336 #define ALT_NOC_MPU_DDR_T_SCHED_DDRTIMING_RDTOMISS_LSB 6
337 #define ALT_NOC_MPU_DDR_T_SCHED_DDRTIMING_WRTOMISS_LSB 12
338 #define ALT_NOC_MPU_DDR_T_SCHED_DDRTIMING_BURSTLEN_LSB 18
339 #define ALT_NOC_MPU_DDR_T_SCHED_DDRTIMING_RDTOWR_LSB 21
340 #define ALT_NOC_MPU_DDR_T_SCHED_DDRTIMING_WRTORD_LSB 26
341 #define ALT_NOC_MPU_DDR_T_SCHED_DDRTIMING_BWRATIO_LSB 31
343 #define ALT_NOC_MPU_DDR_T_SCHED_DDRMOD_AUTOPRECHARGE_LSB 0
344 #define ALT_NOC_MPU_DDR_T_SCHED_DDRMOD_BWRATIOEXTENDED_LSB 1
346 #define ALT_NOC_MPU_DDR_T_SCHED_ACTIVATE_RRD_LSB 0
347 #define ALT_NOC_MPU_DDR_T_SCHED_ACTIVATE_FAW_LSB 4
348 #define ALT_NOC_MPU_DDR_T_SCHED_ACTIVATE_FAWBANK_LSB 10
350 #define ALT_NOC_MPU_DDR_T_SCHED_DEVTODEV_BUSRDTORD_LSB 0
351 #define ALT_NOC_MPU_DDR_T_SCHED_DEVTODEV_BUSRDTOWR_LSB 2
352 #define ALT_NOC_MPU_DDR_T_SCHED_DEVTODEV_BUSWRTORD_LSB 4
354 #define ALT_NOC_FW_DDR_END_ADDR_LSB 16
355 #define ALT_NOC_FW_DDR_ADDR_MASK 0xFFFF
356 #define ALT_NOC_FW_DDR_SCR_EN_HPSREG0EN_SET_MSK BIT(0)
357 #define ALT_NOC_FW_DDR_SCR_EN_HPSREG1EN_SET_MSK BIT(1)
358 #define ALT_NOC_FW_DDR_SCR_EN_HPSREG2EN_SET_MSK BIT(2)
359 #define ALT_NOC_FW_DDR_SCR_EN_HPSREG3EN_SET_MSK BIT(3)
360 #define ALT_NOC_FW_DDR_SCR_EN_HPSREG4EN_SET_MSK BIT(4)
361 #define ALT_NOC_FW_DDR_SCR_EN_HPSREG5EN_SET_MSK BIT(5)
362 #define ALT_NOC_FW_DDR_SCR_EN_HPSREG6EN_SET_MSK BIT(6)
363 #define ALT_NOC_FW_DDR_SCR_EN_HPSREG7EN_SET_MSK BIT(7)
364 #define ALT_NOC_FW_DDR_SCR_EN_MPUREG0EN_SET_MSK BIT(0)
365 #define ALT_NOC_FW_DDR_SCR_EN_MPUREG1EN_SET_MSK BIT(1)
366 #define ALT_NOC_FW_DDR_SCR_EN_MPUREG2EN_SET_MSK BIT(2)
367 #define ALT_NOC_FW_DDR_SCR_EN_MPUREG3EN_SET_MSK BIT(3)
368 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR0REG0EN_SET_MSK BIT(4)
369 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR0REG1EN_SET_MSK BIT(5)
370 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR0REG2EN_SET_MSK BIT(6)
371 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR0REG3EN_SET_MSK BIT(7)
372 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR1REG0EN_SET_MSK BIT(8)
373 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR1REG1EN_SET_MSK BIT(9)
374 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR1REG2EN_SET_MSK BIT(10)
375 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR1REG3EN_SET_MSK BIT(11)
376 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR2REG0EN_SET_MSK BIT(12)
377 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR2REG1EN_SET_MSK BIT(13)
378 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR2REG2EN_SET_MSK BIT(14)
379 #define ALT_NOC_FW_DDR_SCR_EN_F2SDR2REG3EN_SET_MSK BIT(15)
381 #define ALT_IO48_DRAMTIME_MEM_READ_LATENCY_MASK 0x0000003F
382 #endif /* _SOCFPGA_SDRAM_ARRIA10_H_ */