Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
PD78363A,78365A,78366A,78368A
16/8-BIT SINGLE-CHIP MICROCONTROLLERS
DESCRIPTION
PD78366A is provided with a high-speed, high-performance CPU and powerful operation functions. Unlike the
existing PD78328, PD78366A is also provided with a high-resolution PWM signal output function which substantially contributes to improving the performance of the inverter control. A PROM model, PD78P368A, is also available. Detailed functions, etc. are described in the following users manual. Be sure to read the manual to design systems.
FEATURES
Internal 16-bit architecture, external 8-bit data bus High-speed processing by pipeline control method and high- speed operating clock
Minimum instruction execution time: 125 ns (internal clock: at 16 MHz, external clock: 8 MHz)
Real-time pulse unit for inverter control 10-bit resolution A/D converter: 8 channels 8-/9-/10-/12-bit resolution variable PWM signal output function: 2 channels Powerful serial interface: 2 channels Internal memory: ROM: none (PD78365A) 24K bytes (PD78363A) 32K bytes (PD78366A) 48K bytes (PD78368A) RAM: 768 bytes (PD78363A) 2K bytes (PD78365A, 78366A, 78368A)
APPLICATION EXAMPLES
Inverter air conditioner Factory automation fields, such as industrial robots and machine tools.
ORDERING INFORMATION
Part Number Package 80-pin plastic QFP (14 20 mm) 80-pin plastic QFP (14 20 mm) 80-pin plastic QFP (14 20 mm) 80-pin plastic QFP (14 20 mm) Internal ROM Mask ROM None Mask ROM Mask ROM
Unless otherwise specified, the functions and performances of the PD78366 are described throughout this document.
The information in this document is subject to change without notice. Document No. U11109EJ2V0DS00 (2nd edition) Date Published September 1997 N Printed in Japan
The mark
1995 1995
PD78372 subseries
(for control application in automotive appliance)
PD78366A subseries
PD78356 subseries
(for camera, HDD)
PD78352A subseries
(for HDD)
PD78334 subseries
(for control application in OA and FA fields)
PD78322 subseries
High-speed, multi-function, reinforced interrupt, 10-bit A/D
PD78328 subseries
(for inverter)
PD78312A subseries
(for control application in OA and FA fields)
P85/TO05
P84/TO04
P83/TO03
P82/TO02
P81/TO01
P80/TO00
P57/A15
P56/A14
P55/A13
P54/A12
ASTB
80 79 78 77 76 75 74 73 72 71 70 69 68 67 66 65 VSS P00/RTP0 P01/RTP1 P02/RTP2 P03/RTP3 P04/PWM0 P05/TCUD/PWM1 P06/TIUD/TO40 P07/TCLRUD WDTO IC VDD VSS X1 X2 MODE1 RESET P30/TXD0 P31/RXD0 P32/SO/SB0 P33/SI/SB1 P34/SCK P35/TX D1 P36/RX D1 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 64 63 62 61 60 59 58 57 56 55 54 53 52 51 50 49 48 47 46 45 44 43 42 41 P52/A10 P51/A9 P50/A8 P47/AD7 P46/AD6 P45/AD5 P44/AD4 P43/AD3 P42/AD2 P41/AD1 P40/AD0 VSS VDD AV DD AV REF P77/ANI7 P76/ANI6 P75/ANI5 P74/ANI4 P73/ANI3 P72/ANI2 P71/ANI1 P70/ANI0 AV SS
P20/NMI
P12
P13
P14
P15
P16
P17
VSS
P24/INTP3/TI
P21/INTP0
P22/INTP1
P23/INTP2
Caution Connect the IC pin directly to VSS. Remark indicates a ROM code suffix
P25/INTP4
P10
P11
MODE0
P53/A11
P91/WR
P90/RD
P93
P92
PD78363A
PD78365A
PD78366A
PD78368A
Minimum instruction execution time Internal memory ROM RAM Memory space General-purpose registers Number of basic instructions Instruction set
None 2K bytes
32K bytes
48K bytes
64K bytes (externally expandable) 8 bits 16 8 banks 115 Input I/O 16-bit transfer/operation Multiplication/division (16 bits 16 bits, 32 bits 16 bits) Bit manipulation String Sum-of-products operation (16 bits 16 bits + 32 bits) Relative operation
I/O lines
16-bit timer 1 10-bit dead time timer 3 16-bit compare register 4 2 kinds of output mode can be selected Mode 0, set-reset output: 6 channels Mode 1, buffer output: 6 channels 16-bit timer 1 16-bit compare register 1 16-bit timer 1 16-bit capture register 1 16-bit capture/compare register 1 16-bit timer 1 16-bit capture register 2 16-bit capture/compare register 1 16-bit timer 1 16-bit compare register 2 16-bit resolution PWM output: 1 channel Pulse outputs associated with real-time pulse unit: 4 lines 8-/9-/10-/12-bit resolution variable PWM output: 2 channels 10-bit resolution, 8 channels Dedicated baud rate generator UART (w/pin selection function): Clocked serial interface/SBI:
1 channel 1 channel
Interrupt function
External: 6, internal: 14 (of which 2 are multiplexed with external) 4 priority levels can be specified through software 3 types of interrupt processing modes selectable (vectored interrupt, macro service, and context switching) 80-pin plastic QFP (14 20 mm) Watchdog timer Standby function (HALT and STOP modes)
Package Others
PD78363A
24K bytes
PD78366A
32K bytes
PD78368A
48K bytes None
PD78365A
Port 5 (P50-P57)
Port 9 (P90-P93)
P90 always functions as RD strobe signal output pin, and P91 always functions as WR strobe signal output pin. P92 and P93 function as I/O port lines. Always fixed to external memory expansion mode.
None
BLOCK DIAGRAM
EXU NMI 5 INTP 5 PROGRAMMABLE INTERRUPT CONTROLLER MAIN RAM GENERAL REGISTERS 128 8 & DATA MEMORY 128 8
ROM/RAM
ALU
A/D CONVERTER
RWM
WATCHDOG TIMER
PORT
P2
P1
P6
P5
PWM
P0
P8
P7
P4
P3
WDTO
RTP
VDD
VSS
Remark The internal ROM and RAM capacities differ depending on the product.
2.
3.
FUNCTIONAL BLOCKS........................................................................................................... 29
3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 EXECUTION UNIT (EXU) ............................................................................................................... 29 BUS CONTROL UNIT (BCU) ......................................................................................................... 29 ROM/RAM ....................................................................................................................................... 29 PORT FUNCTIONS ........................................................................................................................ 30 CLOCK GENERATOR CIRCUIT ................................................................................................... 32 REAL-TIME PULSE UNIT (RPU) .................................................................................................. 34 REAL-TIME OUTPUT PORT (RTP) .............................................................................................. 42 A/D CONVERTER .......................................................................................................................... 43 SERIAL INTERFACE ..................................................................................................................... 44
4.
5. 6. 7. 8. 9.
EXTERNAL DEVICE EXPANSION FUNCTION ............................................................................. 54 STANDBY FUNCTIONS ...................................................................................................................... 55 RESET FUNCTION ............................................................................................................................... 56 INSTRUCTION SET .............................................................................................................................. 57 EXAMPLE OF SYSTEM CONFIGURATION ........................................................................... 71
PIN FUNCTIONS
PORT PINS
I/O Function Port 0. 8-bit I/O port. Can be set in input or output mode in 1-bit units. Shared by: RTP0-RTP3 PWM0 TCUD/PWM1 TIUD/TO40 TCLRUD I/O Port 1. 8-bit I/O port. Can be set in input or output mode in 1-bit units. Port 2. 6-bit input port. NMI INTP0 INTP1 Input INTP2 INTP3/TI INTP4 Port 3. 7-bit I/O port. Can be set in input or output mode in 1-bit units. I/O TXD0 RXD0 SO/SB0 SI/SB1 SCK TXD1 RXD1 I/O Port 4. 8-bit I/O Port. Can be set in input or output mode in 8-bit units. Port 5. 8-bit I/O port. Can be set in input or output mode in 1-bit units. Port 7. 8-bit input port Port 8. 6-bit I/O port. Can be set in input or output mode in 1-bit units. AD0-AD7
Pin name P00-P03 P04 P05 P06 P07 P10-P17 P20 P21 P22 P23 P24 P25 P30 P31 P32 P33 P34 P35 P36 P40-P47
I/O
P50-P57
I/O
A8-A15
P70-P77
Input
ANI0-ANI7
P80-P85
I/O
TO00-TO05
P90 P91 P92 P93 I/O Port 9. 4-bit I/O port. Can be set in input or output mode in 1-bit units.
RD WR
10
Pin name RTP0-RTP3 NMI INTP0 INTP1 INTP2 INTP3 INTP4 TI TCUD TIUD TCLRUD TO00-TO05 TO40 ANI0-ANI7 TXD0 TXD1 RXD0 RXD1 SCK SI SO SB0
11
12
Table 1-1 shows the I/O circuit types of the respective pins, and recommended connections of the unused pins. Figure 1-1 shows the circuits of the respective pins.
Table 1-1. Pin I/O Circuit Type and Recommended Connections of Unused Pins
Pin P00/RTP0-P03/RTP3 P04/PWM0 P05/TCUD/PWM1 5-A P06/TIUD/TO40 P07/TCLRUD P10-P17 P20/NMI P21/INTP0 P22/INTP1 Connect to VSS P23/INTP2 P24/INTP3/TI P25/INTP4 P30/TXD0 5-A P31/RXD0 P32/SO/SB0 P33/SI/SB1 P34/SCK P35/TXD1 P36/RXD1 5-A P40/AD0-P47/AD7 P50/A8-P57/A15 P70/ANI0-P77/ANI7 P80/TO00-P85/TO05 P90/RD P91/WR P92, P93 ASTB WDTO MODE0, MODE1 RESET AVREF, AVSS AVDD IC 5 19 1 2 Connect to VSS Connect to VDD Connect to VSS Connect to VSS 5-A Input : Independently connect to VDD or VSS through resistor Output : Leave unconnected 9 Connect to VSS 8-A Input : Independently connect to VDD or VSS through resistor Output : Leave unconnected 2-A 2 Input : Independently connect to VDD or VSS through resistor Output : Leave unconnected I/O circuit type Recommended connections
13
Type 5-A
Pull-up enable VDD P-ch
VDD P-ch
IN/OUT N-ch
Type 2
Type 8-A
Pull-up enable Data VDD P-ch
VDD P-ch
IN
Output disable
IN/OUT N-ch
Type 2-A
VDD
Type 9
Comparator IN P-ch Pull-up enable P-ch N-ch + Vref (Threshold voltage)
IN Input enable
Type 5
VDD Data Output disable P-ch N-ch IN/OUT
Type 19
OUT N-ch
Intput enable
14
CPU ARCHITECTURE
MEMORY SPACE
The PD78366A can access a memory space of 64K bytes. Figures 2-1 through 2-3 show the memory map.
FF00H FEFFH
Main RAM (256 8) FF00H Data memory FDFFH Peripheral RAM (1792 8) F700H F6FFH Memory space (64 K 8) Program memory Data memory External memory Note (14080 8)
F700H
BFFFH Program area 1000H 0FFFH 0800H 07FFH 0080H 007FH CALLT instruction table area (64 8) Program memory Data memory Internal ROM (49152 8) 0040H 003FH Vector table area (64 8) 0000H 0000H 0000H 0FFFH CALLF instruction entry area (2048 8) Program area External memory (63232 8)
C000H BFFFH
Note Accessed in external memory expansion mode. Caution For word access (including stack operations) to the main RAM area (FE00H-FEFFH), the address that specifies the operand must be an even value.
15
FF00H FEFFH
Main RAM (256 8) FF00H Data memory FDFFH Peripheral RAM (1792 8) F700H F6FFH Memory space (64 K 8) Program memory Data memory External memory Note (30464 8)
F700H
7FFFH Program area 1000H 0FFFH 0800H 07FFH 0080H 007FH CALLT instruction table area (64 8) Program memory Data memory Internal ROM (32768 8) 0040H 003FH Vector table area (64 8) 0000H 0000H 0000H 0FFFH CALLF instruction entry area (2048 8) Program area External memory (63232 8)
8000H 7FFFH
Note Accessed in external memory expansion mode. Caution For word access (including stack operations) to the main RAM area (FE00H-FEFFH), the address that specifies the operand must be an even value.
16
FF00H FEFFH
Main RAM (256 8) FF00H Data memory FDFFH Peripheral RAM (512 8) FC00H FBFFH Memory space (64 K 8) Program memory Data memory External memory Note (39936 8)
FC00H
5FFFH Program area 1000H 0FFFH 0800H 07FFH 0080H 007FH CALLT instruction table area (64 8) Program memory Data memory Internal ROM (24576 8) 0040H 003FH Vector table area (64 8) 0000H 0000H 0000H 0FFFH CALLF instruction entry area (2048 8) Program area External memory (64512 8)
6000H 5FFFH
Note Accessed in external memory expansion mode. Caution For word access (including stack operations) to the main RAM area (FE00H-FEFFH), the address that specifies the operand must be an even value.
17
The PD78366A is provided with many addressing modes that improve the operability of the memory and can be used with high-level languages. Especially, an area of addresses F700H-FFFFH (In the PD78363A, FC00H-FFFFH) to which the data memory is mapped can be addressed in a mode peculiar to the functions provided in this area, including special function registers (SFR) and general-purpose registers.
SFR addressing
General-purpose register FE80H FE7FH FE20H FE1FH Main RAM FE00H FDFFH Peripheral RAM F700H F6FFH External memory 6C00H BFFFH Internal ROM Note
Register addressing
Direct addressing Register indirect addressing Based addressing Based indexed addressing Based indexed addressing (with displacement)
0000H
Note Is external memory in the ROMless mode. Caution For word access (including stack oprations) to the main RAM area (FE00H-FEFFH), the address that specifies the operand must be an even value.
18
SFR addressing
General-purpose register FE80H FE7FH FE20H FE1FH Main RAM FE00H FDFFH Peripheral RAM F700H F6FFH External memory 8000H 7FFFH Internal ROM Note
Register addressing
Direct addressing Register indirect addressing Based addressing Based indexed addressing Based indexed addressing (with displacement)
0000H
Note Is external memory in the ROMless mode of the PD78365A or PD78366A. Caution For word access (including stack oprations) to the main RAM area (FE00H-FEFFH), the address that specifies the operand must be an even value.
19
SFR addressing
General-purpose register FE80H FE7FH FE20H FE1FH Main RAM FE00H FDFFH Peripheral RAM FC00H FBFFH External memory 6000H 5FFFH Internal ROM Note
Register addressing
Direct addressing Register indirect addressing Based addressing Based indexed addressing Based indexed addressing (with displacement)
0000H
Note Is external memory in the ROMless mode. Caution For word access (including stack oprations) to the main RAM area (FE00H-FEFFH), the address that specifies the operand must be an even value. 2.3 PROCESSOR REGISTERS Control registers General-purpose registers Special function registers (SFRs)
The PD78366A is provided with the following three types of processor registers:
20
: User flag : Sign flag (MSB of execution result) : Zero flag : Register set select flag : Auxiliary carry flag : Interrupt request enable flag : Parity/overflow flag : Carry flag
21
The PD78366A is provided with eight banks of general-purpose registers with one bank consisting of 8 words 16 bits. Figure 2-10 shows the configuration of the general-purpose register banks. The generalpurpose registers are mapped to an area of addresses FE80H-FEFFH. Each of these registers can be used as an 8-bit register. In addition, two registers can be used as one 16-bit register pair (refer to Figure 2-11 ). These general-purpose registers facilitate complicated multitask processing.
Bank 1 Bank 0 RP7 RP6 RP5 RP4 RP3 RP2 RP1 RP0 15 0
15
22
Special function registers (SFRs) are registers assigned special functions such as mode registers and control registers for internal peripheral hardware, and are mapped to a 256-byte address space at FF00H through FFFFH. Table 2-1 lists the SFRs. The meanings of the symbols in this table are as follows: Symbol ................................... Indicates the mnemonic symbol for an SFR. This mnemonic can be coded in the operand field of an instruction. R/W ........................................ Indicates whether the SFR can be read or written. R/W : Read/write R W : Read only : Write only
Bit units for manipulation ...... Indicates bit units in which the SFR can be manipulated. The SFRs that can be manipulated in 16-bit units can be coded as an sfrp operand. Specify an even address for these SFRs. The SFRs that can be manipulated in 1-bit units can be coded as the operand of bit manipulation instructions. On reset ................................. Indicates the status of the register at RESET input. Cautions 1. Do not access the addresses in the range FF00H through FFFFH to which no special function register is allocated. If these addresses are accessed, malfunctioning may occur. 2. Do not write data to the read-only registers. Otherwise, the internal circuit may not operate normally. 3. When using read data as byte data, process undefined bit(s) first. 4. TOUT and TXS are write-only registers. Do no read these registers. 5. Bits 0, 1, and 4 of SBIC are write-only bits. When these bits are read, they are always "0".
23
Address
Symbol
R/W
On reset
24
Address
Symbol
R/W
On reset
25
Address
Symbol
R/W
On reset
: read/write
26
Address
Symbol
R/W
On reset
27
Address
Symbol
R/W
On reset
R/W
G G G G G G G G G G G
Note The value of the MW register at reset time differs depending on the product.
PD78363A PD78368A
: 60H : 00H
28
FUNCTIONAL BLOCKS
EXECUTION UNIT (EXU)
EXU controls address computation, arithmetic and logical operations, and data transfer through microprogram. EXU has an internal main RAM. This RAM can be accessed by instructions faster than the peripheral RAM. 3.2 BUS CONTROL UNIT (BCU)
BCU starts necessary bus cycles according to the physical address obtained by the execution unit (EXU).If EXU does not request start of the bus cycle, an address is generated to prefetch an instruction. The prefetched op code is stored in an instruction queue. 3.3 ROM/RAM
The internal ROM and RAM capacities differ depending on the product. The PD78363A has a 24-KB ROM and a 512-B peripheral RAM. The PD78366A has a 32-KB ROM and a 1792-B peripheral RAM. The PD78368A has a 48-KB ROM and a 1792-B peripheral RAM. The PD78365A does not have a ROM and only has a 1792-B peripheral RAM. Access to the ROM can be disabled by using the MODE0 and MODE1 pins, in which case an external memory of 64 KB can be accessed.
29
The PD78366A is provided with the ports shown in Figure 3-1 for various control operations. The functions of each port are listed in Table 3-1. These ports function not only as digital ports but also as input/output lines of the internal hardware.
P00
P50
Port 0
Port 5
P07 P10
P57
Port 1
P70-P77
Port 7
P17 P80 P20 Port 8 Port 2 P85 P25 P90 P30 P93 Port 3 P36 Port 9
Port 4
P40-P47
30
Port 0
Port 1
8-bit I/O port. Can be set in input or output mode in 1-bit units. 6-bit input port.
Port 2
Port 3
7-bit I/O port. Can be set in input or output in 1-bit units. 8-bit I/O port. Can be set in input or output mode in 8-bit units. 8-bit I/O port. Can be set in input or output mode in 1-bit units. 8-bit input port.
Port 4
Port 5 Port 7
Input analog signals to A/D converter (fixed to the control mode). In control mode, outputs timer of real-time pulse unit (RPU).
Port 8
6-bit I/O port. Can be set in input or output mode in 1-bit units. 4-bit I/O port. Can be set in input or output mode in 1-bit units.
Port 9
31
The clock generator circuit generates and controls the internal system clock (CLK) that is supplied to the CPU.
X1
X2
STOP mode
Remarks 1. 2. 3.
fXX : crystal oscillation frequency fX : external clock frequency fCLK : internal system clock frequency
By connecting an 8-MHz crystal resonator across the X1 and X2 pins, an internal system clock of up to 16 MHz (fCLK) can be generated. The system clock oscillation circuit oscillates by using the crystal resonator connected across the X1 and X2 pins. It stops oscillation in standby mode. An external clock can also be input. To do so, input the clock signal to the X1 pin and leave the X2 pin open. Caution Do not set STOP mode when the external clock is used.
32
X2
Open X2
Cautions 1. Wire the portion enclosed by dotted line in Figure 3-3 as follows to avoid adverse influences due to wiring capacity when using the system clock oscillation circuit. Keep the wiring length as short as possible. Do not cross the wiring with the other signal line. Make sure that the wiring is not close to lines through which a high alternating current flows. Always keep the ground point of the capacitor of the oscillation circuit at the same potential as VSS. Do not ground the circuit to a ground pattern through which a high current flows. Do not extract signals from the oscillator circuit. 2. To input an external clock, do not connect a load such as wiring capacitance to the X2 pin.
33
The real-time pulse unit (RPU) can measure pulse intervals and frequencies, and output programmable pulses (six channels of PWM control signals). The RPU consists of five 16-bit timers (timers 0 through 4), of which one is provided with a 10-bit dead time timer, which is ideal for inverter control. In addition, a function to turn off the output by the software or an external interrupt is also provided. Each timer has the following features:
Timer 0 : Controls the PWM period of the TO00 through TO05 pins. In addition, operates as a
general-purpose interval timer. Timer 0 has the following five operation modes: General-purpose interval timer mode PWM mode 0 (symmetrical triangular wave) PWM mode 0 (asymmetrical triangular wave) PWM mode 0 (saw-tooth wave) PWM mode 1
Timer 1 : Operates as a general-purpose interval timer. Timers 2, 3 : Has a programmable input sampling circuit that rejects the noise of an input signal,
and a capture function.
Timer 4 : Operates as a general-purpose timer or an up-down counter. When operating as a generalpurpose timer, controls the PWM cycle of the TO40 output pin. Timer 4 has the following two operation modes: General-purpose timer mode Up/down counter mode (UDC mode)
34
INTCM03
35
fCLK
DTIME
ALVTO Output off function by external interrupt and software Underflow R S R TO00 (U phase) TO01 (U phase)
BFCM00 CM00 R
10
DTM0 S
R S R
R S R S
36
BFCM00
: Timer register : Compare registers : Reload register : Dead time timers : Bit 2 of TUM0 register
37
Underflow TOUT 6-bit write-only register Output off function by external interrupt and software
TO00 TO02 TO04 (U phase) (V phase) (W phase) TO01 TO03 TO05 (U phase) (V phase) (W phase)
MBUF0-MBUF5 : Master buffer registers SBUF0-SBUF5 : Slave buffer registers TOUT : Timer out register
38
16
Clear
Output off function by external interrupt and software TO00 TO02 TO04 TO01 TO03 TO05
39
INTP3
INTP3/INTCC20
INTOV3
16 4-point sampling noise rejection circuit fCLK fCLK/22 fCLK/23 fCLK/24 INTP1 4-point sampling noise rejection circuit fCLK fCLK/22 fCLK/23 fCLK/24 INTP4 4-point sampling noise rejection circuit fCLK fCLK/22 fCLK/23 fCLK/24 Capture register CT31 INTP4 Capture register CT30 INTP1 Capture/compare register CC30
INTP0
INTP0/INTCC30
40
Timer register TM4 INTCM40 16 Compare register CM40 ALV40 S R Compare register CM41 Q TO40
INTCM41
OVF UDF
TIUD TCUD
Up/down detector
INTCM40
INTCM41
41
The real-time output port is a 4-bit port that can output the contents of the real-time output port register (RTP) in synchronization with the trigger signal from the real-time pulse unit (RPU). It can output synchronization pulses of multiple channels. Also, PWM modulation can be applied to P00-P03.
Internal bus
RTP INTCM03 (from RPU) INTCM10 (from RPU) INTP0/INTCC30 (from RPU) Software trigger
RTPM
PWM0 PWM1
P03P02 P01P00
42
The PD78366A contains a high-speed, high-resolution 10-bit analog-to-digital (A/D) converter (conversion time 12.6 s at an internal clock frequency of 16 MHz). Successive approximation type is adopted. This converter is provided with eight analog input lines (ANI0-ANI7) and can perform various operations as the application requires, in select, scan, and mixed modes. When A/D conversion ends, an internal interrupt (INTAD) occurs. This interrupt can start a macro service that executes automatic data transfer through hardware.
ANI0 ANI1
Input curcuit
AV DD AV REF
ANI6 ANI7
Controller
43
The PD78366A is provided with the following two independent serial interfaces:
Asynchronous serial interface (UART) (with pin selection function) Clocked serial interface
3-line serial I/O mode Serial bus interface mode (SBI mode) Since the PD78366A contains a baud rate generator (BRG), any serial transfer rate can be set regardless of the operating clock frequency. The baud rate generator is a block to generate the shift clock for the transmit/ receive serial interface, and is used commonly with the two channels of the serial interfaces. The serial transfer rate can be selected in a range of 110 bps to 38.4 Kbps by the mode register.
Internal bus
PE FE OVE
TXS
Selector
INTSER INTSR
INTST
44
Selector
1 16
1 16
SO latch
SO/SB0
Busy/ acknowledge detector circuit
MOD1 MOD2
Selector
SCK
INTCSI
1/2
Internal bus
7 BRG
7 BRGC
1 2
Coincidence
Serial interface
45
The PD78366A is provided with two lines that output 8-/9-/10-/12-bit resolution variable PWM signals. The PWM output can be used as a digital-to-analog conversion output by connecting an external lowpass filter, and ideal for controlling actuators such as motors. An output of between 244 Hz and 62.5 kHz can be obtaind, depending on the combination of the count clock (62.5 ns to 1 s) and counter bit length (8, 9, 10, or 12) (at an internal clock frequency of 16 MHz).
Comparator (12)
0-11
Remark n = 0, 1
46
The watchdog timer is a free running timer equipped with a non-maskable interrupt function to prevent program hang-up or deadlock. When an error of the program is detected, the overflow interrupt (INTWDT) of the watchdog timer occurs and the watchdog timer output pin (WDTO) goes low. By connecting this output pin to the RESET pin, any malfunctioning of the application system due to program error can be prevented.
f CLK/29 f CLK/211 f CLK/213 f CLK Clear WDT CLR WDT STOP INTWDT Watchdog timer (8 bits) Overflow S Clear Timer (5 bits) Overflow Q R WDTO
47
INTERRUPT FUNCTIONS
OUTLINE
The PD78366A is provided with powerful interrupt functions that can process interrupt requests from the internal hardware peripherals and external sources. In addition, the following three interrupt processing modes are available. In addition, four levels of interrupt priority can be specified. Vectored interrupt processing Macro service Context switching
Note
Name Trigger NMI pin input Watchdog timer Overflow of timer 3 0 NMI INTWDT INTOV3
Source unit
Macro service
Context switching
Nonmaskable
None 0004H 0006H 0008H 000AH External 3 4 5 6 INTP2 INTP2 pin input External/RPU External 000CH 000EH 0010H 0012H 0014H Provided 8 9 10 11 12 13 14 15 INTCM10 INTCM40 INTCM41 INTSER INTSR INTST INTCSI INTAD BRK BRKCS TRAP RESET CM10 coincidence signal CM40 coincidence signal CM41 coincidence signal Receive error of UART End of UART reception End of UART transfer End of CSI transfer/reception End of A/D conversion BRK instruction BRKCS instruction Illegal op code trap Reset input CSI A/D UART RPU 0016H 0018H 001AH 001CH 001EH 0020H 0022H 0024H 003EH None 003CH
None
1 INTP0/INTCC30 INTP0 pin input/CC30 coincidence signal 2 INTP1 INTP1 pin input
INTP3/INTCC20 INTP3 pin input/CC20 coincidence signal INTP4 INTTM0 INTCM03 INTP4 pin input Underflow of timer 0 CM03 coincidence signal
Maskable
Provided
None Provided
None 0000H
Note Default priority : Priority that takes precedence when two or more maskable interrupts occur at the same time. 0 is the highest priority, and 15 is the lowest.
48
The PD78366A has a total of five macro services. Each macro service is described below. (1) Counter mode: EVTCNT Operation (a) Increments or decrements an 8-bit macro service counter (MSC). (b) A vector interrupt request is generated when MSC reaches 0.
MSC
+1/1
Application example: As event counter, or to measure number of times a value is captured (2) Block transfer mode: BLKTRS Operation (a) Transfers data block between a buffer and a SFR specified by SFR pointer (SFRP). (b) The transfer source and destination can be in SFR or buffer area. The length of the transfer data can be specified to be byte or word. (c) The number of times the data is to be transferred (block size) is specified by MSC. (d) MSC is auto decremented by one each time the macro service has been executed. (e) When MSC reaches 0, a vector interrupt request is generated.
SFRP 1 MSC
Buffer N
Buffer 1
SFR
Internal bus
49
Buffer N
+1/+2
Buffer 1
SFR
Internal bus
Application example: Same as (2) (4) Data differential mode: DTADIF Operation (a) Calculates the difference between the contents of SFR (current value) specified by SFRP and the contents of SFR saved to the last data buffer (LDB). (b) Stores the result of the calculation in a predetermined buffer area. (c) Stores the contents of the current value of the SFR in LDB. (d) The number of times the data is to be transferred (block size) is specified by MSC. Each time the macro service is executed, MSC is auto decremented by one. (e) When MSC reaches 0, a vector interrupt request is generated. Remark The differential calculation can be carried out only with 16-bit SFRs.
Buffer 1
Differential calculation
Internal bus
Application example : To measure cycle and pulse width by the capture register of the real-time pulse unit (RPU)
50
Internal bus
51
This function is to select a specific register bank through the hardware, and to branch execution to a vector address predetermined in the register bank. At the same time, it saves the present contents of the PC and PSW to the register bank when an interrupt occurs, or when the BRKCS instruction is executed. 4.3.1 Context Switching Function by Interrupt Request
When a context switching enable flag corresponding to each maskable interrupt request is set to 1 in the EI (interrupt enable) status, the context switching function can be started. The context switching operation by an interrupt request is performed as follows: (1) When an interrupt request is generated, a register bank to which the context is to be switched is specified by the contents of the low-order 3 bits of the row address (even address) of the corresponding vector table. (2) A predetermined vector address is transferred to the PC in the register bank to which the context is to be switched, and the contents of the PC and PSW immediately before the switching takes place are saved to the register bank. (3) Execution branches to an address indicated by the contents of the PC newly set.
Register Bank RP0 PC RP1 Exchange RP2 Save PSW RP5 RP6 RP7 RP3 RP4
52
The context switching function can be started by the BRKCS instruction. The operation of context switching by an interrupt request is as follows: (1) An 8-bit register is specified by the operand of the BRKCS instruction, and the register bank to which the context is to be switched is specified by the contents of this register (only the low-order 3 bits of 8 bits are valid). (2) The vector address predetermined in the register bank to which the context is to be switched is transferred to the PC, and at the same time, the contents of the PC and PSW immediately before the switching takes place are saved to the register bank. (3) Execution branches to the contents of the PC newly set. 4.3.3 Restoration from Context Switching
To restore from the switched context, one of the following two instructions are used. Which instruction is to be executed is determined by the source that has started the context switching.
53
54
Ordinary
RE
se
SE
lea
re
re lea
se
HA
SE
se
OP
LT
RE
ST
se
STOP
NM
HALT
55
RESET input
Analog delay
Analog delay
Analog delay
Rejected as noise
Reset accepted
Reset released
To effect reset on when power is applied, make sure that sufficient time elapses to stabilize the oscillation after the power is applied until the reset signal is accepted, as shown in Figure 7-2.
VDD
56
Description R0, R1, R2, R3, R4, R5, R6, R7, R8, R9, R10, R11, R12, R13, R14, R15 R0, R1, R2, R3, R4, R5, R6, R7 C, B RP0, RP1, RP2, RP3, RP4, RP5, RP6, RP7 RP0, RP1, RP2, RP3, RP4, RP5, RP6, RP7 DE, HL, VP, UP Special function register symbol (Refer to Table 2-1.) Special function register symbol (register that can be manipulated in 16-bit units. Refer to Table 2-1.) RP0, RP1, RP2, RP3, RP4, RP5/PSW, RP6, RP7 (More than one symbol can be written. However, RP5 can be written only for PUSH and POP instructions, and PSW can be written only for PUSHU and POPU instructions.) [DE], [HL], [DE+], [HL+], [DE], [HL], [VP], [UP] [DE + A], [HL + A], [DE + B], [HL + B], [VP + DE], [VP + HL] [DE + byte], [HL + byte], [VP + byte], [UP + byte], [SP + byte] word[A], word[B], word[DE], word[HL] ; ; ; ; register indirect mode based indexed mode based mode indexed mode
post
mem
FE20H-FF1FH immediate data or label FE20H-FF1EH immediate data (however, bit0 = 0) or label (manipulated in 16-bit units) 0000H-FDFFH immediate data or label; relative addressing 0000H-FDFFH immediate data or label; immediate addressing (However, up to FFFFH can be written for MOV instruction. Only FE00H-FEFFH can be written for MOVTBLW instruction.) 800H-FFFH immediate data or label 40H-7EH immediate data (however, bit0 = 0)Note or label 16-bit immediate data or label 8-bit immediate data or label 3-bit immediate data or label 3-bit immediate data (0-7)
Note Do not access bit0 = 1 (odd address) in word units. Remarks 1. 2. 3. rp and rp1 are the same in terms of register name that can be written but are different in code to be generated. r, r1, rp, rp1, and post can be written in absolute name (R0-R15, RP0-RP7) and function name (X, A, C, B, E, D, L, H, AX, BC, DE, HL, VP, and UP). Immediate addressing can address the entire space. Relative addressing can address only a range of 128 to +127 from the first address of the next instruction.
57
Flag Mnemonic Operand Byte Operation S r1, #byte saddr, #byte sfrNote , r, r1 A, r1 A, saddr saddr, A saddr, saddr A, sfr sfr, A MOV A, mem mem, A #byte 2 3 3 2 1 2 2 3 2 2 1-4 1-4 2 2 4 4 3 3 2 2 2 2 1 2 2-4 2 3 2 3 r1 byte (saddr) byte sfr byte r r1 A r1 A (saddr) (saddr) A (saddr) (saddr) A sfr sfr A A (mem) (mem) A A ((saddrp)) ((saddrp)) A A (addr16) (addr16) A PSWL byte PSWH byte PSWL A PSWH A A PSW L A PSW H A r1 r r1 A (mem) A (saddr) A sfr A ((saddrp)) (saddr) (saddr) Z AC P/V CY
A, [saddrp] [saddrp], A A, !addr16 !addri16, A PSWL, #byte PSWH, #byte PSWL, A PSWH, A A, PSWL A, PSWH A, r1 r, r1 A, mem XCH A, saddr A, sfr A, [saddrp] saddr, saddr
Note When STBC or WDM is written as sfr, this instruction is treated as a dedicated instruction whose number of bytes is different from that of this instruction. Remark For symbols in flag, refer to the table below. Symbol (Blank) 0 1 P V R No change Cleared to 0 Set to 1 Set/cleared according to result P/V flag functions as parity flag P/V flag operates as overflow flag Value previously saved is restored Remarks
58
Flag Mnemonic Operand Byte Operation S rp1, #word saddrp, #word sfrp, #word rp, rp1 AX, saddrp saddrp, AX 3 4 4 2 2 2 3 2 2 4 4 2-4 2-4 2 3 3 2 2-4 2 3 4 2 2 3 3 2-4 2-4 2 3 4 2 2 3 3 2-4 2-4 rp1 word (saddrp) word sfrp word rp rp1 AX (saddrp) (saddrp) AX (saddrp) (saddrp) AX sfrp sfrp AX rp1 (addr16) (addr16) rp1 AX (mem) (mem) AX AX (saddrp) AX sfrp (saddrp) (saddrp) rp rp1 AX (mem) A, CY A + byte (saddr), CY (saddr) + byte sfr, CY sfr + byte r, CY r + r1 A, CY A + (saddr) A, CY A + sfr (saddr), CY (saddr) + (saddr) A, CY A + (mem) (mem), CY (mem) + A A, CY A + byte + CY (saddr), CY (saddr) + byte + CY sfr, CY sfr + byte + CY r, CY r + r1 + CY A, CY A + (saddr) + CY A, CY A + sfr + CY (saddr), CY (saddr) + (saddr) + CY A, CY A + (mem) + CY (mem), CY (mem) + A + CY V V V V V V V V V V V V V V V V V V Z AC P/V CY
MOVW
saddrp, saddrp AX, sfrp sfrp, AX rp1, !addr16 !addr16, rp1 AX, mem mem, AX AX, saddrp AX, sfrp
XCHW
saddrp, saddrp rp, rp1 AX, mem A, #byte saddr, #byte sfr, #byte r, r1
ADD
A, saddr A, sfr
8-bit operation
saddr, saddr A, mem mem, A A, #byte saddr, #byte sfr, #byte r, r1 ADDC A, saddr A, sfr saddr, saddr A, mem mem, A
59
Flag Mnemonic Operand Byte Operation S A, #byte saddr, #byte sfr, #byte r, r1 SUB A, saddr A, sfr saddr, saddr A, mem mem, A A, #byte saddr, #byte sfr, #byte 2 3 4 2 2 3 3 2-4 2-4 2 3 4 2 2 3 3 2-4 2-4 2 3 4 2 2 3 3 2-4 2-4 A, CY A byte (saddr), CY (saddr) byte sfr, CY sfr byte r, CY r r1 A, CY A (saddr) A, CY A sfr (saddr), CY (saddr) (saddr) A, CY A (mem) (mem), CY (mem) A A, CY A byte CY (saddr), CY (saddr) byte CY sfr, CY sfr byte CY r, CY r r1 CY A, CY A (saddr) CY A, CY A sfr CY (saddr), CY (saddr) (saddr) CY A, CY A (mem) CY (mem), CY (mem) A CY A A byte (saddr) (saddr) byte sfr sfr byte r r r1 A A (saddr) A A sfr (saddr) (saddr) (saddr) A A (mem) (mem) (mem) A Z AC P/V CY V V V V V V V V V V V V V V V V V V P P P P P P P P P
8-bit operation
r, r1 SUBC A, saddr A, sfr saddr, saddr A, mem mem, A A, #byte saddr, #byte sfr, #byte r, r1 AND A, saddr A, sfr saddr, saddr A, mem mem, A
60
Flag Mnemonic Operand Byte Operation S A, #byte saddr, #byte sfr, #byte r, r1 OR A, saddr A, sfr saddr, saddr A, mem mem, A A, #byte saddr, #byte sfr, #byte 2 3 4 2 2 3 3 2-4 2-4 2 3 4 2 2 3 3 2-4 2-4 2 3 4 2 2 3 3 2-4 2-4 A A byte (saddr) (saddr) byte sfr sfr byte r, r r1 A A (saddr) A A sfr (saddr) (saddr) (saddr) A A (mem) (mem) (mem) A A A byte (saddr) (saddr) byte sfr sfr byte r r r1 A A (saddr) A A sfr (saddr) (saddr) (saddr) A A (mem) (mem) (mem) A A byte (saddr) byte sfr byte r r1 A (saddr) A sfr (saddr) (saddr) A (mem) (mem) A Z AC P/V CY P P P P P P P P P P P P P P P P P P V V V V V V V V V
8-bit operation
r, r1 XOR A, saddr A, sfr saddr, saddr A, mem mem, A A, #byte saddr, #byte sfr, #byte r, r1 CMP A, saddr A, sfr saddr, saddr A, mem mem, A
61
Flag Mnemonic Operand Byte Operation S AX, #word saddrp, #word sfrp, #word ADDW rp, rp1 AX, saddrp AX, sfrp saddrp, saddrp AX, #word 3 4 5 2 2 3 3 3 4 5 2 2 3 3 3 4 5 2 2 3 3 2 2 2 2 2 AX, CY AX + word (saddrp), CY (saddrp) + word sfrp, CY sfrp + word rp, CY rp + rp1 AX, CY AX + (saddrp) AX, CY AX + sfrp (saddrp), CY (saddrp) + (saddrp) AX, CY AX word (saddrp), CY (saddrp) word sfrp, CY sfrp word rp, CY rp rp1 AX, CY AX (saddrp) AX, CY AX sfrp (saddrp), CY (saddrp) (saddrp) AX word (saddrp) word sfrp word rp rp1 AX (saddrp) AX sfrp (saddrp) (saddrp) AX AX r1 AX (quotient), r1 (remainder) AX r1 AX (high-order 16 bits), rp1 (low-order 16 bits) AX rp1 AXDE (quotient), rp1 (remainder) AXDE rp1 AX (high-order 16 bits), rp1 (low-order 16 bits) AX rp1 AXDE (B) (C) + AXDE B B + 2, C C + 2, n n 1 End if n = 0 or P/V = 1 AXDE (B) (C) + AXDE B B + 2, C C + 2, n n 1 if overflow (P/V = 1) then AXDE 7FFFFFFFH if underflow (P/V = 1) then AXDE 80000000H end if n = 0 or P/V = 1 AX AX + | (DE) (HL) | DE DE + 2 HL HL + 2 C C 1 end if C = 0 or cy = 1 Z AC P/V CY V V V V V V V V V V V V V V V V V V V V V
16-bit operation
saddrp, #word sfrp, #word SUBW rp, rp1 AX, saddrp AX, sfrp saddrp, saddrp AX, #word saddrp, #word sfrp, #word CMPW rp, rp1 AX, saddrp AX, sfrp saddrp, saddrp
Multiplication /division
MACW
MACSW
Relative operation
SACW
[DE + ], [HL + ]
62
Flag Mnemonic Operand Byte Operation S MOVTBLW !addr16, n r1 saddr DEC r1 saddr INCW rp2 saddrp DECW ROR ROL RORC ROLC SHR SHL rp2 saddrp r1, n r1, n r1, n r1, n r1, n r1, n rp1, n 4 1 2 1 2 1 3 1 3 2 2 2 2 2 2 2 (addr16 + 2) (addr16), n n 1 addr16 addr16 2, End if n = 0 r1 r1 + 1 (saddr) (saddr) + 1 r1 r1 1 (saddr) (saddr) 1 rp2 rp2 + 1 (saddrp) (saddrp) + 1 rp2 rp2 1 (saddrp) (saddrp) 1 (CY, r17 r1 0, r1m1 r1m ) n times (CY, r10 r1 7, r1m+1 r1m) n times (CY r10, r17 CY, r1m1 r1m) n times (CY r17, r10 CY, r1m+1 r1m ) n times (CY r10, r17 0, r1m1 r1m) n times (CY r17, r10 0, r1m+1 r1m ) n times (CY rp10, rp115 0, rp1m1 rp1m) n times (CY rp115 , rp10 0, rp1m+1 rp1m ) n times A30 (rp1)30, (rp1)74 A30, (rp1)30 (rp1)74 A30 (rp1)74, (rp1)30 A30, (rp1)74 (rp1)30 0 0 0 P P P P P P P V V V V Z AC P/V CY
Table shift
SHRW
SHLW
rp1, n
ROR4
[rp1]
ROL4
[rp1]
BCD adjustment
Data conversion
CVTBW
Remarks 1. 2.
n of the shift rotate instruction indicates the number of times the shift rotate instruction is executed. The address of the table shift instruction ranges from FE00H to FEFFH.
63
Flag Mnemonic Operand Byte Operation S CY, saddr.bit CY, sfr.bit CY, A.bit CY, X.bit CY, PSWH.bit CY, PSWL.bit MOV1 saddr.bit, CY sfr.bit, CY A.bit, CY X.bit, CY PSWH.bit, CY PSWL.bit, CY CY, saddr.bit CY, /saddr.bit CY, sfr.bit CY, /sfr.bit 3 3 2 2 2 2 3 3 3 3 2 2 2 2 2 2 2 2 3 3 3 3 2 2 2 2 2 2 2 2 3 3 2 2 2 2 CY (saddr.bit) CY sfr.bit CY A.bit CY X.bit CY PSWH.bit CY PSW L.bit (saddr.bit) CY sfr.bit CY A.bit CY X.bit CY PSWH.bit CY PSWL.bit CY CY CY (saddr.bit) CY CY (saddr.bit) CY CY sfr.bit CY CY sfr.bit CY CY A.bit CY CY A.bit CY CY X.bit CY CY X.bit CY CY PSWH.bit CY CY PSWH.bit CY CY PSWL.bit CY CY PSWL.bit CY CY (saddr.bit) CY CY (saddr.bit) CY CY sfr.bit CY CY sfr.bit CY CY A.bit CY CY A.bit CY CY X.bit CY CY X.bit CY CY PSWH.bit CY CY PSWH.bit CY CY PSWL.bit CY CY PSWL.bit Z AC P/V CY
Bit manipulation
CY, A.bit CY, /A.bit AND1 CY, X.bit CY, /X.bit CY, PSWH.bit CY, /PSWH.bit CY, PSWL.bit CY, /PSWL.bit CY, saddr.bit CY, /saddr.bit CY, sfr.bit CY, /sfr.bit CY, A.bit CY, /A.bit OR1 CY, X.bit CY, /X.bit CY, PSWH.bit CY, /PSWH.bit CY, PSWL.bit CY, /PSWL.bit
64
Flag Mnemonic Operand Byte Operation S CY, saddr.bit CY, sfr.bit CY, A.bit XOR1 CY, X.bit CY, PSWH.bit CY, PSWL.bit saddr.bit sfr.bit A.bit SET1 X.bit PSWH.bit 2 2 2 2 3 2 2 2 2 3 3 2 2 2 2 1 1 1 2 2 2 2 3 2 3 3 2 CY CY (saddr.bit) CY CY sfr.bit CY CY A.bit CY CY X.bit CY CY PSWH.bit CY CY PSWL.bit (saddr.bit) 1 sfr.bit 1 A.bit 1 X.bit 1 PSWH.bit 1 PSWL.bit 1 (saddr.bit) 0 sfr.bit 0 A.bit 0 X.bit 0 PSWH.bit 0 PSWL.bit 0 (saddr.bit) (saddr.bit) sfr.bit sfr.bit A.bit A.bit X.bit X.bit PSWH.bit PSWH.bit PSWL.bit PSWL.bit CY 1 CY 0 CY CY 1 0 Z AC P/V CY
Bit manipulation
PSWL.bit saddr.bit sfr.bit A.bit CLR1 X.bit PSWH.bit PSWL.bit saddr.bit sfr.bit A.bit NOT1 X.bit PSWH.bit PSWL.bit SET1 CLR1 NOT1 CY CY CY
65
Flag Mnemonic Operand Byte Operation S CALL !addr16 3 (SP 1) (PC + 3)H, (SP 2) (PC + 3)L, PC addr16, SP SP 2 (SP 1) (PC + 2)H , (SP 2) (PC + 2)L, PC15 11 00001, PC10 0 addr11, SP SP 2 (SP 1) (PC + 1)H, (SP 2) (PC + 1)L, PCH (TPF, 00000000, addr5 + 1), PCL (TPF, 00000000, addr5 ), SP SP 2 (SP 1) (PC + 2)H, (SP 2) (PC + 2)L, PCH rp1 H, PCL rp1 L, SP SP 2 (SP 1) (PC + 2)H, (SP 2) (PC + 2)L, PCH (rp1 + 1), PCL (rp1), SP SP 2 (SP 1) PSWH, (SP 2) PSW L (SP 3) (PC + 1)H, (SP 4) (PC + 1)L, PCL (003EH), PCH (003FH), SP SP 4, IE 0 PCL (SP), PCH (SP + 1), SP SP + 2 PCL (SP), PCH (SP +1) PSWL (SP + 2), PSWH (SP + 3) SP SP + 4 PCL (SP), PCH (SP + 1) PSWL (SP + 2), PSWH (SP + 3) SP SP + 4 (SP 1) sfrH (SP 2) sfrL SP SP 2 {(SP 1) postH, (SP 2) post L, SP SP 2} n times (SP 1) PSWH, (SP 2) PSWL, SP SP 2 {(UP 1) postH, (UP 2) post L, UP UP 2} n times sfrL (SP) sfrH (SP + 1) SP SP + 2 {postL (SP), postH (SP + 1), SP SP + 2} n times PSWL (SP), PSWH (SP + 1), SP SP + 2 {postL (UP),postH (UP + 1), UP UP + 2} n times SP word SP AX AX SP SP SP + 1 SP SP 1 R R R R R R R R R R Z AC P/V CY
CALLF
!addr11
CALLT
[addr5]
BRK
RET
RETB
RETI
2 1 2
sfrp
POP
post PSW
2 1 2 4 2 2 2 2
POPU
MOVW
SP, AX AX, SP
INCW DECW
SP SP
Remark n of the stack manipulation instruction is the number of registers written as post.
66
Flag Mnemonic Operand Byte Operation S CHKL CHKLA sfr sfr !addr16 rp1 BR [rp1] $addr16 BC $addr16 BL BNC $addr16 BNL BZ $addr16 BE BNZ $addr16 BNE BV $addr16 BPE BNV $addr16 BPO BN BP $addr16 $addr16 $addr16 $addr16 $addr16 $addr16 $addr16 $addr16 saddr.bit, $addr16 sfr.bit, $addr16 A.bit, $addr16 BT X.bit, $addr16 PSWH.bit, $addr16 PSWL.bit, $addr16 saddr.bit, $addr16 sfr.bit, $addr16 A.bit, $addr16 BF X.bit, $addr16 PSWH.bit, $addr16 PSWL.bit, $addr16 3 3 3 3 3 3 4 4 3 2 2 3 3 3 3 3 3 3 4 3 2 2 2 2 2 2 2 2 3 3 3 2 (pin level) (signal level before output buffer) A (pin level) (signal level before output buffer) PC addr16 PCH rp1H, PCL rp1L PCH (rp1 + 1), PCL (rp1) PC PC + 2 + jdisp8 PC PC + 2 + jdisp8 if CY = 1 Z AC P/V CY P P
PC PC + 2 + jdisp8 if CY = 0
PC PC + 2 + jdisp8 if Z = 1
PC PC + 2 + jdisp8 if Z = 0
PC PC + 2 + jdisp8 if P/V = 1
PC PC + 2 + jdisp8 if P/V = 0 PC PC + 2 + jdisp8 if S = 1 PC PC + 2 + jdisp8 if S = 0 PC PC + 3 + jdisp8 if (P/V S) Z = 0 PC PC + 3 + jdisp8 if P/V S= 0 PC PC + 3 + jdisp8 if P/V S = 1 PC PC + 3 + jdisp8 if (P/V S) Z = 1 PC PC + 3 + jdisp8 if Z CY = 0 PC PC + 3 + jdisp8 if Z CY = 1 PC PC + 3 + jdisp8 if (saddr.bit) = 1 PC PC + 4 + jdisp8 if sfr.bit = 1 PC PC + 3 + jdisp8 if A.bit = 1 PC PC + 3 + jdisp8 if X.bit = 1 PC PC + 3 + jdisp8 if PSWH.bit = 1 PC PC + 3 + jdisp8 if PSWL.bit = 1 PC PC + 4 + jdisp8 if (saddr.bit) = 0 PC PC + 4 + jdisp8 if sfr.bit = 0 PC PC + 3 + jdisp8 if A.bit = 0 PC PC + 3 + jdisp8 if X.bit = 0 PC PC + 3 + jdisp8 if PSWH.bit = 0 PC PC + 3 + jdisp8 if PSWL.bit = 0
Conditional branch
67
Flag Mnemonic Operand Byte Operation S saddr.bit, $addr16 4 PC PC + 4 + jdisp8 if (saddr.bit) = 1 then reset (saddr.bit) PC PC + 4 + jdisp8 if sfr.bit = 1 then reset sfr.bit PC PC + 3 + jdisp8 if A.bit = 1 then reset A.bit PC PC + 3 + jdisp8 if X.bit = 1 then reset X.bit PC PC + 3 + jdisp8 if PSWH.bit = 1 then reset PSWH.bit PC PC + 3 + jdisp8 if PSWL.bit = 1 then reset PSWL.bit PC PC + 4 + jdisp8 if (saddr.bit) = 0 then set (saddr.bit) PC PC + 4 + jdisp8 if sfr.bit = 0 then set sfr.bit PC PC + 3 + jdisp8 if A.bit = 0 then set A.bit PC PC + 3 + jdisp8 if X.bit = 0 then set X.bit PC PC + 3 + jdisp8 if PSWH.bit = 0 then set PSW H.bit PC PC + 3 + jdisp8 if PSWL.bit = 0 then set PSWL.bit r2 r2 1, then PC PC + 2 + jdisp8 if 2 0 (saddr) (saddr) 1, then PC PC + 3 + jdisp8 if (saddr) 0 PCH R5, PCL R4, R7 PSWH, R6 PSWL, RBS2 0 n, RSS 0, IE 0 PCH R5, PCL R4, R5, R4 addr16 PSWH R7, PSWL R6 PCH R5, PCL R4, R5, R4 addr16 PSWH R7, PSWL R6 R R R R R Z AC P/V CY
sfr.bit, $addr16
PSWH.bit, $addr16
saddr.bit, $addr16
sfr.bit, $addr16
PSWH.bit, $addr16
PSWL.bit, $addr16
BRKCS
RBn
RETCS
!addr16
RETCSB
!addr16
68
Flag Mnemonic Operand Byte Operation S [DE+], A MOVM [DE], A 2 2 (DE+) A, C C 1 End if C = 0 (DE) A, C C 1 End if C = 0 (DE+) (HL+), C C 1 End if C = 0 (DE) (HL), C C 1 End if C = 0 (DE+) A, C C 1 End if C = 0 (DE) A, C C 1 End if C = 0 (DE+) (HL+), C C 1 End if C = 0 (DE) (HL), C C 1 End if C = 0 (DE+) A, C C 1 End if C = 0 or Z = 0 (DE) A, C C 1 End if C = 0 or Z = 0 (DE+) (HL+), C C 1 End if C = 0 or Z = 0 (DE) (HL), C C 1 End if C = 0 or Z = 0 (DE+) A, C C 1 End if C = 0 or Z = 1 (DE) A, C C 1 End if C = 0 or Z = 1 (DE+) (HL+), C C 1 End if C = 0 or Z = 1 (DE) (HL), C C 1 End if C = 0 or Z = 1 (DE+) A, C C 1 End if C = 0 or CY = 0 (DE) A, C C 1 End if C = 0 or CY = 0 (DE+) (HL+), C C 1 End if C = 0 or CY = 0 (DE) (HL), C C 1 End if C = 0 or CY = 0 V Z AC P/V CY
69
Flag Mnemonic Operand Byte Operation S [DE+], A CMPMNC 2 (DE+) A, C C 1 End if C = 0 or CY = 1 (DE) A, C C 1 End if C = 0 or CY = 1 (DE+) (HL+), C C 1 End if C = 0 or CY = 1 (DE) (HL), C C 1 End if C = 0 or CY = 1 STBC byteNote WDM byteNote RSS RSS RBS2 0 n, RSS 0 RBS2 0 n, RSS 1 No Operation IE 1 (Enable Interruptt) IE 0 (Disable Interrupt) Z AC P/V CY V
String
[DE], A
[DE+], [HL+] CMPBKNC [DE], [HL] STBC, #byte WDM, #byte CPU control SWRS RBn SEL RBn, ALT NOP EI DI
2 4 4 1 2 2 1 1 1
MOV
Note If the op code of the STBC register and WDM register manipulation instructions is wrong, an op code trap interrupt occurs. Operation on trap: (SP 1) PSWH, (SP 2) PSWL, (SP 3) (PC 4)H, (SP 4) (PC 4)L, PCL (003CH), PCH (003DH), SP SP 4, IE 0
70
PD78366A
Real-time pulse unit CM03 Dead time setting register U/D 16-bit timer U U
CM00
CM01
V V
TO02 TO03
W W
TO04 TO05
ROM 32K bytes 10-bit A/D converter RAM 2K bytes Generalpurpose port
NMI INTP1
RX D
Indoor apparatus controller
TX D
Serial interface
71
VO I OL Note Output pins other than those in the note Total of all output pins
V mA mA
mA mA mA V V C C
I OH
Analog input voltage A/D converter reference input voltage Operating ambient temperature Storage temperature
P70/ANI0-P77/ANI7 pins
Note P00/RTP0-P03/RTP3, P04/PWM0, P05/TCUD/PWM1, P06/TIUD/TO40, P07/TCLRUD, P10-P17, and P80/TO00-P85/TO05 pins. Caution Product quality may suffer if the absolute rating is exceeded for any parameter, even momentarily. In other words, an absolute maxumum rating is a value at which the possibility of psysical damage to the product cannnot be ruled out. Care must therefore be taken to ensure that the these ratings are not exceeded during use of the product.
Capacitance (T A = 25 C, V SS = VDD = 0 V)
Parameter Input capacitance Output capacitance I/O capacitance Symbol CI CO C IO f = 1 MHz 0 V except measured pins Test conditions MIN. TYP. MAX. 20 20 20 Unit pF pF pF
72
C1
C2
X1 input frequency (f X)
MHz
30
ns
40
170
ns
Caution When using system clock oscillation circuits, to reduce the effect of the wiring capacitouce, etc, wire the area indicated by dotted-line as follows: Make the wiring as short as possible. Do not allow the wiring to intersect other signal lines. Keep it away from other lines in which varying high currents flow. Make sure that the ground point of the oscillation circuit capacitor is always at the same electric potential as VSS. Do not allow the wiring to be grounded to a ground pattern in which very high currents are flowing. Do not extract signals from the oscillation circuit.
73
A A
mA mA V
A A
k
Notes 1. Pins other than those specified in Note 2 . 2. RESET, X1, X2, P20/NMI, P21/INTP0, P22/INTP1, P23/INTP2, P24/INTP3/TI, P25/INTP4, P32/ SO/SB0, P33/SI/SB1 and P34/SCK pins. 3. Pins other than those specified in Notes 4 and 5. 4. P80/TO00-P85/TO05 pins (When I OL = 15 mA is in operation, up to three pins can be ON simultaneously.) 5. P00/RTP0-P03/RTP3, P04/PWM0, P05/TCUD/PWM1, P06/TIUD/TO40 and P07/TCLRUD pins (When I OL = 10 mA is in operation, up to four pins can be ON simultaneously.) as well as P10-P17 pins (When I OL = 10 mA is in operation, up to four pins can be ON simultaneously.). Caution When the P80-P85, P00-P07, and P10-P17 pins are not used under the conditions specified in Notes 4 and 5, they have the same characteristics as in Note 3.
74
Remarks 1. T = t CYK = 1/f CLK (f CLK refers to the internal system clock frequency.) 2. a becomes 1 when the address wait is inserted. Otherwise, it becomes 0. 3. n refers to the number of wait cycles that is inserted by specifying the PWC register. 4. Only the bus timings indicated in this table depend on t CYK.
75
Remark T = tCYK = 1/fCLK (fCLK refers to the internal system clock frequency.)
76
NMI high-/low-level width t WNIH, t WNIL RESET high-/low-level width t WRSH, t WRSL INTP0 high-/low-level width t WI0H, t WI0L
s s
ns
s s s
ns
s s s
ns
s
ns
s s s s s s
ns
s s s
Remarks 1. T = t CYK = 1/f CLK (f CLK refers to the internal system clock frequency.) 2. Ts refers to the input sampling frequency. INTP0-INTP4 can be selected to programmable.
77
A A
Notes 1. The quantization error is excluded. 2. When 0.3 V V IAN 0 V, the conversion result becomes 000H. When 0 V < V IAN < AV REF , the conversion is performed with the 10-bit resolution. When AV REF V IAN +0.3 V, the conversion result becomes 3FFH. 3. The analog input impedance at the time of sampling is the same as the equivalent circuit shown below. (The values in the diagram are TYP. values; they are not guaranteed values)
78
79
High-order address
High-order address
Hi-Z
Data (Input)
Hi-Z
Hi-Z
tHRID
Write Operation
(CLK)
A8-A15 (Output) tSAST AD0-AD7 (Output) Low-order address (Output) tWSTH ASTB (Output) tHSTA WR (Output) tDSTW
High-order address
High-order address
Undefined
tDWST
tDWOD tWWL
tSODW
80
SI tSRXSK tHSKRX
TIUD
tWTIUL
tWCLUH
TCLRUD
tWCLUL
TCUD
81
tWInH
tWInL
82
A B
64 65
80 1
25 24
I M
J K
N NOTE Each lead centerline is located within 0.15 mm (0.006 inch) of its true position (T.P.) at maximum material condition.
L P80GF-80-3B9-2 ITEM A B C D F G H I J K L M N P Q S MILLIMETERS 23.6 0.4 20.0 0.2 14.0 0.2 17.6 0.4 1.0 0.8 0.35 0.10 0.15 0.8 (T.P.) 1.8 0.2 0.8 0.2 0.15+0.10 0.05 0.15 2.7 0.1 0.1 3.0 MAX. INCHES 0.929 0.016 0.795 +0.009 0.008 0.551+0.009 0.008 0.693 0.016 0.039 0.031 0.014 +0.004 0.005 0.006 0.031 (T.P.) 0.071 0.009 0.031+0.009 0.008 0.006+0.004 0.003 0.006 0.106 0.004 0.004 0.119 MAX.
+0.008
55
83
PD78366AGF- -3B9: 80-Pin Plastic QFP (14 20 mm) PD78368AGF- -3B9: 80-Pin Plastic QFP (14 20 mm)
Recommended condition symbol IR35-00-3
Soldering conditions Package peak temperature: 235 C, Duration: 30 sec. max. (210 C or above) Number of times: 3 max. Package peak temperature: 215 C, Duration: 40 sec. max. (200 C or above) Number of times: 3 max. Solder bath temperature: 260 C or less, Time: 10 sec. max., Number of times: 1, Pre-heating temperature: 120 C max. (Package surface temperature) Pin temperature: 300 C or less Duration: 3 sec. max. (per side of device)
VPS
VP15-00-3
Wave soldering
WS60-00-1
Partial heating
Caution Use of more than one soldering method should be avoided (except in the case of partial heating).
84
PD78366A
internal clock : 16 MHz external clock : 8 MHz 250 ns 16K bytes 512 bytes
PD78328
internal clock : 8 MHz, external clock : 16 MHz
16-bit transfer/operation Multiplication/division (16 bits 16 bits, 32 bits 16 bits) Bit manipulation String
Sum-of-products operation (16 bits 16 bits + 32 bits) Relative operation I/O lines Input I/O Real-time pulse unit 14 (of which 8 are multiplexed with analog input) 49 16-bit timer 5 16-bit compare register 7 16-bit capture register 3 16-bit capture/compare register 2 Two output modes selectable Mode 0, set-reset output : 6 channels Mode 1, buffer output : 6 channels
11 (of which 8 are multiplexed with analog input) 41 16-bit timer 3 16-bit compare register 14 16-bit capture/compare register 1 Two output modes selectable Mode 0, set-reset output : 6 channels toggle output : 1 channel Mode 1, buffer output : 8 channels
16-bit resolution PWM output: 1 channel Real-time output port PWM unit A/D converter Serial interface 4 (buffer output in 4-bit units) 8-/9-/10-/12-bit resolution variable PWM output: 2 channels 10-bit resolution, 8 channels Dedicated baud rate generator UART (with pin selection function) : 1 channel Clocked serial interface/SBI : 1 channel External: 6, internal: 14 (2 multiplexed with external) 4 programmable priority levels Dedicated baud rate generator UART : 1 channel Clocked serial interface/SBI : 1 channel External: 4, internal: 17 3 programmable priority levels 4/8 (buffer output in 4-/8-bit units) 8-bit resolution PWM output: 1 channel
Interrupt function
Three processing selectable (vectored interrupt/macro service/context switching) Test source PLL control circuit Package Others None Provided (external 8 MHz internal: 16 MHz) 80-pin plastic QFP (14 20 mm) Watchdog timer Standby functions (HALT mode, STOP mode) Internal: 1 None 64-pin plastic shrink DIP 64-pin plastic QFP (14 20 mm)
85
Host machine
OS
PC-9800 series
IBM PC/ATTM and its compatible model HP9000 series 700TM SPARC stationTM NEWSTM 78K/III series C compiler (CC78K3)
PC DOSTM
This is a C compiler that can be commonly used for 78K/III series. This program converts the program written in C language to object codes microcomputer can execute. When using this compiler, the 78K/III series relocatable assembler (RA78K3) is necessary. Host machine Order code (product name)
OS
PC-9800 series
IBM PC/AT and its compatible model HP9000 series 700 SPARC station NEWS
PC DOS
Remark The operations of the relocatable assembler and C compiler are guaranteed only on the specified host machine and OS described above.
86
Hardware
PA-78P368GF PA-78P368KL
PG-1500 controller
OS
PC-9800 series
PC DOS
Remark The operation of the PG-1500 controller is guaranteed only on the above host machine and OS. Debugging Tools (When IE Controller Is Used)
IE-78350-R Hardware In-circuit emulator that can be used to develop and debug application systems. Connected to a host machine for debugging. I/O emulation board that emulates the peripheral functions of the target device such as I/O ports.
IE-78365-R-EM1
EP-78365GF-R
Emulation probe that connects the IE-78350-R to the target system. One conversion socket, EV-9200G-80 EV-9200G-80, used to connect the target system is supplied as an accessory. Program that controls the IE-78350-R on the host machine. It can automatically execute commands, enhancing debugging efficiency. Host machine Order code (part number)
OS
Software
PC-9800 series
PC DOS
Remark The operation of the IE controller is guaranteed only on the above host machine and OS.
87
RS-232-C
Emulation probe
Software
EP-78365GF-R
Relocatable assembler
C compiler
PG-1500 controller
+
Conversion socket for connecting the emulation probe and the target systemNote PG-1500
PD78P368AGF PD78P368AKL
+
Programmer adapter
+
Target system
PA-78P368GF
PA-78P368KL
Note A socket is provided with the emulation probe. Remarks 1. Host machine and PG-1500 can be directly connected by RS-232-C. 2. 3.5-inch FD represents the supply media of software in this figure.
88
Interface adapter and cable to connect PC-9800 series notebook type personal computer as the host machine. IE-70000-PC-IF-B Interface adapter and cable to connect IBM PC as the host machine. IE-78000-R-SV3 Interface board to connect EWS as the host machine. Integrated debugger Program controlling the in-circuit emulator for the 78K/III series. Used in combination with a device file (DF78365). Can debug a program coded in the C language, structured assembly (ID78K3) language, or assembly language at source program level. Can also split the screen of the host machine into windows on each of which information is displayed, enhancing debugging efficiency. Host machine OS PC-9800 series MS-DOS + WindowsTM Supply media 3.5" 2HD 5" 2HD Order code (part number)
SAA13ID78K3 SAA10ID78K3 IBM PC/AT and compatible PC DOS 3.5" 2HC SAB13ID78K3 + Windows 5" 2HC SAB10ID78K3 machines (Japanese Windows) IBM PC/AT and compatible 3.5" 2HC SBB13ID78K3 machines (English Windows) 5" 2HC SBB10ID78K3 File containing information peculiar to device. Use in combination with an assembler (RA78 K3), C compiler (CC78K3), and integrated debugger (ID78K3). Host machine Order code (part number) OS Supply media PC-9800 series MS-DOS 3.5" 2HD S5A13DF78365 5" 2HD S5A10DF78365 IBM PC/AT and compatible PC DOS 3.5" 2HC S7B13DF78365 machines 5" 2HC S7B10DF78365
Remark The operation of the integrated debugger and device file is guaranteed only on the above host machine and OS.
Software
89
IE-784000-R in-circuit emulator IE-78350-R-EM-A emulation board (optional) IE-78365-R-EM1 I/O emulation board (optional) RS-232C EP-78365GF-R Relocatable assembler C compiler PG-1500 controller
+ +
Emulation probe
Software
+
Conversion socket for connecting the emulation probe and the target systemNote PROM programmer PG-1500 EV-9200G-80
PD78P368AGF PD78P368AKL
+
Programmer adapter
+
Target system
PA-78P368GF
PA-78P368KL
Note A socket is provided with the emulation probe. Remarks 1. Desk top-type PC represents host machine in this figure. 2. 3.5-inch FD represents the supply media of software in this figure.
90
Note Under development Caution Before purchasing this product, you are requested to conclude a contract licensing use by filling out a specified form. Remark When using the RX78K/III real-time OS, the RA78K3 assembler package (optional) is necessary.
91
S5A13FE9000 S5A10FE9000 IBM PC/AT and compatible PC DOS S7B13FE9200 + machines Windows 5" 2HC S7B10FE9200 Program that converts the fuzzy knowledge data obtained by using the fuzzy knowledge data Translator creation tool into assembler source program for the RA78K/III. (FT78K3)Note Host machine Order code (part number) OS Supply media PC-9800 series MS-DOS 3.5" 2HD S5A13FT78K3 5" 2HD S5A10FT78K3 IBM PC/AT and compatible PC DOS 3.5" 2HC S7B13FT78K3 machines 5" 2HC S7B10FT78K3 Fuzzy inference module Program that executes fuzzy inference when linked with the fuzzy knowledge data converted by the translator. (FI78K/III)Note Host machine Order code (part number) OS Supply media S5A13FI78K3 PC-9800 series MS-DOS 3.5" 2HD 5" 2HD S5A10FI78K3 IBM PC/AT and compatible PC DOS 3.5" 2HC S7B13FI78K3 machines 5" 2HC S7B10FI78K3 Fuzzy inference debugger Support software that evaluates and adjusts the fuzzy knowledge data at the hardware level by using an in-circuit emulator. (FD78K/III) Host machine Order code (part number) OS Supply media PC-9800 series MS-DOS 3.5" 2HD S5A13FD78K3 S5A10FD78K3 5" 2HD IBM PC/AT and compatible PC DOS 3.5" 2HC S7B13FD78K3 S7B10FD78K3 machines 5" 2HC
92
93
94
Regional Information
Some information contained in this document may vary from country to country. Before using any NEC product in your application, please contact the NEC office in your country to obtain a list of authorized representatives and distributors. They will verify: Device availability Ordering information Product release schedule Availability of related technical literature Development environment specifications (for example, specifications for third-party tools and components, host computers, power plugs, AC supply voltages, and so forth) Network requirements In addition, trademarks, registered trademarks, export restrictions, and other legal issues may also vary from country to country.
J96. 8
95
: PD78365A
The customer must judge the need for license : PD78363A, 78366A, 78368A No part of this document may be copied or reproduced in any form or by any means without the prior written consent of NEC Corporation. NEC Corporation assumes no responsibility for any errors which may appear in this document. NEC Corporation does not assume any liability for infringement of patents, copyrights or other intellectual property rights of third parties by or arising from use of a device described herein or any other liability arising from use of such device. No license, either express, implied or otherwise, is granted under any patents, copyrights or other intellectual property rights of NEC Corporation or others. While NEC Corporation has been making continuous effort to enhance the reliability of its semiconductor devices, the possibility of defects cannot be eliminated entirely. To minimize risks of damage or injury to persons or property arising from a defect in an NEC semiconductor device, customers must incorporate sufficient safety measures in its design, such as redundancy, fire-containment, and anti-failure features. NEC devices are classified into the following three quality grades: "Standard", "Special", and "Specific". The Specific quality grade applies only to devices developed based on a customer designated "quality assurance program" for a specific application. The recommended applications of a device depend on its quality grade, as indicated below. Customers must check the quality grade of each device before using it in a particular application. Standard: Computers, office equipment, communications equipment, test and measurement equipment, audio and visual equipment, home electronic appliances, machine tools, personal electronic equipment and industrial robots Special: Transportation equipment (automobiles, trains, ships, etc.), traffic control systems, anti-disaster systems, anti-crime systems, safety equipment and medical equipment (not specifically designed for life support) Specific: Aircrafts, aerospace equipment, submersible repeaters, nuclear reactor control systems, life support systems or medical equipment for life support, etc. The quality grade of NEC devices is "Standard" unless otherwise specified in NEC's Data Sheets or Data Books. If customers intend to use NEC devices for applications other than those specified for Standard quality grade, they should contact an NEC sales representative in advance. Anti-radioactive design is not implemented in this product.
M4 96.5