1 
   2 
   3 
   4 
   5 
   6 
   7 
   8 #define NAND_IDR0       (PKUNITY_NAND_BASE + 0x0000)
   9 
  10 
  11 
  12 #define NAND_IDR1       (PKUNITY_NAND_BASE + 0x0004)
  13 
  14 
  15 
  16 #define NAND_IDR2       (PKUNITY_NAND_BASE + 0x0008)
  17 
  18 
  19 
  20 #define NAND_IDR3       (PKUNITY_NAND_BASE + 0x000C)
  21 
  22 
  23 
  24 #define NAND_PAR0       (PKUNITY_NAND_BASE + 0x0010)
  25 
  26 
  27 
  28 #define NAND_PAR1       (PKUNITY_NAND_BASE + 0x0014)
  29 
  30 
  31 
  32 #define NAND_PAR2       (PKUNITY_NAND_BASE + 0x0018)
  33 
  34 
  35 
  36 #define NAND_ECCEN      (PKUNITY_NAND_BASE + 0x001C)
  37 
  38 
  39 
  40 #define NAND_BUF        (PKUNITY_NAND_BASE + 0x0020)
  41 
  42 
  43 
  44 #define NAND_ECCSR      (PKUNITY_NAND_BASE + 0x0024)
  45 
  46 
  47 
  48 #define NAND_CMD        (PKUNITY_NAND_BASE + 0x0028)
  49 
  50 
  51 
  52 #define NAND_DMACR      (PKUNITY_NAND_BASE + 0x002C)
  53 
  54 
  55 
  56 #define NAND_IR         (PKUNITY_NAND_BASE + 0x0030)
  57 
  58 
  59 
  60 #define NAND_IMR        (PKUNITY_NAND_BASE + 0x0034)
  61 
  62 
  63 
  64 #define NAND_CHIPEN     (PKUNITY_NAND_BASE + 0x0038)
  65 
  66 
  67 
  68 #define NAND_ADDR       (PKUNITY_NAND_BASE + 0x003C)
  69 
  70 
  71 
  72 
  73 #define NAND_CMD_CMD_MASK               FMASK(4, 4)
  74 #define NAND_CMD_CMD_READPAGE           FIELD(0x0, 4, 4)
  75 #define NAND_CMD_CMD_ERASEBLOCK         FIELD(0x6, 4, 4)
  76 #define NAND_CMD_CMD_READSTATUS         FIELD(0x7, 4, 4)
  77 #define NAND_CMD_CMD_WRITEPAGE          FIELD(0x8, 4, 4)
  78 #define NAND_CMD_CMD_READID             FIELD(0x9, 4, 4)
  79 #define NAND_CMD_CMD_RESET              FIELD(0xf, 4, 4)
  80