# 第六章 Nand Flash 控制器

# 6.1 概述

目前,Nor Flash 价格较高,而 SDRAM 和 Nand Flash 存储器相对经济,这样促使一些用户在 NAND Flash 上执行启动代码,在 SDRAM 上执行主程序。

s3c2440A 的驱动代码可以在外部的 NAND Flash 存储器上被执行。为了支持 NAND Flash 的 boot loader,s3c2440A 配备了一个内部的 SRAM 缓冲器名为"Steppingstone"。启动时,NAND Flash 上的前 4KByte 字节将被装载到 Steppingstone 上别且装载到 Steppingstone 上的启动代码会被执行。

一般情况下,启动代码会拷贝 NAND Flash 上的内容到 SDRAM。使用硬件的 ECC,NAND Flash 的数据被检查。在完成拷贝的基础上,主程序将在 SDRAM 上被执行。

# 6.2 特性

- (1) **自动启动**: 启动代码在重启时被传输到 4kbytes 的 Steppingstone 上。传输后代码会在 Steppingstone 上被执行
- (2) **NAND Flash 存储器接口**: 支持 256 字、512 字节、1000 字和 2000Byte 页
- (3) **软件模式**:用户可以直接访问 NAND Flash,例如这个特性可以被用于对 NADN Flash 存储器的读/擦除/编程。
- (4) 接口: 8/16 微的 NADN Flash 存储器接口总线
- (5) **硬件 ECC 生成**, 检测和指示(软件纠错)
- (6) **SFR 接口**:支持小端模式,对于数据和 ECC 数据寄存器的字节/半字/字访问,对于其他 寄存器的字访问。
- (7) Steppingstone 接口: 支持大小端,字节/半字/字访问
- (8) Steppingstone 4kB 内部 SRAM 缓冲器可以在 NAND Flash 启动后被用于其他目的。

# MSN: zhuqi428@sina.com

# 5六章 Nand Flash 控制器 Forum: <a href="http://embeddedlinux.thefreehoster.com/">http://embeddedlinux.thefreehoster.com/</a>

# 6.2.1 模块图



Figure 6-1. NAND Flash Controller Block Diagram

#### 6.2.2 Boot loader 功能



Figure 6-2. NAND Flash Controller Boot Loader Block Diagram

在重启期间,NAND Flash控制器通过引脚状态得到连接NAND Flash的信息(NCON(Adv flash), GPG13(页大小), GPG14(地址周期), GPG15(总线宽度) - 参考引脚配置)。在上电或重启以后,NAND Flash控制器自动的装载 4KB的boot loader代码。在装载boot loader代码后,其在steppingstone中被执行。

注:在自动重启期间,ECC没有检查,因为NAND Flash的前 4KB数据一般认为没有位错误。

## 6.2.3 引脚配置

OM[1:0]=00: 使能NAND Flash存储器启动

NCON: NAND Flash存储器选择

0: 普通NAND Flash (256 字/512 字节页大小, 3/4 地址周期)

1: 先进NAND Flash (1K字/2K字节页大小, 4/5 地址周期)

GPG13: NAND Flash存储器页容量选择

0: 页=256 字 (NCON=0) 或页=1K字 (NCON=1)

1: 页=512 字节 (NCON=0) 或页=2K字节(NCON=1)

GPG14: NAND Flash存储器地址周期选择

0: 3 个地址周期(NCON=0) 或 4 个地址周期(NCON=1)

1: 4 个地址周期(NCON=0)或 5 个地址周期(NCON=1)

GPG15 NAND Flash存储器总线宽度选择

0:8位总线宽度

1: 16 位总线宽度

注: NCON,GPG[15:13]引脚配置在重启期间被?

在通常状态下,这些引脚必须被设置为输入以至于当通过软件方式进入睡眠模式或异常

状态时, 引脚状态不会被改变。

## NAND Flash 存储器配置表

| NCON0           | GPG13       | GPG14     | GPG15               |
|-----------------|-------------|-----------|---------------------|
| 0: Normal NAND  | 0: 256Words | 0: 3-Addr | 0:8-bit bus width   |
|                 | 1: 512Bytes | 1: 4-Addr |                     |
| 1: Advance NAND | 0: 1Kwords  | 0: 4-Addr | 1: 16-bit bus width |
|                 | 1: 2Kbytes  | 1: 5-Addr |                     |

注:

例: NAND Flash配置设置

| 部件              | 页大小/总大小         | NCON0 | GPG13 | GPG14 | GPG15 |
|-----------------|-----------------|-------|-------|-------|-------|
| K9S1208V0M-xxxx | 512Byte/512Mbit | 0     | 1     | 1     | 0     |
| K9K2G16U0M-xxxx | 1KW / 2Gbit     | 1     | 0     | 1     | 1     |

## 6.2.4 NAND Flash 存储器时序



