# Z89321/371/391 ## 16-BIT DIGITAL SIGNAL PROCESSORS #### **FEATURES** | Device | DSP ROM<br>(KW) | OTP<br>(KW) | DSP RAM<br>Lines | MIPS<br>(Max) | |--------|-----------------|-------------|------------------|---------------| | Z89321 | 4 | | 512 | 24 | | Z89371 | | 4 | 512 | 16 | | Z89391 | 64* | | 512 | 24 | Note: \*External - 0°C to +70°C Standard Temperature Range -40°C to +85°C Extended Temperature Range - 4.5- to 5.5-Volt Operating Range ### **DSP Core** - 24 MIPS @ 24 MHz Maximum, 16-Bit Fixed Point DSP - 41.7 ns Minimum Instruction Cycle Time - Six-Level Hardware Stack - Six Register Address Pointers - Optimized Instruction Set (30 Instructions) | Device | 40-Pin<br>DIP | 44-Pin<br>PLCC | 44-Pin<br>QFP | 84-Pin<br>PLCC | |--------|---------------|----------------|---------------|----------------| | Z89321 | Х | Х | Х | | | Z89371 | Χ | Χ | Χ | | | Z89391 | | | | Χ | Note: \*General-Purpose ## **On-Board Peripherals** - Dual 8/16-Bit CODEC Interface Capable of up to 10 Mbps - μ-Law Compression Option (Decompression is Performed in Software) - 16-Bit I/O Bus (Tri-Stated) - Three I/O Address Pins (Latched Outputs) - Wait-State Generator - Three Vectored Interrupts - 13-Bit General-Purpose Timer #### **GENERAL DESCRIPTION** The Z893XX products are high-performance Digital Signal Processors (DSPs) with a modified Harvard-type architecture featuring separate program and data memory. The design has been optimized for processing power while minimizing silicon space. The single-cycle instruction execution and bus structure promotes efficient algorithm execution, while the six register pointers provide circular buffering capabilities and dual operand fetching. Three vectored interrupts are complemented by a six-level stack, and the CODEC interface allows high-speed transfer rates to accommodate digital audio and voice data. A dedicated Counter/Timer provides the necessary timing signals for the CODEC interface, and an additional 13-bit timer is available for general-purpose use. The Z893XX DSPs are optimized to accommodate advanced signal processing algorithms. The 24 MIPS (maximum) operating performance and efficient architecture provides real-time instruction execution. Compression, filtering, frequency detection, audio, voice detection/synthesis, and other vital algorithms can all be accommodated. The Z89321/371/391 devices feature an on-board CO-DEC interface, compatible with 8-bit PCM and 16-bit CO-DECs for digital audio applications. Additionally, an on-board wait-state generator is provided to accommodate slow external peripherals. For prototypes, as well as production purposes, the Z89371 member of the DSP product family is a one-time pro-grammable (OTP) device with a 16 MHz maximum operating frequency. **Notes:** All signals with a preceding front slash, "/", are active Low. For example, B//W (WORD is active Low); /B/W (BYTE is active Low, only). Power connections follow conventional descriptions below: | Connection | Circuit | Device | |------------|-----------------|----------| | Power | V <sub>CC</sub> | $V_{DD}$ | | Ground | GND | $V_{SS}$ | Figure 1. Z89321/371/391 Functional Block Diagram ### **PIN DESCRIPTION** Figure 2. Z89321/371 40-Pin DIP Pin Assignments Table 1. Z89321/371 40-Pin DIP Pin Identification | No. | Symbol | Function | Direction | |-------|-----------------|-----------------------------|---------------| | 1-3 | EXT12-<br>EXT14 | External Data<br>Bus | Input/Output | | 4 | V <sub>SS</sub> | Ground | | | 5 | EXT15 | External Data<br>Bus | Input/Output | | 6-7 | EXT3-EXT4 | External Data<br>Bus | Input/Output | | 8 | V <sub>SS</sub> | Ground | | | 9-11 | EXT5-EXT7 | External Data<br>Bus | Input/Output | | 12 | TXD | Serial Output to CODECs | Output | | 13-14 | EXT8-EXT9 | External Data<br>Bus | Input/Output | | 15 | V <sub>SS</sub> | Ground | | | 16-17 | EXT10-<br>EXT11 | External Data<br>Bus | Input/Output | | 18 | UI1 | User Input | Input | | 19 | UI0 | User Input | Input | | 20 | SCLK | CODEC Serial<br>Clock | Input/Output* | | 21 | $V_{DD}$ | Power Supply | Input | | 22 | RD//WR | Strobes for<br>External Bus | Output | Table 1. Z89321/371 40-Pin DIP Pin Identification | No. | Symbol | Function | Direction | |-------|-----------------|---------------------------------|---------------| | 23 | /RESET | Reset | Input | | 24-26 | EA0-EA2 | External Address<br>Bus | Output | | 27 | $V_{DD}$ | Power Supply | Input | | 28 | /DS | Data Strobe for<br>External Bus | Output | | 29 | CLK | Clock | Input | | 30 | FS0 | CODEC 0 Frame<br>Sync | Input/Output* | | 31 | /INT0 | Interrrupt | Input | | 32-33 | UO0-UO1 | User Output | Output | | 34 | FS1 | CODEC 1 Frame<br>Sync | Input/Output* | | 35 | $V_{SS}$ | Ground | | | 36-38 | EXT0-EXT2 | External Data<br>Bus | Input/Output | | 39 | V <sub>SS</sub> | Ground | | | 40 | RXD | Serial Input from CODECs | Input | #### Notes: \*Input/Output is defined by interface mode selection. †HALT/WAIT pins not available on 40-pin DIP package. ## PIN DESCRIPTION (Continued) Figure 3. Z89321/371 44-Pin PLCC Pin Assignments Table 2. Z89321/371 44-Pin PLCC Pin Identification | No. Symbol Function | | Function | Direction | |---------------------|-----------------|------------------------------|---------------| | 1 | HALT | Stop Execution | Input | | 2 | FS0 | CODEC 0 Frame Sync | Input/Output* | | 3 | /INT0 | Interrupt | Input | | 4-5 | O0-UO1 | User Output | Output | | 6 | FS1 | CODEC 1 frame sync | Input/Output* | | 7 | $V_{SS}$ | Ground | | | 8-10 | EXT0-EXT2 | External data bus | Input/Output | | 11 | $V_{SS}$ | Ground | | | 12 | RXD | Serial input from CODECs | Input | | 13-15 | EXT12-EXT14 | External data bus | Input/Output | | 16 | V <sub>SS</sub> | Ground | | | 17 | EXT15 | External data bus | Input/Output | | 18-19 | EXT3-EXT4 | External data bus | Input/Output | | 20 | V <sub>SS</sub> | Ground | | | 21-23 | EXT5-EXT7 | External data bus | Input/Output | | 24 | TXD | Serial output to CODECs | Output | | 25-26 | EXT8-EXT9 | External data bus | Input/Output | | 27 | $V_{SS}$ | Ground | | | 28-29 | EXT10-EXT11 | External data bus | Input/Output | | 30 | /INT2 | Interrupt | Input | | 31 | /INT1 | Interrupt | Input | | 32 | UI1 | User input | Input | | 33 | UI0 | User input | Input | | 34 | SCLK | CODEC serial clock | Input/Output* | | 35 | $V_{DD}$ | Power supply | Input | | 36 | RD//WR | RD//WR strobe for EXT bus | Output | | 37 | WAIT | WAIT state | Input | | 38 | /RESET | Reset | Input | | 39-41 | EA0-EA2 | External Address bus | Output | | 42 | $V_{DD}$ | Power Supply | Input | | 43 | /DS | Data strobe for external bus | Output | | | | | | Note: \* Input or output is defined by interface mode selection. ## PIN DESCRIPTION (Continued) Figure 4. Z89321/371 44-Pin QFP Pin Assignments Table 3. Z89321/371 44-Pin QFP Pin Identification | No. | Symbol | Function | Direction | |-------|-----------------|------------------------------|---------------| | 1-2 | EXT3-EXT4 | External data bus | Input/Output | | 3 | $V_{SS}$ | Ground | | | 4-6 | EXT5-EXT7 | External data bus | Input/Output | | 7 | TXD | Serial output to CODECs | Output | | 8-9 | EXT8-EXT9 | External data bus | Input/Output | | 10 | V <sub>SS</sub> | Ground | | | 11-12 | EXT10-EXT1 | External data bus | Input/Output | | 13 | /INT2 | Interrupt | Input | | 14 | /INT1 | Interrupt | Input | | 15 | UI1 | User input | Input | | 16 | UI0 | User input | Input | | 17 | SCLK | CODEC serial clock | Input/Output* | | 18 | $V_{DD}$ | Power supply | Input | | 19 | RD//WR | RD//WR strobe EXT bus | Output | | 20 | WAIT | WAIT state | Input | | 21 | /RESET | Reset | Input | | 22-24 | EA0-EA2 | External address bus | Output | | 25 | $V_{DD}$ | Power supply | Input | | 26 | /DS | Data strobe for external bus | Output | | 27 | CLK | Clock | Input | | 28 | HALT | Stop execution | Input | | 29 | FS0 | CODEC 0 frame sync | Input/Output* | | 30 | /INT0 | Interrupt | Input | | 31-32 | UO0-UO1 | User output | Output | | 33 | FS1 | CODEC 1 frame sync | Input/Output* | | 34 | V <sub>SS</sub> | Ground | | | 35-37 | EXT0-EXT2 | External data bus | Input/Output | | 38 | $V_{SS}$ | Ground | | | 39 | RXD | Serial input to CODECs | Input | | 40-42 | EXT12-EXT14 | External data bus | Input/Output | | 43 | V <sub>SS</sub> | Ground | | | 44 | EXT15 | External data bus | Input/Output | | | | | | Note: \*Input or output is defined by interface mode selection. ## PIN DESCRIPTION (Continued) Figure 5. Z89391 84-Pin PLCC Pin Assignments Table 4. Z89391 84-Pin PLCC Pin Identification | No. | Symbol | Function | Direction | |-------------|-----------------|---------------------------|-----------| | 1 | RXD | Serial Input from CODEC | Input | | 2 | EXT12 | External Data 12 | In/Output | | 3 | PA4 | Program Address 4 | Output | | 4 | EXT13 | External Data 13 | In/Output | | 5 | PA5 | Program Address 5 | Output | | 6 | EXT14 | External Data 14 | In/Output | | 7 | PA6 | Program Address 6 | Output | | 8 | V <sub>SS</sub> | Ground | | | 9 | PA7 | Program Address 7 | Output | | 10 | EXT15 | External Data 15 | In/Output | | 11 | /PA_EN | Prog. Mem. Address Enable | e Input | | 12 | /EXTEN | Ext. Bus Enable | Input | | 13 | EXT3 | External Data 3 | In/Output | | 14 | PA8 | Program Address 8 | Output | | 15 | EXT4 | External Data 4 | In/Output | | 16 | PA9 | Program Address 9 | Output | | 17 | V <sub>SS</sub> | Ground | | | 18 | EXT5 | External Data 5 | In/Output | | 19 | PA10 | Program Address 10 | Output | | 20 | EXT6 | External Data 6 | In/Output | | 21 | PA11 | Program Address 11 | Output | | 22 | EXT7 | External Data 7 | In/Output | | 23 | TXD | Serial Output to CODEC | Output | | 24 | PA12 | Program Address 12 | Output | | 25 | EXT8 | External Data 8 | In/Output | | 26 | PA13 | Program Address 13 | Output | | 27 | EXT9 | External Data 9 | In/Output | | 28 | V <sub>SS</sub> | Ground | | | 29 | PA14 | Program Address 14 | Output | | 30 | EXT10 | External Data 10 | In/Output | | 31 | PA15 | Program Address 15 | Output | | 32 | V <sub>DD</sub> | Power Supply | Input | | 33 | V <sub>SS</sub> | Ground | · | | 34 | PD0 | Program Data 0 | Input | | 35 | EXT11 | External Data 11 | In/Output | | 36 | PD1 | Program Data 1 | Input | | 37 | INT2 | User Interrupt 2 | Input | | 38 | PD2 | Program Data 2 | Input | | 39 | INT1 | User Interrupt 1 | Input | | 40 | PD3 | Program Data 3 | Input | | 41 | UI1 | User Input 1 | Input | | 42 | UIO | User Input 0 | Input | | <del></del> | JIU | ουσι πιραί υ | прис | Table 4. Z89391 84-Pin PLCC Pin Identification | No. | Symbol | Function | Direction | | | |---------------------|-----------------|-----------------------------------|-----------|--|--| | 43 | SCLK | CODEC Interface Clock | In/Output | | | | 44 | $V_{DD}$ | Power Supply | Input | | | | 45 | RD//WR | R/W External Bus | Output | | | | 46 | PD4 | Program Data 4 | Input | | | | 47 | WAIT | Wait State Input | Input | | | | 48 | PD5 | Program Data 5 | Input | | | | 49 | /RESET | Reset | Input | | | | 50 | PD6 | Program Data 6 | Input | | | | 51 | EA0 | External Address 0 | Output | | | | 52 | PD7 | Program Data 7 | Input | | | | 53 | $V_{DD}$ | Power Supply | Input | | | | 54 | /ROMEN | ROM Enable | Input | | | | 55 | EA1 | External Address 1 | Output | | | | 56 | PD8 | Program Data 8 | Input | | | | 57 | EA2 | External Address 2 | Output | | | | 58 | PD9 | Program Data 9 | Input | | | | 59 | $V_{DD}$ | Power Supply | Input | | | | 60 | PD10 | Program Data 10 | Input | | | | 61 | /DS | External Data Strobe | Output | | | | 62 | CLK | Clock | Input | | | | 63 | PD11 | Program Data 11 | Input | | | | 64 | HALT | Stop Execution | Input | | | | 65 | FS0 | Frame Synch for CODEC Interface 0 | In/Output | | | | 66 | INT0 | User Interrupt 0 | Input | | | | 67 | PD12 | Program Data 12 | Input | | | | 68 | UO0 | User Output 0 | Input | | | | 69 | PD13 | Program Data 13 | Input | | | | 70 | UO1 | User Output 1 | Input | | | | 71 | PD14 | Program Data 14 | Input | | | | 72 | FS1 | Frame Synch for CODEC Interface 1 | In/Output | | | | 73 | PD15 | Program Data 15 | Input | | | | 74 | V <sub>SS</sub> | Ground | | | | | 75 | V <sub>DD</sub> | Power Supply | Input | | | | 76 | PA0 | Program Address 0 | Output | | | | 77 | V <sub>SS</sub> | Ground | | | | | 78 | EXT0 | External Data 0 | In/Output | | | | <del>70</del><br>79 | PA1 | Program Address 1 | Output | | | | 80 | EXT1 | External Data 1 | In/Output | | | | 81 | PA2 | Program Address 2 | Output | | | | 82 | EXT2 | External Data 2 | In/Output | | | | 83 | PA3 | Program Address 3 | Output | | | | | V <sub>SS</sub> | Ground | | | | **Note:** \*Input or output is defined by interface mode selection. ### **ABSOLUTE MAXIMUM RATINGS** | Symbo | I Description | Min. | Max. | Units | |------------------|---------------------|------|------|-------| | $V_{CC}$ | Supply voltage (*) | -0.3 | +7.0 | V | | T <sub>STG</sub> | Storage Temp. | –65° | +150 | °C | | T <sub>A</sub> | Oper. Ambient Temp. | | † | °C | #### Note: Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. ### STANDARD TEST CONDITIONS The characteristics listed below apply for standard test conditions as noted. All voltages are referenced to Ground. Positive current flows into the referenced pin (Figure 6). Figure 6. Test Load Diagram <sup>\*</sup> Voltage on all pins with respect to GND. <sup>†</sup> See Ordering Information. ### DC ELECTRICAL CHARACTERISTICS $(V_{DD} = 5V \pm 10\%, T_A = 0^{\circ}C \text{ to } +70^{\circ}C, \text{ unless otherwise noted.})$ | | | | fclock | =20 M | lHz <sup>1</sup> | fclock | x=16 N | 1Hz <sup>2</sup> | fclock | =24 N | /lHz <sup>3</sup> | | |-----------------|------------------------------------|-------------------------|----------------------|-------|------------------|----------------------|--------|------------------|----------------------|-------|-------------------|-------| | Sym | Parameter | Condition | Min | Тур | Max. | Min | Тур | Max | Min | Тур | Max | Units | | $I_{DD}$ | Supply Current | V <sub>DD</sub> = 5.5V | | 70 | | | 55 | | | 85 | | mA | | I <sub>DC</sub> | DC Power Consumption | 5 | | 5 | | | 5 | | | 5 | | mA | | $V_{IH}$ | Input High Level | | 2.7 | | | 2.7 | | | 2.7 | | | V | | $V_{IL}$ | Input Low Level | | | | .8 | | | .8 | | | .8 | V | | IL | Input Leakage | | | | 10 | | | 10 | | | 10 | μΑ | | V <sub>OH</sub> | Output High Voltage | I <sub>OH</sub> =100 μA | V <sub>DD</sub> -0.2 | | V | V <sub>DD</sub> -0.2 | | | V <sub>DD</sub> -0.2 | | | V | | $V_{OL}$ | Input Low Voltage | I <sub>OL</sub> =2.0 mA | | | .5 | | | .5 | | | .5 | V | | I <sub>FL</sub> | Output Floating<br>Leakage Current | | | | 10 | | | 10 | | | 10 | μΑ | #### Notes: - 1. Z89321 and Z89391 only - 2. Z89371 only. $V_{DD}$ = 5V, $\pm$ 5% for 16 MHz operation. $V_{DD}$ = 5V, $\pm$ 10% for 10 MHz operation. - 3. Z89321 only. Limited availability. Contact Zilog sales office. ### DC ELECTRICAL CHARACTERISTICS $(V_{DD} = 5V 10\%, T_A = -40^{\circ}C \text{ to } +85^{\circ}C, \text{ unless otherwise specified})$ | | | 1 | | | |------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------| | Parameter | Condition | Min | Тур | Max | | Supply Current | V <sub>DD</sub> =5.5V | | 70 | | | DC Power Consumption | | | 5 | | | Input High Level | | 2.7 | | | | Input Low Level | | | | .8 | | Input Leakage | | | | 10 | | Output High Voltage | I <sub>OH</sub> =100 μA | V <sub>DD</sub> -0.2 | | | | Input Low Voltage | I <sub>OL</sub> =2.0 mA | | | .5 | | Output Floating<br>Leakage Current | | | | 10 | | | Supply Current DC Power Consumption Input High Level Input Low Level Input Leakage Output High Voltage Input Low Voltage Output Floating | Supply Current V <sub>DD</sub> =5.5V DC Power Consumption Input High Level Input Low Level Input Leakage Output High Voltage I <sub>OH</sub> =100 μA Input Low Voltage I <sub>OL</sub> =2.0 mA Output Floating | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | #### Notes 1. Z89321 only ## **AC ELECTRICAL CHARACTERISTICS** ( $V_{DD}$ = 5V ±10%, $T_A$ = 0°C to +70°C, unless otherwise specified.) | | | fclock<br>MF | | fclock = | 16 MHz <sup>2</sup> | fclock<br>MF | | | |-------------------------|-------------------------------------|--------------|------|----------|---------------------|--------------|------|-------| | Symbol | Parameter | Min | Max | Min | Max | Min | Max | Units | | Clock | | | | | | | | ns | | TCY | Clock Cycle Time | 50 | | 6.25 | | 41.7 | | ns | | Tr | Clock Rise Time | | 2 | | 2 | | 2 | ns | | Tf | Clock Fall Time | | 2 | | 2 | | 2 | ns | | CPW | Clock Pulse Width | 23 | | 29 | | 19 | | ns | | I/O | | | | | | | | | | DSVALID | /DS Valid Time from CLOCK Fall | 0 | 15 | 0 | 15 | 0 | 15 | ns | | DSHOLD | /DS Hold Time from CLOCK Rise | 4 | 15 | 4 | 15 | 4 | 15 | ns | | EASET | EA Setup Time to /DS Fall | 12 | | 12 | | 12 | | ns | | EAHOLD | EA Hold Time from /DS Rise | 4 | | 4 | | 4 | | ns | | RDSET | Data Read Setup Time to /DS Rise | 14 | | 14 | | 14 | | ns | | RDHOLD | Data Read Hold Time from /DS Rise | 6 | | 6 | | 6 | | ns | | WRVALID | Data Write Valid Time from /DS Fall | | 18 | | 18 | | 18 | ns | | WRHOLD | Data Write Hold Time from /DS Rise | 5 | | 5 | | 5 | | ns | | Interrupt | | | | | | | | | | INTSET | Interrupt Setup Time to CLOCK Fall | 7 | | 7 | | 7 | | ns | | INTWIDTH | Interrupt Low Pulse Width | 1 TCY | | 1 TCY | | 1 TCY | | ns | | CODEC Interface | | | | | | | | | | SSET | SCLK Setup Time from Clock Rise | | 15 | | 15 | | 15 | ns | | FSSET | FSYNC Setup Time from SCLK Rise | | 6 | | 6 | | 6 | ns | | TXSET | TXD Setup Time from SCLK Rise | | 7 | | 7 | | 7 | ns | | RXSET | RXD Setup Time to SCLK Fall | 7 | | 7 | | 7 | | ns | | RXHOLD | RXD Hold Time from SCLK Fall | 0 | | 0 | | 0 | | ns | | Reset | | | | | | | | | | RRISE | Reset Rise Time | | 1000 | | 10000 | | 1000 | ns | | RSET | Reset Setup Time to CLOCK Rise | 15 | | 15 | | 15 | | ns | | RWIDTH | Reset Low Pulse Width | 2 TCY | | 2 TCY | | 2 TCY | | ns | | <b>External Program</b> | n Memory | | | | | | | | | PAVALID | PA Valid Time from CLOCK Rise | | 20 | | 20 | | 20 | ns | | PDSET | PD Setup Time to CLOCK Rise | 10 | | 10 | | 10 | | ns | | PDHOLD | PD Hold Time from CLOCK Rise | 10 | | 10 | | 10 | | ns | | Wait State | | | | | | | | | | WSET | WAIT Setup Time to CLOCK Rise | 23 | | 23 | | 23 | | ns | | WHOLD | WAIT Hold Time from CLOCK Rise | 1 | | 1 | | 1 | | ns | | Halt | | | | | | | | | | HSET | Halt Setup Time to CLOCK Rise | 3 | | 3 | | 3 | | ns | | | Halt Hold Time from CLOCK Rise | 10 | | | | 10 | | | #### Notes: - 1. Z89321 and Z89391 only - 2. Z89371 only $(V_{DD} = 5V \pm 5\%)$ - 3. Z89321 only. Limited availability. Contact Zilog sales office. ## **AC ELECTRICAL CHARACTERISTICS** ( $V_{DD}$ = 5V ±10%, $T_A$ = -40°C to +85°C, unless otherwise specified.) | | | fclock = 20 MHz <sup>1</sup> | | |----------------------|-------------------------------------|------------------------------|------| | Symbol | Parameter | Min | Max | | Clock | | | | | TCY | Clock Cycle Time | 50 | | | Tr | Clock Rise Time | | 5 | | Tf | Clock Fall Time | | 5 | | CPW | Clock Pulse Width | 20 | | | I/O | | | | | DSVALID | /DS Valid Time from CLOCK Fall | 0 | 18 | | DSHOLD | /DS Hold Time from CLOCK Rise | 5 | 18 | | EASET | EA Setup Time to /DS Fall | 15 | | | EAHOLD | EA Hold Time from /DS Rise | 5 | | | RDSET | Data Read Setup Time to /DS Rise | 17 | | | RDHOLD | Data Read Hold Time from /DS Rise | 8 | | | WRVALID | Data Write Valid Time from /DS Fall | | 20 | | WRHOLD | Data Write Hold Time from /DS Rise | 6 | | | Interrupt | | | | | INTSET | Interrupt Setup Time to CLOCK Fall | 9 | | | INTWIDTH | Interrupt Low Pulse Width | 1 TCY | | | CODEC Interface | | | | | SSET | SCLK Setup Time from Clock Rise | | 18 | | FSSET | FSYNC Setup Time from SCLK Rise | | 8 | | TXSET | TXD Setup Time from SCLK Rise | | 9 | | RXSET | RXD Setup Time to SCLK Fall | 9 | | | RXHOLD | RXD Hold Time from SCLK Fall | 0 | | | Reset | | | | | RRISE | Reset Rise Time | | 1000 | | RSET | Reset Setup Time to CLOCK Rise | 18 | | | RWIDTH | Reset Low Pulse Width | 2 TCY | | | External Program Men | nory | | | | PAVALID | PA Valid Time from CLOCK Rise | | 25 | | PDSET | PD Setup Time to CLOCK Rise | 12 | | | PDHOLD | PD Hold Time from CLOCK Rise | 12 | | | Wait State | | | | | WSET | WAIT Setup Time to CLOCK Rise | 28 | | | WHOLD | WAIT Hold Time from CLOCK Rise | 2 | | | Halt | | | | | HSET | Halt Setup Time to CLOCK Rise | 4 | | | | Halt Hold Time from CLOCK Rise | 12 | | DS97DSP0100 PRELIMINARY 13 ## **TIMING DIAGRAMS** Figure 7. Read Timing Figure 8. External (EXT) Bus Read Timing Using WAIT Pin ## TIMING DIAGRAMS (Continued) Figure 9. Write Timing Figure 10. CODEC Interface Timing Figure 11. Interrupt Timing ## **TIMING DIAGRAMS** (Continued) Figure 12. HALT Timing <sup>\*</sup> The RAM and hardware registers are left intact during a warm reset. A cold reset will produce random data in these locations. The status register is set to zeroes in both cases. Figure 13. RESET Timing Figure 14. External Program Memory Port Timing #### ADDRESS SPACE **Program Memory.** Programs of up to 4 K words can be masked into internal ROM (OTP for Z89371). Four locations are dedicated to the vector address for the three interrupts (0FFDH-0FFFH) and the starting address following a Reset (0FFCH). Internal ROM is mapped from 0000H to 0FFFH, and the highest location for program is 0FFBH. A 64 K word External Program Memory Space is available on the Z89391. The vector addresses for the Z89391 reside at FFFCH-FFFFH (Figure 15). Internal Data RAM. The Z89321, 371 and 391 all have internal $512 \times 16$ -bit word data RAM organized as two banks of 256 x 16-bit words each: RAM0 and RAM1. Each data RAM bank is addressed by three pointers: Pn:0 (n = 0-2) for RAM0 and Pn:1 (n = 0-2) for RAM1. The RAM addresses for RAM0 and RAM1 are arranged from 0-255 and 256-511, respectively. The address pointers, which may be written to, or read from, are 8-bit registers connected to the lower byte of the internal 16-bit D-Bus and are used to perform modulo addressing. Three addressing modes are available to access the Data RAM: register indirect, direct addressing, and short form direct. The contents of the RAM can be read to, or written from, in one machine cycle per word, without disturbing any internal registers or status other than the RAM address pointer used for each RAM. The contents of each RAM can be loaded simultaneously into the X and Y inputs of the multiplier. **Registers.** The Z89321 has 19 internal registers and up to an additional eight external registers. The external registers are user-definable for peripherals, such as A/D or D/A, or to DMA, or other addressing peripherals. Both external and internal registers are accessed in one machine cycle. Figure 15. Memory Map #### **FUNCTIONAL DESCRIPTION** **Instruction Timing.** Most instructions are executed in one machine cycle. Long immediate instructions and Jump or Call instructions are executed in two machine cycles. A multiplication or multiplication/accumulate instruction requires a single cycle. Specific instruction cycle times are described in the Condition Code section. Multiply/Accumulate. The multiplier can perform a 16-bit x 16-bit multiply, or multiply accumulate, in one machine cycle using the Accumulator and/or both the X and Y inputs. The multiplier produces a 32-bit result, however, only the 24 most significant bits are saved for the next instruction or accumulation. For operations on very small numbers where the least significant bits are important, the data should first be scaled by eight bits (or the multiplier and multiplicand by four bits each) to avoid truncation errors. Figure 16. Multiplier Block Diagram Note that all inputs to the multiplier should be fractional two's-complement, 16-bit binary numbers (Figure 16). This puts them in the range [-1 to 0.9999695], and the result is in 24 bits so that the range is [-1 to 0.9999999]. In addition, if 8000H is loaded into both X and Y registers, the resulting multiplication is considered an illegal operation as an overflow would result. Positive one cannot be represented in fractional notation, and the multiplier will actually yield the result 8000H x 8000H = 8000H (-1 x -1 = -1). **ALU.** The ALU has two input ports, one of which is connected to the output of the 24-bit Accumulator. The other input is connected to the 24-bit P-Bus, the upper 16 bits of which are connected to the 16-bit D-Bus. A shifter between the P-Bus and the ALU input port can shift the data by three bits right, one bit right, one bit left or no shift (Figure 17). Figure 17. ALU Block Diagram **Hardware Stack.** A six-level hardware stack is connected to the D-Bus to hold subroutine return addresses or data. The Call instruction pushes PC+2 onto the stack, and the RET instruction pops the contents of the stack to the PC. **User Inputs.** The Z89321 has two inputs, UIO and UI1, which may be used by Jump and Call instructions. The Jump or Call tests one of these pins and if appropriate, jumps to a new location. Otherwise, the instruction behaves like a NOP. These inputs are also connected to the status register bits S10 and S11, which may be read by the appropriate instruction (Figure 8). **User Outputs.** The status register bits S5 and S6 connect directly to UO0 and UO1 pins and may be written to by the appropriate instruction. Note: The user output value is the opposite of the status register content. Interrupts. The Z89321 has three positive edge-triggered interrupt inputs. An interrupt is acknowledged at the end of an instruction execution. It takes two machine cycles to enter an interrupt instruction sequence. The PC is pushed onto the stack. A RET instruction transfers the contents of the stack to the PC and decrements the stack pointer by one word. The priority of the interrupts is INT0 = highest, INT2 = lowest. INT1 is dedicated to the CODEC interface and INT2 is dedicated to the 13-bit timer if both peripherals are enabled. Note: The SIEF instruction enables the interrupts. The SIEF instruction must be used before exiting an interrupt routine since the interrupts are automatically disabled when entering the routine. **Registers.** The Z89321 has 19 physical internal registers and up to eight user-defined external registers. The EA2-EA0 determines the address of the external registers. The signals are used to read from or write to the external registers /DS, WAIT, RD//WR. I/O Bus. The processor provides a 16-bit, CMOS-compatible bus. I/O Control pins provide convenient communication capabilities with external peripherals, and single-cycle access is possible. For slower communications, an onboard hardware wait-state generator can be used to accommodate timing conflicts. Three latched I/O address pins are used to access external registers. The EXT 4, 5, 6, 7 pins are used by the internal peripherals. Disabling a peripheral allows access to these addresses for general-purpose use. **CODEC Interface.** The multi-compatible, dual CODEC interface provides the necessary control signals for transmission of CODEC information to the DSP processor. The interface accommodates 8-bit PCM or 16-bit Linear CODECs. Special compatibility with Crystal Semiconductor's 4215/4216 CODECs provides the necessary interface for audio applications. Many general-purpose 8-, 16-bit A/Ds, D/As are adaptable. The interface can also be used as a high-speed serial port. $\mu$ -Law Compression. The 8-bit CODEC interface mode provides $\mu$ -law compression from 13-bit format to 8-bit format. Decompression is performed in software by use of a 128-word lookup table. **Timer.** Two programmable timers are available. One is dedicated to the CODEC interface, the other for general-purpose use. When a time-out event occurs, an interrupt request is generated. Single pass and/or continuous modes are available. If the CODEC interface is not used, both timers can be used for general-purpose. **Note: Wait-State Generator.** An internal wait-state generator is provided to accommodate slow external peripherals. A single wait-state can be implemented through control registers EXT7-2. For additional states, a dedicated pin (WAIT) can be held High. The WAIT pin is monitored only during execution of a read or write instruction to external peripherals (EXT bus). **Note:** A WAIT pin is not available on the 40-pin DIP package. #### **REGISTERS** The internal registers are defined below: | Register | Register Definition | | |----------|-------------------------------------------------------------|--| | P | Output of Multiplier, 24-bit | | | X | X Multiplier Input, 16-bit | | | Υ | Y Multiplier Input, 16-bit | | | A | Accumulator, 24-bit | | | SR | Status Register, 16-bit | | | Pn:b | Six Ram Address Pointers, 8-bit each | | | PC | Program Counter, 16-bit | | | EXT4 | 13-Bit Timer Configuration Register | | | EXT5-1 | CODEC Interface Channel 0 Data | | | EXT5-2 | CODEC Interface Channel 0 Data | | | EXT6-1 | CODEC Interface Channel 1 Data | | | EXT6-2 | CODEC Interface Channel 1 Data | | | EXT7-1 | CODEC Interface Configuration Register | | | EXT7-2 | Wait-State Generator/CODEC Interface Configuration Register | | The following are virtual registers as physical RAM does not exist on the chip. | Register | Register Definition | |----------|----------------------------| | EXTn | External Registers, 16-bit | | BUS | D-Bus | | Dn:b | Eight Data Pointers* | **Note:** \* These occupy the first four locations in RAM bank. **P** holds the result of multiplications and is read-only. ${\bf X}$ and ${\bf Y}$ are two 16-bit input registers for the multiplier. These registers can be utilized as temporary registers when the multiplier is not being used. A is a 24-bit Accumulator. The output of the ALU is sent to this register. When 16-bit data is transferred into this register, it is placed into the 16 MSBs and the least significant eight bits are set to zero. Only the upper 16 bits are transferred to the destination register when the Accumulator is selected as a source register in transfer instructions. **Pn:b** are the pointer registers for accessing data RAM, (n = 0,1,2 refer to the pointer number) (b = 0,1 refers to RAM Bank 0 or 1). They can be directly read from or written to, and can point to locations in data RAM or Program Memory. **EXTn** are external registers (n = 0 to 7). There are eight 16-bit registers provided here for mapping external devices into the address space of the processor. Note that the actual register RAM does not exist on the chip, but would exist as part of the external device, such as an ADC result latch. Use of the CODEC interface and 13-bit timer reduces the number of external registers to four. **BUS** is a read-only register which, when accessed, returns the contents of the D-Bus. Bus is used for emulation only. **Dn:b** refers to locations in RAM that can be used as a pointer to locations in program memory which is efficient for coefficient addressing. The programmer decides which location to choose from two bits in the status register and two bits in the operand. Thus, only the lower 16 possible locations in RAM can be specified. At any one time, there are eight usable pointers, four per bank, and the four pointers are in consecutive locations in RAM. For example, if S3/S4 = 01 in the status register, then D0:0/D1:0/D2:0/D3:0 refer to register locations 4/5/6/7 in RAM Bank 0. Note that when the data pointers are being written to, a number is actually being loaded to Data RAM, so they can be used as a limited method for writing to RAM. **SR** is the status register, which contains the ALU status and certain control bits (Table 5). **Table 5. Status Register Bit Functions** | Status Register Bit | Function | | |-----------------------------|-----------------------------|--| | S15 (N) | ALU Negative | | | S14 (OV) | ALU Overflow | | | S13 (Z) | ALU Zero | | | S12 (L) | Carry | | | S11 (UI1) | User Input 1 | | | S10 (UI0) | User Input 0 | | | S9 (SH3) | MPY Output Arithmetically | | | | Shifted Right by Three Bits | | | S8 (OP) Overflow Protection | | | | S7 (IE) Interrupt Enable | | | | S6 (UO1) | User Output 1 | | | S5 (UO0) | User Output 0 | | | S4-S3 | "Short Form Direct" bits | | | S2-S0 (RPL) | RAM Pointer Loop Size | | | | | | The status register can always be read in its entirety. S15-S10 are set/reset by hardware and can only be read by software. S9-S0 control hardware looping and can be written by software (Table 6). Table 6. RPL Description | S2 | S1 | S0 | Loop Size | |----|----|----|-----------| | 0 | 0 | 0 | 256 | | 0 | 0 | 1 | 2 | | 0 | 1 | 0 | 4 | | 0 | 1 | 1 | 8 | | 1 | 0 | 0 | 16 | | 1 | 0 | 1 | 32 | | 1 | 1 | 0 | 64 | | 1 | 1 | 1 | 128 | S15-S12 are set/reset by the ALU after an operation. S11-S10 are set/reset by the user inputs. S6-S0 are control bits described in Table 5. S7 enables interrupts. If S8 is set, the hardware clamps at maximum positive or negative values instead of overflowing. If S9 is set and a multiple/shift option is used, then the shifter shifts the result three bits right. This feature allows the data to be scaled and prevents overflows. PC is the Program Counter. When this register is assigned as a destination register, one NOP machine cycle is added automatically to adjust the pipeline timing. **External Register, EXT4-EXT7**, are used by the CODEC interface and 13-bit timer, the registers are reviewed in the CODEC interface section. <sup>\*</sup> The output value is the opposite of the status register content. Figure 18. Status Register #### PERIPHERAL OPERATION ## **Disabling Peripherals** Disabling a peripheral (CODEC Interface, Counter) allows general-purpose use of the EXT address for the disabled peripheral. If the peripheral is not disabled, the EXT control signals and EXT data are still provided, but transfer of data on the EXT pins is not available (because internal transfers are being processed on the internal bus). Care must be taken to ensure that control of the EXT bus does not cause bus conflicts. ## Reading Data from CODEC Interface\* External data is serially transferred into the CODEC interface registers from an external CODEC. This serial data is loaded into EXT5-2 (8- or 16-bit modes). Because the interface is double-buffered, data must be transferred to EXT5-1 before being transferred along the internal data bus of the processor. This is accomplished by writing data to EXT5-2. ## Writing Data to CODEC Interface Internal data is transferred from the internal data bus of the processor to the EXT5-2 register. The CODEC interface constantly transfers and receives data during normal operation. Data to be transferred is loaded to EXT5-2 and is automatically serially transferred. **Note:** EXT5-1 and EXT5-2 are used in the example, but this information applies equally to EXT6-1 and EXT6-2. (Refer to Figure 20, CODEC Block Diagram.) Figure 19. EXT7 Register Configuration ### **LOADING EXT7** Because EXT7 is double-buffered, a pair of writes are performed when loading the EXT7 registers (Figure 19). | LD EXT7, #%54F4 | | |-----------------|--| | LD EXT7, #%6CDA | | | LD @P0:0. EXT7 | | Loads CODEC Timer Register Loads Wait-State Register Reads EXT7-1 and places data in RAM Interrupts The Z89321 features three interrupts: | INT0 | General-Purpose | |------|-----------------| | INT1 | CODEC Interface | | INT2 | 13-Bit Timer | If all peripherals are enabled, INTO (general-purpose) can be used. #### **CODEC Interface** The CODEC Interface provides direct-connect capabilities for standard 8-, 16-bit CODECs. The interface also supports 8-bit PCM, 8-bit PCM with hardware $\mu$ -law conversion ( $\mu$ -law expansion is done in software), 16-bit Linear and Crystal's Sigma-Delta Stereo CODEC modes. Registers are used to accommodate the CODEC Interface (EXT5, EXT6 and EXT7). The CODEC interface provides two Frame Sync signals, which allows two channels of data for transmission/receiving. #### **CODEC Interface Hardware** The CODEC Interface hardware uses six 16-bit registers, $\mu$ -law compression logic and general-purpose logic to control transfers to the appropriate register (Figure 20). ## **CODEC Interface Control Signals** #### **SCLK (Serial Clock)** The Serial Clock provides a clock signal for operating the external CODEC. A 4-bit prescaler is used to determine the frequency of the output signal. SCLK = (0.5\* CLK)/PS where: CLK = System Clock PS = 4-bit Prescaler\* **Note:** An internal divide-by-two is performed before the clock signal is passed to the Serial Clock prescaler. Figure 20. CODEC Interface Block Diagram <sup>\*</sup> The Prescaler is an up-counter. #### **TXD (Serial Output to CODEC)** The TXD line provides 8-, 16-, and 64-bit data transfers. Each bit is clocked out of the processor by the rising edge of the SCLK, with the MSB transmitted first. #### **RXD (Serial Input from CODEC)** The RXD line provides 8-, 16-, and 64-bit data transfers. Each bit is clocked into the processor by the falling edge of the SCLK, with the MSB received first. #### FS0, FS1 (Frame Sync) The Frame Sync is used for enabling data transfer/receive. The rising and falling edge of the Frame Sync encloses the serial data transmission. #### Interrupt Once the transmission of serial data is completed an internal interrupt signal is initiated. A single-cycle Low pulse allows an interrupt on INT1. When this occurs, the processor will jump to the defined Interrupt 1 vector location (Figure 21). Figure 21. CODEC Interface Timing (8-Bit Mode) ### **CODEC INTERFACE TIMING** Figure 21 depicts a typical 8-bit serial data transfer using both of the CODEC Interface Channels. The transmitting data is clocked out on the rising edge of the SCLK signal. An external CODEC clocks data in on the falling edge of the SCLK signal. Once the serial data is transmitted, an interrupt is given. The CODEC interface signals are not initiated if the CODEC interface is not enabled. The following modes are available for FSYNC and SCLK signals: | SCLK | FSYNC | |----------|----------| | Internal | Internal | | External | External | | External | Internal | | Internal | External | The CODEC interface timing is independent of the processor clock when external mode is chosen. This feature provides the capability for an external device to control the transfer of data to the Z89321. The Frame Sync signal envelopes the transmitted data, therefore care must be taken to ensure proper sync signal timing (Figure 21). ## **Full Duplex Operation** The Transmit and Receive lines are used for transfer of serial data to or from the CODEC interface. The CODEC interface performs both data transmit and receive simultaneously. ## **Control Registers** The CODEC interface is double-buffered, therefore, four registers are provided for CODEC interface data storage. EXT5-1 and EXT5-2 operate with the Frame Sync 0 while EXT6-1 and EXT6-2 operate with Frame Sync 1. In 8- or 16-bit mode, the CODEC interface uses EXT5-1 and EXT6-1. For Stereo mode, all four registers are used (Figures 22 and 23). The CODEC Interface Control Register (EXT7-1) is shown in Figure 14. Setting of the CODEC mode, FSYNC, and Enable/Disable of CODEC 0 is done through this register. The Wait-State Generator, SCLK, and CODEC 1 are controlled from EXT7-2 (Figure 24). Figure 22. CODEC Interface Data Registers (Channel 0) Figure 23. CODEC Interface Data Registers (Channel 1) ## **REGISTERS** Figure 24. CODEC Interface Control Register Figure 25. WSG, SCLK and CODEC Interface Control Register #### A/D Accommodation The CODEC interface can be used for serial A/D or serial D/A transmission. The interface provides the necessary control signals to adapt to many standard serial converters. The low-pass and smoothing filters are necessary for systems with converters. ## **High-Speed Serial Port** The Z89321 CODEC interface can be used as a high-speed serial port. The necessary control signals are provided for adaptation to standard processors or external peripherals. Byte, word, or 64-bit data can be transmitted at speeds up to 10 Mbps. (Condition includes a 20 MHz oscillator. Data can be transferred with single-cycle instructions to an internal register file.) Figure 26. A/D, D/A Implementation Block Diagram Table 7. Tabulated Transmission Rates\* | Transmission | Rate | |--------------------|-----------| | Maximum SCLK | 10 Mbps | | Maximum Frame Sync | | | 8-bit | 769.2 kHz | | 16-bit | 476.2 kHz | | Stereo (64-bit) | 263.2 kHz | **Note:** Calculations consider the interrupt access time (typically four cycles), transfer of data, loading of new data, and latency periods between CODEC transfers. During the interrupt cycle, developers often execute additional software, affecting the maximum transfer rate. Calculations are for single-channel transfers only. #### 8-Bit CODEC Interface The Z89321 provides an option for a standard 8-bit CODEC interface. Hardware $\mu\text{-law}$ compression is available (expansion performed by software lookup table). The CODEC interface transmits data consisting of 8-bit or compounded 8-bit information. Figure 27 shows a typical schematic arrangement. The timing for this type of arrangement is presented in Figure 28. The flexible design provides adaptation for 16-bit linear CODEC. Figure 27. 8-Bit CODEC Schematic Figure 28. 8-Bit Mode Timing Diagram #### 16-Bit Linear CODEC Interface For higher precision transmissions, a 16-bit linear CODEC is used, however, data is not compressed in this mode of transmission. The Z89321 provides accommodation for two channels of 16-bit transmission (Figure 29). For data acquisition systems, designers may opt for a 16-bit serial A/D. A block diagram of the Z89321 with the AD1876 16-bit 100 Kbps sampling ADC is shown in Figure 30. Figure 29. 16-Bit Mode Timing Diagram Figure 30. 16-Bit Mode Timing Diagram ### **Stereo CODEC Interface** The Z893XX DSP product family CODEC interface provides direct connection to other CODECs for master or slave modes, supporting 64 bits of transmission data (16 bits right channel, 16 bits left channel, and 32 bits of configuration information). This configuration information consists of input gain, input MUX, output attenuation, ADC clipping, and mute and error functions of the CODECs. A key feature of the Z893XX DSP product family is that it adapts easily to other stereo CODECs, including Crystal Semiconductor's CS4215 and CS4216 devices (Figure 31). The 64 bits of data transferred from the CODEC are placed in four registers, EXT5-1, 5-2, 6-1, and 6-2 (Figure 32). Figure 31. Z893XX and CS4216 CODEC Interface Figure 32. CODEC Stereo Mode Timing Diagram ## **16-Bit General-Purpose Timer** The 13-bit counter/timer is available for general-purpose use. When the counter counts down to the zero state, an interrupt is received on INT2. If the counter is disabled, EXT4 can be used as a general-purpose address. The counting operation of the counter can be disabled by resetting bit 14. Selection of the clock source allows the ability to extend the counter value past the 13 bits available in the control register. Use of the CODEC counter output can extend the counter to 26 bits (see Figure 33). **Note:** Placing zeroes into the count value register does not generate an interrupt. Therefore, it is possible to have a single-pass option by loading the counter with zeroes after the start of count. The counter is defaulted to the enable state, but if it is not needed, it can be disabled. However, once disabled, the counter cannot be enabled unless a reset of the processor is performed. #### Example: LD EXT, #%C008 ;1100 0000 0000 1000 ; Enable Counter ; Enable Counting ; Clock Source = OSC/2 ; Count Value = 1000 = 8 ; Interrupt will occur every 16 clock cycles ## **ADDRESSING MODES** (Continued) Figure 33. CODEC Timer Register ### ADDRESSING MODES This section discusses the syntax of the addressing modes supported by the DSP assembler. **Table 8. Addressing Modes** | Symbolic Name | Syntax | Description | |------------------------------------------------------------------------------------------|---------------------------|------------------------------------------------------| | <pre><pre><pre><pre><pre><pre><pre><pre></pre></pre></pre></pre></pre></pre></pre></pre> | Pn:b | Pointer Register | | <pre><dregs> (Points to RAM)</dregs></pre> | Dn:b | Data Register | | <hwregs></hwregs> | X,Y,PC,SR,P, EXTn, A, BUS | Hardware Registers | | <accind> (Points to Program Memory</accind> | @A | Accumulator Memory Indirect | | <direct></direct> | <expression></expression> | Direct Address Expression | | <li><li><li><li></li></li></li></li> | # <const exp=""></const> | Long (16-bit) Immediate Value | | <simm></simm> | # <const exp=""></const> | Short (8-bit) Immediate Value | | <regind> (Points to RAM)</regind> | @Pn:b | Pointer Register Indirect | | | @Pn:b+ | Pointer Register Indirect with Increment | | | @Pn:b-LOOP | Pointer Register Indirect with Loop Decrement | | | @Pn:b+LOOP | Pointer register Indirect with Loop Increment | | <pre><memind> (Points to Program Memory)</memind></pre> | @@Pn:b | Pointer Register Memory Indirect | | | @Dn:b | Data Register Memory Indirect | | | @@Pn:b-LOOP | Pointer Register Memory Indirect with Loop | | | | Decrement | | | @@Pn:b+LOOP | Pointer Register Memory Indirect with Loop Increment | | | @@Pn:b+ | Pointer Register Memory Indirect with Increment | There are eight distinct addressing modes for data transfer <regind> This mode is used for indirect accesses to the data RAM. The address of the RAM location is stored in the pointer. The "@" symbol indicates "indirect" and precedes the pointer, therefore @P1:1 instructs the processor to read or write to a location in RAM1, which is specified by the value in the pointer. <dregs> This mode is also used for accesses to the data RAM, but only the lower 16 addresses in either bank. The 4-bit address comes from the status register and the operand field of the data pointer. Note that data registers are typically used not for addressing RAM, but loading data from program memory space. <memind> This mode is used for indirect accesses to the program memory. The address of the memory is located in a RAM location, which is specified by the value in a pointer. Therefore, @@P1:1 instructs the processor to read (write is not possible) from a location in memory, which is specified by a value in RAM, and the location of the RAM is in turn specified by the value in the pointer. Note that the data pointer can also be used for a memory access in this manner, but only one "@" precedes the pointer. In both cases, the memory address stored in RAM is incremented by one, each time the addressing mode is used, to allow easy transfer of sequential data from program memory. <accind> Similar to the previous mode, the address for the program memory read is stored in the Accumulator. @A in the second operand field loads the number in memory specified by the address in A. <direct> The direct mode allows read or write to data RAM from the Accumulator by specifying the absolute address of the RAM in the operand of the instruction. A number between 0 and 255 indicates a location in RAM0, and a number between 256 and 511 indicates a location in RAM1. **This address mode indicates a long immediate load.** A 16-bit word can be copied directly from the operand into the specified register or memory. <simm> This address mode can only be used for immediate transfer of 8-bit data in the operand to the specified RAM pointer. #### **CONDITION CODES** The following Instruction Description defines the condition codes supported by the DSP assembler. | Code Description | | | |------------------|------------------------|--| | С | Carry | | | EQ | Equal (same as Z) | | | F | False | | | ĪE | Interrupts Enabled | | | MI | Minus | | | NC | No Carry | | | NE | Not Equal (same as NZ) | | | NIE | Not Interrupts Enabled | | | NOV | Not Overflow | | | NU0 | Not User Zero | | If the instruction description refers to the <cc> (condition code) symbol in one of its addressing modes, the instruction will only execute if the condition is true. | Code | Description | | |------|--------------------------------|--| | NU1 | Not User One | | | NZ | Not zero | | | OV | Overflow | | | PL | Plus (Positive) | | | U0 | User Zero | | | U1 | User One | | | UGE | Unsigned Greater Than or | | | | Equal (Same as NC) | | | ULT | Unsigned Less Than (Same as C) | | | Z | Zero | | ### **PACKAGE INFORMATION** Figure 34. 40-Pin Package Diagram Figure 35. 44-Pin PLCC Package Diagram Figure 36. 44-Pin QFP Package Diagram Figure 37. 84-Pin PLCC Package Diagram ## ORDERING INFORMATION | Z89371 | Z89391 | |-------------|-----------------------| | 16 MHz | 20 MHz | | 44-pin PLCC | 84-Pin PLCC | | Z8937116VSC | Z8939120VSC | | | 16 MHz<br>44-pin PLCC | 20 MHz 16 MHz 40-Pin DIP 40-Pin DIP Z8932120PSC Z8937116PSC 20 MHz 16 MHz 44-Pin QFP 44-Pin QFP Z8932120FSC Z8937116FSC For fast results, contact your local Zilog sales office for assistance in ordering the part desired. ### **CODES** Speed **Package** P= Plastic DIP 20 = 20 MHzV = Plastic PLCC 16 = 16 MHz F = Plastic QFP **Environmental** C = Plastic Standard $S = 0^{\circ}C$ to $+70^{\circ}C$ **Temperature** $E = -40^{\circ}C$ to $85^{\circ}C$ Speed Product Number Zilog Prefix © 1997 by Zilog, Inc. All rights reserved. No part of this document may be copied or reproduced in any form or by any means without the prior written consent of Zilog, Inc. The information in this document is subject to change without notice. Devices sold by Zilog, Inc. are covered by warranty and patent indemnification provisions appearing in Zilog, Inc. Terms and Conditions of Sale only. Zilog, Inc. makes no warranty, express, statutory, implied or by description, regarding the information set forth herein or regarding the freedom of the described devices from intellectual property infringement. Zilog, Inc. makes no warranty of merchantability or fitness for any purpose. Zilog, Inc. shall not be responsible for any errors that may appear in this document. Zilog, Inc. makes no commitment to update or keep current the information contained in this document. Zilog's products are not authorized for use as critical components in life support devices or systems unless a specific written agreement pertaining to such intended use is executed between the customer and Zilog prior to use. Life support devices or systems are those which are intended for surgical implantation into the body, or which sustains life whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in significant injury to the user. Zilog, Inc. 210 East Hacienda Ave. Campbell, CA 95008-6600 Telephone (408) 370-8000 FAX 408 370-8056 Internet: http://www.zilog.com