Changes

nand stuff
Line 6: Line 6:  
| armirq = 1
 
| armirq = 1
 
}}
 
}}
 
+
== Register List ==
 
{{reglist|NAND Interface}}
 
{{reglist|NAND Interface}}
 
{{rla|0x0d010000|32|NAND_CTRL|NAND Control and Status}}
 
{{rla|0x0d010000|32|NAND_CTRL|NAND Control and Status}}
{{rld|0x0d010004|32|NAND_CONFIG|??}}
+
{{rla|0x0d010004|32|NAND_CONFIG|??}}
{{rld|0x0d010008|32|NAND_ADDR1|High address bytes}}
+
{{rla|0x0d010008|32|NAND_ADDR1|Address bytes 1-2 (column)}}
{{rld|0x0d01000C|32|NAND_ADDR2|Low address bytes}}
+
{{rla|0x0d01000c|32|NAND_ADDR2|Address bytes 3-5 (row)}}
{{rld|0x0d010010|32|NAND_DATABUF|Address of the Data buffer}}
+
{{rla|0x0d010010|32|NAND_DATABUF|Memory address of the Data buffer}}
{{rld|0x0d010014|32|NAND_ECCBUF|Address of the Spare buffer}}
+
{{rla|0x0d010014|32|NAND_ECCBUF|Memory address of the Spare buffer}}
 
|}
 
|}
 
+
== Register Details ==
{{reg32 | NAND_CTRL | addr = 0x0d010000 | hifields = 5 | lofields = 2 |
+
{{reg32 | NAND_CTRL | addr = 0x0d010000 | hifields = 9 | lofields = 2 |
|1|1|1|5|8|
+
|1|1|1|1|1|1|1|1|8|
|R/W|W|U|W|W|
+
|R/W|W|U|W|W|W|W|W|W|
|EXEC|IRQ||ADDR_MASK|COMMAND||
+
|EXEC|IRQ||A5|A4|A3|A2|A1|COMMAND||
 
|4|12|
 
|4|12|
 
|W|W|
 
|W|W|
Line 27: Line 27:  
{{regdesc
 
{{regdesc
 
|EXEC|Write 1: initiate NAND command<br/>Read: NAND interface busy
 
|EXEC|Write 1: initiate NAND command<br/>Read: NAND interface busy
|IRQ|Set to enable IRQ generation
+
|IRQ|Set to enable IRQ generation when command is complete
|ADDR_MASK|Mask of the address bytes to send (10 {{=}} AA, 08 {{=}} BB, ..., 01 {{=}} FF)
+
|A5|Send fifth address byte (typ. row address high)
 +
|A4|Send fourth address byte (typ. row address mid)
 +
|A3|Send third address byte (typ. row address low)
 +
|A2|Send second address byte (typ. column address high)
 +
|A1|Send first address byte (typ. column address low)
 
|COMMAND|8-bit NAND command
 
|COMMAND|8-bit NAND command
 
|FLAGS|TBD
 
|FLAGS|TBD
 
|DMALEN|Number of bytes to copy
 
|DMALEN|Number of bytes to copy
 
}}
 
}}
 
+
----
{| border="1"
+
{{reg32 | NAND_CONF | addr = 0x0d010004 | hifields = 1 | lofields = 1 |
! base      !! function !! offset !! description !! contents/example
+
|16|
|-
+
|?|
|0x0D010000||NAND      ||  
+
|Unknown||
|-
+
|16|
|           ||         || 0000 W  || command || 9F000000 (CMD 00: start read sector)
+
|?|
|-
+
|Unknown|
||          ||          ||        ||        || 8030B840 (CMD 30: data (starts DMA 0x840 bytes))
+
}}
|-
+
This register probably configures certain aspects of the NAND interface (timings?){{check}}. The bit definitions are unknown. This register is written with the values 0x08000000 and 0x4b3e0e7f during initialization.
||           ||         ||       ||         || 80FF8000 (CMD FF: reset)
+
----
|-
+
{{reg32 | NAND_ADDR1 | addr = 0x0d010008 | hifields = 1 | lofields = 2 |
||           ||         ||         ||        || 00008000 means: wait for R/#B to go down
+
|16|
|-
+
|U|
||           ||          ||        ||        || 1F000000 is the mask of the address bytes to send. (10 = AA, 08 = BB, .., 01 = FF in 08,0c)
+
|||
|-
+
|8|8|
||           ||         || 0000 R  || status || MSB means busy
+
|R/W|R/W|
|-
+
|ADDR2|ADDR1|
||           ||         || 0004 W || config ||  
+
}}
|-
+
This register contains the first two address bytes that can be sent to the NAND chip. Normally it contains the column address (offset within a page).
||           ||         || 0008 W || address #0 || 0000AABB
+
{{regdesc
|-
+
|ADDR2|Second address byte
||           ||         || 000C W  || address #1 || CCDDEEFF, NAND sector, multiply with 0x800 or 0x840 to get offset, 0x40 for ecc
+
|ADDR1|First address byte
|-
+
}}
||           ||         || 0010 W || data addr  || target address for DMA (0x800 main bytes)
+
----
|-
+
{{reg32 | NAND_ADDR2 | addr = 0x0d01000c | hifields = 2 | lofields = 2 |
||           ||         || 0014 W || ecc addr  || target address for DMA (0x40 spare bytes + 0x10 byte HW-calculated ECC syndrome)
+
|8|8|
|-
+
|U|R/W|
||          ||          || 0018 W  || unknown  ||
+
||ADDR5||
|}
+
|8|8|
 +
|R/W|R/W|
 +
|ADDR4|ADDR3|
 +
}}
 +
This register contains the last three address bytes that can be sent to the NAND chip. Normally it contains the row address (page number).
 +
{{regdesc
 +
|ADDR5|Fifth address byte
 +
|ADDR4|Fourth address byte
 +
|ADDR3|Third address byte
 +
}}
 +
----
 +
{{regsimple | NAND_DATABUF | addr = 0x0d010010 | bits = 32 | access = R/W }}
 +
This register contains the DMA address of the page data buffer (0x800 bytes)
 +
----
 +
{{regsimple | NAND_ECCBUF | addr = 0x0d010014 | bits = 32 | access = R/W }}
 +
This register contains the DMA address of the spare and ECC data buffer (0x40 spare bytes + 0x10 bytes of hardware-calculated ECC syndrome).