Z8 Encore!® Motor Control Series
Z8 Encore!® Z8FMC16 MCU
Programming Specification
PRS000502-1005
PRELIMINARY
ZiLOG Worldwide Headquarters  532 Race Street  San Jose, CA 95126-3432
Telephone: 408.558.8500  Fax: 408.558.8300  www.ZiLOG.com
This publication is subject to replacement by a later edition. To determine whether a later edition exists, or
to request copies of publications, contact:
ZiLOG Worldwide Headquarters
532 Race Street
San Jose, CA 95126-3432
Telephone: 408.558.8500
Fax: 408.558.8300
www.ZiLOG.com
ZiLOG is a registered trademark of ZiLOG Inc. in the United States and in other countries. All other products and/or service
names mentioned herein may be trademarks of the companies with which they are associated.
Document Disclaimer
©2005 by ZiLOG, Inc. All rights reserved. Information in this publication concerning the devices, applications, or technology
described is intended to suggest possible uses and may be superseded. ZiLOG, INC. DOES NOT ASSUME LIABILITY FOR OR
PROVIDE A REPRESENTATION OF ACCURACY OF THE INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED
IN TH IS DOCUM EN T. Zi LO G A LSO DO ES NO T ASSU ME LI ABILITY FO R I NTELLECTU AL PROPERTY
INFRINGEMENT RELATED IN ANY MANNER TO USE OF INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED
HEREIN OR OTHERWISE. Except with the express written approval ZiLOG, use of information, devices, or technology as
critical components of life support systems is not authorized. No licenses or other rights are conveyed, implicitly or otherwise, by
this document under any intellectual property rights.
PRS000502-1005
PRELIMINARY
Z8FMC16 MCU
Programming Specification
1
Flash Memory Programming Overview
The Z8 Encore!® Z8FMC16 Motor Control features a Flash program memory selections
of 8KB or 16KB. By using Flash memory, you have the ability to easily update the code.
The Z8 Encore!® features an on-chip Flash controller that typically manages the timing of
Flash control signals for programming, page erase, and mass erase operations. The Flash
controller can also be bypassed to allow direct control of Flash signals via the general
purpose input/output (GPIO) pins. Flash memory can be programmed faster by controlling
the Flash memory signals directly. Bypassing the Flash controller is beneficial when
programming a large number of devices, and is most likely to be used by third party
vendors who are developing the multi-site gang programmers.
Bypassing the Flash Controller
Flash controller bypass mode is enabled by writing the following three bytes of instruction
to the on-chip debugger (OCD) via the DBG interface:
1. 80H - This instruction initiates auto-baud calculation of the DBG interface data and
clock rate.
2. F0H - OCD writes testmode register command.
3. 04H - Data to be written to the testmode register. This data enables the Flash
controller bypass mode.
Flash Memory Control Signals
Depending on the size (number of bytes) available in the Flash memory, the Flash memory
uses fourty two signals for its direct interfacing.
16 signals for the address lines.
8 signals for data input.
8 signals for data output.
10 signals for control operations.
The Flash memory control signals are listed and described in Table 1
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
2
.
Table 1. Flash Memory Control Signals
Signal
Direction
Description
XADDR[9:0]
I
X address input selects a row. XADDR[9:0] corresponds to the upper
10 bits of the program memory address space (PROGMEM[15:6]).
For Z8 Encore!® devices with less than 64KB of program memory, the
unused upper address bits must be set to 0.
YADDR[5:0]
I
Y address input selects one byte within a row. YADDR[5:0]
corresponds to the lower 6 bits of the program memory address space
(PROGMEM[5:0]).
DIN[7:0]
I
Data input.
DOUT[7:0]
O
Data output.
XE
I
X address enable.
YE
I
Y address enable.
SE
I
Sense amplifier enable.
OE
I
Output enable.
ERASE
I
Erase enable. This signal is used to select erase operations.
MAS1
I
Mass erase select. This signal is used to distinguish between page
erase and mass erase operations.
PROG
I
Program enable. This signal is used to select a program operation.
NVSTR
I
Non-volatile store enable. This signal is used during page erase, mass
erase, and programming operations.
TMR
I
This signal should be set to 1 during all operations.
IFREN
I
Information area select.
Flash Memory Operations
When bypassing the Flash controller, all Flash memory operations (read, program, page
erase, and mass erase) are available. The mode of operation is set by the Flash memory
control signals as described in Table 2.
The selection of the Flash main memory or the Flash information area depends on the
IFREN signal as described in Table 3.
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
3
Table 2. Flash Mode Truth Table
Mode
XE
YE
SE
OE
PROG
ERASE MAS1
NVSTR TMR
IFREN
Read
H
H
H
H
L
L
L
L
H
L/H1
Program
H
H
L
L
H
L
L
H
H
L/H1
Page Erase
H
L
L
L
L
H
L
H
H
L/H1
Mass Erase
H
L
L
L
L
H
H
H
H
L/H1
See Table 3 for IFREN signal operation information.
Table 3. IFREN Signal Truth Table
Mode
IFREN = 1
IFREN = 0
Read
Read Information Area
Read Main Memory
Program
Program Information Area Program Main Memory
Page Erase
Page Erase Information
Area
Page Erase Main Memory
Mass Erase
Mass Erase Information
Area
Mass Erase Main Memory
Flash Bypass Mode Register Structure
For using Flash controller bypass mode for all package sizes, the signals must be
registered internally. This allows all data access to occur through pin PWM2L and Port A
[6:0]. Three other pins (PWM2H, PWM1L, and PWM1H), selects one of the input data
registers or the data output register as shown in Table 4.
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
4
Table 4. Control Registers in Flash Bypass Mode
Register Select [PWM2H, PWM1L, PWM1H]
Input/Output
000
001
010
011
100
101
110-111
Input
Input
Input
Input
Input
Output
Input
PWM2L
XADDR[9] XADDR[1] DIN[7]
XE
TMR
DOUT[7]
NOP
Port A6
XADDR[8] XADDR[0] DIN[6]
YE
IFREN
DOUT[6]
NOP
Port A5
XADDR[7] YADDR[5] DIN[5]
SE
NOP
DOUT[5]
NOP
Port A4
XADDR[6] YADDR[4] DIN[4]
OE
NOP
DOUT[4]
NOP
Port A3
XADDR[5] YADDR[3] DIN[3]
ERASE
NOP
DOUT[3]
NOP
Port A2
XADDR[4] YADDR[2] DIN[2]
PROG
NOP
DOUT[2]
NOP
Port A1
XADDR[3] YADDR[1] DIN[1]
MAS1
NOP
DOUT[1]
NOP
Port A0
XADDR[2] YADDR[0] DIN[0]
NVSTR
NOP
DOUT[0]
NOP
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
5
Flash Bypass Mode Register Structure
Figure 1 illustrates the multiplexed register structure that allows access to all Flash
memory signals through GPIO ports.
Flash
Registers
XADDR[9:0]
YADDR[5:0]
Data
Input/Output
PortA0
PortA1
PortA2
PortA3
PortA4
PortA5
PortA6
PWM2L
DIN[7:0]
DOUT[7:0]
Register
Select
PWM2H
PWM1L
PWM1H
XE
YE
OE
SE
ERASE
PROG
MAS1
NVSTR
TMR
IFREN
Figure 1. Flash Bypass Mode Register Structure
Bypass Mode Register Read Timing
Figure 2 illustrates the timing of a read operation using the Flash controller bypass mode
registers. While reading data, output data is latched into the output register on the first
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
6
clock edge. The data is read during the next clock period. Mode selector comprises of the
following pins: PWM2H, PWM1L, and PWM1H.
XIN
Mode
Selector
XX
Port driven
by Chip
101
XX
XX
Data
Data Latched in
Output Register
Figure 2. Bypass Mode Register Read Timing
Bypass Mode Register Write Timing
Figure 3 illustrates the timing of a write operation using the Flash controller bypass mode
registers. When writing data into the registers, the data is latched on the rising edge of
XIN.
XIN
Mode
Selector
Port driven
externally
Data latched in selected
register on rising edge of Xin
Figure 3. Bypass Mode Register Write Timing
Flash Row Programming
The Flash memory can be programmed either as a single byte at a time or as a row of bytes
at a time. Multi-byte row programming allows programming of a full row of Flash
memory without incurring all of the programming setup and recovery time for each byte.
During row programming, the Flash memorys PROG and NVSTR signals are
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
7
continuously asserted until all bytes in a row are programmed. This allows the row to be
programmed faster than if these signals are deasserted after programming each byte.
During row programming, you must ensure that the cumulative programming high voltage
period does not exceed the specification limits for a row.
Flash Memory Timing
Table 5 and Figures 4 through Figure 7 provides the detailed timing information on
accessing the Flash memory in Flash controller bypass mode.
Table 5. Flash Memory Timing Parameters
Parameter
Symbol
Min.
Max.
Unit
X address access time
Txa
-
40
ns
Y address access time
Tya
-
40
ns
OE access time
Toa
-
4
ns
PROG/ERASE to NVSTR setup time
Tnvs
5
-
s
NVSTR hold time
Tnvh
5
-
s
NVSTR hold time (Mass Erase)
Tnvh1
100
-
s
NVSTR to program setup time
Tpgs
10
-
s
Program hold time
Tpgh
20
-
ns
Byte program time
Tprog
30
60
Address / Data setup time
Tads
20
-
ns
Address / Data hold time
Tadh
20
-
ns
Trcv
1
-
s
Thv
-
12
ms
Erase time
Terase
10
-
ms
Mass Erase time
Tme
200
-
ms
Recovery time
Cumulative program high
voltage period1
s
1
Thv is the cumulative high voltage programming time for a single row before the next erase.
Caution:
PRS000502-1005
The same address (byte) cannot be programmed more than twice before
the next erase.
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
8
Flash Read Timing
Figure 4 illustrates the timing of a read operation from the Flash memory.
IFREN
XADDR
XE
Txa
YADDR
YE
SE
OE
DOUT
Tya
Toa
ERASE = 0, MAS1 = 0, NVSTR = 0, TMR = 1
Figure 4. Flash Read Timing
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
9
Flash Program Timing
Figure 5 illustrates the Flash programming operation for three bytes on a single row. The
XADDR is unchanged while PROG and NVSTR are high, but the YADDR changes three
times to identify three different bytes in a single row.
IFREN
XADDR
XE
Tadh
YADDR
YE
DIN
PROG
Tprog
Tnvs
Tpgh
Tads
NVSTR
Tpgs
Tnvh
Trcv
Thv
SE = 0, OE = 0, ERASE = 0, MAS1 = 0, TMR = 1
Figure 5. Flash Byte Program Timing
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
10
Flash Page Erase Timing
Figure 6 illustrates the timing of a Flash page erase operation.
IFREN
XADDR
XE
ERASE
Tnvs
NVSTR
Tnvh
Terase
Trcv
YE = 0, SE = 0, OE = 0, PROG = 0, MAS1 = 0, TMR = 1
Figure 6. Flash Page Erase Timing
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
11
Flash Mass Erase Timing
Figure 7 illustrates the timing of a Flash mass erase operation.With IFREN driven high
(1), the mass erase operation will erase both the main memory and the information area.
With IFREN driven low (0), the mass erase operation will erase only the main memory.
IFREN
XADDR
XE
MAS1
ERASE
Tnvs
NVSTR
Tnvh1
Tme
Trcv
YE = 0, SE = 0, OE = 0, PROG = 0, TMR = 1
Figure 7. Flash Mass Erase Timing
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview
Z8FMC16 MCU
Programming Specification
12
Z8FMC16100 Flash Programming Flowchart
Figure 8 illustrates an example flowchart for read and write operations.
Z8FMC16100 Flash Programming Flowchart
RESET&
DBG Low
START
Release
RESET
5ms
OSCCT L
Wait f or
break
XIN is
Sy sClk
Autobaud
WriteOCD
0x80
FFREQH*
Mass
Erase
Flash?
N
o
WrT estmode
Register
OSCCT L
WriteOCD
0x08,
0x0F,
0xFA,
0x01,
0x4E
20
WriteOCD
0x08,
0x0F,
0xFB,
0x01,
0x20
OSCCT L
Autobaud
WriteOCD
0x80
FCT L 73
Unlockstep1
FCT L
8C
Unlockstep2
FCT L 63
Iss ues Mass erase
Write OCD
0x08,
0x0F,
0xF8,
0x01,
0x73
Write OCD
0x08,
0x0F,
0xF8,
0x01,
0x8C
WriteOCD
0x08,
0x0F,
0xF8,
0x01,
0x63
250 ms
* The Values f or FFREQH and FFREQL are based
on a 20MHz clock source. This v alue is set by the
f ollowing equation
SEL =
PWM2H,PWM1L,PWM1H
{FFREQH[7:0], FFREQL[7:0]}=(Clock Frequency )/
1000
DIO =
PWM2L,PORT[A6:A0]
0x4e20= (20 MHz)/1000
Do not use less then a 32kHz clock source.
SEL = 0x04
DIN =0x80
SetADDRL
As sert XE&
PROG
SEL = 0x01
DIN=addr[7:0]
SEL = 0x03
DIN =0x84
Set ADDRH
SEL = 0x00
DIN =addr[15:8]
Write
Read
DeassertYE
SEL= 0x03
DIN=0xF0
SEL=0x03
DIN =0x85
30 us
SEL=0x03
DIN =0x85
5us
As sert YE
SetDAT A
SetADDRL
SEL = 0x03
DIN=0xC5
SEL = 0x02
DIN=data[7:0]
SEL = 0x01
DIN=addr[7:0]
10 us
DeassertXE&
NVST R
DeassertPROG
Yes
20ns
Set ADDRH
As sertNVST R
No, increm ent YADDR
Wr Done
SEL = 0x00
DIN =addr[15:8]
E7
Write OCD
0x08,
0x0F,
0x86,
0x01,
0xE7
Autobaud
Val ueforWr
T es tmode
Register
Wr/Rd
Memory ?
18
Write OCD
0x08,
0x0F,
0x86,
0x01,
0x18
WriteOCD
0x80
Flash
Controller
By passed
Set
T MR
&
TEST
1
FFREQL*
4E
WriteOCD
0xF0
WriteOCD
0x04
E2
WriteOCD
0x08,
0x0F,
0x86,
0x01,
0xE2
Release
DBG
20us
SEL=0x03
DIN =0x81
Address Val idto
DataVal id
SetADDRL
SEL = 0x01
DIN=addr[7:0]
5us
SEL=0x03
DIN =0x00
45 ns
SEL = 0x05
DOUT =data[7:0]
STOP
1us
Rd Loop
Done
Yes
No, increm ent YADDR
Figure 8. Z8FMC16100 Flash Gang Programming Flow
PRS000502-1005
PRELIMINARY
Flash Memory Programming Overview