# 捷多邦,专业PCB打样工厂TMS320C25。TMS320E25 DIGITAL SIGNAL PROCESSORS SPRS010C-MAY 1987-REVISED DECEMBER 1992 - 80-ns instruction Cycle Time - 544 Words of On-Chip Data RAM - 4K Words of On-Chip Secure Program EPROM (TMS320E25) - 4K Words of On-Chip Program ROM (TMS320C25) - 128K Words of Data/Program Space - 32-Bit ALU/Accumulator - 16 x 16-Bit Multiplier With a 32-Bit Product - Block Moves for Data/Program Management - Repeat Instructions for Efficient Use of Program Space - Serial Port for Direct Codec Interface - Synchronization Input for Synchronous Multiprocessor Configurations - Wait States for Communication to Slow Off-Chip Memories/Peripherals - On-Chip Timer for Control Operations - Single 5-V Supply - Packaging: 68-Pin PGA, PLCC, and CER-QUAD - 68-to-28 Pin Conversion Adapter Socket for EPROM Programming - Commercial and Military Versions Available - CMOS Technology: TMS320C25 ..... 100-ns Cycle Time TMS320E25 ..... 100-ns Cycle Time TMS320C25-50 80-ns Cycle Time TMS320C25-33 ... 120-ns Cycle Time #### 68-PIN GB PACKAGE (TOP VIEW) # 68-PIN FN AND FZ PACKAGES (TOP VIEW) #### description This data sheet provides complete design documentation for the second-generation devices of the TMS320 family. This facilitates the selection of the devices best suited for user applications by providing all specifications and special features for each TMS320 member. This data sheet is divided into four major sections: architecture, electrical specifications, timing diagrams, and mechanical data. In each of these sections, generic information is presented first, followed by specific device information. An index is provided for quick reference to specific information about a device. SPRS010C-MAY 1987-REVISED DECEMBER 1992 # PGA AND PLCC/CER-QUAD 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 | ĪNT2 | 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 | | A3 | K3/30 | A15 | L10/43 | D5 | C2/13 | DS | K10/45 | MSC | C10/59 | VSS | K11/44 | | A4 | L4/31 | BIO | B7/68 | D6 | C1/12 | DX | E11/54 | PS | J10/47 | VSS | 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 | ĪĀCK | B11/60 | SYNC | F2/19 | | | | A10 | K7/38 | DO | F1/18 | D12 | A4/5 | INTO | G1/20 | Vcc | A10/61 | | | | A11 | L8/39 | D1 | E2/17 | D13 | B5/4 | ĪNT1 | G2/21 | Vcc | B10/62 | | | | SIGNALS | I/O/Z† | DEFINITION | |------------|--------|-----------------------------------------------------------------------------------------------------------------------| | Vcc | T | 5-V supply pins | | VSS | 1 | Ground pins | | Xí | 0 | Output from internal oscillator for crystal | | X2/CLKIN | 1 | 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/O 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 | 1 | Reset input | | INT2-INTO | t | External user interrupt inputs | | MP/MC | | Microprocessor/microcomputer mode select pin | | MSC | 0 | Microstate complete signal | | IACK | 0 | Interrupt acknowledge signal | | READY | 1 | Data ready input. Asserted by external logic when using slower devices to indicate that the current bus transaction | | | ١ ۾ | is complete. Bus request signal. Asserted when the TMS320C2x requires access to an external global data memory space | | BR | 0 | External flag output (latched software-programmable signal) | | XF | 1 ' | Hold input. When asserted, TMS320C2x goes into an idle mode and places the data, address, and control lines in | | HOLD | ! 1 | the high impedance state. | | HOLDA | 0 | Hold acknowledge signal | | SYNC | | Synchronization input | | BIO | l ı | Branch control input. Polled by BIOZ instruction. | | DR | | Serial data receive input | | CLKR | 1 | Clock for receive input for serial port | | FSR | | Frame synchronization pulse for receive input | | DX | O/Z | Serial data transmit output | | CLKX | l i | Clock for transmit output for serial port | | FSX | I/O/Z | Frame synchronization pulse for transmit. Configuration as either an input or an output. | <sup>†</sup> I/O/Z denotes input/output/high-impedance state. SPRS010C-MAY 1987-REVISED DECEMBER 1992 Key Features: TMS320C25, TMS320C25-50, TMS320E25 - 80-ns Instruction Cycle Time (TMS320C25-50) - 100-ns Instruction Cycle Time (TMS320C25) - 4K Words of On-Chip Secure Program EPROM (TMS320E25) - 4K Words of On-Chip Program ROM (TMS320C25) - 544 Words of On-Chip RAM - 128K Words of Total Program/Data Memory Space - Wait States for Communications to Slower Off-Chip Memories - Object-Code Compatible With the TMS32020 - Source-Code Compatible With TMS320C1x - 24 Additional Instructions to Support Adaptive Filtering, FFTs, and Extended-Precision Arithmetic - Block Moves for Data/Program Management - Single-Cycle Multiply/Accumulate Instructions - Eight Auxiliary Registers With Dedicated Arithmetic Unit - Bit-Reversed Indexed-Addressing Mode for Radix-2 FFTS - Double-Buffered Serial Port - On-Chip Clock Generator - Single 5-V Supply - Internal Security Mechanism (TMS320E25) - 68-to-28 Pin Conversion Adapter Socket - CMOS Technology - 68-Pin Grid Array (PGA) Package (TMS320C25) - 68-Lead Plastic Leaded Chip Carrier (PLCC) Package (TMS320C25, TMS320C25-50) - 68-Lead CER-QUAD Package (TMS320E25) Table 1 provides an overview of the second-generation TMS320 processors with comparisons of memory, I/O, cycle timing, power, package type, technology, and military support. For specific availability, contact the nearest TI Field Sales Office. Table 1. TMS320 Second-Generation Device Overview | | | | MEMORY | | | | 1/01 | | | CYCLE | TYP | | PACKA | | |---------------|--------|------|-----------|-----|-------|---------|---------|-----|-------|-------|-------|-----|-------|----------| | DEVICE | | | ON-CHIP | OFF | -CHIP | <b></b> | | | TIMER | TIME | POWER | | TYPE | | | | | RAM | ROM/EPROM | | DATA | SER | PAR | DMA | | (ns) | (mW) | PGA | PLCC | CER-QUAD | | TMS320C25 | (CMOS) | 544 | 4K | 64K | 64K | YES | 16×16 | CON | YES | 100 | 500 | 68 | 68 | _ | | TMS320C25-509 | (CMOS) | 544 | 4K | 64K | 64K | YES | 16 × 16 | CON | YES | 80 | 500 | _ | 68 | | | TMS320E25\$ | (CMOS) | 544 | 4K | 64K | 64K | YES | 16 × 16 | CON | YES | 100 | 500 | _ | _ | 68 | | TMS320C26 | (CMOS) | 1568 | 256 | 64K | 64K | YES | 16 × 16 | CON | YES | 100 | 500 | _ | 68 | | <sup>†</sup> SER = serial; PAR = parallel; DMA = direct memory access; CON = concurrent DMA. <sup>\*</sup> Military version available; contact nearest TI Field Sales Office for availability. <sup>§</sup> Military version planned; contact nearest TI Field Sales Office for details. SPRS010C-MAY 1987-REVISED DECEMBER 1992 #### architecture The TMS320 family utilizes a modified Harvard architecture for speed and flexibility. In a strict Harvard architecture, program and data memory lie in two separate spaces, permitting a full overlap of instruction fetch and execution. The TMS320 family's modification of the Harvard architecture allows transfers between program and data spaces, thereby increasing the flexibility of the device. This modification permits coefficients stored in program memory to be read into the RAM, eliminating the need for a separate coefficient ROM. It also makes available immediate instructions and subroutines based on computed values. Increased throughput on the TMS320C2x devices for many DSP applications is accomplished by means of single-cycle multiply/accumulate instructions with a data move option, up to eight auxiliary registers with a dedicated arithmetic unit, and faster I/O necessary for data-intensive signal processing. The architectural design of the TMS320C2x 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. #### 32-bit ALU/accumulator The 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 instructions 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 may be provided from the Product Register (PR) 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. SPRS010C-MAY 1987-REVISED DECEMBER 1992 ## functional block diagram (TMS320C2x) LEGEND A961722 0092906 Accumulator high ACCH ACCL Accumulator low ALU Arithmetic logic unit ARAU Auxiliary register arithmetic unit ARB Auxiliary register pointer buffer Auxiliary register pointer ARP DP DBB Data memory page pointer Serial port data receive register DXR Serial port data transmit register 576 Interrupt flag register IMR Interrupt mask register IR Instruction register Microcall stack QIR Queue instruction register PR Product register PRD Period register for timer Timer Temporary register Program counter PFC Prefetch counter BPTC Repeat instruction counter GREG Global memory allocation register Serial port receive shift register XSR Serial port transmit shift register ARO-AR7 Auxiliary registers STO, ST1 Status registers Carry bit SPRS010C-MAY 1987-REVISED DECEMBER 1992 #### scaling shifter The TMS320C2x scaling shifter has 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 may 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 16 $\times$ 16-bit hardware multiplier 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 instruction set are single-cycle multiply/accumulate instructions that allow both operands to be processed simultaneously. The data for these operations may reside anywhere in internal or external memory, and can be transferred to the multiplier each cycle via the program and data buses. 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 TMS320C2x 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 on the TMS320C25. 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 may be programmed to occur at regular intervals of PRD + 1 cycles of CLKOUT 1 on the TMS320C25. #### memory control The TMS320C2x 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 TMS320C2x 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, EPROM, or high-speed external program memory, the TMS320C2x runs at full speed without wait states. However, the READY line can be used to interface the TMS320C2x 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 TMS320C2x provides three separate address spaces 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 (see Figure 1). The CNFD (configure block B0 as data memory) and CNFP (configure block B0 as program memory) instructions allow dynamic configuration of the memory maps through software. Regardless of the configuration, the user may still execute from external program memory. The TMS320C2x has six registers that 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. SPRS010C-MAY 1987-REVISED DECEMBER 1992 Figure 1. Memory Maps (b) Memory Maps After a CNFP Instruction SPRS010C-MAY 1987-REVISED DECEMBER 1992 #### interrupts and subroutines The TMS320C2x has three external maskable user interrupts \overline{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 (\overline{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 instructions 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 to instructions that are repeated and to instructions that become multicycle due to the READY signal. #### external interface The TMS320C2x 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 throughput. 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 transactions are made with slower devices, the TMS320C2x processor waits until the other device completes its function and signals the processor via the READY line. Then, the TMS320C2x 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 may 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, and may 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 may be implemented by programming one device to transmit while the others are in the receive mode. The serial port on the TMS320C25 is double-buffered and fully static. #### multiprocessing The flexibility of the TMS320C2x allows configurations to satisfy a wide range of system requirements and 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 TMS320C2x 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 TMS320C2x's 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 TMS320C2x 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 TMS320C2x's external memory by asserting HOLD low. This causes the TMS320C2x to place its address data and control lines in a high-impedance state, and assert HOLDA. On the TMS320C2x, program execution from on-chip ROM may proceed concurrently when the device is in the hold mode. SPRS010C-MAY 1987-REVISED DECEMBER 1992 #### instruction set The TMS320C2x 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 memory. Highest throughput is achieved by maintaining data memory on-chip and using either internal or fast external program memory. #### addressing modes The TMS320C2x 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 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 registers (AR0-AR7) provide flexible and powerful indirect addressing on the TMS320C25. To select a specific auxiliary register, the Auxiliary Register Pointer (ARP) is loaded with a value from 0 to 7 for AR0 through AR7, respectively. There are seven types of indirect addressing: auto-increment or auto-decrement, post-indexing by either adding or subtracting the contents of ARO, single indirect addressing with no increment or decrement, and bit-reversal addressing (used in FFTs on the TMS320C25 only) with increment or decrement. All operations are performed on the current auxiliary register in the same cycle as the original instruction, following which the current auxiliary register and ARP may be modified. #### 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. SPRS010C-MAY 1987-REVISED DECEMBER 1992 #### instruction set summary Table 2 lists the symbols and abbreviations used in Table 3, the TMS320C25 instruction set summary. Table 3 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. The symbol (†) indicates those instructions that are not included in the TMS320C1x instruction set. **Table 2. Instruction Symbols** | SYMBOL | DEFINITION | |--------|---------------------------------------------------------------------------------------| | В | 4-bit field specifying a bit code | | СМ | 2-bit field specifying compare mode | | D | Data memory address field | | FO | Format status bit | | M | Addressing mode bit | | K | Immediate operand field | | PA | Port address (PA0-PA15 are predefined assembler symbols equal to 0-15, respectively.) | | PM | 2-bit field specifying P register output shift code | | AR | 3-bit operand field specifying auxiliary register | | s | 4-bit left-shift code | | X | 3-bit accumulator left-shift field | Table 3. TMS320C25 Instruction Set Summary | | ACCUMULATOR MI | Ĭ | | | | | | | | | | _ | | | | | | | |-------------------|--------------------------------------------------------------|--------------|-----------|----|---------|---------|------------|----|------|------------|---|---------------|----------|-----|----------|---|---|----| | MNEMONIC | DESCRIPTION | NO.<br>WORDS | 4- | | | | | | JCTI | | | | | | _ | | | _ | | ABS | Absolute value of accumulator | 1 | <b>15</b> | 14 | 13<br>0 | 12<br>0 | 11 | 10 | 9 | 8 | 7 | <u>6</u><br>0 | <u>5</u> | 1 | 1 | 2 | 1 | | | ADD<br>ADD | | | 0 | 0 | | | 4 | | | | | - | U | ' | ι<br>- D | 0 | ' | | | | Add to accumulator with shift | ' | | - | 0 | 0 | • | 0 | S | | M | 4 | | | . D. | | | • | | ADDU | Add to accumulator with carry | , | 0 | 1 | 0 | _ | 0 | 0 | 1 | 1 | M | _ | | | _ | | | , | | ADDH | Add to high accumulator | 1 1 | 0 | 1 | 0 | 0 | 1 | - | 0 | 0 | М | • | | | . D | | | ٦. | | ADDK | Add to accumulator short immediate | ' | 1 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | • | | | — K | | | | - | | ADDS | Add to low accumulator with sign extension suppressed | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 0 | 1 | М | 4 | | | D | | | -1 | | ADDT | Add to accumulator with shift specified by T register | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | М | 4 | | | - D | | | - | | ADLKT | Add to accumulator long immediate with shift | 2 | 1 | 1 | 0 | 1 | • | | s- | > | 0 | 0 | 0 | 0 | 0 | 0 | 1 | | | AND | AND with accumulator | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | М | 4 | | | D . | | | 4 | | ANDK† | AND immediate with accumulator with shift | 2 | 1 | 1 | 0 | 1 | <b>4</b> - | | s | > | 0 | 0 | 0 | 0 | 0 | 1 | 0 | | | CMPL <sup>†</sup> | 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> ▶ | М | 4 | - | | ۰ ۵ | | | - | | LACK | Load accumulator immediate short | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 4 | | | — к | <u> </u> | | | _ | | LACT <sup>†</sup> | Load accumulator with shift specified by T register | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | М | 4 | | | - D | | | _ | | LALKT | Load accumulator long immediate with shift | 2 | 1 | 1 | 0 | 1 | • | | s— | <b>-</b> > | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | NEG† | Negate accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | | | NORMT | Normalize contents of accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | Х | х | х | 0 | 0 | 1 | | | 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 | <b>←</b> | | 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 | 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 | 4 | - x | <b>-</b> ▶ | М | 4 | | | ۰ ص | | | _ | | SACL | Store low-order accumulator with shift | 1 | 0 | 1 | 1 | 0 | 0 | • | - x | ▶ | М | 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 | | | SFLT | Shift accumulator left | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | | | SFRT | 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 | <b>←</b> | | 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 | М | 4 | | | . 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 | 4 | | | — k | <u> </u> | | | _ | | SUBS | Subtract from low accumulator with sign extension suppressed | 1 | 0 | 1 | 0 | 0 | 0 | 1 | 0 | 1 | М | 4 | | | - D | | | _ | $<sup>\</sup>ensuremath{^{\dagger}}$ These instructions are not included in the TMS320C1x instruction set. Table 3. TMS320C25 Instruction Set Summary (continued) | | ACCUMULATOR ME | TOTAL TIE | FER | LITO | | 31 NC | ,011 | JN3 | | | | | | | | | | _ | |----------|--------------------------------------------------------------------------|-----------|-----|------|------|-------|------|-------------|------|----------|-----|-------------|---|----|------------|----------|------|----------| | MNEMO | NIC DESCRIPTION | NO. | | | | I | NSTE | RUC" | FIOI | A BI | T C | ODE | | | | | | | | | | WORDS | 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 — | | | <b>→</b> | | 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 | ; — | -> | 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 | М | <b>←</b> | | | <b>D</b> — | | | • | | ZALR | Zero low accumulator and load high accumulator with rounding | 1 | 0 | t | 1 | 1 | 1 | 0 | 1 | 1 | М | • | | | D — | | | <b>→</b> | | ZALS | Zero accumulator and load low accumulator with sign extension suppressed | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | М | • | | | D — | | | <b>→</b> | | | AUXILIARY REGISTERS A | ND DATA | PAC | E PC | דאוכ | ER II | ISTR | UCT | 101 | IS | | | | | | | | | | MNEMO | NIC DESCRIPTION | NO. | | | | Į | NSTI | auc. | ΓΙΟΙ | N BI | T C | ODE | | | | | | | | | | WORDS | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADRK | Add to auxiliary register short immediate | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | • | t | | | к — | | | - | | CMPRT | Compare auxiliary register with auxiliary register AR0 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 0 | 0◀ | F CM | 1- | | LAR | Load auxiliary register | 1 | 0 | 0 | 1 | 1 | 0 • | <del></del> | R | - | М | 4 | | | D- | | | -) | | _ARK | Load auxilliary register short immediate | 1 | 1 | 1 | 0 | 0 | 0 < | <b>—</b> | R | - | • | <del></del> | | | - ĸ - | | | - | | _ARP | Load auxilliary register pointer | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 1 ◀ | $\vdash$ | R - | -) | | DP. | Load data memory page pointer | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 0 | М | 4 | | | - D - | | | <b>→</b> | | DPK | Load data memory page pointer immediate | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 0 | 4 | | | | DP | | | | - | | LRLKT | Load auxiliary register long immediate | 2 | 1 | 1 | 0 | 1 | 0 • | <del></del> | R | - | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | MAR | Modify auxiliary register | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | М | 4 | | | - D | | | + | | *I/\(\)! | | | | | | | | | | | | | | | | | | | | SAR | Store auxiliary register | 1 | 0 | 1 | 1 | 1 | 0 • | | R | <b>→</b> | М | 4 | | | - D - | | | • | <sup>†</sup> These instructions are not included in the TMS320C1x instruction set. Table 3. TMS320C25 Instruction Set Summary (continued) | | T REGISTER, P REGI | STER, AN | D M | JLTIF | LY | NST | RUC | rion: | s | | | | | | | | | _ | |-------|----------------------------------------------------------------|--------------|-----|-------|----|-----|-----|-------|------|------|-----|-----|---|---|--------|-----|-------------|----------| | MNEMO | NIC DESCRIPTION | NO.<br>WORDS | | | | | NST | RUC' | rioi | N BI | T C | DDE | | | | | | | | APAC | Add Daniston | | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | LPHT | Add P register to accumulator | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | | | Load high P register | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | М | 4 | | - | - D | | | <b>→</b> | | LT | Load T register | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | М | 4 | | | - D | | | <b>→</b> | | LTA | Load T register and accumulate previous product | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | М | 4 | | | - D | | | <b>→</b> | | LTD | Load T register, accumulate previous product,<br>and move data | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | М | • | | | - D | | | <b>-</b> | | LTP | Load T register and store P register in accumulator | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | М | 4 | | | ۵ - | | | <b>-</b> | | LTS† | Load T register and subtract previous product | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | M | 4 | | | ם - | | | _ | | MACT | Multiply and accumulate | 2 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 1 | М | • | | | - D | | | - | | MACDT | Multiply and accumulate with data move | 2 | 0 | 1 | 0 | 1 | 1 | 1 | 0 | 0 | М | • | | | -<br>D | | | • | | MPY | Multiply (with T register, store product in P register) | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | М | 4 | | | - 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 | 4 | | | | | — 1 | k – | | | | | | <b>→</b> | | MPYS | Multiply and subtract previous product | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 1 | 1 | М | 4 | | | - D | | | _ | | MPYU | Multiply unsigned | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | М | 4 | | | - D | | | → | | 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 | Store high P register | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | М | • | | | -<br>D | _ | | - | | SPL | Store low P register | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | М | • | | | - D | | | _ | | SPMT | Set P register output shift mode | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0.4 | <b>♦</b> PI | M₽ | | SQRAT | Square and accumulate | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 1 | М | _ | _ | _ | · - | _ | | | | sanst | 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 Table 3. TMS320C25 Instruction Set Summary (continued) | | BRAN | CH/CALL | INS | ruc | TIOI | VS. | | | | | | | | | | | | | |-------------------|------------------------------------------------------------------------------------|--------------|-----|------|------|------|-----|-----|------|------|-------|-----|----------|---|------------|------------|---|----------| | MNEMO | NIC DESCRIPTION | NO.<br>WORDS | | | | | INS | TRU | стю | )N E | SIT ( | OD | E | | | | | | | | | | 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 | • | <b>←</b> | | — D | , | | -> | | 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 | • | <b></b> | | — 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> | | вс | Branch on carry | 2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | • | • | | — D | , — | | - | | BGEZ | Branch if accumulator ≥ 0 | 2 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 1 | • | • | | <u>م</u> – | , — | | - | | BGZ | Branch if accumulator > 0 | 2 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | • | • | | <b>—</b> р | , | | - | | BIOZ | Branch on I/O status = 0 | 2 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | 1 | • | ← | | <u> </u> | , | | - | | BLEZ | Branch if accumulator ≤ 0 | 2 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | • | • | | — D | ) | | - | | BLZ | Branch if accumulator < 0 | 2 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | • | • | | <u> </u> | ·— | | - | | BNC | Branch on no carry | 2 | 0 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | • | • | | — D | ) | | - | | 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 | ) | | > | | BZ | Branch if accumulator = 0 | 2 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | • | • | | <u> </u> | <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 | • | • | | — c | <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 E | DATA MEN | IOR | Y OP | ERA | TION | s | | | | | | | | | | | | | | | NO. | | | | | INS | TRU | CTIC | ON E | 3IT ( | COE | ÞΕ | | | | | | | MNEMO | DNIC DESCRIPTION | WORDS | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | DUKDT | Block move from data memory to data memory | 2 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | M | Ť, | Ť | _ | <u> </u> | | Ė | ⇉ | | BLKD†<br>BLKP† | Block move from data memory to data memory Block move from program memory to data | 2 | ' ' | 1 | 1 | 1 | 1 | 1 | 0 | 0 | М | | _ | | c | | | _ | | DLKF | memory | - | ' | • | | | | | • | | | | • | | | | | | | DMOV | Data move in data memory | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 0 | М | • | • | | — C | | | > | | FORT† | Format serial port registers | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | FC | | 1 <b>N</b> | Input data from port | 1 | 1 | 0 | 0 | 0 | 4 | | PA | - | ► M | • | • | | — E | ) | | <b>-</b> | | OUT | Output data to port | 1 | 1 | 1 | 1 | 0 | 4 | | PA | | ► M | • | • | | C | ) — | | <b>-</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† | 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† | 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 | М | | • | | c | ) — | | - | | TBLW | Table write | 1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 1 | М | | • | | — c | ر | | - | <sup>†</sup> These instructions are not included in the TMS320C1x instruction set. Table 3. TMS320C25 Instruction Set Summary (concluded) | | CON | TROL INS | TRU | CTIO | NS | | | | | | | | | | | | | | |-------------------|------------------------------------------------------|--------------|-----|------|----|----|-----|-----|-----|----|-----|----|----|-----|-----|---|---|----------| | MNEMONIC | DESCRIPTION | NO.<br>WORDS | | | | | INS | TRU | CTI | ON | BIT | co | 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 | • | — E | 3 | -▶ | М | 4 | | | . D | | | • | | вітт† | Test bit specified by T register | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 1 | 1 | М | 4 | | | D . | | | • | | CNFD† | Configure block as data memory | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | | CNFPT | 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 | | IDLET | 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 | М | • | | | D- | | | • | | LST1 <sup>†</sup> | Load status register ST1 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 1 | М | 4 | | | D- | | | • | | 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 | | POPDT | Pop top of stack to data memory | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 1 | 0 | М | 4 | | | D- | | | • | | PSHD† | Push data memory value onto stack | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | М | • | | | 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 | 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 | | RPTT | Repeat instruction as specified by data memory value | 1 | 0 | 1 | 0 | 0 | 1 | 0 | 1 | 1 | М | 4 | | | D- | | | <b>→</b> | | RPTK† | 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 | 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 | 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 | 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- | | | • | | SST1 <sup>†</sup> | Store status register ST1 | 1 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | М | • | | | D- | | | • | | SSXMT | Set sign-extension mode | 1 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 | | TRAPT | Software interrupt | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 | $<sup>\</sup>ensuremath{^{\dagger}}$ These instructions are not included in the TMS320C1x instruction set. SPRS010C-MAY 1987-REVISED DECEMBER 1992 #### documentation support Extensive documentation supports the second-generation TMS320 devices from product announcement through applications development. The types of documentation include data sheets with design specifications, complete user's guides, and 750 pages of application reports published in the book, *Digital Signal Processing Applications with the TMS320 Family* (SPRA012A). An application report, *Hardware Interfacing to the TMS320C25* (SPRA014A), is available for that device. A series of DSP textbooks is being published by Prentice-Hall and John Wiley & Sons to support digital signal processing research and education. The TMS320 newsletter, *Details on Signal Processing*, is published quarterly and distributed to update TMS320 customers on product information. The TMS320 DSP bulletin board service provides access to large amounts of information pertaining to the TMS320 family. Refer to the *TMS320 Family Development Support Reference Guide* (SPRU011B) for further information about TMS320 documentation. To receive copies of second-generation TMS320 literature, call the Customer Response Center at 1-800-232-3200. #### specification overview The electrical specifications for the TMS320C25, TMS320E25, and TMS320C25-50 are given in the following pages. Note that the electrical specifications for the TMS320E25 are identical to those for the TMS320C25, with the addition of EPROM-related specifications. SPRS010C-MAY 1987-REVISED DECEMBER 1992 ## absolute maximum ratings over specified temperature range (unless otherwise noted)† | Supply voltage range, V <sub>CC</sub> <sup>‡</sup> | - 0.3 V to 7 V | |----------------------------------------------------|------------------| | Input voltage range: TMS320E25 pins 24 and 25 | -0.3~V to 15 $V$ | | All other inputs | - 0.3 V to 7 V | | Output voltage range | -0.3~V to $7~V$ | | Continuous power dissipation | 1.5 W | | Operating free-air temperature range | 0°C to 70°C | | Storage temperature range | - 55°C to 150°C | <sup>†</sup> Stresses beyond those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only, and functional operation of the device at these or any other conditions beyond those indicated in the "Recommended Operating Conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. #### recommended operating conditions | | | | MIN | NOM | MAX | UNIT | |-----|--------------------------------|---------------------------------------------|-------|-----|-----------------------|------| | Vcc | Supply voltage | | 4.75 | 5 | 5.25 | ٧ | | ٧ss | Supply voltage | | | 0 | | ٧ | | | | All inputs except CLKIN/CLKX/CLKR/INT (0-2) | 2.35 | | V <sub>CC</sub> + 0.3 | ٧ | | VιΗ | High-level input voltage | ĬNT (0-2) | 2.5 | | V <sub>CC</sub> + 0.3 | ٧ | | | | CLKIN/CLKX/CLKR | 3.5 | | V <sub>CC</sub> + 0.3 | ٧ | | | Low-level input voltage | All inputs except MP/MC | - 0.3 | | 0.8 | ٧ | | VIL | Low-level input voitage | MP/MC | - 0.3 | | 0.8 | ٧ | | ЮН | High-level output current | | | | 300 | μΑ | | loL | Low-level output current | | | | 2 | mΑ | | т. | Operating free-air temperature | TMS320C25, TMS320E25 | 0 | | 70 | °C | | TA | Operating nee-air temperature | TMS320C25GBA | 40 | | 85 | °C | #### electrical characteristics over specified free-air temperature range (unless otherwise noted) | | PARAMETER | | TEST CONDITIONS | TM | \$320C2<br>\$320C2<br>\$320E2 | 5-50 | TM | IS320C25 | 5-33 | UNIT | |-----|--------------------------|-----------|-----------------------------------------------------|-----|-------------------------------|------|-----|----------|------|------| | | | | | MIN | TYP§ | MAX | MIN | TYP§ | MAX | | | Voн | High-level output voltag | ge | V <sub>CC</sub> = MIN, I <sub>OH</sub> = MAX | 2.4 | 3 | | 2.4 | 3 | | > | | VoL | Low-level output voltage | | VCC = MIN, IOL = MAX | | 0.3 | 0.6 | | 0.3 | 0.6 | > | | Ιz | Three-state current | | V <sub>CC</sub> = MAX | -20 | | 20 | -20 | | 20 | μΑ | | Ŋ | Input current | | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> | -10 | | 10 | -10 | | 10 | μΑ | | \/ | | Normal | T 0°C V MAY 1 - MAY | | 110 | 185 | | 95 | 185 | mA | | VIL | Low-levelinputvoltage | Idle/HOLD | TA = 0°C, VCC = MAX, f <sub>X</sub> = MAX | | 50 | 100 | | 40 | 100 | ША | | Cı | Input capacitance | | | | 15 | | | 15 | | pF | | CO | Output capacitance | | | | 15 | | | 15 | | pF | <sup>§</sup> All typical values are at VCC = 5 V, TA = 25°. Caution. 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 to 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 appropriate 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. #### **CLOCK CHARACTERISTICS AND TIMING** The TMS32025 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 crystals require an additional tuned LC circuit. | PARAMETER | | TEST CONDITIONS | | TMS320C25<br>TMS320E25 | | TMS320C25-33 | | | UNIT | |-----------------|-----------------------|------------------------------|-----|------------------------|-------|--------------|-----|-------|------| | | | | MIN | TYP | MAX | MIN | TYP | MAX | | | f <sub>x</sub> | Input clock frequency | T <sub>A</sub> = 0°C to 70°C | 6.7 | | 40.96 | 6.7 | | 33.0 | MHz | | f <sub>xs</sub> | Serial port frequency | T <sub>A</sub> = 0°C to 70°C | 0† | | 5.12 | 0† | | 4.125 | MHz | | C1, C2 | | T <sub>A</sub> = 0°C to 70°C | | 10 | | | 10 | | pF | <sup>†</sup> The serial port was tested at a minimum frequency of 1.25 MHz. However, the serial port was fully static but will properly function down to f<sub>SX</sub> = 0 Hz. Figure 2. Internal Clock Option #### 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 | | TMS320C25<br>TMS320E25 | | | TMS320C25-33 | | | | |-------------------|-----------------------------------------------------------------|--------|------------------------|--------|--------|--------------|--------|----|--| | | | MIN | TYP | MAX | MIN | TYP | MAX | | | | <sup>t</sup> c(C) | CLKOUT1/CLKOUT2 cycle time | 97.7 | | 597 | 121.2 | | 597 | ns | | | t₀(CIH-C) | CLKIN high to CLKOUT1/CLKOUT2/STRB high/low | 5 | | 30 | 5 | | 30 | ns | | | <sup>t</sup> f(C) | CLKOUT1/CLKOUT2/STRB fall time | | | 5 | | | 5 | ns | | | tr(C) | CLKOUT1/CLKOUT2/STRB rise time | | | 5 | | | 5 | ns | | | tw(CL) | CLKOUT1/CLKOUT2 low pulse duration | 2Q - 8 | 2Q | 2Q + 8 | 2Q - 8 | 2Q | 2Q + 8 | ns | | | tw(CH) | CLKOUT1/CLKOUT2 high pulse duration | 2Q - 8 | 2Q | 2Q + 8 | 2Q - 8 | 2Q | 2Q + 8 | ns | | | td(C1-C2) | CLKOUT1 high to CLKOUT2 low; CLKOUT2 high to CLKOUT1 high; etc. | Q-5 | Q | Q + 5 | Q – 5 | a | Q + 5 | ns | | NOTE 1: Q = 1/4t<sub>C</sub>(C). ## timing requirements over recommended operating conditions (see Note 1) | | | | TMS320C25<br>TMS320E25 | | | TMS320C25-33 | | | |---------------------|--------------------------------------------------------------------|------|------------------------|-----|------|--------------|-------|----| | | | MIN | NOM | MAX | MIN | NOM | MAX | | | <sup>t</sup> c(Cl) | CLKIN cycle time | 24.4 | | 150 | 30.3 | | 150 | ns | | tf(CI) | CLKIN fall time | | | 5† | | | 5† | ns | | <sup>t</sup> r(CI) | CLKIN rise time | | | 5† | | | 5† | ns | | <sup>t</sup> w(CIL) | CLKIN low pulse duration, t <sub>C(CI)</sub> = 50 ns (see Note 2) | 20 | | - | 20 | | | ns | | tw(CIH) | CLKIN high pulse duration, t <sub>C(CI)</sub> = 50 ns (see Note 2) | 20 | | | 20 | | | ns | | tsu(S) | SYNC setup time before CLKIN low | 5 | | Q-8 | 5 | | Q - 8 | ns | | th(S) | SYNC hold time from CLKIN low | 8 | | | 8 | | | ns | † Value derived from characterization data and not tested. NOTES: 1. $Q = 1/4t_{C(C)}$ . 2. CLKIN duty cycle [tr(CI) + tw(CIH)]/tc(CI) must be within 40-60%. Figure 3. External Clock Option Shown above is a crystal oscillator circuit suitable for providing the input clock signal to the TMS320C25, TMS320E25, and TMS320C25-33. Please refer to "Hardware Interfacing to the TMS320C2x", in *Digital Signal Processing Applications with the TMS320 Family, Volume 2* (document number SPRA016) for details on circuit operation. Figure 4. Test Load Circuit ## TMS320C25, TMS320E25 TMS320C25-33 Figure 5. Voltage Reference Levels #### MEMORY AND PERIPHERAL INTERFACE TIMING # switching characteristics over recommended operating conditions (see Note 1) | | PARAMETER | MIN | TYP | MAX | UNIT | |----------------------|-------------------------------------------------------------------|---------|-----|---------|------| | td(C1-S) | STRB from CLKOUT1 (if STRB is present) | Q-6 | Q | Q+6 | ns | | <sup>t</sup> d(C2-S) | CLKOUT2 to STRB (if STRB is present) | -6 | 0 | 6 | ns | | tsu(A) | Address setup time before STRB low (see Note 3) | Q – 12 | | | ns | | th(A) | Address hold time after STRB high (see Note 3) | Q-8 | | | ns | | tw(SL) | STRB low pulse duration (no wait states, see Note 4) | 2Q - 5 | | 2Q + 5 | ns | | tw(SH) | STRB high pulse duration (between consecutive cycles, see Note 4) | 2Q - 5 | | 2Q + 5 | ns | | t <sub>su(D)W</sub> | Data write setup time before STRB high (no wait states) | 2Q - 20 | | | ns | | th(D)W | Data write hold time from STRB high | Q 10 | Q | | ns | | ten(D) | Data bus starts being driven after STRB low (write cycle) | 0† | • | | ns | | tdis(D) | Data bus three-state after STRB high (write cycle) | | Q | Q + 15† | ກຣ | | td(MSC) | MSC valid from CLKOUT1 | - 12 | 0 | 12 | ns | <sup>†</sup> Value derived from characterization data and not tested. NOTES: 1. Q = 1/4t<sub>C(C)</sub>. 3. A15-A0, PS, DS, IS, R/W, 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. ## timing requirements over recommended operating conditions (see Note 1) | | | MIN | NOM | MAX | דואט | |---------------------|-------------------------------------------------------------------------|-----|-----|---------|------| | ta(A) | Read data access time from address time (read cycle, see Notes 3 and 5) | | | 3Q - 35 | ns | | t <sub>su(D)R</sub> | Data read setup time before STRB high | 23 | | | ns | | th(D)R | Data read hold time from STRB high | 0 | | | ns | | td(SL-R) | READY valid after STRB low (no wait states) | | | Q - 20 | ns | | td(C2H-R) | READY valid after CLKOUT2 high | | | Q - 20 | ns | | th(SL-R) | READY hold time after STRB low (no wait states) | Q+3 | | | ns | | th(C2H-R) | READY hold after CLKOUT2 high | Q+3 | | | ns | | td(M-R) | READY valid after MSC valid | | | 2Q - 25 | ns | | th(M-R) | READY hold time after MSC valid | 0 | | | ns | - NOTES: 1. Q = 1/4t<sub>C(C)</sub>. 3. A15-A0, PS, DS, TS, R/W, and BR timings are all included in timings referenced as "address". - 5. Read data access time is defines as $t_{a(A)} = t_{su(A)} + t_{w(SL)} t_{su(D)R}$ ### RS, INT, BIO, AND XF TIMING ## switching characteristics over recommended operating conditions (see Notes 1 and 6) | | PARAMETER | | MIN | TYP | MAX | UNIT | |--------------------|--------------------------------------|---|-------------|-----|-----|------| | <sup>t</sup> d(RS) | CLKOUT1 low to reset state entered | | | | 22† | ns | | td(IACK) | CLKOUT1 to IACK valid | | - 6 | 0 | 12 | ns | | <sup>t</sup> d(XF) | XF valid before falling edge of STRB | Q | <b>– 15</b> | | | ns | NOTES: 1 Q = $1/4t_{C(C)}$ ## timing requirements over recommended operating conditions (see Notes 1 and 6) | | | MIN | NOM | MAX | UNIT | |---------------------|--------------------------------------|--------------------|-----|-----|------| | t <sub>su(IN)</sub> | INT/BIO/RS setup before CLKOUT1 high | 32 | | | ns | | th(IN) | INT/BIO/RS hold after CLKOUT1 high | 0 | | | ns | | tf(IN) | INT/BIO fall time | | | 8† | ns | | tw(IN) | INT/BIO low pulse duration | t <sub>C</sub> (C) | | | ns | | tw(RS) | RS low pulse duration | 3 <sub>tc(C)</sub> | | | ns | <sup>†</sup> Value derived from characterization data and not tested. #### **HOLD TIMING** ### switching characteristics over recommended operating conditions (see Note 1) | | PARAMETER | MIN | TYP | MAX | UNIT | |-------------------------|---------------------------------------------------------------|-----|-----|-----|------| | <sup>†</sup> d(C1L-AL) | HOLDA low after CLKOUT1 low | 0 | | 10 | ns | | <sup>t</sup> dis(AL-A) | HOLDA low to address three-state | | ot | | ns | | <sup>t</sup> dis(C1L-A) | Address three-state after CLKOUT1 low (HOLD mode, see Note 7) | | | 20† | ns | | td(HH-AH) | HOLD high to HOLDA high | | | 25 | ns | | <sup>t</sup> en(A-C1L) | Address driven before CLKOUT1 low (HOLD mode, see Note 7) | | | 8† | ns | <sup>†</sup> Value derived from characterization data and not tested. NOTES: 1. $Q = 1/4t_{C(C)}$ ## timing requirements over recommended operating conditions (see Note 1) | | MIN | NOM | MAX | UNIT | |-----------------------------------------|-----|-----|--------|------| | td(C2H-H) HOLD valid after CLKOUT2 high | | | Q - 24 | ns | NOTES: 1. $Q = 1/4t_{C(C)}$ <sup>6.</sup> 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 diagrams will occur. 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 diagrams will occur. <sup>7.</sup> A15-A0, PS, DS, IS, STRB, and R/W timings are all included in timings referenced as "address" #### **SERIAL PORT TIMING** # switching characteristics over recommended operating conditions (see Note 1) | | PARAMETER | <br>MIN | TYP | MAX | UNIT | |-----------|-------------------------------------------------------|---------|-----|-----|------| | td(CH-DX) | DX valid after CLKX rising edge (see Note 8) | | | 75 | ns | | td(FL-DX) | DX valid after FSX falling edge (TXM = 0, see Note 8) | | | 40 | ns | | td(CH-FS) | FSX valid after CLKX rising edge (TXM = 1) | | | 40 | ns | NOTES: 1. Q = 1/4t<sub>C</sub>(C). # timing requirements over recommended operating conditions (see Note 1) | | | TMS320C25<br>TMS320E25 | | TMS320C25-33 | | | UNIT | | |----------------------|----------------------------------------------------------------|------------------------|-----|--------------|-----|-----|------|----| | | | MIN | NOM | MAX | MIN | NOM | MAX | | | tc(SCK) | Serial port clock (CLKX/CLKR) cycle time† | 200 | | | 242 | | | ns | | t <sub>f</sub> (SCK) | Serial port clock (CLKX/CLKR) fall time | | | 25‡ | | | 25‡ | ns | | tr(SCK) | Serial port clock (CLKX/CLKR) rise time | | | 25‡ | | | 25‡ | ns | | tw(SCK) | Serial port clock (CLKX/CLKR) low pulse duration (see Note 9) | 80 | | | 97 | | | ns | | tw(SCK) | Serial port clock (CLKX/CLKR) high pulse duration (see Note 9) | 80 | | | 97 | | | ns | | t <sub>su(FS)</sub> | FSX/FSR setup time before CLKX/CLKR falling edge (TXM = 0) | 18 | | | 18 | | | ns | | th(FS) | FSX/FSR hold time after CLKX/CLKR falling edge (TXM = 0) | 20 | | | 20 | | | пѕ | | t <sub>su(DR)</sub> | DR setup time before CLKR falling edge | 10 | | | 10 | | | ns | | th(DR) | DR hold time after CLKR falling edge | 20 | | | 20 | | | ns | <sup>†</sup> The serial port was tested at a minimum frequency of 1.25 MHz. However, the serial port was fully static but will properly function down to f<sub>SX</sub> = 0 Hz. NOTES: 1. Q = 1/4t<sub>C(C)</sub>. <sup>8.</sup> The last occurrence of FSX falling and CLKX rising. <sup>‡</sup> Value derived from characterization data and not tested. <sup>9.</sup> The duty cycle of the serial port clock must be within 40-60%. #### **EPROM PROGRAMMING** ## absolute maximum ratings over specified temperature range (unless otherwise noted)† Supply voltage range, V<sub>PP</sub><sup>‡</sup> ..... - 0.6 V to 15 V Input voltage range on pins 24 and 25 ...... - 0.3 V to 15 V ## recommended operating conditions | | | MIN | NOM | MAX | UNIT | |-----|-----------------------------------------------|------|------|------|------| | Vcc | Programming mode supply voltage (see Note 11) | | 6 | | V | | Vcc | Read mode supply voltage | 4.75 | 5 | 5.25 | V | | Vpp | Programming mode supply voltage | 12 | 12.5 | 13 | V | | Vpp | Read mode supply voltage (see Note 10) | | Vcc | | | NOTES: 10. Vpp can be connected to VCC directly (except in the program mode). VCC supply current in this case would be ICC + Ipp During programming, Vpp must be maintained at 12.5 V (± 0.25 V). 11. VCC must be applied before or at the same time as Vpp and removed after or at the same time as Vpp. This device must not be inserted into or removed from the board when VPP or VCC is applied. ## electrical characteristics over specified temperature range (unless otherwise noted) | | PARAMETER | TEST CONDITIONS | MIN | TYP§ | MAX | UNIT | |------|-------------------------------------------|--------------------------------|-----|------|-----|------| | IPP1 | Vpp supply current | Vpp = V <sub>CC</sub> = 5.25 V | | | 100 | μΑ | | IPP2 | Vpp supply current (during program pulse) | Vpp = 13 V | | 30 | 50 | mΑ | <sup>§</sup> All typical values for ICC are at VCC = 5 V, TA = 25°C. ### recommended timing requirements for programming, $T_A$ = 25°C, $V_{CC}$ = 6 V, $V_{PP}$ = 12.5 V (see Notes 12 and 13) | | | MIN | NOM | MAX | UNIT | |-----------------------|--------------------------------|------|-----|-------|------| | tw(IPGM) | Initial program pulse duration | 0.95 | 1 | 1.05 | ms | | tw(FPGM) | Final pulse duration | 2.85 | | 78.75 | ms | | t <sub>su(A)</sub> | Address setup time | 2 | | | μS | | t <sub>su(E)</sub> | E setup time | 2 | | | μS | | t <sub>su(G)</sub> | G setup time | 2 | | | μS | | <sup>t</sup> dis(G) | Output disable time from G | 0 | | 130¶ | ns | | <sup>t</sup> en(G) | Output enable time from G | | | 150¶ | ns | | t <sub>su(D)</sub> | Data setup time | 2 | | | μS | | t <sub>su</sub> (VPP) | Vpp setup time | 2 | | | μS | | t <sub>su</sub> (VCC) | V <sub>CC</sub> setup time | 2 | | | μS | | th(A) | Address hold time | 0 | | | μs | | th(D) | Data hold time | 2 | | | μS | Value derived from characterization data and not tested. <sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. This is a stress rating only, and functional operation of the device at these or any other conditions beyond those indicated in the "recommended operating conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. ‡ All voltage values are with respect to GND. NOTES: 12. For all switching characteristics and timing measurements, input pulse levels are 0.4 V to 2.4 V and Vpp = 12 5 V ± 0.5 V during programming. <sup>13.</sup> Common test conditions apply for tdis(G) except during programming. SPRS010C-MAY 1987-REVISED DECEMBER 1992 # absolute maximum ratings over specified temperature range (unless otherwise noted)† | Oldfe Haxillani Iatings ever speamer some | • | |----------------------------------------------------|----------------| | Supply voltage range, V <sub>CC</sub> <sup>‡</sup> | – 0.3 V to 7 V | | Input voltage range | -0.3 V to 7 V | | Output voltage range | -0.3 V to 7 V | | Output voltage range | 15\\ | | Continuous power dissipation | 1.0 11 | | Operating free-air temperature range | 0-0 to 70-0 | | Storage temperature range | 55°C to 150°C | <sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. This is a stress rating only, and functional operation of the device at these or any other conditions beyond those indicated in the "recommended operating conditions" section of this specification is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. #### recommended operating conditions | | | | MIN | МОМ | MAX | UNIT | |------------------|------------------------------|-------------------|------|-----|------|------| | Vcc | Supply voltage | | 4.75 | 5 | 5.25 | ٧ | | Vss | Supply voltage | | | 0 | | ٧ | | - 00 | | INTO-INT2 | 2.5 | | | ٧ | | VιΗ | High-level input voltage | CLKIN, CLKX, CLKR | 3.5 | | | V | | - 11 1 | | Other inputs | 2.35 | | | ٧ | | | | MP/MC | | | 8.0 | ٧ | | ۷ <sub>I</sub> L | Low-level input voltage | CLKIN | | | 0.8 | ٧ | | ,,_ | | Other inputs | | | 8.0 | > | | ЮН | High-level output current | | | | 300 | μΑ | | loL | Low-level output current | | | | 2 | mΑ | | TA | Operating free-air temperatu | е | 0 | | 70 | ပ္ | # electrical characteristics over specified free-air temperature range (unless otherwise noted) | | PARAMET | ER | TEST CONDITIONS | MIN | TYP§ | MAX | UNIT | |----------|---------------------------|--------------------------------------------|-----------------------------------------------------|------|------|-----|------| | Vон | High-level output v | oltage | VCC = MIN, IOH = MAX | 2.4 | | | ٧ | | VOL | Low-level output vi | oltage | VCC = MIN, IOL = MAX | | | 0.6 | ٧ | | lz | High-impedance c | urrent | V <sub>CC</sub> = MAX | - 20 | | 20 | μΑ | | lı | Input current | | V <sub>I</sub> = V <sub>SS</sub> to V <sub>CC</sub> | - 10 | | 10 | μΑ | | <u>'</u> | <u> </u> | Normal | T OOD W MAY E MAY | | 110 | 185 | mA | | icc | Supply current Idle, HOLD | $T_A = 0$ °C, $V_{CC} = MAX$ , $F_X = MAX$ | | 50 | 100 | | | | Cı | Input capacitance | | | | 15 | | ρF | | CO | Output capacitanc | e | | | 15 | | pF | <sup>§</sup> All typical values are at V<sub>CC</sub> = 5 V, T<sub>A</sub> = 25°C. <sup>‡</sup> All voltage values are with respect to VSS. ## **CLOCK CHARACTERISTICS AND TIMING** The TMS320C25-50 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. The frequency of CLKOUT1 is one-fourth the crystal fundamental frequency. The crystal should be in 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 crystals require an additional tuned LC circuit. | PAF | RAMETER | TEST CONDITIONS | MIN | TYP† | MAX | UNIT | |-------------------------------|-----------|------------------------------|-----|------|------|------| | f <sub>X</sub> Input clock | frequency | T <sub>A</sub> = 0°C to 70°C | 6.7 | | 51.2 | MHz | | f <sub>SX</sub> Serial port f | requency | T <sub>A</sub> = 0°C to 70°C | 0 | | 6.4 | MHz | | C1, C2 | | T <sub>A</sub> = 0°C to 70°C | | 10 | | pF | <sup>†</sup> The serial port was tested at a minimum frequency of 1.25 MHz. However, the serial port was fully static but will properly function down to $f_{SX} = 0$ Hz. Figure 6. Internal Clock Option #### external clock option An external frequency source can be used by injecting the frequency directly into X2/CLK, with X1 left unconnected. The external frequency injected must conform to specifications listed in the following table. # switching characteristics over recommended operating conditions (see Note 1) | | | MIN | NOM | MAX | UNIT | |-----------------------|-----------------------------------------------------------------|--------|-----|--------|------| | <sup>t</sup> c(C) | CLKOUT1, CLKOUT2 cycle time | 78 13 | | 597 | ns | | <sup>t</sup> d(СІН-С) | CLKIN high to CLKOUT1, CLKOUT2, STRB high, low | 5 | | 27 | ns | | t <sub>f(C)</sub> | CLKOUT1, CLKOUT2, STRB fall time | * + - | | 4 | ns | | tr(C) | CLKOUT1, CLKOUT2, STRB rise time | | | 4 | ns | | tw(CL) | CLKOUT1, CLKOUT2, STRB low pulse duration | 20 - 7 | | 2Q + 3 | ns | | <sup>t</sup> w(CH) | CLKOUT1, CLKOUT2, STRB high pulse duration | 2Q - 3 | | 2Q + 7 | ns | | td(C1-C2) | CLKOUT1 high to CLKOUT2 low, CLKOUT2 high to CLKOUT1 high, etc. | Q-5 | - | Q + 5 | ns | NOTE 1: Q = 1/4 t<sub>c(C)</sub> Figure 7. External Clock Option # timing requirements over recommended operating conditions (see Note 1) | | MIN NO | MAX N | UNIT | |--------------------------------------------------------------------|----------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CLKIN cycle time | 19.53 | 150 | ns | | | | 5† | ns | | CLKIN rise time | | 5† | ns | | CLKIN low pulse duration, t <sub>C</sub> (Cl) = 50 ns (see Note 2) | 20 | | ns | | | 20 | | ns | | | 4 | Q-4 | ns | | | 4 | | ns | | | CLKIN cycle time CLKIN fall time | CLKIN cycle time 19.53 CLKIN fall time | CLKIN cycle time MIN NOM MAX CLKIN fall time 19.53 150 CLKIN fall time 51 51 CLKIN rise time 20 20 CLKIN low pulse duration, t <sub>C(CI)</sub> = 50 ns (see Note 2) 20 20 CLKIN high pulse duration, t <sub>C(CI)</sub> = 50 ns (see Note 2) 20 4 Q - 4 SYNC setup time before CLKIN low 4 Q - 4 | † Value derived from characterization data and not tested. NOTES: 1. Q = $1/4 t_C(C)$ 2. CLKIN duty cycle [ $t_r(CI) + t_W(CIH)$ ]/ $t_C(CI)$ must be within 40-60%. ## **MEMORY AND PERIPHERAL INTERFACE TIMING** # switching characteristics over recommended operating conditions (see Note 1) | | PARAMETER | MIN | TYP | MAX | UNIT | |----------------------|-------------------------------------------------------------------|---------|-----|---------|------| | <sup>t</sup> d(C1-S) | STRB from CLKOUT (if STRB is present) | Q-5 | TIF | Q + 3 | ns | | <sup>t</sup> d(C2-S) | CLKOUT2 to STRB (if STRB is present) | -2 | | 5 | ns | | <sup>t</sup> su(A) | Address setup time before STRB low (see Note 3) | Q - 11 | | | ns | | <sup>t</sup> h(A) | Address hold time after STRB high (see Note 3) | Q-4 | | | ns | | tw(SL) | STRB low pulse duration (no wait states, see Note 4) | 2Q - 5 | | 2Q + 2 | ns | | tw(SH) | STRB high pulse duration (between consecutive cycles, see Note 4) | 2Q - 2 | | 2Q + 5† | ns | | tsu(D)W | Data write setup time before STRB high (no wait) | 2Q - 17 | | | ns | | <sup>t</sup> h(D)W | Data write hold time from STRB high | Q-5 | | | ns | | t <sub>en(D)</sub> | Data bus starts being driven after STRB low (write) | of | | | ns | | <sup>t</sup> dis(D) | Data bus high-impedance state after STRB high, (write) | | Q | Q + 15† | ns | | td(MSC) | MSC valid from CLKOUT1 | -2 | | 9 | ns | <sup>†</sup> Value derived from characterization data and not tested. NOTES: 1. $Q = 1/4t_{C(C)}$ - 3. A15-A0, $\overline{PS}$ , $\overline{DS}$ , $\overline{IS}$ , $\overline{R/W}$ , and $\overline{BR}$ timings are all included in timings referenced as "address" - 4. Delay between CLKOUT1, CLKOUT2, and STRB edges track each other, resulting in tw(SL) and tw(SH) being 2Q with no wait state ## timing requirements over recommended operating conditions (see Note 1) | | | MIN | NOM | MAX | UNIT | |-----------------------|-------------------------------------------------------------|-----|-----|---------|------| | ta(A) | Read data access time from address time (see Notes 3 and 5) | | | 3Q - 30 | ns | | <sup>t</sup> su(D)R | Data read setup time before STRB high | 19 | | | ns | | <sup>t</sup> h(D)R | Data read hold time from STRB high | 0 | - | | ns | | td(SL-R) | READY valid after STRB low (no wait states) | | | Q - 21 | ns | | <sup>t</sup> d(C2H-R) | READY valid after CLKOUT2 high | | | Q - 21 | ns | | th(SL-R) | READY hold time after STRB low (no wait states) | Q-1 | | | ns | | th(C2H-R) | READY valid after CLKOUT2 high | Q-1 | | | ns | | td(M-R) | READY valid after MSC valid | | | 2Q - 24 | ns | | th(M-R) | READY hold time after MSC valid | 0 | | | ns | NOTES: 1. Q = 1/4t<sub>C</sub>(C) - 3. A15-A0, $\overline{PS}$ , $\overline{DS}$ , $\overline{IS}$ , $R/\overline{W}$ , and $\overline{BR}$ timings are all included in timings referenced as "address". - 5. Read data access time is defined as $t_{a(A)} = t_{su(A)} + t_{w(SL)} t_{su(D)R}$ . ## RS, INT, BIO, AND XF TIMING # switching characteristics over recommended operating conditions (see Notes 1 and 14) | | PARAMETER | MiN | TYP | MAX | UNIT | |--------------------|--------------------------------------|-----|-----|-----|------| | <sup>t</sup> d(RS) | CLKOUT1 low to reset state entered | | | 22† | ns | | td(IACK) | CLKOUT1 to IACK valid | -5 | | 7 | ns | | | XF valid before falling edge of STRB | Q-8 | | | ns | <sup>†</sup> Value derived from characterization data and not tested. NOTES: 1. Q = 1/4 t<sub>C</sub>(C) # timing requirements over recommended operating conditions (see Notes 1 and 14) | | | MIN NOM | MAX | UNIT | |---------------------|----------------------------------------|---------------------|-----|------| | t <sub>su(IN)</sub> | INT, BIO, RS setup before CLKOUT1 high | 25 | | ns | | th(IN) | INT, BIO, RS hold after CLKOUT1 high | 0 | | ns | | t <sub>f</sub> (IN) | INT, BIO fall time | | 8† | ns | | w(IN) | INT, BIO low pulse duration | t <sub>C</sub> (C) | | ns | | tw(RS) | RS low pulse duration | 3t <sub>C</sub> (C) | | ns | <sup>†</sup> Value derived from characterization data and not tested. NOTES: 1. Q = 1/4 t<sub>C</sub>(C) #### **HOLD TIMING** # switching characteristics over recommended operating conditions (see Note 1) | | PARAMETER | MIN | TYP | MAX | UNIT | |-------------|------------------------------------------------------------------|-----|-----|-----|------| | td(CIL-AL) | HOLDA low after CLKOUT1 low | 1† | | 11 | ns | | tdis(AL-A) | HOLDA low to address high-impedance | | 0† | | ns | | tdis(CIL-A) | Address high-impedance after CLKOUT1 low (HOLD mode, see Note 7) | | | 20† | ns | | td(HH-AH) | HOLD high to HOLDA high | | | 19 | ns | | ten(A-CIL) | Address driven before CLKOUT1 low (HOLD mode, see Note 7) | | | 8† | ns | <sup>†</sup> Value derived from characterization data and not tested. NOTES: 1. Q = 1/4 t<sub>c</sub>(C) 7. A15-A0, PS, DS, IS, STRB, and R/W timings are all included in timings referenced as "address" # timing requirements over recommended operating conditions (see Note 1) | | MIN | NOM | MAX | UNIT | |-----------------------------------------|-----|-----|--------|------| | td(C2H-H) HOLD valid after CLKOUT2 high | | | Q - 19 | ns | NOTE 1: Q = 1/4 t<sub>c(C)</sub> <sup>14.</sup> RS, INT, BIO are asynchronous inputs and can occur at any time during a clock cycle. <sup>15.</sup> RS, INT, BIO are asynchronous inputs and can occur at any time during a clock cycle. #### **SERIAL PORT TIMING** # switching characteristics over recommended operating conditions (see Note 1) | | PARAMETER | <br>MIN | TYP | MAX | UNIT | |-----------|---------------------------------------------------|--------------|-----|-----|------| | td(CH-DX) | DX valid after CLKX rising edge (see Note 8) | | | 75 | ns | | td(FL-DX) | DX valid after falling edge (TXM = 0, see Note 8) | | | 40 | ns | | td(CH-FS) | FSX valid after CLKX raising edge (TXM = 1) | <br><b>-</b> | | 40 | ns | ## timing requirements over recommended operating conditions (see Note 1) | | | MIN NO | M MAX | UNIT | |---------------------|-----------------------------------------------------------------------|--------|-----------|------| | tc(SCK) | Serial port clock (CLKX/CLKR) cycle time † | 160 | | ns | | tf(SCK) | Serial port clock (CLKX/CLKR) fall time | | 25‡ | ns | | t <sub>r(SCK)</sub> | Serial port clock (CLKX/CLKR) rise time | | 25‡ | ns | | tw(SCK) | Serial port clock (CLKX/CLKR) low or high pulse duration (see Note 9) | 64 | | ns | | <sup>t</sup> su(FS) | FSX or FSR setup time before CLKX, CLKR falling edge (TXM = 0) | 5 | | пѕ | | h(FS) | FSX or FSR hold time before CLKX, CLKR falling edge (TXM = 0) | 10 | | ns | | su(DR) | DR setup time before CLKR falling edge | 5 | | ns | | h(DR) | DR hold time after CLKR falling edge | 10 | · · · · · | ns | <sup>†</sup> The serial port was tested at a minimum frequency of 1.25 MHz. However, the serial port was fully static but will properly function down to f<sub>SX</sub> = 0 Hz. NOTES: 1. $Q = 1/4 t_C(C)$ 9. The cycle of the serial port must be within 40%-60%. NOTES: 1. Q = 1/4 t<sub>C</sub>(C) 8. The last occurrence of FSX falling and CLKX rising. <sup>‡</sup> Value derived from characterization data and not tested. ## PARAMETER MEASUREMENT INFORMATION This section contains all the timing diagrams for the TMS320 second-generation devices. Refer to the top corner of page for the specific device. Timing measurements are referenced to and from a low voltage of 0.8 voltage and a high voltage of 2 volts, unless otherwise noted. Figure 8. Clock Timing SPRS010C-MAY 1987-REVISED DECEMBER 1992 ## PARAMETER MEASUREMENT INFORMATION Figure 9. Memory Read Timing Figure 10. Memory Write Timing Figure 11. One Wait-State Memory Access Timing ## PARAMETER MEASUREMENT INFORMATION <sup>†</sup> Control signals are DS, IS, R/W, and XF. Figure 12. Reset Timing <sup>‡</sup> Serial port controls are DX and FSX. Figure 13. Interrupt Timing Figure 14. Serial Port Receive Timing ## PARAMETER MEASUREMENT INFORMATION Figure 15. Serial Port Transmit Timing Figure 17. 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 will occur; otherwise, a delay of one CLKOUT2 cycle will occur. Figure 18. 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 will occur; otherwise, a delay of one CLKOUT2 cycle will occur. Figure 19. HOLD Timing (Part B) # TYPICAL SUPPLY CURRENT CHARACTERISTICS FOR TMS320C25 # TMS320C25FNL (PLCC) reflow soldering precautions Recent tests have identified an industry-wide problem experienced by surface mounted devices exposed to reflow soldering temperatures. This problem involves a package cracking phenomenon sometimes experienced by large (e.g., 68-lead) plastic leaded chip carrier (PLCC) packages during surface mount manufacturing. This phenomenon occur if the TMS320C25FNL is exposed to uncontrolled levels of humidity prior to reflow solder. This moisture can flash to steam during solder reflow, causing sufficient stress to crack the package and compromise device integrity. If the TMS320C25FNL is being socketed, no special handling precautions are required. In addition, once the device is soldered into the board, no special handling precautions are required. In order to minimize moisture absorption, TI ships the TMS320C25FNL in "dry pack" shipping bags with a RH indicator card and moisture-absorbing desiccant. These moisture-barrier shipping bags will adequately block moisture transmission to allow shelf storage for 12 months from date of seal when stored at less than 60% relative humidity (RH) and less than 30°C. Devices may be stored outside the sealed bags indefinitely if stored at less than 25% RH and 30°C. Once the bag seal is broken, the devices should be stored at less than 60% RH and 30°C as well as reflow soldered within two days of removal. In the event that either of the above conditions is not met, TI recommends these devices be baked in a clean oven at 125°C and 10% maximum RH for 24 hours. This restores the devices to their "dry packed" moisture level. ### NOTE Shipping tubes will not withstand the 125°C baking process. Devices should be transferred to a metal tray or tube before baking. Standard ESD precautions should be followed. In addition, TI recommends that the reflow process not exceed two solder cycles and the temperature not exceed 220°C. If you have any additional questions or concerns, please contact your local TI representative. SPRS010C-MAY 1987-REVISED DECEMBER 1992 ### **MECHANICAL DATA** # 68-pin GB grid array ceramic package (TMS320C25) SPRS010C-MAY 1987-REVISED DECEMBER 1992 ## 68-lead plastic leaded chip carrier package (TMS320C25, TMS320C25-33, and TMS320C25-50) NOTES: A. Centerline of center pin, each side, is within 0,10 (0.004) of package centerline as determined by this dimension. B. Location of each pin is within 0,127 (0.005) of true position with respect to center pin on each side. ### WARNING When reflow soldering is required, refer to page 42 for special handling instructions. #### **MECHANICAL DATA** ### 68-lead FZ CER-QUAD, ceramic leaded chip carrier package (TMS320E25 only) This hermetically-sealed chip carrier package consists of a ceramic base, ceramic cap, and a 68-lead frame. Hermetic sealing is accomplished with glass. The FZ package is intended for both socket- or surface-mounting. Having a Sn/Pb ratio of 60/40, the tin/lead-coated leads do not require special cleaning or processing when being surface-mounted. The 28-pin package is shown in the illustration; refer to the table below for 68-pin package dimensions. - NOTES: A. Glass is optional, and the diameter is dependent on device application. - B Centerline of center pin, each side, is within 0,10 (0.004) of package centerline as determined by dimension B. - C. Location of each pin is within 0,127 (0.005) of true position with respect to center pin on each side. - D. The lead contact points are within 0,15 (0.006) of being planar. # programming the TMS320E25 EPROM cell The TMS320E25 includes a 4K × 16-bit EPROM, implemented from an industry-standard EPROM cell, to perform prototyping and early field testing and to achieve low-volume production. When used with a 4K-word masked-ROM TMS320C25, the TMS320E25 yields a high-volume, low-cost production as a result of more migration paths for data. An EPROM adapter socket (part # TMDX3270120), shown in Figure 20, is available to provide 68-pin to 28-pin conversion for programming the TMS320E25. Figure 20. EPROM Adapter Socket Key features of the EPROM cell include standard programming and verification. For security against copyright violations, the EPROM cell features an internal protection mechanism to prevent proprietary code from being read. The protection feature can be used to protect reading the EPROM contents. This section describes erasure, fast programming and verification, and EPROM protection and verification. ### fast programming and verification The TMS320E25 EPROM cell is programmed using the same family and device codes as the TMS27C64 8K $\times$ 8-bit EPROM. The TMS27C64 EPROM series are ultraviolet-light erasable, electrically programmable read-only memories, fabricated using HVCMOS technology. The TMS27C64 is pin-compatible with existing 28-pin ROMs and EPROMs. The TMS320E25, like the TMS27C64, operates from a single 5-V supply in the read mode; however, a 12.5-V supply is needed for programming. All programming signals are TTL level. For programming outside the system, existing EPROM programmers can be used. Locations may be programmed singly, in blocks, or at random. When programmed in blocks, the data is loaded into the EPROM cell one byte at a time, the high byte first and the low byte second. Figure 21 shows the wiring conversion to program the TMS320E25 using the 28-pin pinout of the TMS27C64. The pin nomenclature table provides a description of the TMS27C64 pins. The code to be programmed into the device should be serial mode. The TMS320E25 uses 13 address lines to address the 4K-word memory in byte format. Pin Nomenclature (TMS320E25) | SIGNALS | I/O DEFINITION | | |--------------------|----------------|-------------------------------------------------------------------| | A12 (MSB)-A0 (LSB) | | On-chip EPROM programming address lines | | CLIN | i | Clock oscillator input | | ΙĒ | 1 1 | EPROM chip select | | EPT | l i | EPROM test mode select | | EPT<br>G | l i | EPROM read/verify select | | GND | 1 1 | Ground | | PGM | 1 | EPROM write/program select | | Q8 (MSB)-Q1 (LSB) | 1/0 | Data lines for byte-wide programming of on-chip 8K bytes of EPROM | | RS ' ' ' | T T | Reset for initializing the device | | Vcc | 1 | 5-V power supply | | VPP | 1 | 12.5-V power supply | Figure 21. TMS320E25 EPROM Conversion to TMS27C64 EPROM Pinout Table 4 shows the programming levels required for programming, verifying and reading the EPROM cell. The paragraphs following the table describe the function of each programming level. PROGRAM OUTPUT TMS320E25 TMS27C64 PROGRAM SIGNAL READ **PROGRAM** DISABLE INHIBIT VERIFY NAME T PIN PIN ٧ıı Vii ۷ін VIL Ē 22 20 Vii PULSE G **PULSE** Х Уιн 42 22 VIН PGM PULSE Х VIH VIH 27 ٧н 41 Vpp Vcc Vcc Vpp VPP VPP 25 1 Vcc Vcc Vcc 61,35 28 VCC+1 VCC+1 VCC+1 Vss Vss 27,44,10 14 Vss ٧ss ٧ss Vss ٧ss Vss CLKIN 52 14 Vss ٧ss Vss ٧ss Vss RS 65 14 Vss ٧ss Vss EPT 24 26 ٧ss ٧ss Vss ٧ss ٧ss HI-Z 11-13,15-19 QOUT HI-Z QOUT Q1-Q8 18-11 DIN ADDR ADDR X ADDR х A12-A10 40-38 2,23,21, ADDR Х ADDR х A9-A7 37,36,34 24,25,3 ADDR X ADDR х ADDR 33 ADDR **A6** ADDR х ADDR Х 5 ADDR **A5** 32 ADDR х ADDR ADDR Х Α4 31 6 Х ADDR х ADDR ADDR A3-A0 30-28.26 7-10 Table 4, TMS320E25 Programming Mode Levels # LEGEND: V<sub>IH</sub> = TTL high level; V<sub>IL</sub> = TTL low level; ADDR = byte address bit $Vpp = 12.5 \text{ V} \pm 0.5 \text{ V}; VCC = 5 \pm 0.25 \text{ V}; X = don't care}$ PULSE = low-going TTL level pulse; DIN = byte to be programmed at ADDR QOUT = byte stored at ADDR; RBIT = ROM protect bit. ### erasure Before programming, the device is erased by exposing the chip through the transparent lid to high-intensity ultraviolet light (wavelength 2537 Å). The recommended minimum exposure dose (UV-intensity × exposure-time) is 15 W\*s/cm². A typical 12 mW/cm², filterless UV lamp will erase the device in 21 minutes. The lamp should be located approximately 2.5 cm above the chip during erasure. After erasure, all bits are in the high state. Note that normal ambient light contains the correct wavelength for erasure. Therefore, when using the TMS320E25, the window should be covered with an opaque label. ### fast programming After erasure (all memory bits in the cell are logic one), logic zeroes are programmed into the desired locations. The fast programming algorithm, shown in Figure 22, is normally used to program the entire EPROM contents, although individual locations may be programmed separately. A programmed logic zero can be erased only by ultraviolet light. Data is presented in parallel (eight bits) on pins Q8-Q1. Once addresses and data are stable, $\overline{PGM}$ is pulsed. The programming mode is achieved when $V_{PP} = 12.5 \text{ V}$ , $\overline{PGM} = V_{IL}$ , $V_{CC} = 6 \text{ V}$ , $\overline{G} = V_{IH}$ , and $\overline{E} = V_{IL}$ More than one TMS320E25 can be programmed when the devices are connected in parallel. Locations can be programmed in any order. Programming uses two types of programming pulses: prime and final. The length of the prime pulse is 1 ms. After each prime pulse, the byte being programmed is verified. If correct data is read, the final programming pulse is applied; if correct data is not read, an additional 1-ms prime pulse is applied up to a maximum of 15 times. The final programming pulse is 4 ms times the number of prime programming pulses applied. This sequence of programming and verification is performed at $V_{CC} = 6 \text{ V}$ , and $V_{PP} = 12.5 \text{ V}$ . When the full fast programming routine is complete, all bits are verified with $V_{CC} = V_{PP} = 5 \text{ V}$ . <sup>†</sup> In accordance with TMS27C64. ### program verify Programmed bits may be verified with $V_{PP} = 12.5 \text{ V}$ when $\overline{G} = V_{IL}$ , $\overline{E} = V_{IL}$ , and $\overline{PGM} = V_{IH}$ . Figure 22 shows the timing for the program and verify operation. Figure 22. Fast Programming Flowchart ### TMS320E25 ### Figure 23. Fast Programming Timing #### program inhibit Programming may be inhibited by maintaining a high level input on the $\overline{E}$ pin or $\overline{PGM}$ pin. ### read The EPROM contents may be read independent of the programming cycle, provided the RBIT (ROM protect bit) has not been programmed. The read is accomplished by setting $\overline{E}$ to zero and pulsing $\overline{G}$ low. The contents of the EPROM location selected by the value on the address inputs appear on Q8-Q1. ### output disable During the EPROM programming process, the EPROM data outputs may be disabled, if desired, by establishing the output disable state. This state is selected by setting the $\overline{G}$ and $\overline{PGM}$ pins high. While output disable is selected, Q8-Q1 are placed in the high-impedance state. # **ROM** protection and verification This section describes the code protection feature included in the EPROM cell, which protects code against copyright violations. Table 6 shows the programming levels required for protecting and verifying the EPROM. The paragraphs following the table describe the protect and verify functions. Table 5. TMS320E25 Protect and Verify EPROM Mode Levels | SIGNAL† | TMS320E25 PIN | TMS27C64 PIN | ROM PROTECT | PROTECT VERIFY | |---------|---------------|--------------|------------------|-----------------| | Ē | 22 | 20 | ViH | VIL | | G | 42 | 22 | V <sub>IH</sub> | V <sub>IL</sub> | | PGM | 41 | 27 | V <sub>iH</sub> | VIH | | VPP | 25 | 1 | Vpp | Vcc | | Vcc | 61,35 | 28 | VCC + 1 | Vcc | | Vss | 10, 27, 44 | 14 | V <sub>SS</sub> | Vss | | CLKIN | 52 | 14 | V <sub>SS</sub> | V <sub>SS</sub> | | RS | 65 | 14 | V <sub>SS</sub> | VSS | | EPT | 24 | 26 | Vpp | Vpp | | Q8-Q1 | 18-11 | 11-13, 15-19 | Q8 = PULSE | Q8 = RBIT | | A12-A10 | 40-38 | 2, 23, 21, | X | Х | | A9-A7 | 37, 36, 34 | 24, 25, 3 | Х | Х | | A6 | 33 | 4 | Х | V <sub>IL</sub> | | A5 | 32 | 5 | Х | Х | | A4 | 31 | 6 | V <sub>!</sub> H | х | | A3-A0 | 30-28, 26 | 7-10 | X | X | <sup>†</sup> In accordance with TMS27C64. #### LEGEND: $V_{IH}$ = TTL high level; $V_{IL}$ = TTL low level; $V_{CC}$ = 5 V ± 0.25 V $Vpp = 12.5 V \pm 0.5 V; X = don't care$ PULSE = low-going TTL level pulse; RBIT = ROM protect bit. ### **EPROM protect** The EPROM protect facility is used to completely disable reading of the EPROM contents to guarantee security of proprietary algorithms. This facility is implemented through a unique EPROM cell called the RBIT (EPROM protect bit) cell. Once the contents to be protected are programmed into the EPROM, the RBIT is programmed, disabling access to the EPROM contents and disabling the microprocessor mode on the device. Once programmed, the RBIT can be cleared only by erasing the entire EPROM array with ultraviolet light, thereby maintaining security of the propietary algorithm. Programming the RBIT is accomplished using the EPROM protect cycle, which consists of setting the $\overline{E}$ , $\overline{G}$ , $\overline{PGM}$ , and A4 pins high, $V_{PP}$ and EPT to 2.5 V $\pm$ 0.5 V, and pulsing Q8 low. The complete sequence of operations involved in programming the RBIT is shown in the flowchart of Figure 24. The required setups in the figure are detailed in Table 5. Figure 24. EPROM Protect Flowchart ### protect verify Protect verify is used following the EPROM protect to verify correct programming of the RBIT (see Figure 24). When using protect verify, Q8 outputs the state of the RBIT. When RBIT = 1, the EPROM is unprotected; when RBIT = 0, the EPROM is protected. The EPROM protect and verify timings are shown in Figure 25. SPRS010C-MAY 1987-REVISED DECEMBER 1992 Figure 25. EPROM Protect Timing