W29N04GV
Release Date: February 9th, 2017
1 Revision B
W29N04GV
4G-BIT 3.3V
NAND FLASH MEMORY
W29N04GV
Release Date: February 9th, 2017
2 Revision B
Table of Contents
1. GENERAL DESCRIPTION ............................................................................................................ 7
2. FEATURES .................................................................................................................................... 7
3. PACKAGE TYPES AND PIN CONFIGURATIONS ....................................................................... 8
3.1 Pin assignment 48-pin TSOP1(x8) ....................................................................................... 8
3.2 Pin assignment 63 ball VFBGA (x8) ..................................................................................... 9
3.3 Pin Descriptions .................................................................................................................. 10
4. PIN DESCRITPIONS ................................................................................................................... 11
4.1 Chip Enable (#CE) .............................................................................................................. 11
4.2 Write Enable (#WE) ............................................................................................................ 11
4.3 Read Enable (#RE) ............................................................................................................. 11
4.4 Address Latch Enable (ALE) .............................................................................................. 11
4.5 Command Latch Enable (CLE) ........................................................................................... 11
4.6 Write Protect (#WP) ............................................................................................................ 11
4.7 Ready/Busy (RY/#BY) ........................................................................................................ 11
4.8 Input and Output (I/Ox) ....................................................................................................... 11
5. BLOCK DIAGRAM ....................................................................................................................... 12
6. MEMORY ARRAY ORGANIZATION ........................................................................................... 13
6.1 Array Organization (x8) ....................................................................................................... 13
7. MODE SELECTION TABLE ........................................................................................................ 14
8. COMMAND TABLE ...................................................................................................................... 15
9. DEVICE OPERATIONS ............................................................................................................... 17
9.1 READ operation .................................................................................................................. 17
9.1.1 PAGE READ (00h-30h) ........................................................................................................ 17
9.1.2 CACHE READ OPERATIONS .............................................................................................. 17
9.1.3 TWO PLANE READ (00h-00h-30h) ...................................................................................... 21
9.1.4 RANDOM DATA OUTPUT (05h-E0h) ................................................................................... 23
9.1.5 READ ID (90h) ...................................................................................................................... 25
9.1.6 READ PARAMETER PAGE (ECh) ....................................................................................... 26
9.1.7 READ STATUS (70h) ........................................................................................................... 28
9.1.8 READ STATUS ENHANCED (78h) ...................................................................................... 30
9.1.9 READ UNIQUE ID (EDh) ...................................................................................................... 31
9.2 PROGRAM operation ......................................................................................................... 32
9.2.1 PAGE PROGRAM (80h-10h) ................................................................................................ 32
9.2.2 SERIAL DATA INPUT (80h) ................................................................................................. 32
9.2.3 RANDOM DATA INPUT (85h) .............................................................................................. 33
9.2.4 CACHE PROGRAM (80h-15h) ............................................................................................. 33
9.2.5 TWO PLANE PAGE PROGRAM .......................................................................................... 35
9.3 COPY BACK operation ....................................................................................................... 38
9.3.1 READ for COPY BACK (00h-35h) ........................................................................................ 38
9.3.2 PROGRAM for COPY BACK (85h-10h) ................................................................................ 38
9.3.3 TWO PLANE READ for COPY BACK ................................................................................... 39
9.3.4 TWO PLANE PROGRAM for COPY BACK .......................................................................... 39
9.4 BLOCK ERASE operation .................................................................................................. 43
W29N04GV
Release Date: February 9th, 2017
3 Revision B
9.4.1 BLOCK ERASE (60h-D0h) ................................................................................................... 43
9.4.2 TWO PLANE BLOCK ERASE .................................................................................................. 44
9.5 RESET operation ................................................................................................................ 45
9.5.1 RESET (FFh) ........................................................................................................................ 45
9.6 FEATURE OPERATION ..................................................................................................... 46
9.6.1 GET FEATURES (EEh) ........................................................................................................ 49
9.6.2 SET FEATURES (EFh) ......................................................................................................... 50
9.7 ONE TIME PROGRAMMABLE (OTP) area ....................................................................... 51
9.8 WRITE PROTECT .............................................................................................................. 52
9.9 BLOCK LOCK ..................................................................................................................... 54
10. ELECTRICAL CHARACTERISTICS ............................................................................................ 55
10.1 Absolute Maximum Ratings (3.3V) ..................................................................................... 55
10.2 Operating Ranges (3.3V) .................................................................................................... 55
10.3 Device power-up timing ...................................................................................................... 56
10.4 DC Electrical Characteristics (3.3V) ................................................................................... 57
10.5 AC Measurement Conditions (3.3V) ................................................................................... 58
10.6 AC timing characteristics for Command, Address and Data Input (3.3V) .......................... 59
10.7 AC timing characteristics for Operation (3.3V) ................................................................... 60
10.8 Program and Erase Characteristics .................................................................................... 61
11. TIMING DIAGRAMS .................................................................................................................... 62
12. INVALID BLOCK MANAGEMENT ............................................................................................... 72
12.1 Invalid blocks ...................................................................................................................... 72
12.2 Initial invalid blocks ............................................................................................................. 72
12.3 Error in operation ................................................................................................................ 73
12.4 Addressing in program operation ....................................................................................... 74
13. PACKAGE DIMENSIONS ............................................................................................................ 75
13.1 TSOP 48-pin 12x20 ............................................................................................................ 75
13.2 Fine-Pitch Ball Grid Array 63-ball ....................................................................................... 76
14. ORDERING INFORMATION ....................................................................................................... 77
15. VALID PART NUMBERS ............................................................................................................. 78
16. REVISION HISTORY ................................................................................................................... 79
W29N04GV
Release Date: February 9th, 2017
4 Revision B
List of Tables
Table 3-1 Pin Descriptions .......................................................................................................................... 10
Table 6-1 Addressing .................................................................................................................................. 13
Table 7-1 Mode Selection ........................................................................................................................... 14
Table 8-1 Command Table .......................................................................................................................... 16
Table 9-1 Device ID and configuration codes for Address 00h ................................................................... 26
Table 9-2 ONFI identifying codes for Address 20h ..................................................................................... 26
Table 9-3 Parameter Page Output Value .................................................................................................... 28
Table 9-4 Status Register Bit Definition……………………………………………………….......................29
Table 9-5 Features ...................................................................................................................................... 46
Table 9-6 Feature Address 80h ................................................................................................................... 47
Table 9-7 Feature Address 81h ................................................................................................................... 48
Table 10-1 Absolute Maximum Ratings ...................................................................................................... 55
Table 10-2 Operating Ranges…………………………………………………………………….......................55
Table 10-3 DC Electrical Characteristics .................................................................................................... 57
Table 10-4 AC Measurement Conditions .................................................................................................... 58
Table 10-5 AC timing characteristics for Command, Address and Data Input ........................................... 59
Table 10-6 AC timing characteristics for Operation………………………………………………................60
Table 10-7 Program and Erase Characteristics .......................................................................................... 61
Table 12-1 Valid Block Number................................................................................................................... 72
Table 12-2 Block failure ............................................................................................................................... 73
Table 15-1 Part Numbers for Industrial Temperature ................................................................................. 78
Table 16-1 History Table ............................................................................................................................. 79
W29N04GV
Release Date: February 9th, 2017
5 Revision B
List of Figures
Figure 3-1 Pin Assignment 48-pin TSOP1 (Package code S) ...................................................................... 8
Figure 3-2 Pin Assignment 63-ball VFBGA (Package code B) ..................................................................... 9
Figure 5-1 NAND Flash Memory Block Diagram ........................................................................................ 12
Figure 6-1 Array Organization ..................................................................................................................... 13
Figure 9-1 Page Read Operations .............................................................................................................. 17
Figure 9-2 Sequential Cache Read Operations .......................................................................................... 19
Figure 9-3 Random Cache Read Operation ............................................................................................... 20
Figure 9-4 Last Address Cache Read Operation ........................................................................................ 21
Figure 9-5 Two Plane Read Page (00h-00h-30h) Operation ...................................................................... 22
Figure 9-6 Random Data Output ................................................................................................................. 23
Figure 9-7 Two Plane Random Data Read (06h-E0h) Operation ............................................................... 24
Figure 9-8 Read ID ...................................................................................................................................... 25
Figure 9-9 Read Parameter Page ............................................................................................................... 26
Figure 9-10 Read Status Operation ............................................................................................................ 29
Figure 9-11 Read Status Enhanced (78h) Operation ................................................................................. 30
Figure 9-12 Read Unique ID ....................................................................................................................... 31
Figure 9-13 Page Program .......................................................................................................................... 32
Figure 9-14 Random Data Input .................................................................................................................. 33
Figure 9-15 Cache Program Start ............................................................................................................... 34
Figure 9-16 Cache Program End ................................................................................................................ 34
Figure 9-17 Two Plane Page Program ........................................................................................................ 36
Figure 9-18 Two Plane Cache Program ...................................................................................................... 37
Figure 9-19 Program for copy back Operation ............................................................................................ 40
Figure 9-20 Copy Back Operation with Random Data Input ....................................................................... 40
Figure 9-21 Two Plane Copy Back.............................................................................................................. 41
Figure 9-22 Two Plane Copy Back with Random Data Input ...................................................................... 41
Figure 9-23 Two Plane Program for copy back ........................................................................................... 42
Figure 9-24 Block Erase Operation ............................................................................................................. 43
Figure 9-25 Two Plane Block Erase Operation ........................................................................................... 44
Figure 9-26 Reset Operation ....................................................................................................................... 45
Figure 9-27 Get Feature Operation ............................................................................................................. 49
Figure 9-28 Set Feature Operation ............................................................................................................. 50
Figure 9-29 Erase Enable ........................................................................................................................... 52
Figure 9-30 Erase Disable ........................................................................................................................... 52
Figure 9-31 Program Enable ....................................................................................................................... 52
Figure 9-32 Program Disable ...................................................................................................................... 53
Figure 9-33 Program for Copy Back Enable ............................................................................................... 53
Figure 9-34 Program for Copy Back Disable .............................................................................................. 53
Figure 10-1 Power ON/OFF sequence ....................................................................................................... 56
Figure 11-1 Command Latch Cycle............................................................................................................. 62
Figure 11-2 Address Latch Cycle ................................................................................................................ 62
Figure 11-3 Data Latch Cycle ...................................................................................................................... 63
Figure 11-4 Serial Access Cycle after Read ............................................................................................... 63
Figure 11-5 Serial Access Cycle after Read (EDO) .................................................................................... 64
W29N04GV
Release Date: February 9th, 2017
6 Revision B
Figure 11-6 Read Status Operation ............................................................................................................ 64
Figure 11-7 Page Read Operation .............................................................................................................. 65
Figure 11-8 #CE Don't Care Read Operation ............................................................................................. 65
Figure 11-9 Random Data Output Operation .............................................................................................. 66
Figure 11-10 Cache Read Operation (1/2) .................................................................................................. 66
Figure 11-11 Cache Read Operation (2/2) .................................................................................................. 67
Figure 11-12 Read ID .................................................................................................................................. 67
Figure 11-13 Page Program ........................................................................................................................ 68
Figure 11-14 #CE Don't Care Page Program Operation ............................................................................. 68
Figure 11-15 Page Program with Random Data Input ................................................................................ 69
Figure 11-16 Copy Back .............................................................................................................................. 69
Figure 11-17 Cache Program ...................................................................................................................... 70
Figure 11-18 Block Erase ............................................................................................................................ 70
Figure 11-19 Reset ...................................................................................................................................... 71
Figure 12-1 flow chart of create initial invalid block table ............................................................................ 73
Figure 12-2 Bad block Replacement ........................................................................................................... 74
Figure 13-1 TSOP 48-PIN 12X20mm ......................................................................................................... 75
Figure 13-2 Fine-Pitch Ball Grid Array 63-Ball ............................................................................................ 76
Figure 14-1 Ordering Part Number Description .......................................................................................... 77
W29N04GV
Release Date: February 9th, 2017
7 Revision B
1. GENERAL DESCRIPTION
The W29N04GV (4G-bit) NAND Flash memory provides a storage solution for embedded systems with
limited space, pins and power. It is ideal for code shadowing to RAM, solid state applications and storing
media data such as, voice, video, text and photos. The device operates on a single 2.7V to 3.6V power
supply with active current consumption as low as 25mA at 3V and 10uA for CMOS standby current.
The memory array totals 553,648,128bytes, and organized into 4,096 erasable blocks of 135,168 bytes.
Each block consists of 64 programmable pages of 2,112-bytes each. Each page consists of 2,048-bytes
for the main data storage area and 64-bytes for the spare data area (The spare area is typically used for
error management functions).
The W29N04GV supports the standard NAND flash memory interface using the multiplexed 8-bit bus to
transfer data, addresses, and command instructions. The five control signals, CLE, ALE, #CE, #RE and
#WE handle the bus interface protocol. Also, the device has two other signal pins, the #WP (Write Protect)
and the RY/#BY (Ready/Busy) for monitoring the device status.
2. FEATURES
Basic Features
Density : 4Gbit (Single chip solution)
Vcc : 2.7V to 3.6V
Bus width : x8
Operating temperature
Industrial: -40°C to 85°C
Single-Level Cell (SLC) technology.
Organization
Density: 4G-bit/512M-byte
Page size
2,112 bytes (2048 + 64 bytes)
Block size
64 pages (128K + 4K bytes)
Highest Performance
Read performance (Max.)
Random read: 25us
Sequential read cycle: 25ns
Write Erase performance
Page program time: 250us(typ.)
Block erase time: 2ms(typ.)
Endurance 100,000 Erase/Program
Cycles(1)
10-years data retention
Command set
Standard NAND command set
Additional command support
Sequential Cache Read
Random Cache Read
Cache Program
Copy Back
Two-plane operation
Contact Winbond for OTP feature
Contact Winbond for block Lock feature
Lowest power consumption
Read: 25mA(typ.3V)
Program/Erase: 25mA(typ.3V)
CMOS standby: 10uA(typ.)
Space Efficient Packaging
48-pin standard TSOP1
63-ball VFBGA
Contact Winbond for stacked
packages/KGD
Note:
1. Endurance specification is based on 1bit/528 byte ECC (Error Correcting Code).
W29N04GV
Release Date: February 9th, 2017
8 Revision B
3. PACKAGE TYPES AND PIN CONFIGURATIONS
W29N04GV is offered in a 48-pin TSOP1 package (Code S) and 63-ball VFBGA package (Code B)
as shown in Figure 3-1 to 3-3, respectively. Package diagrams and dimensions are illustrated in
Section: Package Dimensions.
3.1 Pin assignment 48-pin TSOP1(x8)
Figure 3-1 Pin Assignment 48-pin TSOP1 (Package code S)
Note:
1. These pins might not be connected in the package. Winbond recommends connecting these pins to the
designed external sources for ONFI compatibility.
3
4
1
2
Top View
7
8
5
6
11
12
9
10
15
16
13
14
19
20
17
18
23
24
21
22
46
45
48
47
42
41
44
43
38
37
40
39
34
33
36
35
30
29
32
31
26
25
28
27
48-pin TSOP1
Standard package
12mm x 20mm
N.C
N.C
Vss1
N.C
IO5
IO4
IO7
IO6
DNU
Vcc
N.C
Vcc1
Vcc1
N.C
Vss
N.C
IO1
IO0
IO3
IO2
N.C
Vss1
N.C
N.C
N.C
N.C
N.C
N.C
RY/#BY
#RE
N.C
N.C
N.C
Vcc
#CE
N.C
N.C
CLE
Vss
N.C
#WP
DNU
ALE
#WE
N.C
N.C
N.C
N.C
X8X8
W29N04GV
Release Date: February 9th, 2017
9 Revision B
3.2 Pin assignment 63 ball VFBGA (x8)
Figure 3-2 Pin Assignment 63-ball VFBGA (Package code B)
3 41 2 7 85 6
A
B
910
E
F
C
D
J
K
G
H
L
M
N.CN.C
N.C
RY/#BY
#RE N.CN.C
#CE
N.CCLE
Vss
N.C
#WP ALE #WE
N.C
N.C
N.C
N.C
N.C
N.C
N.C
N.C
N.C
N.C
N.C
N.C
N.CN.C N.C N.CN.C N.C
N.CN.C N.C N.C N.C
N.CN.C N.C
N.C N.C N.CN.C
N.C N.C IO5
IO4
IO7
IO6
N.C
N.C
IO1
IO0
IO3IO2 Vss
Vcc
Vcc
Vss
DNU DNU
Top View, ball down
W29N04GV
Release Date: February 9th, 2017
10 Revision B
3.3 Pin Descriptions
PIN NAME
I/O
FUNCTION
#WP
I
Write Protect
ALE
I
Address Latch Enable
#CE
I
Chip Enable
#WE
I
Write Enable
RY/#BY
O
Ready/Busy
#RE
I
Read Enable
CLE
I
Command Latch Enable
I/O[0-7]
I/O
Data Input/Output (x8)
Vcc
Supply
Power supply
Vss
Supply
Ground
DNU
-
Do Not Use: This pins are unconnected pins.
N.C
-
No Connect
Table 3-1 Pin Descriptions
Note:
1. Connect all Vcc and Vss pins to power supply or ground. Do not leave Vcc or Vss disconnected.
W29N04GV
Release Date: February 9th, 2017
11 Revision B
4. PIN DESCRITPIONS
4.1 Chip Enable (#CE)
#CE pin enables and disables device operation. When #CE is high the device is disabled and the I/O
pins are set to high impedance and enters into standby mode if not busy. When #CE is set low the
device will be enabled, power consumption will increase to active levels and the device is ready for
Read and Write operations.
4.2 Write Enable (#WE)
#WE pin enables the device to control write operations to input pins of the device. Such as, command
instructions, addresses and data that are latched on the rising edge of #WE.
4.3 Read Enable (#RE)
#RE pin controls serial data output from the pre-loaded Data Register. Valid data is present on the
I/O bus after the tREA period from the falling edge of #RE. Column addresses are incremented for
each #RE pulse.
4.4 Address Latch Enable (ALE)
ALE pin controls address input to the address register of the device. When ALE is active high,
addresses are latched via the I/O pins on the rising edge of #WE.
4.5 Command Latch Enable (CLE)
CLE pin controls command input to the command register of the device. When CLE is active high,
commands are latched into the command register via I/O pins on the rising edge of #WE.
4.6 Write Protect (#WP)
#WP pin can be used to prevent the inadvertent program/erase to the device. When #WP pin is active
low, all program/erase operations are disabled.
4.7 Ready/Busy (RY/#BY)
RY/#BY pin indicates the device status. When RY/#BY output is low, it indicates that the device is
processing either a program, erase or read operations. When it returns to high, those operations have
completed. RY/#BY pin is an open drain.
4.8 Input and Output (I/Ox)
I/Ox bi-directional pins are used for the following; command, address and data operations.
W29N04GV
Release Date: February 9th, 2017
12 Revision B
5. BLOCK DIAGRAM
Logic
Control
Status
Register
Command
Register
Address
Register
High Voltage
Generator
NAND Flash
Array
Row Decoder
Column Decoder
Cache Register
Data Register
I/O
Control
#CE
ALE
CLE
#RE
#WE
#WP
I/Ox
RY/#BY
Figure 5-1 NAND Flash Memory Block Diagram
W29N04GV
Release Date: February 9th, 2017
13 Revision B
6. MEMORY ARRAY ORGANIZATION
6.1 Array Organization (x8)
Figure 6-1 Array Organization
I/O7
I/O4
I/O2
1st cycle
A7
A4
A2
2nd cycle
L
L
A10
3rd cycle
A19
A16
A14
4th cycle
A27
A24
A22
5th cycle
L
L
L
Table 6-1 Addressing
Notes:
1. “L” indicates a low condition, which must be held during the address cycle to insure correct processing.
2. A0 to A11 during the 1st and 2nd cycles are column addresses. A12 to A29 during the 3rd, 4th and 5th cycles
are row addresses.
3. A18 is plane address
4. The device ignores any additional address inputs that exceed the device’s requirement.
Plane of even
-
numbered blocks Plane of odd
-
numbered blocks
2048
blocks
Per plane
4096
blocks
Per device
Data Register
Cache Register 2048
2048
2048
2048
2112 bytes 2112 bytes
64
64
64
64
1 block
1 block
1page = (2k+64bytes)
1block = (2k+64bytes×64 pages
= (128k+4k)byte
1plane = (128k+4k)byte×2048blocks
= 2112Mb
1device = 2112Mb ×2planes
= 4224Mb
DQ7
DQ0
W29N04GV
Release Date: February 9th, 2017
14 Revision B
7. MODE SELECTION TABLE
MODE
CLE
ALE
#CE
#WE
#RE
#WP
Read
mode
Command input
H
L
L
H
X
Address input
L
H
L
H
X
Program
Erase
mode
Command input
H
L
L
H
H
Address input
L
H
L
H
H
Data input
L
L
L
H
H
Sequential Read and Data output
L
L
L
H
X
During read (busy)
X
X
X
X
H
X
During program (busy)
X
X
X
X
X
H
During erase (busy)
X
X
X
X
X
H
Write protect
X
X
X
X
X
L
Standby
X
X
H
X
X
0V/Vcc
Table 7-1 Mode Selection
Notes:
1. “H” indicates a HIGH input level, “L” indicates a LOW input level, and “X” indicates a Don’t Care Level.
2. #WP should be biased to CMOS HIGH or LOW for standby.
W29N04GV
Release Date: February 9th, 2017
15 Revision B
8. COMMAND TABLE
COMMAND
1ST
CYCLE
2ND
CYCLE
3rd
CYCLE
4th
CYCLE
Acceptable
during
busy
PAGE READ
00h
30h
READ for COPY BACK
00h
35h
SEQUENTIAL CACHE READ
31h
RANDOM CACHE READ
00h
31h
LAST ADDRESS CACHE READ
3Fh
READ ID
90h
READ STATUS
70h
Yes
RESET
FFh
Yes
PAGE PROGRAM
80h
10h
PROGRAM for COPY BACK
85h
10h
CACHE PROGRAM
80h
15h
BLOCK ERASE
60h
D0h
RANDOM DATA INPUT*1
85h
RANDOM DATA OUTPUT*1
05h
E0h
READ PARAMETER PAGE
ECh
READ UNIQUE ID
EDh
GET FEATURES
EEh
SET FEATURES
EFh
READ STATUS ENHANCED
78h
Yes
TWO PLANE READ PAGE
00h
00h
30h
TWO PLANE READ FOR COPY BACK
00h
00h
35h
TWO PLANE RANDOM DATA READ
06h
E0h
TWO PLANE PROGRAM(TRADITIONAL)
80h
11h
81h
10h
TWO PLANE PROGRAM(ONFI)
80h
11h
80h
10h
TWO PLANE CACHE
PROGRAM(START/CONTINUE)(TRADITIONAL)
80h
11h
81h
15h
TWO PLANE CACHE
PROGRAM(START/CONTINUE) (ONFI)
80h
11h
80h
15h
TWO PLANE CACHE
PROGRAM(END)(TRADITIONAL)
80h
11h
81h
10h
TWO PLANE CACHE PROGRAM(END)(ONFI)
80h
11h
80h
10h
TWO PLANE PROGRAM FOR COPY
BACK(TRADITIONAL)
85h
11h
81h
10h
TWO PLANE PROGRAM FOR COPY
BACK(ONFI)
85h
11h
85h
10h
W29N04GV
Release Date: February 9th, 2017
16 Revision B
TWO PLANE BLOCK ERASE(TRADITIONAL)
60h
60h
D0h
TWO PLANE BLOCK ERASE(ONFI)
60h
D1h
60h
D0h
Table 8-1 Command Table
Notes:
1. RANDOM DATA INPUT and RANDOM DATA OUTPUT command is only to be used within a page.
2. Any commands that are not in the above table are considered as undefined and are prohibited as inputs.
3. Do not cross plane address boundaries when using Copy Back Read and Program for copy back.
W29N04GV
Release Date: February 9th, 2017
17 Revision B
9. DEVICE OPERATIONS
9.1 READ operation
9.1.1 PAGE READ (00h-30h)
When the device powers on, 00h command is latched to command register. Therefore, system only
issues five address cycles and 30h command for initial read from the device. This operation can also
be entered by writing 00h command to the command register, and then write five address cycles,
followed by writing 30h command. After writing 30h command, the data is transferred from NAND
array to Data Register during tR. Data transfer progress can be done by monitoring the status of the
RY/#BY signal output. RY/#BY signal will be LOW during data transfer. Also, there is an alternate
method by using the READ STATUS (70h) command. If the READ STATUS command is issued
during read operation, the Read (00h) command must be re-issued to read out the data from Data
Register. When the data transfer is complete, RY/#BY signal goes HIGH, and the data can be read
from Data Register by toggling #RE. Read is sequential from initial column address to the end of the
page. (See Figure 9-1)
Figure 9-1 Page Read Operations
9.1.2 CACHE READ OPERATIONS
To obtain a higher degree of performance read operations, the device’s Cache and Data Register
can be used independent of each other. Data can be read out from the Cache Register, while array
data is transferred from the NAND Array to the Data Register.
The CACHE READ mode starts with issuing a PAGE READ command (00h-30h) to transfer a page
of data from NAND array to the Cache Register. RY/#BY signal will go LOW during data transfer
indicating a busy status. Copying the next page of data from the NAND array to the Data Register
while making the Cache Register page data available is done by issuing either a SEQUENTIAL
CACHE READ (31h) or RANDOM CACHE READ (00h-31h) command. The SEQUENTIAL CACHE
READ mode will copy the next page of data in sequence from the NAND array to the Data Register
or use the RANDOM CACHE READ mode (00h-31h) to copy a random page of data from NAND
array to the Data Register. The RY/#BY signal goes LOW for a period of tRCBSY during the page
data transfer from NAND array to the Data Register. When RY/#BY goes HIGH, this means that the
Address (5cycles) 30hData Output ( Serial Access )
Dont care
l/Ox
#RE
RY/#BY
ALE
#WE
#CE
CLE
00h
tR
W29N04GV
Release Date: February 9th, 2017
18 Revision B
Cache Register data is available and can be read out of the Cache Register by with toggling #RE,
which starts at address column 0. If it is desired to start at a different column address, a RANDOM
DATA OUTPUT (05h-E0h) command can be used to change the column address to read out the data.
At this point in the procedure when completing the read of the desired number of bytes, one of two
things can be chosen. Continue CACHE READ (31h or 00h-31h) operations or end the CACHE READ
mode with a LAST ADDRESS CACHE READ (3Fh) command.
To continue with the read operations, execute the CACHE READ (31h or 00h-31h) command. The
RY/#BY signal goes LOW for the period of tRCBSY while data is copied from Data Register to the
Cache Register and the next page of data starts being copied from the NAND array to the Data
Register. When RY/#BY signal goes HIGH signifying that the Cache Register data is available, at this
time #RE can start toggling to output the desired data starting at column 0 address or using the
RANDOM DATA OUPUT command for random column address access.
To terminate the CACHE READ operations a LAST ADDRESS CACHE READ (3Fh) command is
issued, RY/#BY signal goes LOW and the Data Register contents is copied to the Cache Register.
At the completion of the Data Register to Cache Register transfer, RY/#BY goes HIGH indicating data
is available at the output of the Cache Register. At this point Data can be read by toggling #RE starting
at column address 0 or using the RANDOM DATA OUPUT command for random column address
access. The device NAND array is ready for next command set.
W29N04GV
Release Date: February 9th, 2017
19 Revision B
9.1.2.1. SEQUENTIAL CACHE READ (31h)
The SEQUENTIAL CACHE READ (31h) copies the next page of data in sequence within block to the
Data Register while the previous page of data in the Cache Register is available for output. This is
done by issuing the command (31h), RY/#BY signal goes LOW and the STATUS REGISTER bits 6
and 5 = “00” for the period of tRCBSY. When RY/#BY signal goes HIGH and STATUS REGISTER
bits 6 and 5 = “10”, data at the Cache Register is available. The data can be read out from the Cache
Register by toggling #RE, starting address is column 0 or by using the RANDOM DATA OUTPUT
command for random column address access.
Figure 9-2 Sequential Cache Read Operations
9.1.2.2. RANDOM CACHE READ (00h-31h)
The RANDOM CACHE READ (00h-31h) will copy a particular page from NAND array to the Data
Register while the previous page of data is available at the Cache Register output. Perform this
function by first issuing the 00h command to the Command Register, then writing the five address
cycles for the desired page of data to the Address Register. Then write the 31h command to the
Command Register. Note; the column address bits are ignored.
After the RANDOM CACHE READ command is issued, RY/#BY signal goes LOW and STATUS
REGISTER bits 6 and 5 equal “00” for the period of tRCBSY. When RY/#BY signal goes HIGH and
STATUS REGISTER bits 6 and 5 equal “10”, the page data in the Cache Register is available. The
data can read out from the Cache Register by toggling #RE, the starting column address will be 0 or
use the RANDOM DATA OUTPUT (05h-E0h) command change the column address to start reading
out the data.
RY/#BY
ALE
CLE
#CE
#WE
#RE
I/Ox 00h30hData Output (Serial Access) Data output (Serial Access)
tR tRCBSY
tRCBSY
Address(5cycles) 31h 31h
Dont care
W29N04GV
Release Date: February 9th, 2017
20 Revision B
RY/#BY
ALE
CLE
#CE
#WE
#RE
I/Ox 00h
tR
Page L
Address(5cycles)
Page M
Address(5cycles)
tRCBSY
Page L
DataOut
Page N
Address(5cycles)
tRCBSY
Page M
DataOut
30h 00h 31h00h 31h
Dont care
Figure 9-3 Random Cache Read Operation
W29N04GV
Release Date: February 9th, 2017
21 Revision B
9.1.2.3. LAST ADDRESS CACHE READ (3Fh)
The LAST ADDRESS CACHE READ (3Fh) copies a page of data from the Data Register to the Cache
Register without starting the another cache read. After writing the 3Fh command, RY/#BY signal goes
LOW and STATUS REGISTER bits 6 and 5 equals “00” for the period of tRCBSY. When RY/#BY
signal goes HIGH and STATUS REGISTER bits 6 and 5 equals “11”, the Cache Register data is
available, and the device NAND array is in ready state. The data can read out from the Cache Register
by toggling #RE, starting at address column 0 or us RANDOM DATA OUTPUT (05h-E0h) command
to change the column address to read out the data.
Page N DataOut
DataOutput
ALE
CLE
#CE
#WE
#RE
l/Ox 31h
(Serial Access)
3Fh
tRCBSY
Page N
tRCBSY
RY/#BY
Address(5cycles)
Dont care
Figure 9-4 Last Address Cache Read Operation
9.1.3 TWO PLANE READ (00h-00h-30h)
TWO PLANE READ (00h-00h-30h) transfers two pages data from the NAND array to the data
registers. Each page address have to be indicated different plane address.
To set the TWO PLANE READ mode, write the 00h command to the command register, and then
write five address cycles for plane 0. Secondly, write the 00h command to the command register, and
five address cycles for plane 1. Finally, the 30h command is issued. The first-plane and second-plane
addresses must be identical for all of issued address except plane address.
After the 30h command is written, page data is transferred from both planes to their respective data
registers in tR. RY/#BY goes LOW While these are transfered,. When the transfers are complete,
RY/#BY goes HIGH. To read out the data, at first, system writes TWO PLANE RAMDOM DATA READ
(06h-E0h) command to select a plane, next, repeatedly pulse #RE to read out the data from selected
plane. To change the plane address, issues TWO PLANE RANDOM DATA READ (06h-E0h)
command to select the another plane address, then repeatedly pulse #RE to read out the data from
the selected plane data register.
Alternatively, data transfers can be monitored by the READ STATUS (70h). When the transfers are
complete, status register bit 6 is set to 1. To read data from the first of the two planes even when
W29N04GV
Release Date: February 9th, 2017
22 Revision B
READ STATUS ENHANCED (78h) command is used, the system must issue the TWO PLANE
RANDOM DATA READ (06h-E0h) command at first and pulse #RE repeatedly.
Write a TWO PLANE RANDOM DATA READ (06h-E0h) command to select the other plane ,after the
data cycle is complete. pulse #RE repeatedly to output the data beginning at the specified column
address,
During TWO PLANE READ operation,the READ STATUS ENHANCED (78h) command is prohibited .
Figure 9-5 Two Plane Read Page (00h-00h-30h) Operation
CLE
#WE
ALE
#RE
I/
RY/#BY
Col
Add1
Col
Add2 Row
Add1
Row
Add2
Row
Add3 30h
00h
tR
00h
Column address J Plane 1 address
Plane address M
Plane address M
Column address J Plane 0 address
1
CLE
#WE
ALE
#RE
I/ E0h
06h DOUT0DOUT1DOUTn
Selected Plane data
1
RY/#BY
Plane 0 or Plane 1 address
Address (5cycles)
Col
Add1 Col
Add2
Row
Add1
Row
Add2
Row
Add3
W29N04GV
Release Date: February 9th, 2017
23 Revision B
9.1.4 RANDOM DATA OUTPUT (05h-E0h)
The RANDOM DATA OUTPUT allows the selection of random column addresses to read out data
from a single or multiple of addresses. The use of the RANDOM DATA OUTPUT command is
available after the PAGE READ (00h-30h) sequence by writing the 05h command following by the
two cycle column address and then the E0h command. Toggling #RE will output data sequentially.
The RANDOM DATA OUTPUT command can be issued multiple times, but limited to the current
loaded page.
Figure 9-6 Random Data Output
9.1.4.1. TWO PLANE RANDOM DATA OUTPUT (06h-E0h)
TWO PLANE RANDOM DATA READ (06h-E0h) command can indicate to specified plane and
column address on cache register . This command is accepted by a device when it is ready.
Issuing 06h to the command register, two column address cycles, three row address cycles, E0h are
followed, this enables data output mode on the address device’s cache register at the specified
column address. After the E0h command , the host have to wait at least tWHR before requesting data
output. The selected device is in data output mode until another valid command is issued.
The TWO PLANE RANDOM DATA READ (06h-E0h) command is used to select the cache register
to be enabled for data output. When the data output is complete on the selected plane, the
command can be issued again to start data output on another plane.
If there is a need to update the column address without selecting a new cache register, the RANDOM
DATA READ (05h-E0h) command can be used instead.
#RE
RY/#BY
I/Ox 05hE0h
Address(2cycles)
30h
Address(5cycles)
tR
Data out Data out
00h
W29N04GV
Release Date: February 9th, 2017
24 Revision B
Figure 9-7 Two Plane Random Data Read (06h-E0h) Operation
CLE
ALE
#RE
I/ E0h
06hData Out
Data Out
#WE
#CE
Address (5cycles)
W29N04GV
Release Date: February 9th, 2017
25 Revision B
9.1.5 READ ID (90h)
READ ID command is comprised of two modes determined by the input address, device (00h) or
ONFI (20h) identification information. To enter the READ ID mode, write 90h to the Command
Register followed by a 00h address cycle, then toggle #RE for 5 single byte cycles, W29N04GV. The
pre-programmed code includes the Manufacturer ID, Device ID, and Product-Specific Information
(see Table 9.1). If the READ ID command is followed by 20h address, the output code includes 4
single byte cycles of ONFI identifying information (See Table 9.2). The device remains in the READ
ID Mode until the next valid command is issued.
#WE
CLE
#CE
ALE
#RE
I/Ox 90h00h
(or 20h)
Address 1 Cycle
tAR
tREA
tWHR
Byte0 Byte1 Byte2 Byte3 Byte4
Figure 9-8 Read ID
W29N04GV
Release Date: February 9th, 2017
26 Revision B
# of
Byte/Cycles
1st
Byte/Cycle
2nd
Byte/Cycle
3rd
Byte/Cycle
4th
Byte/Cycle
5th
Byte/Cycle
W29N04GV
EFh
DCh
90h
95h
54h
Description
MFR ID
Device ID
Cache
Programming
Supported
Page Size:2KB
Spare Area Size:64b
BLK Size w/o Spare:128KB
Organized:x8
Serial Access:25ns
Table 9-1 Device ID and configuration codes for Address 00h
# of Byte/Cycles
1st
Byte/Cycle
2nd
Byte/Cycle
3rd
Byte/Cycle
4th
Byte/Cycle
Code
4Fh
4Eh
46h
49h
Table 9-2 ONFI identifying codes for Address 20h
9.1.6 READ PARAMETER PAGE (ECh)
READ PARAMETER PAGE can read out the device’s parameter data structure, such as,
manufacturer information, device organization, timing parameters, key features, and other pertinent
device parameters. The data structure is stored with at least three copies in the device’s parameter
page. Figure 9-9 shows the READ PARAMETER PAGE timing. The RANDOM DATA OUTPUT (05h-
E0h) command is supported during data output.
I/Ox
CLE
#WE
ALE
#RE
RY/#BY
ECh P00
00h
tR
・・・
P10P01P11・・・
Figure 9-9 Read Parameter Page
W29N04GV
Release Date: February 9th, 2017
27 Revision B
Byte
Description
Value
0-3
Parameter page signature
4Fh, 4Eh, 46h, 49h
4-5
Revision number
02h, 00h
6-7
Features supported
18h,00h
8-9
Optional commands supported
3Fh,00h
10-31
Reserved
00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h,
00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h
32-43
Device manufacturer
57h, 49h, 4Eh, 42h, 4Fh, 4Eh, 44h, 20h, 20h, 20h, 20h,
20h
44-63
Device model
W29N04GV
57h,32h,39h,4Eh,30h,34h,47h,56h,20h,20h,20h,20h,
20h,20h,20h,20h,20h,20h,20h,20h
64
Manufacturer ID
EFh
65-66
Date code
00h, 00h
67-79
Reserved
00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h,
00h, 00h
80-83
# of data bytes per page
00h, 08h, 00h, 00h
84-85
# of spare bytes per page
40h, 00h
86-89
# of data bytes per partial page
00h, 02h, 00h, 00h
90-91
# of spare bytes per partial page
10h, 00h
92-95
# of pages per block
40h, 00h, 00h, 00h
96-99
# of blocks per unit
00h, 10h, 00h, 00h
100
# of logical units
01h
101
# of address cycles
23h
102
# of bits per cell
01h
103-104
Bad blocks maximum per unit
50h, 00h
105-106
Block endurance
01h, 05h
107
Guaranteed valid blocks at beginning
of target
01h
108-109
Block endurance for guaranteed valid
blocks
00h, 00h
110
# of programs per page
04h
111
Partial programming attributes
00h
112
# of ECC bits
01h
113
# of interleaved address bits
01h
114
Interleaved operation attributes
0Ch
115-127
Reserved
00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h,
00h, 00h
W29N04GV
Release Date: February 9th, 2017
28 Revision B
Byte
Description
Value
128
I/O pin capacitance
0Ah
129-130
Timing mode support
1Fh, 00h
131-132
Program cache timing
1Fh, 00h
133-134
Maximum page program time
BCh, 02h
135-136
Maximum block erase time
10h, 27h
137-138
Maximum random read time
19h, 00h
139-140
tCCS minimum
46h, 00h
141-163
Reserved
00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h,
00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h, 00h,
00h
164-165
Vendor specific revision #
01h,00h
166-253
Vendor specific
00h
254-255
Integrity CRC
Set at shipment
256-511
Value of bytes 0-255
512-767
Value of bytes 0-255
>767
Additional redundant parameter pages
Table 9-3 Parameter Page Output Value
9.1.7 READ STATUS (70h)
The W29N04GV has an 8-bit Status Register which can be read during device operation. Refer to
Table 9.4 for specific Status Register definitions. After writing 70h command to the Command
Register, read cycles will only read from the Status Register. The status can be read from I/O[7:0]
outputs, as long as #CE and #RE are LOW. Note; #RE does not need to be toggled for Status Register
read. The Command Register remains in status read mode until another command is issued. To
change to normal read mode, issue the PAGE READ (00h) command. After the PAGE READ
command is issued, data output starts from the initial column address.
W29N04GV
Release Date: February 9th, 2017
29 Revision B
Figure 9-10 Read Status Operation
SR bit
Page Read
Cache Read
Page Program
Cache
Program
Block Erase
Definition
I/O 0
Not Use
Not Use
Pass/Fail
Pass/Fail(N)
Pass/Fail
0=Successful
Program/Erase
1=Error
in Program/Erase
I/O 1
Not Use
Not Use
Not Use
Pass/Fail(N-1)
Not Use
0=Successful
Program
1=Error in Program
I/O 2
Not Use
Not Use
Not Use
Not Use
Not Use
0
I/O 3
Not Use
Not Use
Not Use
Not Use
Not Use
0
I/O 4
Not Use
Not Use
Not Use
Not Use
Not Use
0
I/O 5
Ready/Busy
Ready/Busy1
Ready/Busy
Ready/Busy
Ready/Busy
Ready = 1
Busy = 0
I/O 6
Ready/Busy
Cache
Ready/Busy2
Ready/Busy
Cache
Ready/Busy
Ready/Busy
Ready = 1
Busy = 0
I/O 7
Write Protect
Write Protect
Write Protect
Write Protect
Write Protect
Unprotected = 1
Protected = 0
Table 9-4 Status Register Bit Definition
Notes:
1. SR bit 5 is 0 during the actual programming operation. If cache mode is used, this bit will be 1 when all
internal operations are complete.
2. SR bit 6 is 1 when the Cache Register is ready to accept new data. RY/#BY follows bit 6.
#CE
CLE
#WE
#RE
tCLR
I/Ox 70hStatus Output
tREA
W29N04GV
Release Date: February 9th, 2017
30 Revision B
9.1.8 READ STATUS ENHANCED (78h)
The READ STATUS ENHANCED (78h) command returns the status of the addressed plane on a
target even when it is busy (SR BIT 6 = 0).
Writing 78h to the command register, followed by three row address cycles containing the page, plane
and block addresses that is same as executed addresses, puts the device into read status mode. The
device stays in this mode until another valid command is issued
The device status is returned when the host requests data output. The SR BIT 6 and SR bit 5 bits of
the status register are shared for all planes on the device. The SR BIT 1 and SR BIT 0 (SR bit0) bits
are specific to the plane specified in the row address.
The READ STATUS ENHANCED (78h) command also enables the device for data output. To begin
data output following a READ operation after the device is ready (SR BIT 6 = 1), issue the READ
MODE (00h) command, then begin data output. If the host needs to change the cache register that
will output data, use the TWO PLANE RANDOMDATA READ (06h-E0h) command after the device
is ready
Use of the READ STATUS ENHANCED (78h) command is prohibited when OTP mode is enabled. It
is also prohibited following some of the other reset, identification.
Figure 9-11 Read Status Enhanced (78h) Operation
CLE
ALE
#RE
I/ Status Output
78h
#WE
#CE
Address (3cycles)
W29N04GV
Release Date: February 9th, 2017
31 Revision B
9.1.9 READ UNIQUE ID (EDh)
The W29N04GV NAND Flash device has a method to uniquely identify each NAND Flash device by
using the READ UNIQUE ID command. The format of the ID is limitless, but the ID for every NAND
Flash device manufactured, will be guaranteed to be unique.
Numerous NAND controllers typically use proprietary error correction code (ECC) schemes. In these
cases Winbond cannot protect unique ID data with factory programmed ECC. However, to ensure
data reliability, Winbond will program the NAND Flash devices with 16 bytes of unique ID code,
starting at byte 0 on the page, immediately followed by 16 bytes of the complement of that unique ID.
The combination of these two actions is then repeated 16 times. This means the final copy of the
unique ID will resides at location byte 511. At this point an XOR or exclusive operation can be
performed on the first copy of the unique ID and its complement. If the unique ID is good, the results
should yield all the bits as 1s. In the event that any of the bits are 0 after the XOR operation, the
procedure can be repeated on a subsequent copy of the unique ID data.
Figure 9-12 Read Unique ID
I/Ox
CLE
#WE
ALE
#RE
RY/#BY
EDh
Unique ID data
tR
Byte0 Byte1 Byte14 Byte15
00h
W29N04GV
Release Date: February 9th, 2017
32 Revision B
9.2 PROGRAM operation
9.2.1 PAGE PROGRAM (80h-10h)
The W29N04GV Page Program command will program pages sequentially within a block, from the
lower order page address to higher order page address. Programming pages out of sequence is
prohibited. The W29N04GV supports partial-page programming operations up to 4 times before an
erase is required if partitioning a page. Note; programming a single bit more than once without first
erasing it is not supported.
9.2.2 SERIAL DATA INPUT (80h)
Page Program operation starts with the execution of the Serial Data Input command (80h) to the
Command Register, following next by inputting five address cycles and then the data is loaded. Serial
data is loaded to Cache Register with each #WE cycle. The Program command (10h) is written to the
Command Register after the serial data input is finished. At this time the internal write state controller
automatically executes the algorithms for program and verifies operations. Once the programming
starts, determining the completion of the program process can be done by monitoring the RY/#BY
output or the Status Register Bit 6, which will follow the RY/#BY signal. RY/#BY will stay LOW during
the internal array programming operation during the period of (tPROG). During page program
operation, only two commands are available, READ STATUS (70h) and RESET (FFh). When the
device status goes to the ready state, Status Register Bit 0 (I/O0) indicates whether the program
operation passed (Bit0=0) or failed (Bit0=1), (see Figure 9-13). The Command Register remains in
read status mode until the next command is issued.
Figure 9-13 Page Program
tPROG
Address (5cycles)
RY/#BY
I/Ox Din80h10h70hStatus
I/O0 =0 pass
I/O0 =1 fail
W29N04GV
Release Date: February 9th, 2017
33 Revision B
9.2.3 RANDOM DATA INPUT (85h)
After the Page Program (80h) execution of the initial data has been loaded into the Cache Register,
if the need for additional writing of data is required, using the RANDOM DATA INPUT (85h) command
can perform this function to a new column address prior to the Program (10h) command. The
RANDOM DATA INPUT command can be issued multiple times in the same page (See Figure 9-14).
Figure 9-14 Random Data Input
9.2.4 CACHE PROGRAM (80h-15h)
CACHE PROGEAM (80h) command is started by writing the command to the Command Register.
The next writes should be five cycles of address, and then either writing a full or partial page of input
data into the Cache Register. Issuing the CACHE PROGRAM (15h) command to the Command
Register, starting transferring data from the Cache Register to the Data Register on the rising edge
of #WE and RY/#BY will go LOW. Programming to the array starts after the data has been copied
into the Data Register and RY/#BY returns to HIGH.
When RY/#BY returns to HIGH, the next input data can be written to the Cache Register by issuing
another CACHE PROGRAM command series. The time RY/#BY goes LOW, is typical controlled by
the actual programming time. The time for the first programming pass equals the time it takes to
transfer the data from the Cache Register to the Data Register. On the second and subsequent
programming passes, data transfer from the Cache Register to the Data Register is held until Data
Register content is programming into the NAND array.
The CACHE PROGRAM command can cross block address boundaries. RANDOM DATA INPUT
(85h) commands are permitted with CACHE PROGRAM operations. Status Register’s Cache
RY/#BY (Bit 6 or I/O6) can be read after issuing the READ STATUS (70h) command for confirming
when the Cache Register is ready or busy. RY/#BY, always follows Status Register Bit 6 (I/O6). Status
Register’s RY/#BY Bit 5 (I/O5) can be polled to determine whether the array programming is in
progress or completed for the current programming cycle.
RY/#BY
I/Ox
#WE
ALE
#RE
#CE
Din 70h Status
Address (5cycles)
80h10h
Address
(2cycles)
85hDin
tPROG
Dont care
CLE
W29N04GV
Release Date: February 9th, 2017
34 Revision B
If only RY/#BY is used for detecting programming status, the last page of the program sequence must
use the PAGE PROGRAM (10h) command instead of the CACHE PROGRAM (15h) command. If the
CACHE PROGRAM (15h) command is used every time, including the last page programming, Status
Register’s Bit 5 (I/O5) must be used to determine when programming is complete.
Status Register’s Pass/Fail, Bit 1 (I/O1) returns the pass/fail status for the previous page when Status
Register’s Bit 6 (I/O6) equals a “1” (ready state). The pass/fail status of the current PROGRAM
operation is returned with Status Register’s Bit 0 (I/O0) when Bit 5 (I/O5) of the Status Register equals
a “1” (ready state) as shown in Figure 9-15 and 9-16.
Note: The CACHE PROGRAM command cannot be used on blocks 0-3 if used as boot blocks.
Figure 9-15 Cache Program Start
Figure 9-16 Cache Program End
RY/#BY
I/Ox
tCBSY
CLE
#WE
ALE
#RE
#CE
Address&Data Input
80h 15h Address& Data Input
80h 15h
tCBSY
Address&Data Input
80h 10h
tLPROG
70h Status
Dont care
RY/#BY
I/Ox
tCBSY
CLE
#WE
ALE
#RE
#CE
Address&Data Input
80h15hAddress& Data Input
80h15h
tCBSY
Address&Data Input
80h 15h
tLPROG
Dont care
W29N04GV
Release Date: February 9th, 2017
35 Revision B
9.2.5 TWO PLANE PAGE PROGRAM
TWO PLANE PAGE PROGRAM command make it possible for host to input data to the addressed
plane's cache register and queue the cache register to be moved to the NAND Flash array.
This command can be issued several times. Each time a new plane address is specified that plane
is also queued for data transfer. To input data for the final plane and to begin the program operation
for all previously queued planes, either the PAGE PROGRAM command or the CACHE PROGRAM
command have to be issued. All of the queued planes will move the data to the NAND Flash array.
When it is ready (SR BIT 6 = 1), this command is accepted.
At the block and page address is specified, input a page to the cache register and queue it to be
moved to the NAND Flash array, the 80h is issued to the command register. Unless this command
has been preceded by a TWO PLANE PAGE PROGRAM command, issuing the 80h to the command
register clears all of the cache registers' contents on the selected target. Write five address cycles
containing the column address and row address; data input cycles follow. Serial data is input
beginning at the column address specified. At any time, while the data input cycle, the RANDOM
DATA INPUT (85h) command can be issued. When data input is complete, write 11h to the command
register. The device will go busy (SR BIT 6 = 0, SR BIT 5 = 0) for tDBSY.
To ascertain the progress of tDBSY, the host can monitor the target's RY/#BY signal or, the status
operations (70h, 78h) can be used alternatively. When the device status shows that it is ready (SR
BIT 6 = 1), additional TWO PLANE PAGE PROGRAM commands can be issued to queue additional
planes for data transfer, then, the PAGE PROGRAM or CACHE PROGRAM commands can be
issued.
When the PAGE PROGRAM command is used as the final command of a two plane program
operation, data is transferred from the cache registers to the NAND Flash array for all of the
addressed planes during tPROG. When the device is ready (SR BIT 6 = 1, SR BIT 5 = 1), the host
should check the status of the SR BIT 0 for each of the planes to verify that programming completed
successfully.
When the CACHE PROGRAM command is used as the final command of a program cache two plane
operation, data is transferred from the cache registers to the data registers after the previous array
operations completed. Then, the data is moved from the data registers to the NAND Flash array for
all of the addressed planes. This occurs while tCBSY. After tCBSY, the host should check the status
of the SR BIT 1 for each of the planes from the previous program cache operation, if any, to verify
that programming completed successfully.
When system issues TWO PLANE PAGE PROGRAM, PAGE PROGRAM, and CACHE PROGRAM
commands, READ STATUS (70h) command can confirm whether the operation(s) passed or failed.
If the status after READ STATUS (70h) command indicates an error (SR BIT 0 = 1 and/or SR BIT 1
= 1), READ STATUS ENHANCED (78h) command can be determined which plane is failed.
TWO PLANE PROGRAM commands require five-cycle addresses, one address indicates the
operational plane. These addresses are subject to the following requirements:
The column address bits must be valid address for each plane
The plane select bit, A18, must be set to “L” for 1st address input, and set to “H” for 2nd address input.
The page address (A17-A12) and block address (A29-A19) of first input are dont care. It follows
secondary inputted page address and block address.
Two plane operations must be same type operation across the planes; for example, it is not possible
to perform a PROGRAM operation on one plane with an ERASE operation on another.
W29N04GV
Release Date: February 9th, 2017
36 Revision B
Figure 9-17 Two Plane Page Program
RY/#BY
Data
Input
FirstPlane
(1024 block)
Block 0
Block 2
:
Block 4092
Block 4094
Second Plane
(1024 block)
Block 1
Block 3
:
Block 4093
Block 4095
80h
Page program
Setup code
A0-A11=Valid
A12-A17=set to `Low`
A18=set to `Low`
A19-A29=set to `Low`
Confirm
Code
Multiplane Page
Program setup
code
A0-A11=Valid
A12-A17=Valid
A18=set to `High`
A19-A29=Valid
Confirm
Code
Read Status
Register
11h81h10h70hSR0
1)The same row address, except for A18, is applied to the two blocks.
2)Any command between 11h and 81h is prohibited except 70h,78h,and FFh
tDBSY tPROG
(Program busy time)
Busy Busy
Address Inputs Data Input Data Input
Address Inputs
l/Ox
80h11h81h10h
81h:Traditional Protocol 80h:ONFI Protocol
W29N04GV
Release Date: February 9th, 2017
37 Revision B
Figure 9-18 Two Plane Cache Program
CLE
80hDin
N
Din
M11h
#CE
#WE
ALE
#RE
I/ Din
N
Din
M15h
tWC tADL tADL
81h
RY/#BY tDBSY tCBSY
A0 A11 = Valid
A12 A17 = dont care
A18 = Low
A19 A29 = dont care
A0 A11 = Valid
A12 A17 = Valid
A18 = set to High
A19 A29 = Valid
Return to A Can be repeated up
to 63times
A
CLE
80hDin
N
Din
M11h
#CE
#WE
ALE
#RE
I/ Din
N
Din
M
tADL
RY/#BY
tDBSY tPROG
1.In this figure the Read Status Register (70h) is used ,but the Read Status Enhanced (78h) can be used as well.
tADL
tWHBL
A
81h: Traditional Protocol 80h:ONFI Protocol
A0 A11 = Valid
A12 A17 = dont care
A18 = Low
A19 A29 = dont care
A0 A11 = Valid
A12 A17 = Valid
A18 = set to High
A19 A29 = Valid
81h10h70hSR0
Address (5cycles) Address (5cycles)
Address (5cycles) Address (5cycles)
W29N04GV
Release Date: February 9th, 2017
38 Revision B
9.3 COPY BACK operation
Copy Back operations require two command sets. Issue a READ for COPY BACK (00h-35h)
command first, then the PROGRAM for COPY BACK (85h-10h) command. Copy back operations are
only supported within a same plane.
9.3.1 READ for COPY BACK (00h-35h)
The READ for COPY BACK command is used together with the PROGRAM for COPY BACK (85h-
10h) command. To start execution, READ for COPY BACK (00h) command is written to the Command
Register, followed by the five cycles of the source page address. To start the transfer of the selected
page data from the memory array to the Cache Register, write the 35h command to the Command
Register.
After execution of the READ for COPY BACK command sequence and RY/#BY returns to HIGH
marking the completion of the operation, the transferred data from the source page into the Cache
Register may be read out by toggling #RE. Data is output sequentially from the column address that
was originally specified with the READ for COPY BACK command. RANDOM DATA OUTPUT (05h-
E0h) commands can be issued multiple times without any limitation after READ for COPY BACK
command has been executed (see Figures 9-19 and 9-20).
At this point the device is in ready state to accept the PROGRAM for COPY BACK command.
9.3.2 PROGRAM for COPY BACK (85h-10h)
After the READ for COPY BACK command operation has been completed and RY/#BY goes HIGH,
the PROGRAM for COPY BACK command can be written to the Command Register. The command
results in the transfer of data from the Cache Register to the Data Register, then internal operations
start programming of the new destination page. The sequence would be, write 85h to the Command
Register, followed by the five cycle destination page address to the NAND array. Next write the 10h
command to the Command Register; this will signal the internal controller to automatically start to
program the data to new destination page. During this programming time, RY/#BY will LOW. The
READ STATUS command can be used instead of the RY/#BY signal to determine when the program
is complete. When Status Register Bit 6 (I/O6) equals to “1”, Status Register Bit 0 (I/O0) will indicate
if the operation was successful or not.
The RANDOM DATA INPUT (85h) command can be used during the PROGRAM for COPY BACK
command for modifying the original data. Once the data is copied into the Cache Register using the
READ for COPY BACK (00h-35h) command, follow by writing the RANDOM DATA INPUT (85h)
command, along with the address of the data to be changed. The data to be changed is placed on
the external data pins. This operation copies the data into the Cache Register. Once the 10h
command is written to the Command Register, the original data and the modified data are transferred
to the Data Register, and programming of the new page commences. The RANDOM DATA INPUT
command can be issued numerous times without limitation, as necessary before starting the
programming sequence with 10h command.
Since COPY BACK operations do not use external memory and the data of source page might include
a bit errors, a competent ECC scheme should be developed to check the data before programming
data to a new destination page.
W29N04GV
Release Date: February 9th, 2017
39 Revision B
9.3.3 TWO PLANE READ for COPY BACK
To improve read through rate, TWO PLANE READ for COPY BACK operation is copied data
concurrently from one or two plane to the specified cache registers.
TWO PLANE PROGRAM for COPY BACK command can move the data in two pages from the cache
registers to different pages. This operation improves system performance than PROGRAM for COPY
BACK operation.
9.3.4 TWO PLANE PROGRAM for COPY BACK
Function of TWO PLANE PROGRAM for COPY BACK command is equal to TWO-PLANE PAGE
PROGRAM command, except that when 85h is written to the command register, then cache register
contents are not cleared. Refer to TWO-PLANE PAGE PROGRAM for more details features.
W29N04GV
Release Date: February 9th, 2017
40 Revision B
Optional No limitation
RY/#BY
I/Ox
tR
CLE
#WE
ALE
#RE
#CE
00h 35h 85h 10h
tPROG
70h
Status
Output
Address(5cycles)
DataOutput
Address
(2cycles)
85h
Dont care
Address(5Cycles) Data Input Data Input
Figure 9-19 Program for copy back Operation
Figure 9-20 Copy Back Operation with Random Data Input
Optional
Data output
No limitation
RY / # BY
I/ Ox
tR tPROG
CLE
#WE
ALE
#RE
#CE
Data Output
00hAddress (5cycles) 35h05hAddress
(2cycles) E0h 85hAddress(5cycles) 10h70hStatus
Output
Dont care
W29N04GV
Release Date: February 9th, 2017
41 Revision B
RY/#BY
I/O× 00h Address(5cycles)
Plane 0 source
00h Address(5cycles)
Plane 1 source
35h
tR
RY/#BY
I/O×
1
85h Address(5cycles)
Plane 0 destination
11h
tDBSY
06h Address(5cycles)
Plane 0 or Plane 1 source address
E0h
#RE
Data Output 06h Address(2cycles)
Data from selected Plane Selected Plane
column address
E0h
#RE
Data Output
Data from selected plane
From new column address
85h Address(5cycles) 10h 70h Status
Plane 1 destination
2
2
RY/#BY
#RE
I/O×
Optional
tPROG
1
Figure 9-21 Two Plane Copy Back
Figure 9-22 Two Plane Copy Back with Random Data Input
00h
I/ Address(5cycles)
Plane 0 source
00hAddress(5cycles)
Plane 1 source
35h
tR
1
tDBSY
data
Plane 0 destination optional
Unlimited number
of repetitions
85hAddress(5cycles) 10h70hStatus
Plane 1 destination
1
RY/#BY
I/
85hData 11h
tPROG
85h
RY/#BY
Address(5cycles) Address(2cycles)
W29N04GV
Release Date: February 9th, 2017
42 Revision B
Figure 9-23 Two Plane Program for copy back
RY/#BY
tR tDBSY
Busy Busy Busy Busy
tPROG
tR
00h35h00h35h35hAddress
(5 cycles) 10h70hSR0
Col Add.1,2
Row Add.1,2,3
Row Add1,2,3
Col Add1,2
Source address on Plane0 Source address on Plane1
Col Add1,2
Row Add.1,2,3
A0 - A11 = set to `Low
A12-A17 = Valid
A18 = set to `High
A19-A29 = Valid
Read
code
Read
code
Copy back
code
Copy back
code Read Status Register
85h11h
Col Add.1,2
Source address on Plane1
Row Add 2,3
Destination address on Plane0
l/O Address
(5 cycles)
Address
(5 cycles)
Address
(5 cycles) 85h
Spare area
SourcePage
TargetPage
Main area
First plane
SourcePage
TargetPage
Main area Spare area
Second plane
(1):Read for copy back on first plane
(2):Read for copy back on second plane
(3):Two-plane copy back program
(1) (3) (2) (3)
85h:ONFI Protocol
81h:Traditional Protocol
A0 - A11 = dont care
A12-A17 = dont care
A18 = set to `Low
A19- A29 = dont care
Single plane copy back read can be used to two plane operation.
W29N04GV
Release Date: February 9th, 2017
43 Revision B
9.4 BLOCK ERASE operation
9.4.1 BLOCK ERASE (60h-D0h)
Erase operations happen at the architectural block unit. This W29N04GV has 2048 erase blocks.
Each block is organized into 64 pages (x8:2112 bytes/page), 132K bytes (x8:128K + 4K bytes)/block.
The BLOCK ERASE command operates on a block by block basis.
Erase Setup command (60h) is written to the Command Register. Next, the three cycle block address
is written to the device. The page address bits are loaded during address block address cycle, but
are ignored. The Erase Confirm command (D0h) is written to the Command Register at the rising
edge of #WE, RY/#BY goes LOW and the internal controller automatically handles the block erase
sequence of operation. RY/#BY goes LOW during Block Erase internal operations for a period of
tBERS,
The READ STATUS (70h) command can be used for confirm block erase status. When Status
Register Bit6 (I/O6) becomes to “1”, block erase operation is finished. Status Register Bit0 (I/O0) will
indicate a pass/fail condition (see Figure 9-24).
CLE
#WE
ALE
RY/#BY
#CE
#RE
I/Ox
tBERS
I/ O 0 =0 pass
I/ O 0 =1 fail
Address Input (3cycles)
60hD0h Status Output
70h
Dont care
Figure 9-24 Block Erase Operation
W29N04GV
Release Date: February 9th, 2017
44 Revision B
9.4.2 TWO PLANE BLOCK ERASE
TWO PLANE BLOCK ERASE (60h-D1h) command indicates two blocks in the specified plane that is
to be erased. To start ERASE operation for indicated blocks in the specified plane, write the BLOCK
ERASE (60h-D0h) command.
To indicate a block to be erased, writing 60h to the command register, then, write three address cycles
containing the row address, the page address is ignored. By writing D1h command to command
register, the device will go busy (SR BIT 6 = 0, SR BIT 5 = 0) for tDBSY.
To confirm busy status during tDBSY, the host can monitor RY/#BY signal. Instead, system can use
READ STATUS (70h) or READ STATUS ENHANCED (78h) commands. When the status shows
ready (SR BIT 6 = 1, SR BIT 5 = 1), additional TWO PLANE BLOCK ERASE commands can be
issued for erasing two blocks in a specified plane.
When system issues TWO PLANE BLOCK ERASE (60h-D1h), and BLOCK ERASE (60h-D0h)
commands, READ STATUS (70h) command can confirm whether the operation(s) passed or failed.
If the status after READ STATUS (70h) command indicates an error (SR BIT 0 = 1), READ STATUS
ENHANCED (78h) command can be determined which plane is failed.
TWO PLANE BLOCK ERASE commands require three cycles of row addresses; one address
indicates the operational plane. These addresses are subject to the following requirements:
The plane select bit, A18, must be set to “L” for 1st address input, and set to “H” for 2nd address input.
The block address (A29-A19) of first address input is dont care. It follows secondary inputted block
address.
Two plane operations must be same type operation across the planes; for example, it is not possible
to perform a PROGRAM operation on one plane with an ERASE operation on another.
Figure 9-25 Two Plane Block Erase Operation
RY/#BY
CLE
#WE
ALE
#RE
I/Ox
Busy
R1A R2A R3A 60hR1B R2B D0h
D1h R3B
tBERS
Busy
tDBSY
#CE
60h
Dont care
A17-A12 = don’t care
A18 = set to Low
A29-A19 = dont care
A17-A12 = dont care
A18 = set to High
A29-A19 = Valid
W29N04GV
Release Date: February 9th, 2017
45 Revision B
9.5 RESET operation
9.5.1 RESET (FFh)
READ, PROGRAM, and ERASE commands can be aborted by the RESET (FFh) command during
the time the W29N04GV is in the busy state. The Reset operation puts the device into known status.
The data that is processed in either the programming or erasing operations are no longer valid. This
means the data can be partially programmed or erased and therefore data is invalid. The Command
Register is cleared and is ready to accept next command. The Data Register and Cache Register
contents are marked invalid.
The Status Register indicates a value of E0h when #WP is HIGH; otherwise a value of 60h is written
when #WP is LOW. After RESET command is written to the command register, RY/#BY goes LOW
for a period of tRST (see Figure 9-26).
CLE
#WE
RY/#BY
#CE
I/Ox
RESET
command
tRST
tWB
FFh
Figure 9-26 Reset Operation
W29N04GV
Release Date: February 9th, 2017
46 Revision B
9.6 FEATURE OPERATION
The GET FEATURES (EEh) and SET FEATURES (EFh) commands are used to change the NAND
Flash device behavior from the default power on settings. These commands use a one-byte feature
address to determine which feature is to be read or modified. A range of 0 to 255 defines all features;
each is described in the features table (see Table 9.5 thru 9.7). The GET FEATURES (EEh) command
reads 4-Byte parameter in the features table (See GET FEATURES function). The SET FEATURES
(EFh) command places the 4-Byte parameter in the features table (See SET FEATURES function).
When a feature is set, meaning it remains active by default until the device is powered off. The set
feature remains the set even if a RESET (FFh) command is issued.
Feature address
Description
00h
N.A
02h-7Fh
Reserved
80h
Vendor specific parameter : Programmable I/O drive strength
81h
Vendor specific parameter : Programmable RY/#BY pull-down strength
82h-FFh
Reserved
Table 9-5 Features
W29N04GV
Release Date: February 9th, 2017
47 Revision B
Feature Address 80h: Programmable I/O Drive Strength
Sub feature
parameter
Options
I/O7
I/O6
I/O5
I/O4
I/O3
I/O2
I/O1
I/O0
Value
Notes
P1
I/O
drive strength
Full (default)
Reserved (0)
0
0
00h
1
Three-quarters
Reserved (0)
0
1
01h
One-half
Reserved (0)
1
0
02h
One-quarter
Reserved (0)
1
1
03h
P2
Reserved (0)
00h
P3
Reserved (0)
00h
P4
Reserved (0)
00h
Table 9-6 Feature Address 80h
Note:
1. The default drive strength setting is Full strength. The Programmable I/O Drive Strength mode is used to
change from the default I/O drive strength. Drive strength should be selected based on expected loading of
the memory bus. This table shows the four supported output drive-strength settings. The device returns to
the default drive strength mode when a power cycle has occurred. AC timing parameters may need to be
relaxed if I/O drive strength is not set to full.
W29N04GV
Release Date: February 9th, 2017
48 Revision B
Feature Address 81h: Programmable RY/#BY Pull-down Strength
Sub feature
parameter
Options
I/O7
I/O6
I/O5
I/O4
I/O3
I/O2
I/O1
I/O0
Value
Notes
P1
RY/#BY
pull-down
strength
Full (default)
Reserved (0)
0
0
00h
1
Three-quarters
Reserved (0)
0
1
01h
One-half
Reserved (0)
1
0
02h
One-quarter
Reserved (0)
1
1
03h
P2
Reserved (0)
00h
P3
Reserved (0)
00h
P4
Reserved (0)
00h
Table 9-7 Feature Address 81h
Note:
1. The default programmable RY/#BY pull-down strength is set to Full strength. The pull-down strength is used
to change the RY/#BY pull-down strength. RY/#BY pull-down strength should be selected based on expected
loading of RY/#BY. The four supported pull-down strength settings are shown. The device returns to the
default pull-down strength when a power cycle has occurred.
W29N04GV
Release Date: February 9th, 2017
49 Revision B
9.6.1 GET FEATURES (EEh)
The GET FEATURES command returns the device feature settings including those previously set by
the SET FEATURES command. To use the Get Feature mode write the command (EEh) to the
Command Register followed by the single cycle byte Feature Address. RY/#BY will goes LOW for the
period of tFEAT. If Read Status (70h) command is issued for monitoring the process completion
status, Read Command (00h) has to be executed to re-establish data output mode. Once, RY/#BY
goes HIGH, the device feature settings can be read by toggling #RE. The device remains in Feature
Mode until another valid command is issued to Command Register. See Figure 9-27.
I/Ox
CLE
#WE
ALE
#RE
RY/#BY
FA
Feature address
1 cycle
#CE
EEh
tFEAT
P1 P2 P4P3
Figure 9-27 Get Feature Operation
W29N04GV
Release Date: February 9th, 2017
50 Revision B
9.6.2 SET FEATURES (EFh)
The SET FEATURES command sets the behavior parameters by selecting a specified feature
address. To change device behavioral parameters, execute Set Feature command by writing EFh to
the Command Register, followed by the single cycle feature address. Each feature parameter (P1-
P4) is latched at the rising edge of each #WE. The RY/#BY signal will go LOW during the period of
tFEAT while the four feature parameters are stored. The Read Status (70h) command can be issued
for monitoring the progress status of this operation. The parameters are stored in device until the
device goes through a power on cycle. The device remains in feature mode until another valid
command is issued to Command Register.
I/Ox
CLE
#WE
ALE
#RE
RY/#BY
FA
#CE
EFh
tFEAT
P1 P2 P4P3
tWB
tADL
Figure 9-28 Set Feature Operation
W29N04GV
Release Date: February 9th, 2017
51 Revision B
9.7 ONE TIME PROGRAMMABLE (OTP) area
The device has One-Time Programmable (OTP) memory area comprised of a number of pages (2112
bytes/page) (1056words/page). This entire range of pages is functionally guaranteed. Only the OTP
commands can access the OTP area. When the device ships from Winbond, the OTP area is in an
erase state (all bits equal “1”). The OTP area cannot be erased, therefore protecting the area only
prevent further programming. Contact to Winbond for using this feature.
W29N04GV
Release Date: February 9th, 2017
52 Revision B
9.8 WRITE PROTECT
#WP pin can enable or disable program and erase commands preventing or allowing program and
erase operations. Figure 9-29 to 9-34 shows the enabling or disabling timing with #WP setup time
(tWW) that is from rising or falling edge of #WP to latch the first commands. After first command is
latched, #WP pin must not toggle until the command operation is complete and the device is in the
ready state. (Status Register Bit5 (I/O5) equal 1)
I /Ox
#WE
#WP
tWW
RY/#BY
60h D0h
Figure 9-29 Erase Enable
I/Ox
#WE
#WP
tWW
RY/#BY
60hD0h
Figure 9-30 Erase Disable
I/Ox
#WE
#WP
tWW
RY/#BY
10 h
( or 15h)
80 h
Figure 9-31 Program Enable
W29N04GV
Release Date: February 9th, 2017
53 Revision B
I/Ox
#WE
#WP
80 h
tWW
RY/#BY
10 h
( or 15h)
Figure 9-32 Program Disable
I/Ox
#WE
#WP
85h
tWW
RY/#BY
10h
Figure 9-33 Program for Copy Back Enable
I/Ox
#WE
#WP
85h
tWW
RY/#BY
10 h
Figure 9-34 Program for Copy Back Disable
W29N04GV
Release Date: February 9th, 2017
54 Revision B
9.9 BLOCK LOCK
The device has block lock feature that can protect the entire device or user can indicate a ranges of
blocks from program and erase operations. Using this feature offers increased functionality and
flexibility data protection to prevent unexpected program and erase operations. Contact to Winbond
for using this feature.
W29N04GV
Release Date: February 9th, 2017
55 Revision B
10. ELECTRICAL CHARACTERISTICS
10.1 Absolute Maximum Ratings (3.3V)
PARAMETERS
SYMBOL
CONDITIONS
RANGE
UNIT
Supply Voltage
VCC
0.6 to +4.6
V
Voltage Applied to Any Pin
VIN
Relative to Ground
0.6 to +4.6
V
Storage Temperature
TSTG
65 to +150
°C
Short circuit output current, I/Os
5
mA
Table 10-1 Absolute Maximum Ratings
Notes:
1. Minimum DC voltage is -0.6V on input/output pins. During transitions, this level may undershoot to -2.0V for
periods <30ns.
2. Maximum DC voltage on input/output pins is Vcc+0.3V which, during transitions, may overshoot to Vcc+2.0V
for periods <20ns.
3. This device has been designed and tested for the specified operation ranges. Proper operation outside of
these levels is not guaranteed. Exposure to absolute maximum ratings may affect device reliability.
Exposure beyond absolute maximum ratings may cause permanent damage.
10.2 Operating Ranges (3.3V)
PARAMETER
SYMBOL
CONDITIONS
SPEC
UNIT
MIN
MAX
Supply Voltage
VCC
2.7
3.6
V
Ambient Temperature,
Operating
TA
Industrial
-40
+85
°C
Table 10-2 Operating Ranges
W29N04GV
Release Date: February 9th, 2017
56 Revision B
10.3 Device power-up timing
The device is designed to avoid unexpected program/erase operations during power transitions.
When the device is powered on, an internal voltage detector disables all functions whenever Vcc is
below about 2V at 3V device. Write Protect (#WP) pin provides hardware protection and is
recommended to be kept at VIL during power up and power down. A recovery time of minimum 1ms
is required before internal circuit gets ready for any command sequences (See Figure 10-1).
Figure 10-1 Power ON/OFF sequence
5 ms (Max)
Vcc
RY/#BY
1ms
(Min)
Undefined
#WP
#WE
W29N04GV
Release Date: February 9th, 2017
57 Revision B
10.4 DC Electrical Characteristics (3.3V)
PARAMETER
SYMBOL
CONDITIONS
SPEC
UNIT
MIN
TYP
MAX
Sequential Read current
Icc1
tRC= tRC MIN
#CE=VIL
IOUT=0mA
-
25
35
mA
Program current
Icc2
-
-
25
35
mA
Erase current
Icc3
-
-
25
35
mA
Standby current (TTL)
ISB1
#CE=VIH
#WP=0V/Vcc
-
-
1
mA
Standby current (CMOS)
ISB2
#CE=Vcc 0.2V
#WP=0V/Vcc
-
10
50
µA
Input leakage current
ILI
VIN= 0 V to Vcc
-
-
±10
µA
Output leakage current
ILO
VOUT=0V to Vcc
-
-
±10
µA
Input high voltage
VIH
I/O7~0, #CE,#WE,#RE,
#WP,CLE,ALE
0.8 x Vcc
-
Vcc + 0.3
V
Input low voltage
VIL
-
-0.3
-
0.2 x Vcc
V
Output high voltage(1)
VOH
IOH=-400µA
2.4
-
-
V
Output low voltage(1)
VOL
IOL=2.1mA
-
-
0.4
V
Output low current
IOL(RY/#BY)
VOL=0.4V
8
10
mA
Table 10-3 DC Electrical Characteristics
Note:
1. VOH and VOL may need to be relaxed if I/O drive strength is not set to full.
2. IOL (RY/#BY) may need to be relaxed if RY/#BY pull-down strength is not set to full
W29N04GV
Release Date: February 9th, 2017
58 Revision B
10.5 AC Measurement Conditions (3.3V)
PARAMETER
SYMBOL
SPEC
UNIT
MIN
MAX
Input Capacitance(1), (2)
CIN
-
10
pF
Input/Output Capacitance(1), (2)
CIO
-
10
pF
Input Rise and Fall Times
TR/TF
-
5
ns
Input Pulse Voltages
-
0 to VCC
V
Input/Output timing Voltage
-
Vcc/2
V
Output load (1)
CL
1TTL GATE and CL=30pF
-
Table 10-4 AC Measurement Conditions
Notes:
1. Verified on device characterization , not 100% tested
2. Test conditions TA=25’C, f=1MHz, VIN=0V
W29N04GV
Release Date: February 9th, 2017
59 Revision B
10.6 AC timing characteristics for Command, Address and Data Input (3.3V)
PARAMETER
SYMBOL
SPEC
UNIT
MIN
MAX
ALE to Data Loading Time
tADL
70
-
ns
ALE Hold Time
tALH
5
-
ns
ALE setup Time
tALS
10
-
ns
#CE Hold Time
tCH
5
-
ns
CLE Hold Time
tCLH
5
-
ns
CLE setup Time
tCLS
10
-
ns
#CE setup Time
tCS
15
-
ns
Data Hold Time
tDH
5
-
ns
Data setup Time
tDS
10
-
ns
Write Cycle Time
tWC
25
-
ns
#WE High Hold Time
tWH
10
-
ns
#WE Pulse Width
tWP
12
-
ns
#WP setup Time
tWW
100
-
ns
Table 10-5 AC timing characteristics for Command, Address and Data Input
Note:
1. tADL is the time from the #WE rising edge of final address cycle to the #WE rising edge of first data cycle.
W29N04GV
Release Date: February 9th, 2017
60 Revision B
AC timing characteristics for Operation (3.3V)
10.7 AC timing characteristics for Operation (3.3V)
PARAMETER
SYMBOL
SPEC
UNIT
MIN
MAX
ALE to #RE Delay
tAR
10
-
ns
#CE Access Time
tCEA
-
25
ns
#CE HIGH to Output High-Z(1)
tCHZ
-
30
ns
CLE to #RE Delay
tCLR
10
-
ns
#CE HIGH to Output Hold
tCOH
15
-
ns
Cache Busy in Cache Read mode
tRCBSY
-
25
µs
Output High-Z to #RE LOW
tIR
0
-
ns
Data Transfer from Cell to Data Register
tR
-
25
µs
READ Cycle Time
tRC
25
-
ns
#RE Access Time
tREA
-
20
ns
#RE HIGH Hold Time
tREH
10
-
ns
#RE HIGH to Output Hold
tRHOH
15
-
ns
#RE HIGH to #WE LOW
tRHW
100
-
ns
#RE HIGH to Output High-Z(1)
tRHZ
-
100
ns
#RE LOW to output hold
tRLOH
5
-
ns
#RE Pulse Width
tRP
12
-
ns
Ready to #RE LOW
tRR
20
-
ns
Reset Time (READ/PROGRAM/ERASE)(2)
tRST
-
5/10/500
µs
#WE HIGH to Busy(3)
tWB
-
100
ns
#WE HIGH to #RE LOW
tWHR
60
-
ns
Table 10-6 AC timing characteristics for Operation
Notes: AC characteristics may need to be relaxed if I/O drive strength is not set to “full.”
1. Transition is measured ±200mV from steady-state voltage with load. This parameter is sampled and not
100 % tested.
2. Do not issue new command during tWB, even if RY/#BY is ready.
W29N04GV
Release Date: February 9th, 2017
61 Revision B
10.8 Program and Erase Characteristics
PARAMETER
SYMBOL
SPEC
UNIT
TYP
MAX
Number of partial page programs
NoP
-
4
cycles
Page Program time
tPROG
250
700
µs
Busy Time for Cache program (1)
tCBSY
3
700
µs
Busy Time for SET FEATURES /GET FEATURES
tFEAT
-
1
µs
Busy Time for program/erase at locked block
tLBSY
-
3
µs
Busy Time for OTP program when OTP is protected
tOBSY
-
30
µs
Block Erase Time
tBERS
2
10
ms
Last Page Program time (2)
tLPROG
-
-
-
Busy Time for Two Plane page program and Two Plane Block
Erase
tDBSY
0.5
1
µs
Table 10-7 Program and Erase Characteristics
Note:
1. tCBSY maximum time depends on timing between internal program complete and data-in.
2. tLPROG = Last Page program time (tPROG) + Last -1 Page program time (tPROG) Last page Address,
Command and Data load time.
W29N04GV
Release Date: February 9th, 2017
62 Revision B
11. TIMING DIAGRAMS
Figure 11-1 Command Latch Cycle
Figure 11-2 Address Latch Cycle
tCS
Command
tWP
tCLHtCLS
tCH
tALS tALH
tDS tDH
Dont care
CLE
#WE
ALE
I/Ox
#CE
tCS
Address
tWP
tWC
tALS tALH
tDS tDH
tCLS
tWH
Dont care Undefined
CLE
#CE
I/Ox
#WE
ALE
W29N04GV
Release Date: February 9th, 2017
63 Revision B
Figure 11-3 Data Latch Cycle
Note:
1. Din Final = 2,111(x8)
Figure 11-4 Serial Access Cycle after Read
Din 0
tWP
tCLH
tALS
tDS tDH
tWP tWP
Din 1
tDS tDH
tWH
Din Final1
tDS tDH
tCH
tWC
Dont care
CLE
#CE
I/Ox
#WE
ALE
tCHZ
tCEA
tRP
tRHZ
Dout Dout
tREA
tREH
tREA
Dout
tREA
tRHOH
tCOH
tRHZ
tRR tRC
Dont care
#CE
I/Ox
#RE
RY/#BY
W29N04GV
Release Date: February 9th, 2017
64 Revision B
Figure 11-5 Serial Access Cycle after Read (EDO)
Figure 11-6 Read Status Operation
tCHZ
tCEA
tRP
Dout
tREA
tREH
tREA
tCOH
tRHZ
tRR
tRC
Dout
tRHOH
tRLOH
Dont care
I/Ox
RY/#BY
#RE
#CE
Dout
#CE
#RE
#WE
tWP tCH
tRHZ
tCHZ
CLE
I/Ox
tCOH
Status
output
tRHOH
tRP
tCEA
tCS
tCLR
tCLS tCLH
70h
tDS tDH tIR tREA
tWHR
Dont care
W29N04GV
Release Date: February 9th, 2017
65 Revision B
Busy
Dout
n+1
Dout
n
Dout
m
00h 30h
tAR
tWB
tCLR
tRC
tRR
tWC
tRP
tRHZ
tR
I/Ox
#WE
ALE
#RE
RY/#BY
CLE
#CE
Dont care
Address(5Cycles)
Figure 11-7 Page Read Operation
CLE
#WE
ALE
RY/#BY
#CE
#RE
I/Ox
Out
tCEA
tREA
tCOH
tCHZ
#CE
#RE
I/Ox
tR
00hAddress (4 cycles) 30hData output
Dont care
Figure 11-8 #CE Don't Care Read Operation
W29N04GV
Release Date: February 9th, 2017
66 Revision B
tRC
tRR
Colu mn address n
tREA
Column address m
tCLR
tAR
tWB
tWC
tWHR
00h30h05h E0h
Busy
tR
#WE
ALE
#RE
RY/#BY
CLE
#CE
I/Ox
Dont care
Figure 11-9 Random Data Output Operation
I/Ox
#WE
ALE
#RE
RY/#BY
CLE
#CE
00hCol
add 1 Col
add 2 30h
tRC
tCS
Row
add 1 Ro w
add 2
tR
Colu mn address
00h
tCLS tCLH
tWC
Page ad dress
m
tCH
tWB
tDCBSYR1
31h
Page ad dress m
31h
tCEA
Dou t
1
Dou t
0Dou t
tRR
tDS tDH tREA
Colu mn address 0 1
Dont care
Figure 11-10 Cache Read Operation (1/2)
W29N04GV
Release Date: February 9th, 2017
67 Revision B
I/Ox
#WE
ALE
#RE
RY/#BY
CLE
#CE
tDS tDH
tRHW
1
tCLS tCLH
tCS tCH
tCEA
tRC
tRR
31h 3FhDout
Dout
0Dout
1
Dout
Dout
0Dout
1
Dout
Page address
m+1
tREA
Column address 0
Page address
m+2
Column address 0
tRCBSY tRCBSY
Dont care
Figure 11-11 Cache Read Operation (2/2)
Note:
1. See Table 9.1 for actual value.
I/Ox
#WE
#RE
CLE
#CE
ALE
tAR
90h
(or 20h)
Address, 1 cycle
00hByte 1Byte 0
tREA
Byte 2 Byte 4
Byte 3
tWHR
Figure 11-12 Read ID
W29N04GV
Release Date: February 9th, 2017
68 Revision B
I/Ox
#WE
ALE
#RE
RY/#BY
CLE
#CE
80hCol
add 1 Col
add 2
tWC
Row
add 1 Row
add 2 Status
SERIAL DATA
INPUT command
70h
tPROGtWB
tADL
10h
1 up to m Byte
serial inpu t
PROGRAM
command
READ STATUS
command
x8 device:m = 2112 bytes
tWHR
Dont care
Figure 11-13 Page Program
I/Ox
CLE
#WE
ALE
#CE
80hAddress(4 cycles) Data input Data input 10h
#WE
#CE
tCS tCH
tWP
Dont care
Figure 11-14 #CE Don't Care Page Program Operation
W29N04GV
Release Date: February 9th, 2017
69 Revision B
I/Ox
CLE
#WE
ALE
#RE
#CE
80hCol
add 2
Col
add 1
WC
Din
Din
N+1
Serial Data
Inpu t Command
85hStatus
70h
10h
Din
N+1
Serial INPUT
Command
Program
Command
tADL
tWB
tPROG
Random Data Input
Command
RY/#BY
Colu mn address Serial INPUT
Row
add2
tADL
Col
add1 Col
add2 Din
Dont care
Row
add1
Figure 11-15 Page Program with Random Data Input
Figure 11-16 Copy Back
00h
WC
Serial data INPUT
Command
tADL
Program
Command
tWB
tPROG
I/Ox
CLE
#WE
ALE
#RE
#CE
RY/#BY
tWB
tR
Busy
Col
add 1 Col
add 2 Row
add1 Row
add2 35h85hCol
add 1 Col
add 2 Row
add1 Row
add2 Din
1Din
n10h Status
70h
Dont care
W29N04GV
Release Date: February 9th, 2017
70 Revision B
80h10h
I/Ox
CLE
#WE
ALE
#RE
#CE
WC
Serial data INPU T
Command
Din
Serial INPUT Program
Command
Program
Command
tADL
tWB
tCBSY
Last page input and programming
RY/#BY
80hDin
15h
tPROG
Status
70h
WC tADL
tWB
Din
Din
Dont care
Col
add 2 Row
add1 Row
add2 Row
add3
Col
add1 Col
add2 Row
add1 Row
add2
Col
add1 Row
add3
Figure 11-17 Cache Program
#RE
RY/#BY
CLE
#CE
#WE
ALE
Busy
60h D0h
tBERS
tWC
Status
70h
BLOCK ERASE SETUP
command
ERASE
command READ STATUS
command
tWB
I/Ox
Dont care
Address(3cycles)
Figure 11-18 Block Erase
W29N04GV
Release Date: February 9th, 2017
71 Revision B
I/Ox
#WE
RY/#BY
CLE
#CE
FFh
tRST
RESET
command
tWB
Figure 11-19 Reset
W29N04GV
Release Date: February 9th, 2017
72 Revision B
12. INVALID BLOCK MANAGEMENT
12.1 Invalid blocks
The W29N04GV may have initial invalid blocks when it ships from factory. Also, additional invalid
blocks may develop during the use of the device. Nvb represents the minimum number of valid blocks
in the total number of available blocks (See Table 12.1). An invalid block is defined as blocks that
contain one or more bad bits. Block 0, block address 00h is guaranteed to be a valid block at the time
of shipment.
Parameter
Symbol
Min
Max
Unit
Valid block number
Nvb
4016
4096
blocks
Table 12-1 Valid Block Number
12.2 Initial invalid blocks
Initial invalid blocks are defined as blocks that contain one or more invalid bits when shipped from
factory.
Although the device contains initial invalid blocks, a valid block of the device is of the same quality
and reliability as all valid blocks in the device with reference to AC and DC specifications. The
W29N04GV has internal circuits to isolate each block from other blocks and therefore, the invalid
blocks will not affect the performance of the entire device.
Before the device is shipped from the factory, it will be erased and invalid blocks are marked. All initial
invalid blocks are marked with non-FFh at the first byte of spare area on the 1st or 2nd page. The initial
invalid block information cannot be recovered if inadvertently erased. Therefore, software should be
created to initially check for invalid blocks by reading the marked locations before performing any
program or erase operation, and create a table of initial invalid blocks as following flow chart
W29N04GV
Release Date: February 9th, 2017
73 Revision B
Figure 12-1 flow chart of create initial invalid block table
12.3 Error in operation
Additional invalid blocks may develop in the device during its life cycle. Following the procedures
herein is required to guarantee reliable data in the device.
After each program and erase operation, check the status read to determine if the operation failed. In
case of failure, a block replacement should be done with a bad-block management algorithm. The
system has to use a minimum 1-bit ECC per 528 bytes of data to ensure data recovery.
Operation
Detection and recommended procedure
Erase
Status read after erase Block Replacement
Program
Status read after program Block Replacement
Read
Verify ECC ECC correction
Table 12-2 Block failure
W29N04GV
Release Date: February 9th, 2017
74 Revision B
Figure 12-2 Bad block Replacement
Note:
1. An error happens in the nth page of block A during program or erase operation.
2. Copy the data in block A to the same location of block B which is valid block.
3. Copy the nth page data of block A in the buffer memory to the nth page of block B
4. Creating or updating bad block table for preventing further program or erase to block A
.
12.4 Addressing in program operation
The pages within the block have to be programmed sequentially from LSB (least significant bit) page
to the MSB (most significant bit) within the block. The LSB is defined as the start page to program,
does not need to be page 0 in the block. Random page programming is prohibited.
W29N04GV
Release Date: February 9th, 2017
75 Revision B
13. PACKAGE DIMENSIONS
13.1 TSOP 48-pin 12x20
Figure 13-1 TSOP 48-PIN 12X20mm
e
1
48
b
E
D
Y
A1
A
A2
L1
L
c
H
D
0.020
0.004
0.007
0.037
0.002
MIN.
0.60
Y
L
L1
c
0.50
0.10
0.70
0.21
MILLIMETER
A
A2
b
A1
0.95
0.17
0.05
Symbol
MIN.
1.20
0.27
1.05
1.00
0.22
MAX.
NOM.
0.028
0.008
0.024
0.011
0.041
0.047
0.009
0.039
NOM.
INCH
MAX.
E
H
D
0
5
0
5
e
D
18.3
18.4
18.5
19.8
20.0
20.2
11.9
12.0
12.1
0.720
0.724
0.728
0.780
0.787
0.795
0.468
0.472
0.476
0.10
0.80
0.031
0.004
0.020
0.50
W29N04GV
Release Date: February 9th, 2017
76 Revision B
13.2 Fine-Pitch Ball Grid Array 63-ball
Figure 13-2 Fine-Pitch Ball Grid Array 63-Ball
W29N04GV
Release Date: February 9th, 2017
77 Revision B
14. ORDERING INFORMATION
Figure 14-1 Ordering Part Number Description
Winbond Standard Product
W: Winbond
Product Family
ONFI compatible NAND Flash memory
Density
04: 4 Gbit
Product Version
G
Supply Voltage and Bus Width
V: 2.7~3.6V and x8 device
Packages
S: TSOP 48
B: VFBGA-63
Temparature Ranges
I: -40 to 85'C
Option Information
A: General Product
(Contact Winbond for Option information)
Reserved
A: General Product
W
29N
04
G
V
I
A
A
S
W29N04GV
Release Date: February 9th, 2017
78 Revision B
15. VALID PART NUMBERS
The following table provides the valid part numbers for the W29N04GV NAND Flash Memory. Please
contact Winbond for specific availability by density and package type. Winbond NAND Flash
memories use a 12-digit Product Number for ordering.
Part Numbers for Industrial Temperature:
PACKAGE
TYPE
DENSITY
VCC
BUS
PRODUCT NUMBER
TOP SIDE MARKING
S
TSOP-48
4G-bit
3V
X8
W29N04GVSIAA
W29N04GVSIAA
B
VFBGA-63
4G-bit
3V
X8
W29N04GVBIAA
W29N04GVBIAA
Table 15-1 Part Numbers for Industrial Temperature
W29N04GV
Release Date: February 9th, 2017
79 Revision B
16. REVISION HISTORY
VERSION
DATE
PAGE
DESCRIPTION
0.1
11/19/14
New Create as Preliminary
0.2
02/01/16
27, 55
Update Parameter Page Output Value
Update Notes of Absolute Maximum Ratings
A
06/01/16
Remove Preliminary
B
02/09/17
44
Change A18 address input requirement of Two Plane
Block Erase operation
Table 16-1 History Table
Trademarks
Winbond is trademark of Winbond Electronics Corporation.
All other marks are the property of their respective owner.
Important Notice
Winbond products are not designed, intended, authorized or warranted for use as components in
systems or equipment intended for surgical implantation, atomic energy control instruments, airplane
or spaceship instruments, transportation instruments, traffic signal instruments, combustion control
instruments, or for other applications intended to support or sustain life. Furthermore, Winbond
products are not intended for applications wherein failure of Winbond products could result or lead to
a situation where in personal injury, death or severe property or environmental damage could occur.
Winbond customers using or selling these products for use in such applications do so at their own
risk and agree to fully indemnify Winbond for any damages resulting from such improper use or sales.