28F128J3A, 28F640J3A, 28F320J3A
Preliminary
23
issuing the Program Resume command allows continuing of the suspended programming
operation. To resume the suspended erase, the user must wait for the programming operation to
complete before issuing the Block Erase Resume command.
The only other valid commands while block erase is suspended are Read Query, Read Status
Register, Clear Status Register, Configure, and Block Erase Resume. After a Block Erase Resume
command is written to the flash memory, the WSM will continue the block erase process. Status
register bits SR.6 and SR.7 will automatically clear and STS (in default mode) will return to V
OL
.
After the Erase Resume command is written, the device automatically outputs status register data
when read (see
Figure 11,
“
Block Erase Suspend/Resume Flowchart
”
on page 34
). V
PEN
must
remain at V
PENH
(the same V
PEN
level used for block erase) while block erase is suspended. Block
erase cannot resume until program operations initiated during block erase suspend have completed.
4.8
Write to Buffer Command
To program the flash device, a Write to Buffer command sequence is initiated. A variable number
of bytes, up to the buffer size, can be loaded into the buffer and written to the flash device. First, the
Write to Buffer Setup command is issued along with the Block Address (see
Figure 7,
“
Write to
Buffer Flowchart
”
on page 30
). At this point, the eXtended Status Register (XSR, see
Table 17
)
information is loaded and XSR.7 reverts to
“
buffer available
”
status. If XSR.7 = 0, the write buffer
is not available. To retry, continue monitoring XSR.7 by issuing the Write to Buffer setup
command with the Block Address until XSR.7 = 1. When XSR.7 transitions to a
“
1,
”
the buffer is
ready for loading.
Now a word/byte count is given to the part with the Block Address. On the next write, a device
start address is given along with the write buffer data. Subsequent writes provide additional device
addresses and data, depending on the count. All subsequent addresses must lie within the start
address plus the count.
Internally, this device programs many flash cells in parallel. Because of this parallel programming,
maximum programming performance and lower power are obtained by aligning the start address at
the beginning of a write buffer boundary (i.e., A
4
–
A
0
of the start address = 0).
After the final buffer data is given, a Write Confirm command is issued. This initiates the WSM
(Write State Machine) to begin copying the buffer data to the flash array. If a command other than
Write Confirm is written to the device, an
“
Invalid Command/Sequence
”
error will be generated
and Status Register bits SR.5 and SR.4 will be set to a
“
1.
”
For additional buffer writes, issue
another Write to Buffer Setup command and check XSR.7.
If an error occurs while writing, the device will stop writing, and status register bit SR.4 will be set
to a
“
1
”
to indicate a program failure. The internal WSM verify only detects errors for
“
1
”
s that do
not successfully program to
“
0
”
s. If a program error is detected, the status register should be
cleared. Any time SR.4 and/or SR.5 is set (e.g., a media failure occurs during a program or an
erase), the device will not accept any more Write to Buffer commands. Additionally, if the user
attempts to program past an erase block boundary with a Write to Buffer command, the device will
abort the write to buffer operation. This will generate an
“
Invalid Command/Sequence
”
error and
status register bits SR.5 and SR.4 will be set to a
“
1.
”
Reliable buffered writes can only occur when V
PEN
= V
PENH
. If a buffered write is attempted
while V
PEN
≤
V
PENLK
, status register bits SR.4 and SR.3 will be set to
“
1.
”
Buffered write attempts
with invalid V
CC
and V
PEN
voltages produce spurious results and should not be attempted. Finally,
successful programming requires that the corresponding block lock-bit be reset. If a buffered write
is attempted when the corresponding block lock-bit is set, SR.1 and SR.4 will be set to
“
1.
”