SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 - Military Temperature Range – –55°C to 125°C - 100-ns or 80-ns Instruction Cycle Times - 544 Words of Programmable On-Chip Data - 4K Words of On-Chip Program ROM - 128K Words of Data/Program Space - 16 Input and 16 Output Channels - 16-Bit Parallel Interface - **Directly Accessible External Data Memory** Space - Global Data Memory Interface - 16-Bit Instruction and Data Words - 16 × 16-Bit Multiplier With a 32-Bit Product - 32-Bit ALU and Accumulator - Single-Cycle Multiply/Accumulate Instructions - 0 to 16-Bit Scaling Shifter - **Bit Manipulation and Logical Instructions** - **Instruction Set Support for Floating-Point** Operations, Adaptive Filtering, and **Extended-Precision Arithmetic** - **Block Moves for Data/Program** Management - Repeat Instructions for Efficient Use of **Program Space** - **Eight Auxiliary Registers and Dedicated Arithmetic Unit for Indirect Addressing** - Serial Port for Direct Code Interface - **Synchronization Input for Synchronous Multiprocessor Configurations** - Wait States for Communication to Slow-Off-Chip Memories/Peripherals - **On-Chip Timer for Control Operations** - **Three External Maskable User Interrupts** - Input Pin Polled by Software Branch Instruction - 1.6-μm CMOS Technology - **Programmable Output Pin for Signaling External Devices** - Single 5-V Supply - **On-Chip Clock Generator** - Packaging: - 68-Pin Leaded Ceramic Chip Carrier (FJ - 68-Pin Ceramic Grid Array (GB Suffix) - 68-Pin Leadless Ceramic Chip Carrier (FD Suffix) #### 68-Pin FJ and FD Packages (Top View) #### 68-Pin GB Package (Top View) Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet. SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 ### description This data sheet provides design documentation for the SMJ320C25 and the SMJ320C25-50 digital signal processor (DSP) devices in the SMJ320™ family of VLSI digital signal processors and peripherals. The SMJ320 family supports a wide range of digital signal processing applications such as tactical communications, quidance, military modems, speech processing, spectrum analysis, audio processing, digital filtering, high-speed control, graphics, and other computation-intensive applications. Differences between the SMJ320C25 and the SMJ320C25-50 are specifically identified, as in the following paragraph and in the parameter tables on pages 18 through 24 of this data sheet. When not specifically differentiated, the term SMJ320C25 is used to describe both devices. The SMJ320C25 has a 100-ns instruction cycle time. The SMJ320C25-50 has an 80-ns instruction cycle time. With these fast instruction cycle times and their innovative memory configurations, these devices perform operations necessary for many real-time digital signal processing algorithms. Since most instructions require only one cycle, the SMJ320C25 is capable of executing 12.5 million instructions per second. On-chip data RAM of 544 16-bit words, on-chip program ROM of 4K words, direct addressing of up to 64K words of external data memory space and 64K words of external program memory space, and multiprocessor interface features for sharing global memory minimize unnecessary data transfers to take full advantage of the capabilities of the instruction set. Table 1. PGA/CLCC/LCCC Pin Assignments | FUNCTION | PIN | FUNCTION | PIN | FUNCTION | PIN | FUNCTION | PIN | FUNCTION | PIN | FUNCTION | PIN | |----------|-------|----------|--------|----------|-------|----------|--------|----------|--------|-----------------|--------| | A0 | K1/26 | A12 | K8/40 | D2 | E1/16 | D14 | A5/3 | INT2 | H1/22 | Vcc | H2/23 | | A1 | K2/28 | A13 | L9/41 | D3 | D2/15 | D15 | B6/2 | ĪS | J11/46 | Vcc | L6/35 | | A2 | L3/29 | A14 | K9/42 | D4 | D1/14 | DR | J1/24 | MP/MC | A6/1 | V <sub>SS</sub> | B1/10 | | А3 | K3/30 | A15 | L10/43 | D5 | C2/13 | DS | K10/45 | MSC | C10/59 | VSS | K11/44 | | A4 | L4/31 | BI0 | B7/68 | D6 | C1/12 | DX | E11/54 | PS | J10/47 | V <sub>SS</sub> | L2/27 | | A5 | K4/32 | BR | G11/50 | D7 | B2/11 | FSR | J2/25 | READY | B8/66 | XF | D11/56 | | A6 | L5/33 | CLKOUT1 | C11/58 | D8 | A2/9 | FSX | F10/53 | RS | A8/65 | X1 | G10/51 | | A7 | K5/34 | CLKOUT2 | D10/57 | D9 | B3/8 | HOLD | A7/67 | R/W | H11/48 | X2/CLKIN | F11/52 | | A8 | K6/36 | CLKR | B9/64 | D10 | A3/7 | HOLDA | E10/55 | STRB | H10/49 | | | | A9 | L7/37 | CLKX | A9/63 | D11 | B4/6 | IACK | B11/60 | SYNC | F2/19 | | | | A10 | K7/38 | D0 | F1/18 | D12 | A4/5 | INT0 | G1/20 | VCC | A10/61 | | · | | A11 | L8/39 | D1 | E2/17 | D13 | 85/4 | INT1 | G2/21 | VCC | B10/62 | | | SMJ320 is a trademark of Texas Instruments Incorporated. SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 ### **Terminal Functions** | SIGNALS | I/O/Z† | DEFINITION | |-----------|--------|------------------------------------------------------------------------------------------------------------------------------------------| | Vcc | I | 5-V supply pins | | VSS | I | Ground pins | | X1 | 0 | Output from internal oscillator for crystal | | X2/CLKIN | I | Input to internal oscillator from crystal or external clock | | CLKOUT1 | 0 | Master clock output (crystal or CLKIN frequency/4) | | CLKOUT2 | 0 | A second clock output signal | | D15-D0 | I/O/Z | 16-bit data bus D15 (MSB) through D0 (LSB). Multiplexed between program, data, and I/0 spaces. | | A15-A0 | O/Z | 16-bit address bus A15 (MSB) through A0 (LSB) | | PS,DS,IS | O/Z | Program, data, and I/O space select signals | | R/W | O/Z | Read / write signal | | STRB | O/Z | Strobe signal | | RS | I | Reset input | | INT2-INT0 | I | External user interrupt inputs | | MP/MC | I | Microprocessor/microcomputer mode select pin | | MSC | 0 | Microstate complete signal | | IACK | 0 | Interrupt acknowledge signal | | READY | I | Data ready input. Asserted by external logic when using slower devices to indicate that the current bus transaction is complete. | | BR | 0 | Bus request signal. Asserted when the SMJ320C25 requires access to an external global data memory space. | | XF | 0 | External flag output (latched software-programmable signal) | | HOLD | 1 | Hold input. When asserted, SMJ320C25 goes into an idle mode and places the data, address, and control lines in the high-impedance state. | | HOLDA | 0 | Hold acknowledge signal | | SYNC | I | Synchronization input | | BIO | I | Branch control input. Polled by BIOZ instruction | | DR | I | Serial data receive input | | CLKR | I | Clock for receive input for serial port | | FSR | I | Frame synchronization pulse for receive input | | DX | O/Z | Serial data transmit output | | CLKX | I | Clock for transmit output for serial port | | FSX | I/O/Z | Frame synchronization pulse for transmit. Configurable as either an input or an output. | <sup>†</sup> I/O/Z denotes input/output/high-impedance state. SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 ### block diagram LEGEND: ACCH = Accumulator high ACCL = Accumulator low ALU = Arithmetic logic unit ARAU = Auxiliary register arithmetic unit ARB = Auxiliary register pointer buffer ARP = Auxiliary register pointer DP = Data memory page pointer DRR = Serial port data receive register DXR = Serial port data transmit register IFR = Interrupt flag register IMR = Interrupt mask register IR = Instruction register MCS = Microcall stack QIR = Queue instruction register PR = Product register PRD = Period register for timer TIM = Timer TR = Temporary register PC = Program counter PFC = Prefetch counter RPTC = Repeat instruction counter GREG = Global memory allocation register RSR = Serial port receive shift register XSR = Serial port transmit shift register AR0-AR7 = Auxiliary registers ST0, ST1 = Status registers C = Carry bit TEXAS INSTRUMENTS #### architecture The SMJ320C25 increases performance of DSP algorithms through innovative additions to the SMJ320 architecture. Increased throughput on the SMJ320C25 for many DSP applications is accomplished by means of single-cycle multiply/accumulate instructions with a data move option, eight auxiliary registers with a dedicated arithmetic unit, and faster I/O necessary for data-intensive signal processing. The architectural design of the SMJ320C25 emphasizes overall speed, communication, and flexibility in processor configuration. Control signals and instructions provide floating-point support, block-memory transfers, communication to slower off-chip devices, and multiprocessing implementations. Two large on-chip RAM blocks, configurable either as separate program and data spaces or as two contiguous data blocks, provide increased flexibility in system design. Programs of up to 4K words can be masked into the internal program ROM. The remainder of the 64K-word program memory space is located externally. Large programs can execute at full speed from this memory space. Programs can also be downloaded from slow external memory to high-speed on-chip RAM. A total of 64K data memory address space is included to facilitate implementation of DSP algorithms. The VLSI implementation of the SMJ320C25 incorporates all of these features as well as many others, such as a hardware timer, serial port, and block data transfer capabilities. #### 32-bit ALU/accumulator The SMJ320C25 32-bit arithmetic logic unit (ALU) and accumulator perform a wide range of arithmetic and logical instructions, the majority of which execute in a single clock cycle. The ALU executes a variety of branch instructions dependent on the status of the ALU or a single bit in a word. These instruction provide the following capabilities: - Branch to an address specified by the accumulator - Normalize fixed-point numbers contained in the accumulator - Test a specified bit of a word in data memory. One input to the ALU is always provided from the accumulator, and the other input can be provided from the product register (PA) of the multiplier or the input scaling shifter which has fetched data from the RAM on the data bus. After the ALU has performed the arithmetic or logical operations, the result is stored in the accumulator. The 32-bit accumulator is split into two 16-bit segments for storage in data memory. Additional shifters at the output of the accumulator perform shifts while the data is being transferred to the data bus for storage. The contents of the accumulator remain unchanged. ### scaling shifter The SMJ320C25 scaling shifter has a 16-bit input connected to the data bus and a 32-bit output connected to the ALU. The scaling shifter produces a left shift of 0 to 16 bits on the input data, as programmed in the instruction. The LSBs of the output are filled with zeroes, and the MSBs can be either filled with zeroes or sign-extended, depending upon the status programmed into the SXM (sign-extension mode) bit of status register ST1. ### 16 X 16-bit parallel multiplier The SMJ320C25 has a 16 x 16-bit hardware multiplier, which is capable of computing a signed or unsigned 32-bit product in a single machine cycle. The multiplier has the following two associated registers: - A 16-bit temporary register (TR) that holds one of the operands for the multiplier, and - A 32-bit product register (PR) that holds the product. Incorporated into the SMJ320C25 instruction set are single-cycle multiply/accumulate instruction that allow both operands to be processed simultaneously. The data for these operations can reside anywhere in internal or external memory and can be transferred to the multiplier each cycle via the program and data buses. SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 ### 16 X 16-bit parallel multiplier (continued) Four product shift modes are available at the product register (PR) output that are useful when performing multiply/accumulate operations, fractional arithmetic, or justifying fractional products. #### timer The SMJ320C25 provides a memory-mapped 16-bit timer for control operations. The on-chip timer (TIM) register is a down counter that is continuously clocked by CLKOUT1. A timer interrupt (TINT) is generated every time the timer decrements to zero. The timer is reloaded with the value contained in the period (PRD) register within the next cycle after it reaches zero so that interrupts can be programmed to occur at regular intervals of PRD + 1 cycles of CLKOUT1. #### memory control The SMJ320C25 provides a total of 544 16-bit words of on-chip data RAM, divided into three separate blocks (B0, B1, and B2). Of the 544 words, 288 words (blocks B1 and B2) are always data memory, and 256 words (block B0) are programmable as either data or program memory. A data memory size of 544 words allows the SMJ320C25 to handle a data array of 512 words (256 words if on-chip RAM is used for program memory), while still leaving 32 locations for intermediate storage. When using block B0 as program memory, instructions can be downloaded from external program memory into on-chip RAM and then executed. When using on-chip program RAM, ROM, or high-speed external program memory, the SMJ320C25 runs at full speed without wait states. However, the READY line can be used to interface the SMJ320C25 to slower, less-expensive external memory. Downloading programs from slow off-chip memory to on-chip program RAM speeds processing while cutting system costs. The SMJ320C25 provides three separate address states for program memory, data memory, and I/O. The on-chip memory is mapped into either the 64K-word data memory or program memory space, depending upon the memory configuration. The CNF0 (configure block B0 as data memory) and CNFP (configure block B0 as program memory) instruction allow dynamic configuration of the memory maps through software. Regardless of the configuration, the user can still execute from external program memory. The SMJ320C25 has six registers which are mapped into the data memory space: a serial port data receive register, serial port data transmit register, timer register, period register, interrupt mask register, and global memory allocation register. ### memory control (continued) #### (a) Memory Maps After a CNFD Instruction (b) Memory Maps After a CNFP Instruction Figure 1. Memory Maps SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 ### interrupts and subroutines The SMJ320C25 has three external maskable user interrupts INT2–INT0, available for external devices that interrupt the processor. Internal interrupts are generated by the serial port (RINT and XINT), by the timer (TINT), and by the software interrupt (TRAP) instruction. Interrupts are prioritized with reset (RS) having the highest priority and the serial port transmit interrupt (XINT) having the lowest priority. All interrupt locations are on two-word boundaries so that branch instruction can be accommodated in those locations if desired. A built-in mechanism protects multicycle instructions from interrupts. If an interrupt occurs during a multicycle instruction, the interrupt is not processed until the instruction is completed. This mechanism applies both to instructions that are repeated or become multicycle due to the READY signal. #### external interface The SMJ320C25 supports a wide range of system interfacing requirements. Program, data, and I/O address spaces provide interface to memory and I/O. thus maximizing system throughout. I/O design is simplified by having I/O treated the same way as memory. I/O devices are mapped into the I/O address space using the processor's external address and data buses in the same manner as memory-mapped devices. Interface to memory and I/O devices of varying speeds is accomplished by using the READY line. When transitions are made with slower devices, the SMJ320C25 processor waits until the other device completes its function and signals the processor via the READY line. Then, the SMJ320C25 continues execution. A full-duplex serial port provides communication with serial devices, such as codecs, serial A/D converters, and other serial systems. The interface signals are compatible with codecs and many other serial devices with a minimum of external hardware. The serial port can also be used for intercommunication between processors in multiprocessing applications. The serial port has two memory-mapped registers: the data transmit register (DXR) and the data receive register (DRR). Both registers operate in either the byte mode or 16-bit word mode, any can be accessed in the same manner as any other data *memory* location. Each register has an external clock, a framing synchronization pulse, and associated shift registers. One method of multiprocessing can be implemented by programming one device to transmit while the others are in the receive mode. ### multiprocessing The flexibility of the SMJ320C25 allows configurations to satisfy a wide range of system requirements. The SMJ320C25 can be used as follows: - A standalone processor - A multiprocessor with devices in parallel - A slave/host multiprocessor with global memory space - A peripheral processor interfaced via processor-controlled signals to another device. For multiprocessing applications, the SMJ320C25 has the capability of allocating global data memory space and communicating with that space via the $\overline{BR}$ (bus request) and READY control signals. Global memory is data memory shared by more than one processor. Global data memory access must be arbitrated. The 8-bit memory-mapped GREG (global memory allocation register) specifies part of the SMJ320C25s data memory as global external memory. The contents of the register determine the size of the global memory space. If the current instruction addresses an operand within that space, $\overline{BR}$ is asserted to request control of the bus. The length of the memory cycle is controlled by the READY line. The SMJ320C25 supports DMA (direct memory access) to its external program/data memory using the HOLD and HOLDA signals. Another processor can take complete control of the SMJ320C25s external memory by asserting HOLD low. This causes the SMJ320C25 to place its address, data, and control lines in a high-impedance state, and assert HOLDA. Program execution from on-chip memory can proceed concurrently while the device is in the hold mode. SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 #### instruction set The SMJ320C25 microprocessor implements a comprehensive instruction set that supports both numeric-intensive signal processing operations as well as general-purpose applications, such as multiprocessing and high-speed control. For maximum throughput, the next instruction is prefetched while the current one is being executed. Since the same data lines are used to communicate to external data/program or I/O space, the number of cycles may vary depending upon whether the next data operand fetch is from internal or external program memory. Highest throughput is achieved by maintaining data memory on-chip and using either internal or fast external program memory. #### addressing modes The SMJ320C25 instruction set provides three memory addressing modes: direct, indirect, and immediate addressing. Both direct and indirect addressing can be used to access data memory. In direct addressing, seven bits of the instruction word are concatenated with the nine bits of the data memory page pointer to form the 16-bit data memory address. Indirect addressing accesses data memory through the eight auxiliary registers. In immediate addressing, the data is based on a portion of the instruction word(s). In direct memory addressing, the instruction word contains the lower seven bits of the data memory address. This field is concatenated with the nine bits of the data memory page pointer to form the full 16-bit address. Thus, memory is paged in the direct addressing mode with a total of 512 pages, each page containing 128 words. Eight auxiliary register (AR0–AR7) provide flexible and powerful indirect addressing. To select a specific auxiliary register, the Auxiliary Register Pointer (ARP) is loaded with a value from 0 through 7 for AR0–AR7, respectively. There are seven types of indirect addressing: auto-increment or auto-decrement, post-indexing by either adding or subtracting the contents of AR0, or single indirect addressing with no increment or decrement and bit-reversal addressing (used in FFTs) with increment or decrement. All operations are performed on the current auxiliary register in the same cycle as the original instruction, followed by anew ARP value being loaded. #### repeat feature A repeat feature, used with instructions such as multiply/accumulates, block moves, I/O transfers, and table read/writes, allows a single instruction to be performed up to 256 times. The repeat counter (RPTC) is loaded with either a data memory value (RPT instruction) or an immediate value (RPTK instruction). The value of this operand is one less than the number of times that the next instruction is executed. Those instructions that are normally multicycle are pipelined when using the repeat feature, and effectively become single-cycle instructions. #### instruction set summary Table 1 lists the symbols and abbreviations used in Table 1, the instruction set summary, Table 2 consists primarily of single-cycle, single-word instructions. Infrequently used branch, I/O, and CALL instructions are multicycle. The instruction set summary is arranged according to function and alphabetized within each functional grouping. SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 ## instruction set summary (continued) # **Table 1. Instruction Symbols** | SYMBOL | MEANING | |--------|----------------------------------------------------------------------------------------------| | В | 4-bit field specifying a bit code | | СМ | 2-bit field specifying compare mode | | D | Data memory address field | | F0 | Format status bit | | М | Addressing mode bit | | К | Immediate operand field | | PA | Port address (PA0–PA15 are predefined assembler symbols equal to 0 through 15, respectively) | | PM | 2-bit field specifying P register output shift code | | R | 3-bit operand field specifying auxiliary register | | S | 4-bit left-shift code | | Х | 3-bit accumulator left-shift field | Table 2. SMJ320C25 Instruction Set Summary | MNEMONIC | DESCRIPTION | NO. | | | | | INS | TRU | ICTI | ON | віт | COL | ÞΕ | | | | | | |-------------------|--------------------------------------------------------------|-------|----|----|----|----|-----|-----|------|------------|-----|-----|----|-----|-------|---|---|---| | WINEWONIC | DESCRIPTION | WORDS | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | | | ABS | Absolute value of accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | | | ADD | Add to accumulator with shift | 1 | 0 | 0 | 0 | 0 | • | | s— | <b>-</b> ▶ | М | 4 | | | - D- | | | - | | ADDC‡ | Add to accumulator with carry | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | М | • | | | - D - | | _ | - | | ADDH | Add to high accumulator | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 0 | М | 4 | | | - D- | | — | - | | ADDK‡ | Add to accumulator short immediate | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | • | | | — к | (— | | | _ | | ADDS | Add to low accumulator with sign extension suppressed | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | М | • | | | - D- | | | | | ADDT | Add to accumulator with shift specified by T register | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | М | • | | | - D- | | — | _ | | ADLK† | Add to accumulator long immediate with shift | 2 | 1 | 1 | 0 | 1 | • | | s— | <b>-</b> ▶ | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | AND | AND with accumulator | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | М | 4 | | | - D- | | | _ | | ANDK <sup>†</sup> | AND immediate with accumulator with shift | 2 | 1 | 1 | 0 | 1 | • | | s— | <b>-</b> ▶ | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | | CMPL† | Complement accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | | | LAC | Load accumulator with shift | 1 | 0 | 0 | 1 | 0 | • | | s— | <b>-</b> ▶ | М | • | | | - D- | | | _ | | LACK | Load accumulator immediate short | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | • | | | — к | ( | | | | | LACT <sup>†</sup> | Load accumulator with shift specified by T register | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | М | • | | | - D- | | — | _ | | LALK† | Load accumulator long immediate with shift | 2 | 1 | 1 | 0 | 1 | • | | s— | <b>-</b> ▶ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | NEG <sup>†</sup> | Negate accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | | | NORM† | Normalize contents of accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 4 | | | - D- | | | _ | | OR | OR with accumulator | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | М | 4 | | | - D- | | _ | _ | | ORK† | OR immediate with accumulator with shift | 2 | 1 | 1 | 0 | 1 | • | | s— | <b>-</b> | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | | ROL‡ | Rotate accumulator left | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | | | ROR <sup>‡</sup> | Rotate accumulator right | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 0 | | | SACH | Store high accumulator with shift | 1 | 0 | 1 | 1 | 0 | 1 | • | - x | <b>-</b> ▶ | М | 4 | | | - D- | | _ | _ | | SACL | Store low-order accumulator with shift | 1 | 0 | 1 | 1 | 0 | 0 | • | - x | <b>-</b> ▶ | М | 4 | | | - D- | | | _ | | SBLK† | Subtract from accumulator long immediate with shift | 2 | 1 | 1 | 0 | 1 | • | | s— | <b>-</b> | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | SFL† | Shift accumulator left | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | | SFR† | Shift accumulator right | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | | SUB | Subtract from accumulator with shift | 1 | 0 | 0 | 0 | 1 | • | | s— | <b>-</b> ▶ | М | 4 | | | - D - | | | _ | | SUBB‡ | Subtract from accumulator with borrow | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | М | 4 | | | - D - | | | _ | | SUBC | Conditional subtract | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | М | • | | | - D - | | | _ | | SUBH | Subtract from high accumulator | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | М | 4 | | | - D- | | | _ | | SUBK‡ | Subtract from accumulator short immediate | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 1 | • | | | — к | ( | | | _ | | SUBS | Subtract from low accumulator with sign extension suppressed | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | М | • | | | - D- | | | _ | $<sup>\</sup>ensuremath{^{\dagger}}$ These instructions are not included in the TMS320C1x instruction set. <sup>&</sup>lt;sup>‡</sup> These instructions are not included in the TMS32020 instruction set. Table 2. SMJ320C25 Instruction Set Summary (continued) | | ACCUMULATOR ME | MORY RE | FER | ENC | E IN | STRU | JCTI | ONS | | | | | | | | | | | |------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|--------------------------------------------|----------------------------|---------------------------------|---------------------------------|---------------------------------|-----------------------------|---------------------------------|-----------------------|-----------------------|-----|-----|--------|------------------------------------|-----|------------|---------------| | MNEMO | NIC DESCRIPTION | NO.<br>WORDS | | | | | IN | ISTR | UCT | ΓΙΟΝ | I BI | тсс | DDE | | | | | | | | | WORDO | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SUBT† | Subtract from accumulator with shift specified by T register | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | М | • | | | - D | | | • | | XOR | Exclusive-OR with accumulator | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | М | • | | | - D | | | - | | XORK† | Exclusive-OR immediate with accumulator with shift | 2 | 1 | 1 | 0 | 1 | • | — s | 3 - | - | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | | ZAC | Zero accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | ZALH | Zero low accumulator and load high accumulator | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | М | • | | | - D | | | → | | ZALR‡ | Zero low accumulator and load high accumulator with rounding | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | М | • | | | - D | | | - | | ZALS | Zero accumulator and load low accumulator with sign extension suppressed | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | М | • | | | - D | | | - | | | AUXILIARY REGISTERS A | ND DATA | PAG | E PC | TNIC | ER IN | NSTR | RUCT | ION | IS | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | MNEMO | NIC DESCRIPTION | NO. | | | | | IN | ISTR | UCI | ΓΙΟΝ | I BI | тс | DDE | | | | | | | MNEMO | NIC DESCRIPTION | NO.<br>WORDS | 15 | 14 | 13 | 12 | 11 | ISTR<br>10 | UC1 | FION<br>8 | 7 | | | 4 | 3 | 2 | 1 | 0 | | MNEMO ADRK‡ | NIC DESCRIPTION Add to auxiliary register short immediate | _ | | <b>14</b> | <b>13</b> | <b>12</b> | | | | | | | | | <b>3</b><br>K - | 2 | 1 | 0 | | | | WORDS | 15 | | | | 11 | 10 | 9 | 8 | | | | | | | | 0<br>→<br>M-► | | ADRK‡ | Add to auxiliary register short immediate Compare auxiliary register with auxiliary | WORDS<br>1 | <b>15</b> | 1 | 1 | 1 | 11 | 10 | 9 | <b>8</b> | 7 | | 5 | 4 | K - | 0 • | | <b>→</b> | | ADRK‡ CMPR† | Add to auxiliary register short immediate Compare auxiliary register with auxiliary register AR0 | WORDS<br>1<br>1 | 0<br>1 | 1 | 1 0 | 1 | <b>11</b> 1 | 10 | 9 | <b>8</b> | 0 | | 5 | 4 | К -<br>0 | 0 • | | <b>→</b> | | ADRK‡ CMPR† LAR | Add to auxiliary register short immediate Compare auxiliary register with auxiliary register AR0 Load auxiliary register | 1<br>1<br>1 | 15<br>0<br>1<br>0 | 1<br>1<br>0 | 1 0 1 | 1<br>0<br>1 | <b>11</b> 1 | 10 | 9 | <b>8</b> | 0 | | 5 | 4 | K -<br>0<br>- D | 0 • | | <b>→</b> | | ADRK‡ CMPR† LAR LARK | Add to auxiliary register short immediate Compare auxiliary register with auxiliary register AR0 Load auxiliary register Load auxiliary register short immediate | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 15<br>0<br>1<br>0<br>1 | 1<br>1<br>0<br>1 | 1<br>0<br>1<br>0 | 1<br>0<br>1<br>0 | 1 1 0 4 | 10 | 9 | <b>8</b> | 0 | 1 | 0 | 1 | K -<br>0<br>- D | 0 • | <b>¢</b> c | <b>→</b> | | ADRK‡ CMPR† LAR LARK LARK | Add to auxiliary register short immediate Compare auxiliary register with auxiliary register AR0 Load auxiliary register Load auxiliary register short immediate Load auxiliary register pointer | 1 1 1 1 1 1 1 1 | 15<br>0<br>1<br>0<br>1<br>0 | 1<br>1<br>0<br>1 | 1<br>0<br>1<br>0 | 1<br>0<br>1<br>0 | 11<br>1<br>1<br>0 •<br>0 • | 10<br>1<br>1 | 9 | 8<br>0<br>0<br> | 0 | 1 | 0 | 1 | K -<br>0<br>- D<br>- K<br>1<br>- D | 0 • | <b>¢</b> c | <b>→</b> | | ADRK‡ CMPR† LAR LARK LARK LARP LDP | Add to auxiliary register short immediate Compare auxiliary register with auxiliary register AR0 Load auxiliary register Load auxiliary register short immediate Load auxiliary register pointer Load data memory page pointer | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 15<br>0<br>1<br>0<br>1<br>0<br>0 | 1<br>1<br>0<br>1<br>1 | 1<br>0<br>1<br>0<br>0 | 1<br>0<br>1<br>0<br>1 | 11<br>1<br>1<br>0 •<br>0 •<br>0 | 10<br>1<br>1<br>1<br>1<br>0 | 9 | 8<br>0<br>0<br>1<br>0 | 0 | 1 | 0 | 1 0 | K -<br>0<br>- D<br>- K<br>1<br>- D | 0 • | <b>¢</b> c | <b>→</b> | | ADRK‡ CMPR† LAR LARK LARP LDP | Add to auxiliary register short immediate Compare auxiliary register with auxiliary register AR0 Load auxiliary register Load auxiliary register short immediate Load auxiliary register pointer Load data memory page pointer immediate | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0<br>1<br>0<br>1<br>0<br>0<br>0 | 1<br>1<br>0<br>1<br>1<br>1 | 1<br>0<br>1<br>0<br>0<br>0 | 1<br>0<br>1<br>0<br>1<br>1 | 11<br>1<br>1<br>0 •<br>0<br>0 | 10<br>1<br>1<br>1<br>1<br>0 | 9<br>1<br>1<br>R<br>R<br>0<br>1 | 8<br>0<br>0<br>1<br>0 | 7<br>0<br>M<br>1<br>M | 1 0 | 0 0 | 1<br>0 | K - 0 - D - K 1 - D | 0 | <b>€</b> C | M → | | ADRK‡ CMPR† LAR LARK LARP LDP LDPK LRLK† | Add to auxiliary register short immediate Compare auxiliary register with auxiliary register AR0 Load auxiliary register Load auxiliary register short immediate Load auxiliary register pointer Load data memory page pointer Load data memory page pointer immediate Load auxiliary register long immediate | 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>2 | 15<br>0<br>1<br>0<br>1<br>0<br>0<br>1<br>1 | 1<br>0<br>1<br>1<br>1<br>1 | 1<br>0<br>1<br>0<br>0<br>0<br>0 | 1<br>0<br>1<br>0<br>1<br>1<br>0 | 11<br>1<br>1<br>0 •<br>0<br>0 | 10<br>1<br>1<br>1<br>1<br>0 | 9<br>1<br>1<br>R<br>R<br>0<br>1 | 8<br>0<br>0<br>1<br>0 | 7<br>0<br>1<br>1<br>M | 1 0 | 0 0 | 1<br>0 | K - 0 - D - K 1 - D - O | 0 | <b>€</b> C | M → | <sup>†</sup> These instructions are not included in the TMS320C1x instruction set. <sup>&</sup>lt;sup>‡</sup>These instructions are not included in the TMS32020 instruction set. SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 # Table 2. SMJ320C25 Instruction Set Summary (continued) | | T REGISTER, P REGI | STER, AN | DΜU | JLTIF | LY I | NSTF | RUCT | ION: | S | | | | | | | | | | |------------------|-------------------------------------------------------------|--------------|-----|-------|------|------|------|------|-----|-----|-----|-----|----|---|-----|-----|------------|----------| | MNEMO | NIC DESCRIPTION | NO.<br>WORDS | | | | | IN | STR | JCT | ION | ВІТ | cc | DE | | | | | | | | | WORDO | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | APAC | Add P register to accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | | LPH <sup>†</sup> | Load high P register | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | М | • | | | - D | — | | <b>→</b> | | LT | Load T register | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | М | • | | | - D | | | <b>→</b> | | LTA | Load T register and accumulate previous product | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | М | • | | | - D | — | | <b>→</b> | | LTD | Load T register, accumulate previous product, and move data | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | M | 4 | | | - D | | | <b>-</b> | | LTP† | Load T register and store P register in accumulator | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | М | 4 | | | - D | | | <b>-</b> | | LTS <sup>†</sup> | Load T register and subtract previous product | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | М | • | | | - D | | | <b>-</b> | | MAC† | Multiply and accumulate | 2 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | М | • | | | - D | | | <b>→</b> | | MACD† | Multiply and accumulate with data move | 2 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | М | • | | | - D | | | <b>→</b> | | MPY | Multiply (with T register, store product in P register) | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | M | • | | | - D | | | <b>-</b> | | MPYA‡ | Multiply and accumulate previous product | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 0 | М | 4 | | | - D | | | <b>-</b> | | MPYK | Multiply immediate | 1 | 1 | 0 | 1 | • | | | | | — I | ζ – | | | | | | - | | MPYS‡ | Multiply and subtract previous product | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | М | 4 | | | - D | | | <b>-</b> | | MPYU‡ | Multiply unsigned | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | М | 4 | | | - D | | | <b>→</b> | | PAC | Load accumulator with P register | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | | SPAC | Subtract P register from accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 1 | 0 | | SPH <sup>‡</sup> | Store high P register | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | М | • | | | - D | | | <b>→</b> | | SPL‡ | Store low P register | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | М | 4 | | | - D | | | <b>→</b> | | SPM <sup>†</sup> | Set P register output shift mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 • | <b>◆</b> P | M₽ | | SQRA† | Square and accumulate | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | М | 4 | | | - D | | | <b>—</b> | | SQRS† | Square and subtract previous product | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 0 | М | 4 | | | - D | | | <b>—</b> | <sup>†</sup> These instructions are not included in the TMS320C1x instruction set. <sup>&</sup>lt;sup>‡</sup>These instructions are not included in the TMS32020 instruction set. Table 2. SMJ320C25 Instruction Set Summary (continued) | | BRAN | ICH/CALL | INS | TRUC | CTIO | NS | | | | | | | | | | | _ | | |-------------------|-----------------------------------------------|--------------|------|------|------|------|----|------|-----|-------------|------|----------|--------------------------------------------------|----------|-------|---|----------|----------| | MNEMO | NIC DESCRIPTION | NO.<br>WORDS | | | | | II | NSTR | NC. | TIOI | N BI | T C | ODE | Ē | | | | | | | | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | В | Branch unconditionally | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | • | | | – D | | | <b>→</b> | | BACCT | Branch to address specified by accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | | BANZ | Branch on auxiliary register not zero | 2 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | • | | | – D | | | <b>→</b> | | BBNZ† | Branch if TC bit ≠ 0 | 2 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | • | | | – D | | | <b>→</b> | | BBZ† | Branch if TC bit = 0 | 2 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | • | | | – D | | | <b>→</b> | | BC‡ | Branch on carry | 2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | • | | | – D | | | <b>→</b> | | BGEZ | Branch if accumulator ≥ 0 | 2 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | ◀ | | | – D | | | <b>→</b> | | BGZ | Branch if accumulator > 0 | 2 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | • | - | | – D | | | <b>→</b> | | BIOZ | Branch on I/O status = 0 | 2 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | • | | | – D | | | <b>→</b> | | BLEZ | Branch if accumulator $\leq 0$ | 2 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | • | | | – D | — | | <b>→</b> | | BLZ | Branch if accumulator < 0 | 2 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | < | | | – D | | | <b>→</b> | | BNC‡ | Branch on no carry | 2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | < | | | – D | _ | | <b>→</b> | | BNV† | Branch if no overflow | 2 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | • | | | – D | _ | | <b>→</b> | | BNZ | Branch if accumulator ≠ 0 | 2 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | 1 | • | | | – D | | | <b>→</b> | | BV | Branch on overflow | 2 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | • | | | – D | | | <b>→</b> | | BZ | Branch if accumulator = 0 | 2 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | • | | | – D | | | <b>→</b> | | CALA | Call subroutine indirect | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | | CALL | Call subroutine | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | • | | | – D | | | <b>→</b> | | RET | Return from subroutine | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | | | I/O AND I | DATA MEN | /IOR | Y OP | ERA | ΓΙΟN | s | | | | | | | | | | | | | MUEMO | NIO DEGODIDATION | NO. | | | | | II | NSTR | NC. | TIOI | N BI | T C | ODE | <u> </u> | | | | | | MNEMO | NIC DESCRIPTION | WORDS | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | BLKD† | Block move from data memory to data memory | 2 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | М | <u> </u> | | | – D | | <u> </u> | <u> </u> | | BLKP† | Block move from program memory to data memory | 2 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | М | • | <del> </del> | | – D | _ | | <b>→</b> | | DMOV | Data move in data memory | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | М | • | | | – D | | | <b>→</b> | | FORT† | Format serial port registers | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | FO | | IN | Input data from port | 1 | 1 | 0 | 0 | 0 | • | — F | - Α | <b>-</b> | М | 4 | | | – D | | | <b>→</b> | | OUT | Output data to port | 1 | 1 | 1 | 1 | 0 | • | | Α- | <b>&gt;</b> | . М | | | | ם – | | | · | | RFSM‡ | Reset serial port frame synchronization mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 0 | | RTXM <sup>†</sup> | Reset serial port transmit mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | RXF <sup>†</sup> | Reset external flag | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | SFSM‡ | Set serial port frame synchronization mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | | STXM <sup>†</sup> | Set serial port transmit mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | | SXF† | Set external flag | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 1 | | TBLR | Table read | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | М | _ | _ | | – D | | | _ | | TBLW | Table write | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | М | _ | | | – D | | | _ | | | | | | | - | | | - | - | | | • | | | $\nu$ | | | | <sup>†</sup> These instructions are not included in the TMS320C1x instruction set. $<sup>\</sup>mbox{\ensuremath{\ddagger}}$ These instructions are not included in the TMS32020 instruction set. SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 # Table 2. SMJ320C25 Instruction Set Summary (concluded) | | CON | TROL INS | TRU | СТІО | NS | | | | | | | | | | | | | | |-------------------|------------------------------------------------------|----------|-----|------|----|----|----|-----|-----|-----|-----|----|----|-----|-------|---|---|----------| | MNEMONIC | DESCRIPTION | NO. | | | | | IN | STR | UCT | ION | ВІТ | cc | DE | | | | | | | | | WORDS | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | віт† | Test bit | 1 | 1 | 0 | 0 | 1 | • | — Е | 3 — | -▶ | М | • | | | - D - | | | <b>→</b> | | вітт† | Test bit specified by T register | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | М | • | | | - D - | | | → | | CNFD† | Configure block as data memory | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | CNFP† | Configure block as program memory | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | | DINT | Disable interrupt | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | EINT | Enable interrupt | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | IDLE† | Idle until interrupt | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | | LST | Load status register STO | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | М | 4 | | | - D - | | | <b>→</b> | | LST1 <sup>†</sup> | Load status register ST1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | М | • | | | - D- | | | <b>→</b> | | NOP | No operation | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | POP | Pop top of stack to low accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | | POPD† | Pop top of stack to data memory | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | М | • | | | - D - | | | <b>→</b> | | PSHD† | Push data memory value onto stack | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | М | 4 | | | - D - | | | <b>→</b> | | PUSH | Push low accumulator onto stack | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | | RC <sup>‡</sup> | Reset carry bit | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | | RHM‡ | Reset hold mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | | ROVM | Reset overflow mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | RPT† | Repeat instruction as specified by data memory value | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | М | • | | | - D- | | | <b>→</b> | | RPTK <sup>†</sup> | Repeat instruction as specified by immediate value | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | • | | | — к | ( | | | <b>→</b> | | RSXM <sup>†</sup> | Reset sign-extension mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | | RTC <sup>‡</sup> | Reset test/control flag | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | | sc‡ | Set carry bit | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 1 | | SHM <sup>‡</sup> | Set hold mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | | SOVM | Set overflow mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | | SST | Store status register ST0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | М | 4 | | | - D- | | | <b>→</b> | | SST1 <sup>†</sup> | Store status register ST1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | М | • | | | - D- | | | <b>→</b> | | ssxm† | Set sign-extension mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | | STC‡ | Set test/control flag | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | TRAP† | Software interrupt | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | <sup>&</sup>lt;sup>†</sup> These instructions are not included in the TMS320C1x instruction set. <sup>‡</sup> These instructions are not included in the TMS32020 instruction set. SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 ### development systems and software support Texas Instruments offers concentrated development support and complete documentation for designing an SMJ320C25-based microprocessor system. When developing an application, tools are provided to evaluate the performance of the processor, to develop the algorithm implementation, and to fully integrate the design's software and hardware modules. When questions arise, additional support can be obtained by calling the nearest Texas Instruments Regional Technology Center (RTC). Sophisticated development operations are performed with the SMJ320C25 Macro Assembler/linker, Simulator, and Emulator (XDS). The macro assembler and linker are used to translate program modules into object code and link them together. This puts the program modules into a form which can be loaded into the SMJ320C25 Simulator or Emulator. The simulator provides a quick means for initially debugging SMJ320C25 software while the emulator provides the real-time in-circuit emulation necessary to perform system level debug efficiently. Table 3 gives a complete list of SMJ320C25 software and hardware development tools. Table 3. SMJ/SMJ320C25 Software and Hardware Support | | MACRO ASSEMBLERS/LINKERS | | |---------------|--------------------------|----------------| | Host Computer | Operating System | Part Number | | DECVAX | VMS | TMDS324210-08 | | TI/IBM PC | MS/PC-DOS | TMDS3242810-0 | | | | | | | SIMULATORS | | | Host Computer | Operating System | Part Number | | DECVAX | VMS | TMDS3242211-08 | | TI/IBM PC | MS/PC-DOS | TMDS3242811-02 | | | • | • | | | EMULATORS | | | Model | Power Supply | Part Number | | XDS/22 | Included | TMDS3262221 | SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 # absolute maximum ratings over operating free-air temperature (unless otherwise noted)† | Supply voltage, V <sub>CC</sub> | |-------------------------------------------| | Input voltage range | | Output voltage range0.3 V to 7 V | | Continuous power dissipation 1.0 W | | Storage temperature range – 65°C to 150°C | <sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. ### recommended operating conditions‡ | | | | SM | J320C25 | -50 | SI | /J320C2 | :5 | | |------------|---------------------------|--------------------------------|------|---------|------|------|---------|------|------| | | | | MIN | NOM | MAX | MIN | NOM | MAX | UNIT | | VCC | Supply voltage | | 4.75 | 5 | 5.25 | 4.5 | 5 | 5.5 | V | | Vss | Supply voltage | | | 0 | | | 0 | | V | | | | READY | 3.00 | | | 2.35 | | | | | | | D15-D0 | 2.20 | | | 2.20 | | | | | <b>.</b> , | TP-L I IP 1 16 | FSX | 2.20 | | | 2.30 | | | ., | | VIH | High-level input voltage | CLKR, CLKX | 3.50 | | | 3.50 | | | V | | | | CLKIN | 4.00 | | | 3.50 | | | | | | | All others | 3.00 | | | 3.00 | | | | | | | D15-D0, FSX, CLKIN, CLKR, CLKX | | | 0.80 | | | 0.80 | | | VIL | Low-level input voltage | HOLD | | | 0.70 | | | 0.70 | V | | | | All others | | | 0.80 | | | 0.70 | | | lOH | High-level output current | | | | 300 | | | 300 | μΑ | | loL | Low-level output current | | | | 2 | | | 2 | mA | | TC | Operating case temperatur | re | -55 | | 125 | -55 | | 125 | °C | T<sub>C</sub> MAX at maximum rated operating conditions at any point on case T<sub>C</sub> MIN at initial (time zero) power up This device contains circuits to protect its inputs and outputs against damage due to high static voltages or electrostatic fields. These circuits have been qualified to protect this device against electrostatic discharges (ESD) of up to 2 kV according to MIL-STD-883C, Method 3015; however, it is advised that precautions be taken to avoid application of any voltage higher than maximum-rated voltages to these high-impedance circuits. During storage or handling, the device leads should be shorted together or the device should be placed in conductive foam. In a circuit, unused inputs should always be connected to an appropriated logic voltage level, preferably either V<sub>CC</sub> or ground. Specific guidelines for handling devices of this type are contained in the publication *Guidelines for Handling Electrostatic-Discharge-Sensitive (ESDS) Devices and Assemblies* available from Texas Instruments. <sup>†</sup> All voltage values are with respect to VSS. ### electrical characteristics over specified free-air temperature range (unless otherwise noted) | | PARAMET | ER | TEST CONDITIONS | | MJ320C2<br>J320C25 | , | UNIT | |------|---------------------------|----------------|------------------------------|-----|--------------------|-----|------| | | | | | MIN | TYP§ | MAX | | | Vон | High-level output voltage | | $V_{CC} = MIN, I_{OH} = MAX$ | 24 | 3 | | V | | VOL | Low-level output voltage | | $V_{CC} = MIN, I_{OL} = MAX$ | | 0.3 | 0.6 | V | | ΙZ | Three-state current | | V <sub>CC</sub> = MAX | -20 | | 20 | μΑ | | | Les de const | X2/CLKIN | V V | -20 | | 20 | | | l II | Input current | All other pins | $V_I = V_{SS}$ to $V_{CC}$ | -10 | | 10 | μΑ | | | | Normal | .,, | | | 185 | | | ICC | Supply current | Idle/R5L5 | $V_{CC} = MAX, f_X = MAX$ | | | 100 | mA | | Ci | Input capacitance | | | | 15 | | pF | | Co | Output capacitance | | | | 15 | | pF | <sup>§</sup> All typical values are at V<sub>CC</sub> = 5 V, T<sub>A</sub> = 25°C #### **CLOCK CHARACTERISTICS AND TIMING** The SMJ320C25 can use either its internal oscillator or an external frequency source for a clock. ### internal clock option The internal oscillator is enabled by connecting a crystal across X1 and X2/CLKIN (see Figure 2). The frequency of CLKOUT1 is one-fourth the crystal fundamental frequency. The crystal should be either fundamental or overtone mode, and parallel resonant, with an effective series resistance of 30 $\Omega$ , a power dissipation of 1 mW, and be specified at a load capacitance of 20 pF. Note that overtone of crystals require an additional tuned LC circuit (see the application report, *Hardware Interfacing to the TMS320C25*). | | DADAMETED | TEAT COMPLETIONS | SMJ | 320C25 | -50 | SN | 1J320C2 | 5 | | |----------------|-----------------------|----------------------------|------|--------|------|------|---------|------|------| | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | f <sub>X</sub> | Input clock frequency | T <sub>A</sub> = -55°C MIN | 6.7† | | 50.0 | 6.7† | | 40.0 | MHz | | C1, C2 | | T <sub>C</sub> = 125°C MAX | | 10 | | | 10 | | pF | <sup>&</sup>lt;sup>†</sup> These values are derived from characterization data and are not tested. Figure 2. Internal Clock Options ### external clock option An external frequency source can be used by injecting the frequency directly into X2/CLKIN with X1 left unconnected. The external frequency injected must conform to the specifications listed in the following table. ### switching characteristics over recommended operating conditions (see Note 1) | | PARAMETER | SMJ320 | C25-50 | SN | /J320C2 | 5 | | |--------------------|---------------------------------------------------------|--------|--------|--------|---------|--------|------| | | PARAMETER | MIN | MAX | MIN | NOM | MAX | UNIT | | t <sub>C</sub> (C) | Cycle time, CLKOUT1/CLKOUT2 | 80 | 600 | 100 | | 600 | ns | | td(CIH-C) | Delay time, CLKIN high to CLKOUT1/CLKOUT2/STRB high/low | 5 | 28 | 5 | | 30 | (1S | | | Delay time, CLKOUT1 high to CLKOUT2 low, | 0 0 | 0 . 0 | 0 0 | | 0 . 0 | | | td(C1–C2) | Delay time, CLKOUT2 high to CLKOUT1 high, etc. | Q – 6 | Q + 3 | Q-6 | Q | Q + 6 | ns | | t <sub>f</sub> (C) | Fall time, CLKOUT1/CLKOUT2/STRB | | 5 | | | 5 | ns | | t <sub>r(C)</sub> | Rise time, CLKOUT1/CLKOUT2/STRB | | 3 | | | 5 | ns | | tw(CL) | Pulse duration, CLKOUT1/CLKOUT2 low | 2Q - 7 | 2Q + 5 | 2Q – 8 | 2Q | 2Q + 8 | ns | | tw(CH) | Pulse duration, CLKOUT1/CLKOUT2 high | 2Q - 5 | 2Q + 7 | 2Q – 8 | 2Q | 2Q + 8 | ns | <sup>†.</sup>This parameter is not production tested NOTE 1: $Q = 1/4t_{C(C)}$ ## timing requirements over recommended operating conditions (see Note 1) | | | SMJ320C25-50 | | SMJ32 | | | |---------------------|---------------------------------------------------------------------|-----------------|-------|-------|-------|----| | | | MIN MAX MIN MAX | MAX | UNIT | | | | t <sub>C</sub> (CI) | Cycle time, CLKIN | 20 | 150 | 25 | 150 | ns | | tw(CIL) | Pulse duration, CLKIN low, t <sub>C(CI)</sub> = 25 ns (see Note 2) | 8 | | 10 | 15 | ns | | tw(CIH) | Pulse duration, CLKIN high, t <sub>C(CI)</sub> = 25 ns (see Note 2) | 8 | | 10 | 15 | ns | | t <sub>su(S)</sub> | Setup time, SYNC before CLKIN low | 4 | Q – 4 | 5 | Q – 5 | ns | | th(S) | Hold time, SYNC from CLKIN low | 4 | | 8 | | ns | NOTES: 1: $Q = 1/4t_{C(C)}$ 2. Rise and rall times, assuming a 40–60% duty cycle, are incorporated within this specification CLKIN rise and fall times must be less than 5 ns Figure 3. Test Load Circuit Figure 4. Voltage Reference Levels ### switching characteristics over recommended operating conditions (see Note 1) | | DADAMETED | SMJ320 | C25-50 | SN | 1J320C2 | 25 | LINUT | |---------------------|-------------------------------------------------------------------|------------|---------------------|---------|---------|---------------------|-------| | | PARAMETER | MIN | MAX | MIN | TYP | MAX | UNIT | | td(C1-S) | STRB from CLKOUT1 (if STRB is present) | Q – 5 | Q + 3 | Q – 6 | Q | Q+6 | ns | | td(C2-S) | CLKOUT2 to STRB (if STRB is present) | -2 | 5 | -6 | 0 | 6 | ns | | t <sub>su(A)</sub> | Address setup time before STRB low (see Note 3) | Q – 13 | | Q – 12 | | | ns | | th(A) | Address hold time after STRB high (see Note 3) | Q – 4 | | Q – 8 | | | ns | | tw(SL) | STRB low pulse duration (no wait states, see Note 4) | 2Q - 5 | 2Q + 5 | 2Q – 5 | 2Q | 2Q + 5 | ns | | tw(SH) | STRB high pulse duration (between consecutive cycles, see Note 4) | 2Q - 5 | 2Q + 5 | 2Q – 5 | | 2Q + 5 | ns | | t <sub>su(D)W</sub> | Data write setup time before STRB high (no wait states) | 2Q – 17 | | 2Q - 20 | | | ns | | th(D)W | Data write hold time from STRB high | Q – 5 | | Q – 10 | Q | | ns | | ten(D) | Data bus starts being driven after STRB low (write cycle) | 0† | | 0† | | | ns | | tdis(D) | Data bus three-state after STRB high (write cycle) | | Q + 15 <sup>†</sup> | | Q | Q + 15 <sup>†</sup> | ns | | td(MSC) | MSC valid from CLKOUT1 | <b>-</b> 5 | 10 | -10 | 0 | 10 | ns | <sup>†</sup> These values are derived from characterization data and not tested. # timing requirements over recommended operating conditions (see Note 1) | | | SMJ320C25-50 | | SMJ3 | 320C25 | | |----------------------|--------------------------------------------------------------------------|--------------|---------|------|---------|------| | | | MIN | MAX | MIN | MAX | UNIT | | ta(A) | Access time, read data from address time (read cycle, see Notes 3 and 5) | | 3Q - 31 | | 3Q - 35 | ns | | t <sub>su(D)R</sub> | Setup time, data read before STRB high | 17 | | 23 | | ns | | th(D)R | Hold time, data read from STRB high | 0 | | 0 | | ns | | td(SL-R) | Delay time, READY valid after STRB low (no wait states) | | Q – 20 | | Q – 20 | ns | | td(C2H-R) | Delay time, READY valid after CLKOUT2 high | | Q – 21 | | Q – 20 | ns | | th(SL-R) | Hold time, READY after STRB low (no wait states) | Q – 1 | | Q+3 | | ns | | th(C2H-R) | Hold time, READY after CLKOUT2 high | Q – 1 | | Q+3 | | ns | | t <sub>d</sub> (M–R) | Delay time, READY valid after MSC valid | | 2Q - 25 | | 2Q – 25 | ns | | th(M–R) | Hold time, READY after MSC valid | 0 | | 0 | | ns | - NOTES: 1: 0 = 1/4t<sub>C(C)</sub> 3. A15–A0, PS, DS, IS, RW, and BR timings are all included in timings referenced as "address" - 4. Delays between CLKOUT1 /CLKOUT2 edges and STRB edges track each other, resulting in tw(SL) and tw(SH) being 2Q with no wait states. - 5. Read data access time is defined as $t_{a(A)} = t_{su(A)} + t_{w(SL)} t_{su(D)R} + t_{r(C)}$ . # RS, INT, BIO, and XF timing ### switching characteristics over recommended operating conditions (see Note 1) | PARAMETER | | SMJ320C25-50 | | | SM | | | | |---------------------|--------------------------------------------------|-----------------|-----|-----|-----------------|-----|-----|------| | | | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | t <sub>d</sub> (RS) | Delay time, CLKOUT1 low to reset state entered | | | 22† | | | 22† | ns | | td(IACK) | Delay time, CLKOUT1 to IACK valid | <sub>-5</sub> † | 0 | 7 | _8 <sup>†</sup> | 0 | 8 | ns | | t <sub>d(XF)</sub> | Delay time, XF valid before falling edge of STRB | Q – 10 | | | Q – 12 | | | ns | ### timing requirements over recommended operating conditions (see Note 1) | | | SMJ3200 | C25-50 | SMJ32 | | | |---------------------|--------------------------------------------|---------------------|--------|---------------------|-----|------| | | | MIN | MAX | MIN | MAX | UNIT | | t <sub>su(IN)</sub> | Setup time, INT/BIO/RS before CLKOUT1 high | 25 | | 32 | | ns | | th(IN) | Hold time, INT/BIO/RS after CLKOUT1 high | 0 | | 0 | | ns | | tw(IN) | Pulse duration, INT/BIO low | t <sub>C</sub> (C) | | t <sub>C</sub> (C) | | ns | | tw(RS) | Pulse duration, RS low | 3t <sub>C</sub> (C) | | 3t <sub>C</sub> (C) | | ns | ## switching characteristics over recommended operating conditions (see Note 1) | | PARAMETER | SMJ320C25-50 | | | SN | 5 | LINIT | | |-------------------------|-----------------------------------------------------------------------------|--------------|-----|-----|-----|-----|-------|------| | | PARAMETER | MIN | TYP | MAX | MIN | TYP | MAX | UNIT | | <sup>t</sup> d(C1L-AL) | Delay time, HOLDA low after CLKOUT1 low | -1 | | 11 | -1 | | 10 | ns | | tdis(AL-A) | Disable time, HOLDA low to address three-state | | 0 | | | 0 | | ns | | <sup>t</sup> dis(C1L-A) | Disable time, address three-state after CLKOUT1 low (HOLD mode, see Note 7) | | | 20† | | | 20† | ns | | <sup>t</sup> d(HH-AH) | Delay time, HOLD high to HOLDA high | | | 19 | | | 25 | ns | | <sup>t</sup> en(A-C1L) | Enable time, address driven before CLKOUT1 low (HOLD mode, see Note 7) | | | 8† | | | 8† | ns | ## timing requirements over recommended operating conditions (see Note 1) | | SMJ320 | C25-50 | SMJ32 | UNIT | | |------------------------------------------------------------------|--------|--------|-------|--------|------| | | MIN | MAX | MIN | MAX | UNIT | | t <sub>d</sub> (C2H-H) Delay time, HOLD valid after CLKOUT2 high | | Q – 19 | | Q – 24 | ns | <sup>†</sup> These values are derived from characterization data and not tested. NOTES: 1. Q = 1/4t<sub>C</sub>(C) 6. RS, INT, and BIO are asynchronous inputs and can occur at any time during a clock cycle. However, if the specified setup time is met, the exact sequence shown in the timing diagram occurs. INT/BIO fall time must be less than 8 ns. 7. A15–A0, PS, DS, IS, STRB, and R/W timings are all included in timings referenced as "address". SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 ## serial port timing ## switching characteristics over recommended operating conditions (see Note 1) | | PARAMETER | | C25-50 | SMJ32 | | | |-----------|-------------------------------------------------------------------|-----|--------|-------|-----|------| | PARAMETER | | MIN | MAX | MIN | MAX | UNIT | | td(CH-DX) | Delay time, DX valid after CLKX rising edge (see Note 8) | | 75 | | 80 | ns | | td(FL-DX) | Delay time, DX valid after FSX falling edge (TXM = 0. see Note 8) | | 40 | | 45 | ns | | td(CH-FS) | FSX valid after CLKX rising edge (TXM = 1) | | 40 | | 45 | ns | # timing requirements over recommended operating conditions (see Note 1) | | | SMJ32 | 20C25-50 | SMJ320C25 | | | |----------------------|----------------------------------------------------------------|-------|----------|-----------|---------|------| | | | MIN | MAX | MIN | MAX | UNIT | | f <sub>SX</sub> | Serial port frequency | 1.25 | 6250 | 1.25 | 5000 | kHz | | t <sub>c</sub> (SCK) | Serial port clock (CLKX/CLKR) cycle time | 160 | 800 000 | 200 | 800 000 | ns | | tw(SCK1 | Serial port clock (CLKX/CLKR) low pulse duration (see Note 9) | 64 | | 80 | | ns | | tw(SCK) | Serial port clock (CLKX/CLKR) high pulse duration (see Note 9) | 64 | | 80 | | ns | | t <sub>su(FS)</sub> | FSX/FSR setup time before CLKX/CLKR falling edge (TXM = 0) | 5 | | 18 | | ns | | th(FS) | FSX/FSR hold time after CLKX/CLKR falling edge (TXM = 0) | 10 | | 20 | | ns | | t <sub>su(DR)</sub> | OR setup time before CLKR falling edge | 5 | | 10 | | ns | | th(DR) | OR hold time after CLKR falling edge | 10 | | 20 | | ns | NOTES: 1: $Q = 1/4t_{C(C)}$ 8. The last occurrence of FSX falling and CLKX rising. <sup>9.</sup> The duty cycle of the serial port clock must be within 40-60% .Serial port clock (CLKX/CLKR) rise and fall times must be less than ### **TIMING DIAGRAMS** Timing measurements are referenced to <u>and from a low voltage</u> of 0.8 V and a high voltage of 2.2 V with the exception of CLKOUT1, CLKOUT2, and <u>STRB</u> timing that are referenced from a falling edge low voltage of 1.1 V and a rising edge low voltage of 2.2 V. Figure 5. Clock Timing Figure 6. Memory Read Timing Figure 7. Memory Write Timing Figure 8. One Wait-State Memory Access Timing <sup>‡</sup> Serial port controls are DX and FSX. Figure 9. Reset Timing Figure 11. BIO Timing Figure 12. External Flag Timing <sup>†</sup> HOLD is an asynchronous input and can occur at any time during a clock cycle. If the specified timing is met, the exact sequence shown occurs; otherwise, a delay of one CLKOUT2 cycle occurs. Figure 13. HOLD Timing (part A) <sup>†</sup> HOLD is an asynchronous input and can occur at any time during a clock cycle. If the specified timing is met, the exact sequence shown occurs; otherwise, a delay of one CLKOUT2 cycle occurs. Figure 14. HOLD Timing (part B) Figure 15. Serial Port Receive Timing Figure 16. Serial Port Transmit Timing #### **MECHANICAL DATA** ### FD (S-CQCC-N\*\*) #### **44 TERMINAL SHOWN** #### **LEADLESS CERAMIC CHIP CARRIER** - NOTES: A. All linear dimensions are in inches (millimeters). - B. This drawing is subject to change without notice. - C. This package can be hermetically sealed with a metal lid. - D. The terminals are gold plated. - E. Falls within JEDEC MS-004 SGUS007D - AUGUST 1988 - REVISED OCTOBER 2001 ### FJ (S-CQCC-J\*\*) ### J-LEADED CERAMIC CHIP CARRIER ### **44 PINS SHOWN** NOTES: A. All linear dimensions are in inches (millimeters). - B. This drawing is subject to change without notice. - C. The index mark may appear on top or bottom depending on package vendor. - D. This package is hermetically sealed with a metal lid. ### GB (S-CPGA-P68) #### **CERAMIC PIN GRID ARRAY PACKAGE** NOTES: A. All linear dimensions are in inches (millimeters). - B. This drawing is subject to change without notice. - C. Index mark may appear on top or bottom depending vendor. - D. Pins are located within 0.010 (0,25) diameter of true position relative to each other at maximum material condition and within 0.030 (0,76) diameter relative to the edges of the ceramic. - E. This package can be hermetically sealed with metal lids or with ceramic lids using glass frit. - F. The pins can be gold plated or solder dipped. - G. Falls within MIL STD 1835 CMGA1-PN, CMGA13-PN and JEDEC MO-067 AA, MO-066 AA respectively #### **IMPORTANT NOTICE** Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment. TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed. TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards. TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third—party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI. Reproduction of information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements. Mailing Address: Texas Instruments Post Office Box 655303 Dallas, Texas 75265 Copyright @ 2001, Texas Instruments Incorporated