Figure 6-3. CLE & ALE Timing (TACLS=1, TWRPH0=0, TWRPH1=0)



Figure 6-4. nWE & nRE Timing (TWRPH0=0, TWRPH1=0)

## 6.2.5 软件模式

s3c2440A仅支持软件模式访问。使用此模式,你可以完整的访问NAND Flash。NAND Flash控制器支持NAND Flash存储器的直接访问接口。

- (1) 写命令寄存器=NAND Flash存储器命令周期
- (2) 写地址寄存器=NAND Flash存储器地址周期
- (3) 写数据寄存器=写数据到NAND Flash (写周期)
- (4) 读数据寄存器=从NAND Flash读数据(读周期)
- (5) 读主ECC寄存器和空闲ECC寄存器=从NAND Flash存储器读数据
- 注: 在软件模式中, 你必须用查询或中断来检测RnB状态输入引脚。

## 6.2.6 数据寄存器配置

(1) 16 位NAND Flash存储器接口

A.字访问

| 寄存器    | 大小端 | 位[31:24]                  | 位[23:16]                 | 位[15:8]                   | 位[7:0]                   |
|--------|-----|---------------------------|--------------------------|---------------------------|--------------------------|
| NFDATA | 小端  | 2 <sup>nd</sup> I/O[15:8] | 2 <sup>nd</sup> I/O[7:0] | 1stI/O[15:8]              | 1 <sup>st</sup> I/O[7:0] |
| NFDATA | 大端  | 1st I/O[15:8]             | 1stI/O[7:0]              | 2 <sup>nd</sup> I/O[15:8] | 2 <sup>nd</sup> I/O[7:0] |

#### B.半字访问

| 寄存器    | 大小端  | 位[31:24] | 位[23:16] | 位[15:8]       | 位[7:0]               |
|--------|------|----------|----------|---------------|----------------------|
| NFDATA | 大/小端 | 无效值      | 无效值      | 1st I/0[15:8] | $1^{\rm st}I/0[7:0]$ |

#### (2) 8位 NAND Flash 存储器接口

A.字访问

| 寄存器    | 大小端 | 位[31:24]                 | 位[23:16]                 | 位[15:8]                  | 位[7:0]                   |
|--------|-----|--------------------------|--------------------------|--------------------------|--------------------------|
| NFDATA | 小端  | 4 <sup>th</sup> I/O[7:0] | 3 <sup>rd</sup> I/O[7:0] | 2 <sup>nd</sup> I/O[7:0] | 1st I/O[7:0]             |
| NFDATA | 大端  | 1st I/O[7:0]             | 2 <sup>nd</sup> I/O[7:0] | 3 <sup>rd</sup> I/O[7:0] | 4 <sup>th</sup> I/O[7:0] |

#### B.半字访问

| 寄存器    | 大小端 | 位[31:24] | 位[23:16] | 位[15:8]                  | 位[7:0]                   |
|--------|-----|----------|----------|--------------------------|--------------------------|
| NFDATA | 小端  | 无效值      | 无效值      | 2 <sup>nd</sup> I/O[7:0] | 1 <sup>st</sup> I/O[7:0] |
| NFDATA | 大端  | 无效值      | 无效值      | 1 <sup>st</sup> I/O[7:0] | 2 <sup>nd</sup> I/O[7:0] |

#### C.字节访问

| 寄存器    | 大小端  | 位[31:24] | 位[23:16] | 位[15:8] | 位[7:0]       |
|--------|------|----------|----------|---------|--------------|
| NFDATA | 大/小端 | 无效值      | 无效值      | 无效值     | 1st I/O[7:0] |

## 6.2.7 Steppingstone (4k 字节 SRAM)

NAND Flash 控制器使用 NAND Flash 作为启动缓冲器且你可以将这个区域用作其他用途。

## 6.2.8 ECC (错误纠错码)

NAND Flash 控制器包括 4 个 ECC(错误接错码)模块。两个模块(一个用于 data[7:0],一个用于 data[15:8])可以被用于(上限)2048bytes 的 ECC 奇偶码的生成,另外两个模块(一个用于 data[7:0],一个用于 data[15:8])可以被用于(上限)16bytes 的 ECC 奇偶校验码的生

成。

- -28 位 ECC 奇偶码=22 位行奇偶+6 位列奇偶
- -14 位 ECC 奇偶码=8 位行奇偶+6 位列奇偶

## 2048 字节 ECC 奇偶码分配表

|         | DATA7 | DATA6  | DATA5 | DATA4  | DATA3 | DATA2 | DATA1 | DATA0  |
|---------|-------|--------|-------|--------|-------|-------|-------|--------|
| MECCn_0 | P64   | P64'   | P32   | P32'   | P16   | P16'  | P8    | P8'    |
| MECCn_1 | P1024 | P1024' | P512  | P512'  | P256  | P256' | P128  | P128'  |
| MECCn_2 | P4    | P4'    | P2    | P2'    | P1    | P1'   | P2048 | P2048' |
| MECCn_3 | P8192 | P8192' | P4096 | P4096' | _     | _     | _     | _      |

