File indexing completed on 2025-05-11 08:23:42
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032
0033
0034 #ifndef XNANDPSU_HW_H
0035 #define XNANDPSU_HW_H
0036
0037 #ifdef __cplusplus
0038 extern "C" {
0039 #endif
0040
0041
0042 #ifndef __rtems__
0043 #include "xil_io.h"
0044 #else
0045 #include <bsp/xil-compat.h>
0046 #endif
0047
0048
0049
0050
0051
0052 #define XNANDPSU_PKT_OFFSET 0x00U
0053 #define XNANDPSU_MEM_ADDR1_OFFSET 0x04U
0054
0055 #define XNANDPSU_MEM_ADDR2_OFFSET 0x08U
0056
0057 #define XNANDPSU_CMD_OFFSET 0x0CU
0058 #define XNANDPSU_PROG_OFFSET 0x10U
0059 #define XNANDPSU_INTR_STS_EN_OFFSET 0x14U
0060
0061 #define XNANDPSU_INTR_SIG_EN_OFFSET 0x18U
0062
0063 #define XNANDPSU_INTR_STS_OFFSET 0x1CU
0064
0065 #define XNANDPSU_READY_BUSY_OFFSET 0x20U
0066
0067 #define XNANDPSU_FLASH_STS_OFFSET 0x28U
0068 #define XNANDPSU_TIMING_OFFSET 0x2CU
0069 #define XNANDPSU_BUF_DATA_PORT_OFFSET 0x30U
0070
0071 #define XNANDPSU_ECC_OFFSET 0x34U
0072 #define XNANDPSU_ECC_ERR_CNT_OFFSET 0x38U
0073
0074 #define XNANDPSU_ECC_SPR_CMD_OFFSET 0x3CU
0075
0076 #define XNANDPSU_ECC_CNT_1BIT_OFFSET 0x40U
0077
0078 #define XNANDPSU_ECC_CNT_2BIT_OFFSET 0x44U
0079
0080 #define XNANDPSU_ECC_CNT_3BIT_OFFSET 0x48U
0081
0082 #define XNANDPSU_ECC_CNT_4BIT_OFFSET 0x4CU
0083
0084 #define XNANDPSU_CPU_REL_OFFSET 0x58U
0085 #define XNANDPSU_ECC_CNT_5BIT_OFFSET 0x5CU
0086
0087 #define XNANDPSU_ECC_CNT_6BIT_OFFSET 0x60U
0088
0089 #define XNANDPSU_ECC_CNT_7BIT_OFFSET 0x64U
0090
0091 #define XNANDPSU_ECC_CNT_8BIT_OFFSET 0x68U
0092
0093 #define XNANDPSU_DATA_INTF_OFFSET 0x6CU
0094 #define XNANDPSU_DMA_SYS_ADDR0_OFFSET 0x50U
0095
0096 #define XNANDPSU_DMA_SYS_ADDR1_OFFSET 0x24U
0097
0098 #define XNANDPSU_DMA_BUF_BND_OFFSET 0x54U
0099
0100 #define XNANDPSU_SLV_DMA_CONF_OFFSET 0x80U
0101
0102
0103
0104
0105
0106 #define XNANDPSU_PKT_PKT_SIZE_MASK 0x000007FFU
0107 #define XNANDPSU_PKT_PKT_CNT_MASK 0x00FFF000U
0108 #define XNANDPSU_PKT_PKT_CNT_SHIFT 12U
0109
0110
0111
0112
0113
0114 #define XNANDPSU_MEM_ADDR1_COL_ADDR_MASK 0x0000FFFFU
0115
0116 #define XNANDPSU_MEM_ADDR1_PG_ADDR_MASK 0xFFFF0000U
0117
0118 #define XNANDPSU_MEM_ADDR1_PG_ADDR_SHIFT 16U
0119
0120
0121
0122
0123
0124 #define XNANDPSU_MEM_ADDR2_MEM_ADDR_MASK 0x000000FFU
0125
0126 #define XNANDPSU_MEM_ADDR2_BUS_WIDTH_MASK 0x01000000U
0127 #define XNANDPSU_MEM_ADDR2_NFC_BCH_MODE_MASK 0x0E000000U
0128
0129 #define XNANDPSU_MEM_ADDR2_MODE_MASK 0x30000000U
0130
0131 #define XNANDPSU_MEM_ADDR2_CHIP_SEL_MASK 0xC0000000U
0132 #define XNANDPSU_MEM_ADDR2_CHIP_SEL_SHIFT 30U
0133
0134 #define XNANDPSU_MEM_ADDR2_BUS_WIDTH_SHIFT 24U
0135 #define XNANDPSU_MEM_ADDR2_NFC_BCH_MODE_SHIFT 25U
0136
0137
0138
0139
0140
0141 #define XNANDPSU_CMD_CMD1_MASK 0x000000FFU
0142
0143 #define XNANDPSU_CMD_CMD2_MASK 0x0000FF00U
0144
0145 #define XNANDPSU_CMD_PG_SIZE_MASK 0x03800000U
0146 #define XNANDPSU_CMD_DMA_EN_MASK 0x0C000000U
0147
0148 #define XNANDPSU_CMD_ADDR_CYCLES_MASK 0x70000000U
0149
0150 #define XNANDPSU_CMD_ECC_ON_MASK 0x80000000U
0151 #define XNANDPSU_CMD_CMD2_SHIFT 8U
0152
0153 #define XNANDPSU_CMD_PG_SIZE_SHIFT 23U
0154 #define XNANDPSU_CMD_DMA_EN_SHIFT 26U
0155 #define XNANDPSU_CMD_ADDR_CYCLES_SHIFT 28U
0156
0157 #define XNANDPSU_CMD_ECC_ON_SHIFT 31U
0158
0159
0160
0161
0162
0163 #define XNANDPSU_PROG_RD_MASK 0x00000001U
0164 #define XNANDPSU_PROG_MUL_DIE_MASK 0x00000002U
0165 #define XNANDPSU_PROG_BLK_ERASE_MASK 0x00000004U
0166 #define XNANDPSU_PROG_RD_STS_MASK 0x00000008U
0167 #define XNANDPSU_PROG_PG_PROG_MASK 0x00000010U
0168 #define XNANDPSU_PROG_MUL_DIE_RD_MASK 0x00000020U
0169 #define XNANDPSU_PROG_RD_ID_MASK 0x00000040U
0170 #define XNANDPSU_PROG_RD_PRM_PG_MASK 0x00000080U
0171
0172 #define XNANDPSU_PROG_RST_MASK 0x00000100U
0173 #define XNANDPSU_PROG_GET_FEATURES_MASK 0x00000200U
0174 #define XNANDPSU_PROG_SET_FEATURES_MASK 0x00000400U
0175 #define XNANDPSU_PROG_RD_UNQ_ID_MASK 0x00000800U
0176
0177 #define XNANDPSU_PROG_RD_STS_ENH_MASK 0x00001000U
0178
0179 #define XNANDPSU_PROG_RD_INTRLVD_MASK 0x00002000U
0180
0181 #define XNANDPSU_PROG_CHNG_RD_COL_ENH_MASK 0x00004000U
0182
0183
0184 #define XNANDPSU_PROG_COPY_BACK_INTRLVD_MASK 0x00008000U
0185
0186 #define XNANDPSU_PROG_RD_CACHE_START_MASK 0x00010000U
0187
0188 #define XNANDPSU_PROG_RD_CACHE_SEQ_MASK 0x00020000U
0189
0190 #define XNANDPSU_PROG_RD_CACHE_RAND_MASK 0x00040000U
0191
0192 #define XNANDPSU_PROG_RD_CACHE_END_MASK 0x00080000U
0193
0194 #define XNANDPSU_PROG_SMALL_DATA_MOVE_MASK 0x00100000U
0195
0196 #define XNANDPSU_PROG_CHNG_ROW_ADDR_MASK 0x00200000U
0197
0198 #define XNANDPSU_PROG_CHNG_ROW_ADDR_END_MASK 0x00400000U
0199
0200 #define XNANDPSU_PROG_RST_LUN_MASK 0x00800000U
0201 #define XNANDPSU_PROG_PGM_PG_CLR_MASK 0x01000000U
0202
0203
0204 #define XNANDPSU_PROG_VOL_SEL_MASK 0x02000000U
0205 #define XNANDPSU_PROG_ODT_CONF_MASK 0x04000000U
0206
0207
0208
0209
0210
0211 #define XNANDPSU_INTR_STS_EN_BUFF_WR_RDY_STS_EN_MASK 0x00000001U
0212
0213
0214
0215 #define XNANDPSU_INTR_STS_EN_BUFF_RD_RDY_STS_EN_MASK 0x00000002U
0216
0217
0218
0219 #define XNANDPSU_INTR_STS_EN_TRANS_COMP_STS_EN_MASK 0x00000004U
0220
0221
0222
0223 #define XNANDPSU_INTR_STS_EN_MUL_BIT_ERR_STS_EN_MASK 0x00000008U
0224
0225
0226
0227 #define XNANDPSU_INTR_STS_EN_ERR_INTR_STS_EN_MASK 0x00000010U
0228
0229
0230
0231
0232
0233
0234
0235 #define XNANDPSU_INTR_STS_EN_DMA_INT_STS_EN_MASK 0x00000040U
0236
0237
0238 #define XNANDPSU_INTR_STS_EN_ERR_AHB_STS_EN_MASK 0x00000080U
0239
0240
0241
0242
0243
0244
0245
0246 #define XNANDPSU_INTR_SIG_EN_BUFF_WR_RDY_STS_EN_MASK 0x00000001U
0247
0248
0249
0250 #define XNANDPSU_INTR_SIG_EN_BUFF_RD_RDY_STS_EN_MASK 0x00000002U
0251
0252
0253
0254 #define XNANDPSU_INTR_SIG_EN_TRANS_COMP_STS_EN_MASK 0x00000004U
0255
0256
0257
0258 #define XNANDPSU_INTR_SIG_EN_MUL_BIT_ERR_STS_EN_MASK 0x00000008U
0259
0260
0261
0262 #define XNANDPSU_INTR_SIG_EN_ERR_INTR_STS_EN_MASK 0x00000010U
0263
0264
0265
0266
0267
0268
0269
0270 #define XNANDPSU_INTR_SIG_EN_DMA_INT_STS_EN_MASK 0x00000040U
0271
0272
0273 #define XNANDPSU_INTR_SIG_EN_ERR_AHB_STS_EN_MASK 0x00000080U
0274
0275
0276
0277
0278
0279
0280
0281 #define XNANDPSU_INTR_STS_BUFF_WR_RDY_STS_EN_MASK 0x00000001U
0282
0283
0284 #define XNANDPSU_INTR_STS_BUFF_RD_RDY_STS_EN_MASK 0x00000002U
0285
0286
0287 #define XNANDPSU_INTR_STS_TRANS_COMP_STS_EN_MASK 0x00000004U
0288
0289 #define XNANDPSU_INTR_STS_MUL_BIT_ERR_STS_EN_MASK 0x00000008U
0290
0291 #define XNANDPSU_INTR_STS_ERR_INTR_STS_EN_MASK 0x00000010U
0292
0293
0294
0295 #define XNANDPSU_INTR_STS_DMA_INT_STS_EN_MASK 0x00000040U
0296
0297
0298 #define XNANDPSU_INTR_STS_ERR_AHB_STS_EN_MASK 0x00000080U
0299
0300
0301
0302
0303
0304
0305 #define XNANDPSU_INTR_BUFF_WR_RDY_STS_EN_MASK 0x00000001U
0306
0307
0308 #define XNANDPSU_INTR_BUFF_RD_RDY_STS_EN_MASK 0x00000002U
0309
0310
0311 #define XNANDPSU_INTR_TRANS_COMP_STS_EN_MASK 0x00000004U
0312
0313
0314 #define XNANDPSU_INTR_MUL_BIT_ERR_STS_EN_MASK 0x00000008U
0315
0316 #define XNANDPSU_INTR_ERR_INTR_STS_EN_MASK 0x00000010U
0317
0318
0319
0320 #define XNANDPSU_INTR_DMA_INT_STS_EN_MASK 0x00000040U
0321
0322 #define XNANDPSU_INTR_ERR_AHB_STS_EN_MASK 0x00000080U
0323
0324
0325
0326
0327
0328
0329 #define XNANDPSU_ID2_DEVICE_ID2_MASK 0x000000FFU
0330
0331
0332
0333
0334
0335 #define XNANDPSU_FLASH_STS_FLASH_STS_MASK 0x0000FFFFU
0336
0337
0338
0339
0340
0341
0342 #define XNANDPSU_TIMING_TCCS_TIME_MASK 0x00000003U
0343
0344 #define XNANDPSU_TIMING_SLOW_FAST_TCAD_MASK 0x00000004U
0345
0346 #define XNANDPSU_TIMING_DQS_BUFF_SEL_MASK 0x00000078U
0347
0348
0349 #define XNANDPSU_TIMING_TADL_TIME_MASK 0x00007F80U
0350
0351
0352
0353
0354
0355
0356
0357 #define XNANDPSU_ECC_ADDR_MASK 0x0000FFFFU
0358 #define XNANDPSU_ECC_SIZE_MASK 0x01FF0000U
0359 #define XNANDPSU_ECC_HAMMING_BCH_MASK 0x02000000U
0360
0361
0362
0363
0364
0365
0366 #define XNANDPSU_ECC_ERR_CNT_PKT_BND_ERR_CNT_MASK 0x000000FFU
0367
0368
0369 #define XNANDPSU_ECC_ERR_CNT_PG_BND_ERR_CNT_MASK 0x0000FF00U
0370
0371
0372
0373
0374
0375
0376
0377 #define XNANDPSU_ECC_SPR_CMD_SPR_CMD_MASK 0x000000FFU
0378
0379
0380 #define XNANDPSU_ECC_SPR_CMD_ECC_ADDR_CYCLES_MASK 0x70000000U
0381
0382
0383
0384
0385
0386
0387
0388
0389
0390 #define XNANDPSU_DATA_INTF_SDR_MASK 0x00000007U
0391 #define XNANDPSU_DATA_INTF_NVDDR_MASK 0x00000038U
0392 #define XNANDPSU_DATA_INTF_NVDDR2_MASK 0x000001C0U
0393 #define XNANDPSU_DATA_INTF_DATA_INTF_MASK 0x00000600U
0394
0395 #define XNANDPSU_DATA_INTF_NVDDR_SHIFT 3U
0396 #define XNANDPSU_DATA_INTF_DATA_INTF_SHIFT 9U
0397
0398
0399
0400
0401
0402 #define XNANDPSU_DMA_BUF_BND_BND_MASK 0x00000007U
0403
0404 #define XNANDPSU_DMA_BUF_BND_4K 0x0U
0405 #define XNANDPSU_DMA_BUF_BND_8K 0x1U
0406 #define XNANDPSU_DMA_BUF_BND_16K 0x2U
0407 #define XNANDPSU_DMA_BUF_BND_32K 0x3U
0408 #define XNANDPSU_DMA_BUF_BND_64K 0x4U
0409 #define XNANDPSU_DMA_BUF_BND_128K 0x5U
0410 #define XNANDPSU_DMA_BUF_BND_256K 0x6U
0411 #define XNANDPSU_DMA_BUF_BND_512K 0x7U
0412
0413
0414
0415
0416
0417 #define XNANDPSU_SLV_DMA_CONF_SDMA_TX_RX_MASK 0x00000001U
0418
0419
0420
0421
0422 #define XNANDPSU_SLV_DMA_CONF_DMA_TRANS_CNT_MASK 0x001FFFFEU
0423
0424
0425
0426 #define XNANDPSU_SLV_DMA_CONF_DMA_BURST_SIZE_MASK 0x00E00000U
0427
0428
0429
0430 #define XNANDPSU_SLV_DMA_CONF_DMA_TMOUT_CNT_VAL_MASK 0x0F000000U
0431
0432
0433
0434 #define XNANDPSU_SLV_DMA_CONF_SDMA_EN_MASK 0x10000000U
0435
0436
0437
0438
0439
0440
0441
0442
0443
0444
0445
0446
0447
0448
0449
0450
0451
0452
0453
0454
0455
0456
0457 #define XNandPsu_ReadReg(BaseAddress, RegOffset) \
0458 Xil_In32((BaseAddress) + (RegOffset))
0459
0460
0461
0462
0463
0464
0465
0466
0467
0468
0469
0470
0471
0472
0473
0474
0475 #define XNandPsu_WriteReg(BaseAddress, RegOffset, Data) \
0476 Xil_Out32(((BaseAddress) + (RegOffset)), (Data))
0477
0478
0479
0480
0481
0482 #ifdef __cplusplus
0483 }
0484 #endif
0485
0486 #endif
0487