M29DW640D
16/56
Program Command
The Program command can be used to program a
value to one address in the memory array at a
time. The command requires four Bus Write oper-
ations, the final Write operation latches the ad-
dress and data in the internal state machine and
starts the Program/Erase Controller.
Programming can be suspended and then re-
sumed by issuing a Program Suspend command
and a Program Resume command, respectively
(see
Program Suspend Command
and
Program
Resume Command
paragraphs).
If the address falls in a protected block then the
Program command is ignored, the data remains
unchanged. The Status Register is never read and
no error condition is given.
After programming has started, Bus Read opera-
tions in the Bank being programmed output the
Status Register content, while Bus Read opera-
tions to the other Bank output the contents of the
memory array. See the section on the Status Reg-
ister for more details. Typical program times are
given in Table
7
.
After the program operation has completed the
memory will return to the Read mode, unless an
error has occurred. When an error occurs Bus
Read operations to the Bank where the command
was issued will continue to output the Status Reg-
ister. A Read/Reset command must be issued to
reset the error condition and return to Read mode.
Note that the Program command cannot change a
bit set at ’0’ back to ’1’. One of the Erase Com-
mands must be used to set all the bits in a block or
in the whole memory from ’0’ to ’1’.
Fast Program Commands
There are five Fast Program commands available
to improve the programming throughput, by writing
several adjacent Words or Bytes in parallel.
Double Word Program Command.
This
used to write two adjacent Words in x16 mode, in
parallel. The addresses of the two Words must dif-
fer only in A0.
Three bus write cycles are necessary to issue the
command.
The first bus cycle sets up the command.
The second bus cycle latches the Address and
the Data of the first Word to be written.
The third bus cycle latches the Address and
the Data of the second Word to be written and
starts the Program/Erase Controller.
is
■
■
■
Quadruple Word Program Command.
This is
used to write a page of four adjacent Words, in x16
mode, in parallel. The addresses of the four Words
must differ only in A1 and A0.
Five bus write cycles are necessary to issue the
command.
The first bus cycle sets up the command.
The second bus cycle latches the Address and
the Data of the first Word to be written.
The third bus cycle latches the Address and
the Data of the second Word to be written.
The fourth bus cycle latches the Address and
the Data of the third Word to be written.
The fifth bus cycle latches the Address and the
Data of the fourth Word to be written and starts
the Program/Erase Controller.
Double Byte Program Command.
This is used
to write two adjacent Bytes in x8 mode, in parallel.
The addresses of the two Bytes must differ only in
DQ15A-1.
Three bus write cycles are necessary to issue the
command.
The first bus cycle sets up the command.
The second bus cycle latches the Address and
the Data of the first Byte to be written.
The third bus cycle latches the Address and
the Data of the second Byte to be written and
starts the Program/Erase Controller.
Quadruple Byte Program Command.
This
used to write four adjacent Bytes in x8 mode, in
parallel. The addresses of the four Bytes must dif-
fer only in A0, DQ15A-1.
Five bus write cycles are necessary to issue the
command.
The first bus cycle sets up the command.
The second bus cycle latches the Address and
the Data of the first Byte to be written.
The third bus cycle latches the Address and
the Data of the second Byte to be written.
The fourth bus cycle latches the Address and
the Data of the third Byte to be written.
The fifth bus cycle latches the Address and the
Data of the fourth Byte to be written and starts
the Program/Erase Controller.
Octuple Byte Program Command.
This is used
to write eight adjacent Bytes, in x8 mode, in paral-
lel. The addresses of the eight Bytes must differ
only in A1, A0 and DQ15A-1.
Nine bus write cycles are necessary to issue the
command.
The first bus cycle sets up the command.
The second bus cycle latches the Address and
the Data of the first Byte to be written.
The third bus cycle latches the Address and
the Data of the second Byte to be written.
The fourth bus cycle latches the Address and
the Data of the third Byte to be written.
■
■
■
■
■
■
■
■
is
■
■
■
■
■
■
■
■
■