#### 16 字节ECC奇偶码分配表

|         | DATA7 | DATA6 | DATA5 | DATA4 | DATA3 | DATA2 | DATA1 | DATA0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| SECCn_0 | P16   | P16'  | P8    | P8'   | P4    | P4'   | P2    | P2'   |
| SECCn_1 | P1    | P1'   | P64   | P64'  | P32   | P32'  | -     | -     |

## 6.2.8.1 ECC 模块特点

ECC 生成由控制寄存器的 ECC 锁位(主 ECC 锁、空闲 ECC 锁)来控制。

#### 6.2.8.2 ECC 寄存器配置 (大小端)

## (1) 16 位 NAND Flash 存储器接口

| 寄存器      | 位[31:24]                | 位[23:16]                | 位[15:8]                 | 位[7:0]                  |
|----------|-------------------------|-------------------------|-------------------------|-------------------------|
| NFMECCD0 | 2 <sup>nd</sup> ECC for | 2 <sup>nd</sup> ECC for | 1st ECC for             | 1 <sup>st</sup> ECC for |
|          | I/O[15:8]               | I/O[7:0]                | I/O[15:8]               | I/O[7:0]                |
| NFMECCD1 | 4 <sup>th</sup> ECC for | 4 <sup>th</sup> ECC for | 3 <sup>rd</sup> ECC for | 3 <sup>rd</sup> ECC for |
|          | I/O[15:8]               | I/O[7:0]                | I/O[15:8]               | I/O[7:0]                |

| 寄存器     | 位[31:24]                | 位[23:16]                | 位[15:8]     | 位[7:0]      |
|---------|-------------------------|-------------------------|-------------|-------------|
| NFSECCD | 2 <sup>nd</sup> ECC for | 2 <sup>nd</sup> ECC for | 1st ECC for | 1st ECC for |
|         | I/O[15:8]               | I/O[7:0]                | I/O[15:8]   | I/O[7:0]    |

#### (2) 8位 NAND Flash 存储器接口

| 寄存器      | 位[31:24] | 位[23:16]                         | 位[15:8] | 位[7:0]                           |
|----------|----------|----------------------------------|---------|----------------------------------|
| NFMECCD0 | -        | 2 <sup>nd</sup> ECC for I/O[7:0] | -       | 1st ECC for I/O[7:0]             |
| NFMECCD1 | -        | 4 <sup>th</sup> ECC for I/O[7:0] | -       | 3 <sup>rd</sup> ECC for I/O[7:0] |

| 寄存器     | 位[31:24] | 位[23:16]                         | 位[15:8] | 位[7:0]               |
|---------|----------|----------------------------------|---------|----------------------|
| NFSECCD | -        | 2 <sup>nd</sup> ECC for I/O[7:0] | -       | 1st ECC for I/O[7:0] |

#### 6.2.8.3 ECC 编程指引

- (1) 在软件模式下,ECC 模块为所有的读写数据生成 ECC 奇偶码。因此你通过写 InitECC 位(NFCONT[4])置 1 来重置 ECC 的值,且在读写数据之前清 0 theMainECCLock 位(NFCONT[15])。
- (2) 不管读还是写数据, ECC 模块在寄存器 NFMECC0/1 上生成 ECC 奇偶码。
- (3) 在你完整的读写一页后(不包括空闲区域数据), theMainECCLock 位置 1(锁定)。ECC

奇偶码被锁定且 ECC 状态寄存器的值不会被改变。

(4) 生成空闲区域 ECC 奇偶码, 清 0 (非锁定) SpareECCLock 位 (NFCONT[6])

- (5) 不管读还是写数据,空闲区域 ECC 模块在寄存器 NFSECC 上生成 ECC 奇偶码
- (6) 在你完整的读写空闲区域后, SpareECCLock 位置 1(锁定)。ECC 奇偶码被锁定且 ECC

状态寄存器的值不会被改变

- (7) 一旦完成你可以使用这些值去记录到空闲区域或检查位错误。
- 注: NFSECCD 是为空闲区域的 ECC 服务(通常,用户写主数据区域的 ECC 值到空闲区域,这些值和 NFMECC0/1 中的值一样)且从主数据区域中生成。

## 6.2.9 NAND Flash 存储器分布



Figure 6-5. NAND Flash Memory Mapping

注: SROM 意为 ROM 和 SRAM 类型存储器。

## 6.2.10 NAND Flash 存储器配置



Figure 6-6. A 8-bit NAND Flash Memory Interface

当你写地址时,data[15:8]和 data[7:0]写同样的地址。

Forum: http://embeddedlinux.thefreehoster.com/



Figure 6-7. Two 8-bit NAND Flash Memory Interface



Figure 6-8. A 16-bit NAND Flash Memory Interface

# 6.3 NADN Flash 寄存器

- (1) NADN Flash 配置寄存器 (NFCONF)
- (2) NADN Flash 控制寄存器 (NFCONT)
- (3) NADN Flash 命令寄存器(NFCMMD)
- (4) NADN Flash 地址寄存器(NFADDR)
- (5) NADN Flash 数据寄存器(NFDATA)
- (6) NADN Flash 主数据区域 ECC 寄存器 (NFMECCD0/1)
- (7) NADN Flash 空闲区域 ECC 寄存器 (NFSECCD)
- (8) NADN Flash 操作状态寄存器(NFSTAT)
- (9) NADN Flash ECC0/1 状态寄存器(NFESTAT0/1)
- (10) NADN Flash 主数据区域ECC状态寄存器(NFMECC)
- (11) NADN Flash 空闲区域ECC状态寄存器(NFSECC)
- (12) NADN Flash 块地址寄存器(NFSBLK &NFEBLK)

## 6.3.1 NADN Flash 配置寄存器

#### NAND FLASH CONFIGURATION REGISTER (NFCONF)

| 寄存器    | 地址         | 读写  | 描述              | 复位值        |
|--------|------------|-----|-----------------|------------|
| NFCONF | 0x4E000000 | R/W | NAND Flash配置寄存器 | 0x0000100X |

|                   | 10/14 Mail Control 1 |                                                                                                                                                                                                                                                                                                                                                          |                    |  |  |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--|--|
| NFCONF            | 位                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 描述                                                                                                                                                                                                                                                                                                                                                       | 初始值                |  |  |
| 保留                | [15:!4]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 保留                                                                                                                                                                                                                                                                                                                                                       | -                  |  |  |
| TACLS             | [13:12]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | CLE & ALE duration setting value (0~3) Duration = HCLK x TACLS                                                                                                                                                                                                                                                                                           | 01                 |  |  |
| 保留                | [11]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 保留                                                                                                                                                                                                                                                                                                                                                       | 0                  |  |  |
| TWRPH0            | [10:8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | TWRPH0 duration setting value (0~7) Duration = HCLK x (TWRPH0 + 1)                                                                                                                                                                                                                                                                                       | 000                |  |  |
| 保留                | [7]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 保留                                                                                                                                                                                                                                                                                                                                                       | 0                  |  |  |
| TWRPH1            | [6:4]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | TWRPH1 duration setting value (0~7) Duration = HCLK x (TWRPH1 + 1)                                                                                                                                                                                                                                                                                       | 000                |  |  |
| AdvFlash<br>(只读)  | [3]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Advance NAND flash memory for auto-booting 0: Support 256 or 512 byte/page NAND flash memory 1: Support 1024 or 2048 byte/page NAND flash memory This bit is determined by NCON0 pin status during reset and wake-up from sleep mode.                                                                                                                    | H/W Set (NCON0)    |  |  |
| PageSize<br>(只读)  | [2]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NAND flash memory page size for auto-booting AdvFlash PageSize When AdvFlash is 0, 0: 256 Word/page, 1: 512 Bytes/page When AdvFlash is 1, 0: 1024 Word/page, 1: 2048 Bytes/page This bit is determined by GPG13 pin status during reset and wake-up from sleep mode. After reset, the GPG13 can be used as general I/O port or External interrupt.      | H/W Set<br>(GPG13) |  |  |
| AddrCycle<br>(只读) | [1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NAND flash memory Address cycle for auto-booting AdvFlash AddrCycle When AdvFlash is 0, 0: 3 address cycle 1: 4 address cycle When AdvFlash is 1, 0: 4 address cycle 1: 5 address cycle This bit is determined by GPG14pin status during reset and wake-up from sleep mode. After reset, the GPG14can be used as general I/O port or External interrupt. | H/W Set<br>(GPG14) |  |  |
| BusWidth<br>(读写)  | [0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | NAND Flash Memory I/O bus width for auto-booting and general access. 0: 8-bit bus 1: 16-bit bus  This bit is determined by GPG15 pin status during reset and wake-up from sleep mode. After reset, the GPG15 can be used as general I/O port or External interrupt. This bit can be changed by software.                                                 | H/W Set<br>(GPG15) |  |  |

# 6.3.2 控制寄存器

## **CONTROL REGISTER (NFCONT)**

| 寄存器    | 地址         | 读写  | 描述              | 复位值    |
|--------|------------|-----|-----------------|--------|
| NFCONT | 0x4E000004 | R/W | NAND Flash控制寄存器 | 0x0384 |

| NFCONT     | 位       | 描述                                                         | 初始值 |
|------------|---------|------------------------------------------------------------|-----|
| 保留         | [15:14] | 保留                                                         | 0   |
| Lock-tight | [13]    | Lock-tight configuration                                   | 0   |
|            |         | 0: Disable lock-tight 1: Enable lock-tight,                |     |
|            |         | Once this bit is set to 1, you cannot clear. Only reset or |     |
|            |         | wake up from sleep mode can make this bit disable          |     |
|            |         | (cannot cleared by software).                              |     |
|            |         | When it is set to 1, the area setting in NFSBLK            |     |
|            |         | (0x4E000038) to NFEBLK (0x4E00003C)-1 is unlocked,         |     |
|            |         | and except this area, write or erase command will be       |     |
|            |         | invalid and only read command is valid.                    |     |
|            |         | When you try to write or erase locked area, the illegal a  |     |

|             |       | ccess will be occur (NFSTAT[3] bit will be set).                                          |    |  |  |
|-------------|-------|-------------------------------------------------------------------------------------------|----|--|--|
|             |       | If the NFSBLK and NFEBLK are same, entire area will                                       |    |  |  |
|             |       | be locked.                                                                                |    |  |  |
| Soft Lock   | [12]  | Soft Lock configuration                                                                   | 1  |  |  |
|             |       | 0: Disable lock 1: Enable lock                                                            |    |  |  |
|             |       | Soft lock area can be modified at any time by software.                                   |    |  |  |
|             |       | When it is set to 1, the area setting in NFSBLK                                           |    |  |  |
|             |       | (0x4E000038) to NFEBLK (0x4E00003C)-1 is unlocked,                                        |    |  |  |
|             |       | and except this area, write or erase command will be                                      |    |  |  |
|             |       | invalid and only read command is valid.                                                   |    |  |  |
|             |       | When you try to write or erase locked area, the illegal                                   |    |  |  |
|             |       | access will be occur (NFSTAT [3] bit will be set).                                        |    |  |  |
|             |       | If the NFSBLK and NFEBLK are same, entire area will                                       |    |  |  |
|             |       | be locked.                                                                                |    |  |  |
| 保留          | [11]  | 保留                                                                                        | 0  |  |  |
| EnbIllegalA | [10]  | Illegal access interrupt control                                                          | 0  |  |  |
| ccINT       |       | 0: Disable interrupt 1: Enable interrupt                                                  |    |  |  |
|             |       | Illegal access interrupt is occurred when CPU tries to                                    |    |  |  |
|             |       | program or erase locking area (the area setting in                                        |    |  |  |
|             |       | NFSBLK (0x4E000038) to NFEBLK(0x4E00003C)-1).                                             |    |  |  |
| EnbRnBINT   | [9]   | RnB status input signal transition interrupt control                                      | 0  |  |  |
|             |       | 0: Disable RnB interrupt                                                                  |    |  |  |
|             |       | 1: Enable RnB interrupt                                                                   |    |  |  |
| RnB_TransMo | [8]   | RnB transition detection configuration                                                    | 0  |  |  |
| de          |       | 0: Detect rising edge 1: Detect falling edge                                              |    |  |  |
| 保留          | [7]   | 保留                                                                                        | 1  |  |  |
| SpareECCLoc | [6]   | ·                                                                                         |    |  |  |
| k           |       | 0: Unlock spare ECC 1: Lock spare ECC Spare area ECC status register is FSECC(0x4E000034) |    |  |  |
| MainECCLock | [5]   | Lock Main data area ECC generation                                                        | 1  |  |  |
| Mainecclock | [9]   | 0: Unlock main data area ECC generation                                                   | 1  |  |  |
|             |       | 1: Lock main data area ECC generation                                                     |    |  |  |
|             |       | Main area ECC status register is NFMECC0/1                                                |    |  |  |
|             |       | (0x4E00002C/30)                                                                           |    |  |  |
| InitECC     | [4]   | Initialize ECC decoder/encoder(Write-only)                                                | 0  |  |  |
| IIII CECC   | [ד]   | 1: Initialize ECC decoder/encoder                                                         | U  |  |  |
| 保留          | [2:3] | 保留                                                                                        | 00 |  |  |
| Reg_nCE     | [1]   | NAND Flash Memory nFCE signal control                                                     | 1  |  |  |
| •           |       | 0: Force nFCE to low (Enable chip select)                                                 |    |  |  |
|             |       | 1: Force nFCE to high (Disable chip select)                                               |    |  |  |
|             |       | <b>Note:</b> During boot time, it is controlled automatically.                            |    |  |  |
|             |       | This value is only valid while MODE bit is 1                                              |    |  |  |
| MODE        | [0]   | NAND flash controller operating mode                                                      | 0  |  |  |
|             |       | 0: NAND flash controller disable (Don't work)                                             |    |  |  |
|             |       | 1: NAND flash controller enable                                                           |    |  |  |

## 第八草 Nanu Flash 在制命 Forum. <u>Intp://embeddediinux.tireireenoster.com/</u>

## 6.3.3 命令寄存器

## **COMMAND REGISTER (NFCMMD)**

| 寄存器    | 地址         | 读写  | 描述               | 复位值  |
|--------|------------|-----|------------------|------|
| NFCMMD | 0x4E000008 | R/W | NAND Flash命令集寄存器 | 0x00 |

| NFCMMD | 位      | 描述               | 初始值  |
|--------|--------|------------------|------|
| 保留     | [15:8] | 保留               | 0x00 |
| NFCMMD | [7:0]  | NAND Flash存储器命令值 | 0x00 |

# 6.3.4 地址寄存器

## **ADDRESS REGISTER (NFADDR)**

| 寄存器    | 地址         | 读写  | 描述               | 复位值        |
|--------|------------|-----|------------------|------------|
| NFADDR | 0x4E00000C | R/W | NAND Flash地址集寄存器 | 0x0000xx00 |

| NFADDR | 位      | 描述               | 初始值  |
|--------|--------|------------------|------|
| 保留     | [15:8] | 保留               | 0x00 |
| NFADDR | [7:0]  | NAND Flash存储器地址值 | 0x00 |

## 6.3.5 数据寄存器

## **DATA REGISTER (NFDATA)**

| 寄存器    | 地址         | 读写  | 描述              | 复位值    |
|--------|------------|-----|-----------------|--------|
| NFDATA | 0x4E000010 | R/W | NAND Flash数据寄存器 | 0xXXXX |

| NFDATA | 位      | 描述                     | 初始值    |
|--------|--------|------------------------|--------|
| NFDATA | [31:0] | NAND Flash对于I/O读/编程数据值 | 0xXXXX |
|        |        | 注:参考数据寄存器配置            |        |

# 6.3.6 主数据区域 ECC 寄存器

## MAIN DATA AREA REGISTER (NFMECCD0/1)

| 寄存器      | 地址         | 读写  | 描述                 | 复位值        |
|----------|------------|-----|--------------------|------------|
| NFMECCD0 | 0x4E000014 | R/W | 对于主数据读取 NAND Flash | 0x00000000 |
|          |            |     | 第一第二ECC寄存器         |            |
| NFMECCD1 | 0x4E000018 | R/W | 对于主数据读取NAND Flash  | 0x00000000 |
|          |            |     | 第三第四ECC寄存器         |            |

| NFMECCD0   | 位       | 描述               | 初始值  |
|------------|---------|------------------|------|
| ECCData1_1 | [31:24] | 对于I/O[15:8]的ECC2 | 0x00 |
| ECCData1_0 | [23:16] | 对于I/O[7:0]的ECC2  | 0x00 |
| ECCData0_0 | [15:8]  | 对于I/O[15:8]的ECC1 | 0x00 |
| ECCData0_1 | [7:0]   | 对于I/O[7:0]的ECC1  | 0x00 |

| NFMECCD1   | 位       | 描述               | 初始值  |
|------------|---------|------------------|------|
| ECCData3_1 | [31:24] | 对于I/O[15:8]的ECC4 | 0x00 |

MSN: zhuqi428@sina.com

Forum: http://embeddedlinux.thefreehoster.com/

| ECCData3_0 | [23:16] | 对于I/O[7:0]的ECC4  | 0x00 |
|------------|---------|------------------|------|
| ECCData2_0 | [15:8]  | 对于I/O[15:8]的ECC3 | 0x00 |
| ECCData2_1 | [7:0]   | 对于I/O[7:0]的ECC3  | 0x00 |

注: 仅字访问有效。

# 6.3.7 空闲区域 ECC 寄存器

## **SPARE AREA ECC REGISTER (NFSECCD)**

| 寄存器     | 地址         | 读写  | 描述             | 复位值        |
|---------|------------|-----|----------------|------------|
| NFSECCD | 0x4E00001C | R/W | 对于空闲区域数据读取NAND | 0x00000000 |
|         |            |     | Flash的ECC寄存器   |            |

| NFSECCD    | 位       | 描述               | 初始值  |
|------------|---------|------------------|------|
| ECCData1_1 | [31:24] | 对于I/O[15:8]的ECC2 | 0x00 |
| ECCData1_0 | [23:16] | 对于I/O[7:0]的ECC2  | 0x00 |
| ECCData0_0 | [15:8]  | 对于I/O[15:8]的ECC1 | 0x00 |
| ECCData0_1 | [7:0]   | 对于I/O[7:0]的ECC1  | 0x00 |

注: 仅字访问有效。

# 6.3.8 操作状态寄存器

# NFCON STATUS REGISTER(NFSTAT)

| 寄存器    | 地址         | 读写  | 描述                | 复位值    |
|--------|------------|-----|-------------------|--------|
| NFSTAT | 0x4E000020 | R/W | NAND Flash操作状态寄存器 | 0xXX00 |

| NFSECCD       | 位     | 描述                                           | 初始值 |
|---------------|-------|----------------------------------------------|-----|
| 保留            | [7]   | 保留                                           |     |
| 保留            | [6:4] | 保留                                           |     |
| IllegalAccess | [3]   | 一旦 Soft Lock或Lock-tight 使能,对存储器的             |     |
|               |       | 非法访问(编程或擦除)使得此位置位。                           |     |
|               |       | 0: 未检测到非法访问                                  |     |
|               |       | 1: 检测到非法访问                                   |     |
| RnB_TransDete | [2]   | When RnB low to high transition is occurred, | 0   |
| ct            |       | this value set and issue interrupt if        |     |
|               |       | enabled. To clear this value write '1'.      |     |
|               |       | 0: RnB transition is not detected            |     |
|               |       | 1: RnB transition is detected                |     |
|               |       | Transition configuration is set in           |     |
|               |       | RnB_TransMode(NFCONT[8]).                    |     |
| nCE (只读)      | [1]   | nCE输出引脚 1 的状态                                | 1   |
| RnB (只读)      | [0]   | RnB输入引脚的状态                                   | 1   |
|               |       | 0: NAND Flash存储器忙                            |     |
|               |       | 1: NAND Flash存储器准备好操作                        |     |

# 6.3.9 ECC0/1 状态寄存器

## **ECCO/1 STATUS REGISTER (NFESTATO/1)**

| 寄存器      | 地址         | 读写  | 描述                       | 复位值        |
|----------|------------|-----|--------------------------|------------|
| NFESTAT0 | 0x4E000024 | R/W | 对于I/0[7:0]NAND Flash ECC | 0x00000000 |
|          |            |     | 状态寄存器                    |            |
| NFESTAT1 | 0x4E000028 | R/W | 对于I/0[15:8]NAND Flash    | 0x00000000 |
|          |            |     | ECC状态寄存器                 |            |

| NFESTAT0     | 位       | 描述                                            | 初始值  |  |  |  |  |
|--------------|---------|-----------------------------------------------|------|--|--|--|--|
| SErrorDataNo | [24:21] | In spare area, Indicates which number data is | 00   |  |  |  |  |
|              |         | error                                         |      |  |  |  |  |
| SErrorBitNo  | [20:18] | In spare area, Indicates which bit is error   | 000  |  |  |  |  |
| MErrorDataNo | [17:7]  | In main data area, Indicates which number     | 0x00 |  |  |  |  |
|              |         | data is error                                 |      |  |  |  |  |
| MErrorBitNo  | [6:4]   | In main data area, Indicates which bit is     | 000  |  |  |  |  |
|              |         | error                                         |      |  |  |  |  |
| SpareError   | [3:2]   | Indicates whether spare area bit fail error   | 00   |  |  |  |  |
|              |         | occurred                                      |      |  |  |  |  |
|              |         | 00: No Error 01: 1-bit error(correctable)     |      |  |  |  |  |
|              |         | 10: Multiple error 11: ECC area error         |      |  |  |  |  |
| MainError    | [1:0]   | Indicates whether main data area bit fail     | 00   |  |  |  |  |
|              |         | error occurred                                |      |  |  |  |  |
|              |         | 00: No Error 01: 1-bit error(correctable)     |      |  |  |  |  |
|              |         | 10: Multiple error 11: ECC area error         |      |  |  |  |  |

| NFESTAT1     | 位       | 描述                                            | 初始值  |  |  |  |  |
|--------------|---------|-----------------------------------------------|------|--|--|--|--|
| SErrorDataNo | [24:21] | In spare area, Indicates which number data is | 00   |  |  |  |  |
|              |         | error                                         |      |  |  |  |  |
| SErrorBitNo  | [20:18] | In spare area, Indicates which bit is error   | 000  |  |  |  |  |
| MErrorDataNo | [17:7]  | In main data area, Indicates which number     | 0x00 |  |  |  |  |
|              |         | data is error                                 |      |  |  |  |  |
| MErrorBitNo  | [6:4]   | In main data area, Indicates which bit is     | 000  |  |  |  |  |
|              |         | error                                         |      |  |  |  |  |
| SpareError   | [3:2]   | Indicates whether spare area bit fail error 0 |      |  |  |  |  |
|              |         | occurred                                      |      |  |  |  |  |
|              |         | 00: No Error 01: 1-bit error(correctable)     |      |  |  |  |  |
|              |         | 10: Multiple error 11: ECC area error         |      |  |  |  |  |
| MainError    | [1:0]   | Indicates whether main data area bit fail     | 00   |  |  |  |  |
|              |         | error occurred                                |      |  |  |  |  |
|              |         | 00: No Error 01: 1-bit error(correctable)     |      |  |  |  |  |
|              |         | 10: Multiple error 11: ECC area error         |      |  |  |  |  |

# 6.3.10 主数据区域 ECC 状态寄存器

## MAIN DATA AREA ECC STATUS REGISTER (NFMECC0/1)

MSN: zhuqi428@sina.com

Nand Flash 控制器 Forum: <a href="http://embeddedlinux.thefreehoster.com/">http://embeddedlinux.thefreehoster.com/</a>

| 寄存器     | 地址         | 读写  | 描述                      | 复位值      |
|---------|------------|-----|-------------------------|----------|
| NFMECC0 | 0x4E00002C | R/W | 对于I/0[7:0]NAND Flash 主区 | 0xXXXXXX |
|         |            |     | 域ECC状态寄存器               |          |
| NFMECC1 | 0x4E000030 | R/W | 对于I/0[15:8]NAND Flash 主 | 0xXXXXXX |
|         |            |     | 区域ECC状态寄存器              |          |

| NFMECC0 | 位       | 描述                    | 初始值  |
|---------|---------|-----------------------|------|
| MECC0_3 | [31:24] | 对于I/O[7:0]的主区域ECC3 状态 | 0xXX |
| MECC0_2 | [23:16] | 对于I/O[7:0]的主区域ECC2 状态 | 0xXX |
| MECC0_1 | [15:8]  | 对于I/O[7:0]的主区域ECC1 状态 | 0xXX |
| MECC0_0 | [7:0]   | 对于I/O[7:0]的主区域ECC0 状态 | 0xXX |

| NFMECC1 | 位       | 描述                    | 初始值  |
|---------|---------|-----------------------|------|
| MECC1_3 | [31:24] | 对于I/O[7:0]的主区域ECC3 状态 | 0xXX |
| MECC1_2 | [23:16] | 对于I/O[7:0]的主区域ECC2 状态 | 0xXX |
| MECC1_1 | [15:8]  | 对于I/O[7:0]的主区域ECC1 状态 | 0xXX |
| MECC1_0 | [7:0]   | 对于I/O[7:0]的主区域ECC0 状态 | 0xXX |

## 6.3.11 空闲区域 ECC 状态寄存器

## **SPARE AREA ECC STATUS REGISTER (NFSECC)**

| 寄存器    | 地址         | 读写  | 描述                      | 复位值      |
|--------|------------|-----|-------------------------|----------|
| NFSECC | 0x4E000034 | R/W | 对于I/0[15:0]NAND Flash 空 | 0xXXXXXX |
|        |            |     | 闲区域ECC状态寄存器             |          |

| NFSECC  | 位       | 描述                      | 初始值  |
|---------|---------|-------------------------|------|
| MSCC1_1 | [31:24] | 对于I/O[15:8]的空闲区域ECC3 状态 | 0xXX |
| MSCC1_0 | [23:16] | 对于I/O[15:8]的空闲区域ECC2 状态 | 0xXX |
| MSCC0_1 | [15:8]  | 对于I/O[7:0]的空闲区域ECC1 状态  | 0xXX |
| MSCC0_0 | [7:0]   | 对于I/O[7:0]的空闲区域ECC0 状态  | 0xXX |

# 6.3.12 块地址寄存器

## **BLOCK ADDRESS REGISTER (NFSBLK &NFEBLK)**

| 寄存器    | 地址         | 读写  | 描述                 | 复位值      |
|--------|------------|-----|--------------------|----------|
| NFSBLK | 0x4E000038 | R/W | NAND Flash可编程开始块地址 | 0x000000 |
| NFEBLK | 0x4E00003C | R/W | NAND Flash可编程终止块地址 | 0x000000 |

注: NAND Flash可以在开始地址和终止地址之间被编程。当软锁(soft lock)或锁紧(lock-tight)被使能开始地址和终止地址为同一值,整个NAND Flash区域被锁定。

| NFSBLK     | 位       | 描述          | 初始值  |
|------------|---------|-------------|------|
| SBLK_ADDR2 | [23:16] | 块擦除操作的第三块地址 | 0x00 |
| SBLK_ADDR1 | [15:8]  | 块擦除操作的第二块地址 | 0x00 |
| SBLK_ADDR0 | [7:0]   | 块擦除操作的第一块地址 | 0x00 |

| NFEBLK     | 位       | 描述          | 初始值  |
|------------|---------|-------------|------|
| EBLK_ADDR2 | [23:16] | 块擦除操作的第三块地址 | 0x00 |

S3C2440A 中文 Datasheet 第六章 Nand Flash 控制器 MSN: zhuqi428@sina.com

Forum: http://embeddedlinux.thefreehoster.com/

| EBLK_ADDR1 | [15:8] | 块擦除操作的第二块地址 | 0x00 |
|------------|--------|-------------|------|
| EBLK_ADDR0 | [7:0]  | 块擦除操作的第一块地址 | 0x00 |

NFSBLK 和 NFEBLK 可以被修改,当软锁(soft lock)位(NFCONT[12])被使能。 NFSBLK 和 NFEBLK 不可以被修改,当锁紧(Lock-tight)位(NFCONT[13])被置位。

