- CMOS/EEPROM/EPROM Technologies on a Single Device - Mask-ROM Devices for High-Volume Production - One-Time-Programmable (OTP) EPROM Devices for Low-Volume Production - Reprogrammable-EPROM Devices for Prototyping Purposes - Internal System Memory Configurations - On-Chip Program Memory Versions - ROM: 4K or 8K Bytes - EPROM: 8K Bytes - Data EEPROM: 256 Bytes - Static RAM: 256 Bytes Usable as Registers - Flexible Operating Features - Low-Power Modes: STANDBY and HALT - Commercial, Industrial, and Automotive Temperature Ranges - Clock Options - Divide-by-1 (2 MHz-5 MHz SYSCLK) PLL - Divide-by-4 (0.5 MHz-5 MHz SYSCLK) - Supply Voltage (V<sub>CC</sub>) 5 V ±10% - 16-Bit General-Purpose Timer - Software Configurable as - a 16-Bit Event Counter, or - a 16-Bit Pulse Accumulator, or - a 16-Bit Input Capture Function, or - Two Compare Registers, or a Self-Contained Pulse-Width-Modulation (PWM) Function - Software Programmable Input Polarity - 8-Bit Prescaler, Providing a 24-Bit Real-Time Timer - On-Chip 24-Bit Watchdog Timer - Mask-ROM Devices: Hard Watchdog, Simple Counter, or Standard Watchdog - Flexible Interrupt Handling - Serial Peripheral Interface (SPI) - Serial Communications Interface 1 (SCI1) - TMS370 Series Compatibility - Register-to-Register Architecture - 128 or 256 General-Purpose Registers - 14 Powerful Addressing Modes - Instructions Upwardly Compatible With All TMS370 Devices # FN AND FZ PACKAGES (TOP VIEW) #### JC, JD, N AND NJ PACKAGES (TOP VIEW) - CMOS/TTL Compatible I/O Pins/Packages - All Peripheral Function Pins Software Configurable for Digital I/O - 33 Bidirectional Pins, 1 Input Pin - 44-Pin Plastic and Ceramic Leaded Chip Carrier (LCC) Packages - 40-Pin Plastic and Ceramic Dual-In-Line (DIP) Packages - Workstation/PC-Based Development System - C Compiler and C Source Debugger - Real-Time In-Circuit Emulation - Extensive Breakpoint/Trace Capability - Multi-Window User Interface - Microcontroller Programmer 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. # **Pin Descriptions** | PIN | | | | | | | | |----------------------------------------------|-------------------------------------------|------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | NAME | DIP<br>(40) | PLCC<br>(44) | TYPET | DESCRIPTION | | | | | A0<br>A1<br>A2<br>A3<br>A4<br>A5<br>A6<br>A7 | 18<br>17<br>16<br>15<br>14<br>13<br>11 | 20<br>19<br>18<br>17<br>16<br>15<br>13 | I/O | Port A pins are general-purpose bidirectional I/O ports. | | | | | B0<br>B1<br>B2<br>B3<br>B4<br>B5<br>B6<br>B7 | 39<br>40<br>1<br>2<br>3<br>23<br>24<br>25 | 44<br>1<br>2<br>3<br>4<br>26<br>27<br>28 | I/O | Port B pins are general-purpose bidirectional I/O ports. | | | | | C0 | 4 | 5 | I/O | Port C pin is a general-purpose bidirectional I/O port. | | | | | D3<br>D4<br>D5<br>D6<br>D7 | 21<br>20<br>35<br>22<br>19 | 23<br>22<br>40<br>24<br>21 | I/O | Port D pins are general-purpose bidirectional I/O ports. D3 is also configurable as SYSCLK. | | | | | INT1<br>INT2<br>INT3 | 6<br>7<br>8 | 7<br>8<br>9 | <br> /O<br> /O | External interrupt (non-maskable or maskable) general-purpose input pin External maskable interrupt input/general-purpose bidirectional pin External maskable interrupt input/general-purpose bidirectional pin | | | | | T1IC/CR<br>T1PWM<br>T1EVT | 31<br>30<br>29 | 36<br>35<br>34 | I/O | Timer 1 input-capture/counter-reset input pin/general-purpose bidirectional pin Timer 1 pulse width modulation output pin/general-purpose bidirectional pin Timer 1 external event-input pin/general-purpose bidirectional pin | | | | | SPISOMI<br>SPISIMO<br>SPICLK | 28<br>27<br>26 | 32<br>31<br>30 | I/O | SPI slave output pin, master input pin/general-purpose bidirectional pin SPI slave input pin, master output pin/general-purpose bidirectional pin SPI bidirectional serial clock pin/general-purpose bidirectional pin | | | | | SCITXD<br>SCIRXD<br>SCICLK | 38<br>37<br>36 | 43<br>42<br>41 | I/O | SCI transmit data output pin/general-purpose bidirectional pin <sup>‡</sup> SCI receive data input pin/general-purpose bidirectional pin SCI bidirectional serial clock pin/general-purpose bidirectional pin | | | | | RESET | 5 | 6 | I/O | System reset bidirectional pin; as input, RESET initializes microcontroller; as open-drain output, RESET indicates an internal failure was detected by the watchdog or oscillator fault circuit. | | | | | МС | 34 | 39 | I | Mode control-input pin. MC enables the EEPROM write-protection override (WPO) mode and EPROM Vpp. | | | | | XTAL2/CLKIN<br>XTAL1 | 33<br>32 | 38<br>37 | 0 | Internal oscillator crystal input/external clock source input<br>Internal oscillator output for crystal | | | | | Vcc | 9 | 10 | | Positive supply voltage | | | | | VSS | 12 | 14 | | Ground reference | | | | | NC | | 11<br>25<br>29<br>33 | | No connections | | | | <sup>†</sup> I = input, O = output ‡ The three-pin configuration SCI is referred to as SCI1. # functional block diagram #### description The TMS370C020A, TMS370C022A, TMS370C320A, TMS370C322A, TMS370C722, and SE370C722 devices are members of the TMS370 family of single-chip 8-bit microcontrollers. Unless otherwise noted, the term TMS370Cx2x refers to these devices. The TMS370 family provides cost-effective real-time system control through integration of advanced peripheral modules and various function on-chip memory configurations. The TMS370Cx2x family uses high-performance silicon-gate CMOS EPROM and EEPROM technology. Low operating power, wide operating temperature range, and noise immunity of CMOS technology coupled with the high performance and extensive on-chip peripheral functions make the TMS370Cx2x devices attractive in system designs for automotive electronics, industrial motor, computer peripheral controls, telecommunications, and consumer applications. All TMS370Cx2x devices contain the following on-chip peripheral modules: - Serial peripheral interface (SPI) - Serial communications interface 1 (SCI1) - One 24-bit general-purpose watchdog (WD) timer - One 16-bit general-purpose timer with an 8-bit prescaler Table 1 lists memory configurations of the TMS370Cx2x devices. PROGRAM MEMORY (BYTES) **DATA MEMORY (BYTES) DEVICE** PIN/PACKAGES ROM **EPROM** RAM **EEPROM** 44/FN-PLCC TMS370C020A 4K 256 256 40/N-DIP 40/NJ‡-PSDIP 44/FN-PLCC TMS370C022A 8K 256 256 40/N-DIP 40/NJ‡-PSDIP 44/FN-PLCC TMS370C320A 4K 256 40/N-DIP 40/NJ‡-PSDIP 44/FN-PLCC TMS370C322A 8K 256 40/N-DIP 40/NJ<sup>‡</sup>-PSDIP 44/FN-PLCC TMS370C722 256 256 40/N-DIP ЯK 40/NJ<sup>‡</sup>-PSDIP 44/FZ-CLCC **Table 1. Memory Configurations** 8K The suffix letter A appended to the device names in Table 1 indicates the configuration of the devices. ROM or EPROM devices have different configurations as indicated in Table 2. ROM devices with the suffix letter A are configured through a programmable contact during manufacture. 256 256 40/JD-CDIP 40/JC-CSDIP SE370C722<sup>†</sup> <sup>†</sup> System evaluators and development tools are for use only in a prototype environment, and their reliability has not been characterized. <sup>&</sup>lt;sup>‡</sup> The NJ designator for the 40-pin plastic shrink DIP package was formerly known as N2. The mechanical drawing of the NJ is identical to the N2 package and did not need to be requalified. #### description (continued) **Table 2. Suffix Letter Configuration** | DEVICET | WATCHDOG TIMER | CLOCK | LOW-POWER MODE | | |-----------------|----------------|-----------------------------------|---------------------|--| | EPROM without A | Standard | Divide-by-4 (Standard oscillator) | Enabled | | | | Standard | | | | | ROM A | Hard | Divide-by-4 or Divide-by-1 (PLL) | Enabled or disabled | | | | Simple | | | | <sup>†</sup> Refer to the "device numbering conventions" section for device nomenclature and the "device part numbers" section for ordering. The 4K bytes and 8K bytes of mask-programmable ROM in the TMS370C020, TMS370C022, TMS370C320, and TMS370C322 are replaced in the TMS370C722 and SE370C722 with 8K bytes of EPROM. All other available memory and on-chip peripherals are identical, except there are no data EEPROMs on the TMS370C320 and TMS370C322 devices. OTP (TMS370C722) devices and the reprogrammable device (SE370C722) are available. TMS370C722 (OTP) devices are in plastic packages. This microcontroller is effective to use for immediate production updates for other members of the TMS370Cx2x family or for low-volume production runs when the mask charge or cycle time for the low-cost mask ROM devices is not practical. The SE370C722 has a windowed ceramic package to allow reprogramming of the program EPROM memory during the prototyping phase of design. These SE370C722 devices allow quick updates to breadboards and prototype systems while creating multiple initial designs. The TMS370Cx2x family provides two low-power modes (STANDBY and HALT) for applications where low power consumption is critical. Both modes stop all central processing unit (CPU) activity (that is, no instructions are executed). In the STANDBY mode, the internal oscillator, the general-purpose timer, and the SCI receiver start-bit detection remain active. In the HALT mode, all device activity is stopped. The device retains all RAM data and peripheral configuration bits throughout both low-power modes. The TMS370Cx2x features advanced register-to-register architecture that allows arithmetic and logical operations without requiring an accumulator (e.g., ADD R24, R47; add the contents of register 24 to the contents of register 47 and store the result in register 47). The TMS370Cx2x family is fully instruction-set-compatible, providing easy transition between members of the TMS370 8-bit microcontroller family. The SPI provides a convenient method of serial interaction for high speed communications between simpler shift-register type devices, such as display drivers, analog-to-digital (A/D) converter, PLL, I/O expansion, or other microcontrollers in the system. The TMS370Cx2x devices have two operational modes of serial communications provided by the SCI1 module. The SCI1 allows standard RS-232-C communications with other common data transmission equipment. The TMS370Cx2x family provides the system designer with an economical, efficient solution to real-time control applications. The TMS370 family extended development system (XDS™) and compact development tool (CDT™) meet the challenge of efficiently developing the software and hardware required to design the TMS370Cx2x into complex applications. The application source code can be written in assembly and C language, and the output code can be generated by the linker. The TMS370 family XDS development tool communicates through a standard RS-232-C interface with a personal computer. This allows the use of the personal computer editors and software utilities already familiar to the designer. The TMS370 family XDS emphasizes ease-of-use through extensive menus and screen windowing so that a system designer can begin developing software with minimal training. Precise real-time in-circuit emulation and extensive symbolic debug and analysis tools ensure efficient software and hardware implementation as well as a reduced time-to-market cycle. XDS and CDT are trademarks of Texas Instruments Incorporated. SPNS018C - FEBRUARY 1993 - REVISED FEBRUARY 1997 #### central processing unit (CPU) The TMS370Cx2x device uses the high-performance 8-bit TMS370 CPU module. The 'x2x uses an efficient register-to-register architecture that eliminates the conventional accumulator bottleneck. The complete 'x2x instruction map is shown in Table 17 in the instruction set overview section. The '370Cx2x CPU architecture provides the following components: #### CPU registers: - A stack pointer that points to the last entry in the memory stack - A status register that monitors the operation of the instructions and contains the global interrupt-enable bits - A program counter that points to the memory location of the next instruction to be executed #### Memory blocks: - 256-byte general-purpose RAM that can be used for data memory storage, program instructions, general purpose register, or the stack - A peripheral file that provides access to all internal peripheral modules, system-wide control functions, and EEPROM/EPROM programming control - 256-byte EEPROM module, that provides in-circuit programmability and data retention in power-off conditions - 4K- or 8K-byte ROM or 8K-byte EPROM Figure 1 illustrates the CPU registers and memory blocks. # central processing unit (CPU) (continued) <sup>†</sup> Reserved means the address space is reserved for future expansion. Figure 1. Programmer's Model #### stack pointer (SP) The SP is an 8-bit CPU register. Stack operates as a last-in, first-out, read/write memory. Typically the stack is used to store the return address on subroutine calls as well as the status register contents during interrupt sequences. The SP points to the last entry or top of the stack. The SP is incremented automatically before data is pushed onto the stack and decremented after data is popped from the stack. The stack can be placed anywhere in the on-chip RAM. #### status register (ST) The ST monitors the operation of the instructions and contains the global interrupt-enable bits. The ST includes four status bits (condition flags) and two interrupt-enable bits. - The four status bits indicate the outcome of the previous instruction; conditional instructions (for example, the conditional-jump instructions) use the status bits to determine program flow. - The two interrupt-enable bits control the two interrupt levels. <sup>‡</sup> Not available means the address space is not accessible. #### central processing unit (CPU) (continued) The ST, status-bit notation, and status-bit definitions are shown in Table 3. #### **Table 3. Status Registers** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|----------|----------| | С | N | Z | V | IE2 | IE1 | Reserved | Reserved | | RW-0 | RW-0 | RW-0 | RW-0 | RW-0 | RW-0 | | | R = read, W = write, 0 = value after reset #### program counter (PC) The contents of the PC point to the memory location of the next instruction to be executed. The PC consists of two 8-bit registers in the CPU: the program counter high (PCH) and program counter low (PCL). These registers contain the most significant byte (MSbyte) and least significant byte (LSbyte) of a 16-bit address. During reset, the contents of the reset vector (7FFEh, 7FFFh) are loaded into the PC. The PCH (MSbyte of the PC) is loaded with the contents of memory location 7FFEh, and the PCL (LSbyte of the PC) is loaded with the contents of memory location 7FFFh. Figure 2 shows this operation using an example value of 6000h as the contents of the reset vector. Figure 2. Program Counter After Reset #### memory map The TMS370Cx2x architecture is based on the Von Neuman architecture, where the program memory and data memory share a common address space. All peripheral input/output is memory mapped in this same common address space. As shown in Figure 3, the TMS370Cx2x provides memory-mapped RAM, ROM, EPROM, data EEPROM, I/O pins, peripheral functions, and system-interrupt vectors. The peripheral file contains all I/O port control, peripheral status and control, EEPROM, EPROM, and system-wide control functions. The peripheral file is located between 1010h to 105Fh and is divided logically into five peripheral file frames of 16 bytes each. Each on-chip peripheral is assigned to a separate frame through which peripheral control and data information is passed. # memory map (continued) <sup>†</sup> Reserved means the address space is reserved for future expansion. Figure 3. TMS370Cx2x Memory Map #### RAM/register file (RF) Locations within the RAM address space can serve as the RF, general-purpose read/write memory, program memory, or stack instructions. The TMS370Cx2x contains 256 bytes of internal RAM mapped beginning at location 0000h (R0) and continuing through location 00FFh (R255). The first two registers, R0 and R1, are also called register A and B, respectively. Some instructions implicitly use register A or B; for example, the instruction LDSP (load SP) assumes that the value to be loaded into the stack pointer is contained in register B. Registers A and B are the only registers cleared on reset. #### peripheral file (PF) The TMS370Cx2x control registers contain all the registers necessary to operate the system and peripheral modules on the device. The instruction set includes some instructions that access the PF directly. These instructions designate the register by the number of the PF relative to 1000h, preceded by P0 for a hexadecimal designator or P for a decimal designator. For example, the system-control register 0 (SCCR0) is located at address 1010h; its peripheral file hexadecimal designator is P010, and its decimal designator is P16. Table 4 shows the TMS370Cx2x PF address map. <sup>‡</sup> Not available means the address space is not accessible. #### peripheral file (PF) (continued) Table 4. TMS370Cx2x Peripheral File Address Map | ADDRESS RANGE | PERIPHERAL FILE<br>DESIGNATOR | DESCRIPTION | |---------------|-------------------------------|-------------------------------------------| | 1000h-100Fh | P000-P00F | Reserved | | 1010h-101Fh | P010-P01F | System and EPROM/EEPROM control registers | | 1020h-102Fh | P020-P02F | Digital I/O port control registers | | 1030h-103Fh | P030-P03F | SPI peripheral control registers | | 1040h-104Fh | P040-P04F | Timer 1 registers | | 1050h-105Fh | P050-P05F | SCI1 peripheral control registers | | 1060h-10FFh | P060-P0FF | Reserved | #### data EEPROM The TMS370Cx2x devices contain 256 bytes of data EEPROM and are memory mapped beginning at location 1F00h and continuing through location 1FFFh. Writing to the data EEPROM module is controlled by the data EEPROM control register (DEECTL) and the write-protection register (WPR). Programming algorithm examples are available in the TMS370 Family User's Guide (literature number SPNU127) or the TMS370 Family Data Manual (literature number SPNS014B). The data EEPROM features include the following: #### Programming: - Bit-, byte-, and block-write/erase modes - Internal charge pump circuitry. No external EEPROM programming voltage supply is needed. - Control register: Data EEPROM programming is controlled by the DEECTL located in the PF frame beginning at location P01A. See Table 5. - In-circuit programming capability. There is no need to remove the device to program it. - Write protection. Writes to the data EEPROM are disabled during the following conditions. - Reset. All programming of the data EEPROM module is halted. - Write protection active. There is one write-protect bit per 32-byte EEPROM block. - Low-power mode operation - Write protection can be overridden by applying 12 V to MC. Table 5. Data EEPROM and Program EPROM Control Registers Memory Map | ADDRESS | SYMBOL | NAME | |---------|--------|--------------------------------| | P01A | DEECTL | Data EEPROM Control Register | | P01B | _ | Reserved | | P01C | EPCTL | Program EPROM Control Register | #### program EPROM† The TMS370C722 and SE370C722 devices contain 8K bytes of program EPROM mapped, beginning at location 6000h and continuing through location 7FFFh, as shown in Figure 3. Reading the program EPROM modules is identical to reading other internal memory. During programming, the program EPROM is controlled by the EPROM control register (EPCTL). The program EPROM module features include: - Programming - In-circuit programming capability if V<sub>PP</sub> is applied to MC - Control register: EPROM programming is controlled by the EPROM control register (EPCTL) located in the peripheral file (PF) frame at location P01C as shown in Table 5. - Write protection: Writes to the program EPROM are disabled under the following conditions: - Reset: All programming to the EPROM module is halted - Low-power modes - 13 V not applied to MC # program ROM† The program ROM consists of 4K or 8K bytes of mask programmable read-only memory (see Table 6). The program ROM is used for permanent storage of data or instructions. Programming of the mask ROM is performed at the time of device fabrication. **Table 6. Program ROM Memory Map** | | 'x20A | 'x22A | |---------------|-------------|-------------| | ROM size | 4K bytes | 8K bytes | | Memory mapped | 7000h-7FFFh | 6000h-7FFFh | #### system reset The system-reset operation ensures an orderly start-up sequence for the TMS370Cx2x CPU-based device. Three actions can cause a system reset. Two of these actions are internally generated, while one (RESET) is controlled externally. These actions are as follows: - Watchdog (WD) timer. A watchdog-generated reset occurs if an improper value is written to the WD key register, or if the re-initialization does not occur before the watchdog timer timeout. See the TMS370 Family User's Guide (literature number SPNU127) or the TMS370 Family Data Manual (literature number SPNS014B) for more information. - Oscillator reset. Reset occurs when the oscillator operates outside the recommended operating range. See the TMS370 Family User's Guide (literature number SPNU127) or the TMS370 Family Data Manual (literature number SPNS014B) for more information. - External RESET Pin. A low-level signal can trigger an external reset. To ensure a reset, the external signal should be held low for one SYSCLK cycle. Signals of less than one SYSCLK can generate a reset. See the TMS370 Family User's Guide (literature number SPNU127) or the TMS370 Family Data Manual (literature number SPNS014B) for more information. Once a reset source is activated, the external $\overline{\text{RESET}}$ pin is driven (active) low for a minimum of eight SYSCLK cycles. This allows the 'x2x device to reset external system components. Additionally, if a cold start ( $V_{CC}$ is off for several hundred milliseconds) condition or oscillator failure occurs or $\overline{\text{RESET}}$ pin is held low, then the reset logic holds the device in a reset state for as long as these actions are active. <sup>†</sup> Memory addresses 7FF0h through 7FFFh are reserved for interrupt and reset vectors. Trap vectors, used with TRAP0 through TRAP15 instructions are located between addresses 7FC0h and 7FDFh. SPNS018C - FEBRUARY 1993 - REVISED FEBRUARY 1997 #### system reset (continued) After a reset, the program can check the oscillator fault flag, the cold start flag and the watchdog reset to determine the source of the reset. A reset does not clear these flags. Table 7 lists the reset sources. **Table 7. Reset Sources** | REGISTER | ADDRESS | PF | BIT NO. | CONTROL BIT | SOURCE OF RESET | |----------|---------|------|---------|-------------------|-------------------------| | SCCR0 | 1010h | P010 | 7 | COLD START | Cold (power-up) | | SCCR0 | 1010h | P010 | 4 | OSC FLT FLAG | Oscillator out of range | | T1CTL2 | 104Ah | P04A | 5 | WD OVRFL INT FLAG | Watchdog timer timeout | Once a reset is activated, the following sequence of events occurs: - 1. The CPU registers are initialized: ST = 00h, SP = 01h (reset state). - Registers A and B are initialized to 00h (no other RAM is changed). - 3. The contents of the LSbyte of the reset vector (07FFh) are read and stored in the PCL. - 4. The contents of the MSbyte of the reset vector (07FEh) are read and stored in the PCH. - 5. Program execution begins with an opcode fetch from the address pointed to by the PC. The reset sequence takes 20 SYSCLK cycles from the time the reset pulse is released until the first opcode fetch. During a reset, RAM contents (except for registers A and B) remain unchanged, and the module control register bits are initialized to their reset state. SPNS018C - FEBRUARY 1993 - REVISED FEBRUARY 1997 #### interrupts The TMS370 family software-programmable interrupt structure supports flexible on-chip and external-interrupt configurations to meet real-time interrupt-driven application requirements. The hardware-interrupt structure incorporates two priority levels as shown in Figure 4. Interrupt level 1 has a higher priority than interrupt level 2. The two priority levels can be enabled independently by the global-interrupt enable bits (IE1 and IE2) of the status register. Each system interrupt is configured independently on either the high- or low-priority chain by the application program during system initialization. Within each interrupt chain, the interrupt priority is fixed by the position of the system interrupt. However, since each system interrupt is configured selectively on either the high- or low-priority interrupt chain, the application program can elevate any system interrupt to the highest priority. Arbitration between the two priority levels is performed within the CPU. Arbitration within each of the priority chains is performed within the peripheral modules to support interrupt expansion to future modules. Pending interrupts are serviced upon completion of current instruction execution, depending on their interrupt mask and priority conditions. The TMS370Cx2x has seven hardware system interrupts (plus RESET) as shown in Table 8. Each system interrupt has a dedicated interrupt vector located in program memory through which control is passed to the interrupt service routines. A system interrupt can have multiple interrupt sources (e.g., SCI RXNT has two interrupt sources). All of the interrupt sources are individually maskable by local interrupt-enable control bits in the associated peripheral file. Each interrupt source FLAG bit is individually readable for software polling or for determining which interrupt source generated the associated system interrupt. #### interrupts (continued) Figure 4. Interrupt Control Four of the system interrupts are generated by on-chip peripheral functions, and three external interrupts are supported. Software configuration of the external interrupts is performed through the INT1, INT2, and INT3 control registers in peripheral file frame 1. Each external interrupt is individually software configurable for input polarity (rising or falling) for ease of system interface. External interrupt INT1 is software configurable as either a maskable or non-maskable interrupt. When INT1 is configured as non-maskable, it cannot be masked by the individual- or global-enable mask bits. The INT1 NMI bit is protected during non-privileged operation and therefore should be configured during the initialization sequence following reset. To maximize pin flexibility, external interrupts INT2 and INT3 can be software configured as general-purpose input/output pins if the interrupt function is not required (INT1 can be similarly configured as an input pin). #### interrupts (continued) **Table 8. Hardware System Interrupts** | INTERRUPT SOURCE | INTERRUPT FLAG | SYSTEM<br>INTERRUPT | VECTOR<br>ADDRESS | PRIORITY <sup>†</sup> | |--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------|-------------------|-----------------------| | External RESET Watchdog Overflow Oscillator Fault Detect | COLD START<br>WD OVRFL INT FLAG<br>OSC FLT FLAG | RESET‡ | 7FFEh, 7FFFh | 1 | | External INT1 | INT1 FLAG | INT1‡ | 7FFCh, 7FFDh | 2 | | External INT2 | INT2 FLAG | INT2‡ | 7FFAh, 7FFBh | 3 | | External INT3 | INT3 FLAG | INT3‡ | 7FF8h, 7FF9h | 4 | | SPI RX/TX Complete | SPI INT FLAG | SPIINT | 7FF6h, 7FF7h | 5 | | Timer 1 Overflow Timer 1 Compare 1 Timer 1 Compare 2 Timer 1 External Edge Timer 1 Input-Capture Watchdog Overflow | T1 OVRFL INT FLAG T1C1 INT FLAG T1C2 INT FLAG T1EDGE INT FLAG T1IC INT FLAG WD OVRFL INT FLAG | T1INT§ | 7FF4h, 7FF5h | 6 | | SCI RX Data Register Full<br>SCI RX Break Detect | RXRDY FLAG<br>BRKDT FLAG | RXINT <sup>‡</sup> | 7FF2h, 7FF3h | 7 | | SCI TX Data Register Empty | TXRDY FLAG | TXINT | 7FF0h, 7FF1h | 8 | <sup>†</sup> Relative priority within an interrupt level. #### privileged operation and EEPROM write-protection override The TMS370Cx2x family enables the designer to software-configure the system and peripherals to meet the requirements of a broad variety of applications. The non-privileged mode of operation ensures the integrity of the system configuration once defined for an end application. Following a hardware reset, the TMS370Cx2x operates in the privileged mode where all peripheral file registers have unrestricted read/write access and the application program configures the system during the initialization sequence following reset. As the last step of system initialization, the PRIVILEGE DISABLE bit (SCCR2.0) is set to 1, causing the device to enter the non-privileged mode, thus disabling write operations to specific configuration control bits within the peripheral file. The system configuration bits listed in Table 9 are write-protected during the non-privileged mode and must be configured by software prior to exiting the privileged mode. <sup>‡</sup> Releases microcontroller from STANDBY and HALT low-power modes. <sup>§</sup> Releases microcontroller from STANDBY low-power mode. #### privileged operation and EEPROM write-protection override (continued) Table 9. Privileged Bits | REG | ISTER <sup>†</sup> | CONTROL BIT | |--------|----------------------------------------------------------|-------------------------------------------------------------------------| | NAME | LOCATION | CONTROL BIT | | SCCR0 | P010.5<br>P010.6 | PF AUTO WAIT<br>OSC POWER | | SCCR1 | P011.2<br>P011.4 | MEMORY DISABLE<br>AUTOWAIT DISABLE | | SCCR2 | P012.0<br>P012.1<br>P012.3<br>P012.4<br>P012.6<br>P012.7 | PRIVILEGE DISABLE INT1 NMI CPU STEST BUS STEST PWRDWN/IDLE HALT/STANDBY | | SCIPRI | P05F.4<br>P05F.5<br>P05F.6<br>P05F.6 | SCI ESPEN<br>SCI RX PRIORITY<br>SCI TX PRIORITY<br>SCI STEST | | T1PRI | P04F.6<br>P04F.7 | T1 PRIORITY<br>T1 STEST | | SPIPRI | P03F.5<br>P03F.6<br>P03F.7 | SPI ESPEN<br>SPI PRIORITY<br>SPI STEST | <sup>&</sup>lt;sup>†</sup> The privileged bits are shown in a bold typeface in Table 11. The WPO mode provides an external hardware method of overriding the WPR of data EEPROM on the TMS370Cx2x. WPO mode is entered by applying a 12-V input to the MC pin after the RESET pin input goes high. The high voltage on the MC pin during the WPO mode is not the programming voltage for the data EEPROM or program EPROM. All EEPROM programming voltages are generated on-chip. The WPO mode provides hardware system level capability to modify the personality or calibration information in the data EEPROM while the device remains in the application, but only while a 12-V external input is present on the MC pin (normally not available in the end application except in a service or diagnostic environment). #### low-power operating modes The TMS370Cx2x devices have two low-power modes (STANDBY and HALT) and an IDLE mode. For mask-ROM devices, low-power modes can be disabled permanently through a programmable contact when the mask is manufactured. The STANDBY and HALT low-power modes significantly reduce power consumption by reducing or stopping the activity of the various on-chip peripherals when processing is not required. Each of the low-power modes is entered by executing the IDLE instruction when the PWRDWN/IDLE bit in SCCR2 has been set to 1. The HALT/STANDBY bit in SCCR2 controls the low-power mode selection. In the STANDBY mode (HALT/STANDBY = 0), all CPU activity and most peripheral module activity stops; however, the oscillator, internal clocks, timer 1, and receive start-bit detection circuit of the SCI1 remain active. System processing is suspended until a qualified interrupt (hardware RESET, external interrupt on INT1, INT2, INT3, timer 1 interrupt, or low level on the receive pin of the SCI1) is detected. In the HALT mode (HALT/STANDBY = 1), the TMS370Cx2x is in its lowest power consumption mode. The oscillator and internal clocks are stopped, causing all internal activity to be halted. System activity is suspended until a qualified interrupt (hardware RESET, external interrupt on the INT1, INT2, INT3, or low level on the receive pin of the SCI1) is detected. The power-down mode-selection bits are summarized in Table 10. #### low-power operating modes (continued) Table 10. Low-Power/Idle Control Bits | POWER-DOWN | CONTROL BITS | MODE SELECTED | | | |--------------------------|---------------------------|---------------|--|--| | PWRDWN/IDLE<br>(SCCR2.6) | HALT/STANDBY<br>(SCCR2.7) | | | | | 1 | 0 | STANDBY | | | | 1 | 1 | HALT | | | | 0 | χ† | IDLE | | | † Don't care When low-power modes are disabled through a programmable contact, writing to the SCCR2.6-7 bits is ignored. In addition, if an IDLE instruction is executed when low-power modes are disabled, the device always enters the IDLE mode. To provide a method for always exiting low-power modes for mask-ROM devices, INT1 is enabled automatically as a nonmaskable interrupt (NMI) during low-power modes when the hard watchdog mode is selected. This means that the NMI always is generated, regardless of the interrupt enable flags. The following information is preserved throughout both the STANDBY and HALT modes: RAM (register file), CPU registers (SP, PC, and ST), I/O pin direction and output data, and status registers of all on-chip peripheral functions. Since all CPU instruction processing is stopped during the STANDBY and HALT modes, the clocking of the WD timer is inhibited. #### clock modules The 'x2x family provides two clock options that are referred to as divide-by-1 (phase-locked loop) and divide-by-4 (standard oscillator). Both the divide-by-1 and divide-by-4 options are configurable during the manufacturing process of a TMS370 MCU. The 'x2x masked ROM devices offer both options to meet system engineering requirements. Only one of the two clock options is allowed on each ROM device. The divide-by-1 clock module option provides reduced electromagnetic interference (EMI) with no added cost. The divide-by-1 provides a one-to-one match of the external resonator frequency (CLKIN) to the internal system clock (SYSCLK) frequency, whereas the divide-by-4 produces a SYSCLK which is one-fourth the frequency of the external resonator. Inside of the divide-by-1 module, the frequency of the external resonator is multiplied by four, and the clock module then divides the resulting signal by four to provide the four-phased internal system clock signals. The resulting SYSCLK is equal to the resonator frequency. These are formulated as follows: Divide-by-4 option : SYSCLK = $$\frac{\text{external resonator frequency}}{4} = \frac{\text{CLKIN}}{4}$$ Divide-by-1 option : SYSCLK = $\frac{\text{external resonator frequency}}{4} = \text{CLKIN}$ The main advantage of a divide-by-1 oscillator is the improved EMI performance. The harmonics of low-speed resonators extend through fewer of the emissions spectrum than the harmonics of faster resonators. The divide-by-1 reduces the resonator speed by four, and this results in a steeper decay of emissions produced by the oscillator. # system configuration registers Table 11 contains peripheral file frame 1 system configuration and control register functions for controlling EEPROM programming. The privileged bits are shown in bold typeface and shaded. Table 11. Peripheral File Frame 1: System Configuration and Control Registers<sup>†</sup> | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | |----------------------|------------------|------------------|-----------------|---------------------|------------------|-------------------|------------------|----------------------|--------| | P010 | COLD<br>START | OSC<br>POWER | PF AUTO<br>WAIT | OSC FLT<br>FLAG | MC PIN<br>WPO | MC PIN<br>DATA | | μΡ/μC<br>MODE | SCCR0 | | P011 | _ | _ | _ | AUTOWAIT<br>DISABLE | _ | MEMORY<br>DISABLE | | _ | SCCR1 | | P012 | HALT/<br>STANDBY | PWRDWN/<br>IDLE | | BUS<br>STEST | CPU<br>STEST | | INT1<br>NMI | PRIVILEGE<br>DISABLE | SCCR2 | | P013 | | | | | | | | | ] | | to<br>P016 | | | | Rese | erved | | | | | | 1 010 | INT1 | INT1 | | | | INT1 | INT1 | INT1 | 1 | | P017 | FLAG | PIN DATA | _ | _ | _ | POLARITY | PRIORITY | ENABLE | INT1 | | P018 | INT2<br>FLAG | INT2<br>PIN DATA | _ | INT2<br>DATA DIR | INT2<br>DATA OUT | INT2<br>POLARITY | INT2<br>PRIORITY | INT2<br>ENABLE | INT2 | | P019 | INT3<br>FLAG | INT3<br>PIN DATA | _ | INT3<br>DATA DIR | INT3<br>DATA OUT | INT3<br>POLARITY | INT3<br>PRIORITY | INT3<br>ENABLE | INT3 | | P01A | BUSY | _ | _ | _ | _ | AP | W1W0 | EXE | DEECTL | | P01B | Reserved | | | | | | | | ] | | P01C | BUSY | VPPS | _ | | _ | _ | W0 | EXE | EPCTL | | P01D<br>P01E<br>P01F | Reserved | | | | | | | | | <sup>†</sup> Privileged bits are shown in bold typeface. # peripheral file frame 2 Peripheral file frame 2 contains the digital I/O pin configuration and control registers. Table 12 and Table 13 detail the specific addresses, registers, and control bits within the peripheral file frame. Table 12. Peripheral File Frame 2: Digital Port Control Registers | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | ] | |------|-----------------------------------------|-------------|------------------|-----------------|------------------|-------|-------|------------------------------------------------|--------| | P020 | | | | Res | erved | | | | APORT1 | | P021 | | | Po | rt A Control Re | gister 2 (must l | oe 0) | | | APORT2 | | P022 | Port A Data | | | | | | | | ADATA | | P023 | Port A Direction | | | | | | | | ADIR | | P024 | | | | Res | erved | | | | BPORT1 | | P025 | | | Po | rt B Control Re | gister 2 (must l | oe 0) | | | BPORT2 | | P026 | | | | Port I | 3 Data | | | | BDATA | | P027 | Port B Direction | | | | | | | | BDIR | | P028 | Reserved | | | | | | | | CPORT1 | | P029 | 1 | ı | ı | I | ı | _ | ı | Port C<br>Control<br>Register 2<br>(must be 0) | CPORT2 | | P02A | | _ | _ | | | _ | _ | Port C Data | CDATA | | P02B | | ı | | ı | | _ | | Port C<br>Direction | CDIR | | P02C | Port D Control Register 1 (must be 0) — | | | | | | _ | _ | DPORT1 | | P02D | Port D Control Register 2 (must be 0)† | | | | | _ | _ | _ | DPORT2 | | P02E | | Port D Data | | | | _ | _ | _ | DDATA | | P02F | | | Port D Direction | n | | _ | _ | _ | DDIR | <sup>&</sup>lt;sup>†</sup> To configure pin D3 as SYSCLK, set port D control register 2 = 08h. **Table 13. Port Configuration Register Setup** | PORT | PIN | abcd<br>00q1 | abcd<br>00y0 | | | | | | | | |------|-------------------------------------------------------------------------------------------------|--------------|--------------|--|--|--|--|--|--|--| | А | 0-7 | Data out q | Data in y | | | | | | | | | В | 0-7 | Data out q | Data in y | | | | | | | | | С | 0 | Data out q | Data in y | | | | | | | | | D | 3-7 | Data out q | Data in y | | | | | | | | | | a = Port × Control Register 1 <sup>‡</sup> b = Port × Control Register 2 c = Data d = Direction | | | | | | | | | | <sup>‡</sup> DPORT only #### programmable timer 1 The programmable timer module of the TMS370Cx2x provides the enhanced timer resources required to perform real-time system control. The Timer 1 module contains the general-purpose timer T1 and the watchdog (WD) timer. The two independent 16-bit timers (T1 and WD) allow program selection of input clock sources (real-time, external event, or pulse-accumulate) with multiple 16-bit registers (input-capture and compare) for special timer function control. The timer 1 module includes three external device pins that can be used for multiple counter functions (operation-mode dependent), or used as general-purpose I/O pins. The T1 module is shown in Figure 5. Figure 5. Timer 1 Block Diagram - Three T1 I/O pins - T1IC/CR: T1 input capture / counter-reset input pin, or general-purpose bidirectional I/O pin - T1PWM: T1 pulse-width-modulation (PWM) output pin, or general-purpose bidirectional I/O pin - T1EVT: T1 event input pin, or general-purpose bidirectional I/O pin - Two operational modes: - Dual-compare mode: Provides PWM signal - Capture/compare mode: Provides input capture pin - One 16-bit general-purpose resettable counter - One 16-bit compare register with associated compare logic - One 16-bit capture/compare register, which, depending on the mode of operation, operates as either capture or compare register - One 16-bit WD counter can be used as an event counter, a pulse accumulator, or an interval timer if WD feature is not needed. - Prescaler/clock sources that determine one of eight clock sources for general-purpose timer # programmable timer 1 (continued) - Selectable edge-detection circuitry that, depending on the mode of operation, senses active transitions on the input capture pins (T1IC/CR) - Interrupts that can be generated on the occurrence of: - A capture - A compare equal - A counter overflow - An external edge detection - Sixteen T1 module control registers located in the PF frame beginning at address P040 The T1 module control registers are listed in Table 14. # programmable timer 1 (continued) **Table 14. Timer Module Register Memory Map** | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | | | | | |------|----------------------------------------------|----------------------------------|----------------------------------|----------------------------------|----------------------|---------------------|---------------------|---------------------|--------|--|--|--|--|--| | | Modes: Dual-Compare and Capture/Compare | | | | | | | | | | | | | | | P040 | Bit 15 | | Т | 1Counter MSb | yte | | | Bit 8 | T1CNTR | | | | | | | P041 | Bit 7 | | Т | 1 Counter LSb | yte | | | Bit 0 | | | | | | | | P042 | Bit 15 | | Comp | oare Register N | ЛSbytе | | | Bit 8 | T1C | | | | | | | P043 | Bit 7 | | Com | pare Register l | _Sbyte | | | Bit 0 | | | | | | | | P044 | Bit 15 Capture/Compare Register MSbyte Bit 8 | | | | | | | | | | | | | | | P045 | Bit 7 Capture/Compare Register LSbyte Bit 0 | | | | | | | | | | | | | | | P046 | Bit 15 Watchdog Counter MSbyte Bit 8 | | | | | | | | | | | | | | | P047 | Bit 7 Watchdog Counter LSbyte Bit 0 | | | | | | | | | | | | | | | P048 | Bit 7 | | Wa | atchdog Reset | Key | | | Bit 0 | WDRST | | | | | | | P049 | WD OVRFL<br>TAP SEL† | WD INPUT<br>SELECT2 <sup>†</sup> | WD INPUT<br>SELECT1 <sup>†</sup> | WD INPUT<br>SELECT0 <sup>†</sup> | _ | T1 INPUT<br>SELECT2 | T1 INPUT<br>SELECT1 | T1 INPUT<br>SELECT0 | T1CTL1 | | | | | | | P04A | WD OVRFL<br>RST ENA <sup>†</sup> | WD OVRFL<br>INT ENA | WD OVRFL<br>INT FLAG | T1 OVRFL<br>INT ENA | T1 OVRFL<br>INT FLAG | _ | _ | T1<br>SW RESET | T1CTL2 | | | | | | | | Mode: Dual-0 | Compare | | | | | | | | | | | | | | P04B | T1EDGE<br>INT FLAG | T1C2<br>INT FLAG | T1C1<br>INT FLAG | _ | _ | T1EDGE<br>INT ENA | T1C2<br>INT ENA | T1C1<br>INT ENA | T1CTL3 | | | | | | | P04C | T1<br>MODE=0 | T1C1<br>OUT ENA | T1C2<br>OUT ENA | T1C1<br>RST ENA | T1CR<br>OUT ENA | T1EDGE<br>POLARITY | T1CR<br>RST ENA | T1EDGE<br>DET ENA | T1CTL4 | | | | | | | | Mode: Captu | re/Compare | | | | - | | | | | | | | | | P04B | T1EDGE<br>INT FLAG | _ | T1C1<br>INT FLAG | _ | _ | T1EDGE<br>INT ENA | _ | T1C1<br>INT ENA | T1CTL3 | | | | | | | P04C | T1<br>MODE = 1 | T1C1<br>OUT ENA | _ | T1C1<br>RST ENA | _ | T1EDGE<br>POLARITY | _ | T1EDGE<br>DET ENA | T1CTL4 | | | | | | | | Modes: Dual | -Compare and | Capture/Cor | npare | | | | | | | | | | | | P04D | _ | _ | _ | _ | T1EVT<br>DATA IN | T1EVT<br>DATA OUT | T1EVT<br>FUNCTION | T1EVT<br>DATA DIR | T1PC1 | | | | | | | P04E | T1PWM<br>DATA IN | T1PWM<br>DATA OUT | T1PWM<br>FUNCTION | T1PWM<br>DATA DIR | T1IC/CR<br>DATA IN | T1IC/CR<br>DATA OUT | T1IC/CR<br>FUNCTION | T1IC/CR<br>DATA DIR | T1PC2 | | | | | | | P04F | T1 STEST | T1<br>PRIORITY | _ | _ | _ | _ | _ | _ | T1PRI | | | | | | <sup>†</sup> Once the WD OVRFL RST ENA bit is set, these bits cannot be changed until a reset; this applies only to the standard watchdog and to simple counter. In the hard watchdog, these bits can be modified at any time; the WD INPUT SELECT2 bits are ignored. #### programmable timer 1 (continued) Figure 6 shows the Timer 1 capture/compare mode block diagram. The annotations on the diagram identify the register and the bit(s) in the PF. For example, the actual address of T1CTL2.0 is 104Ah, bit 0, in the T1CTL2 register. Figure 6. Capture/Compare Mode #### programmable timer 1 (continued) Figure 7 shows the Timer 1 dual-compare mode block diagram. The annotations on the diagram identify the register and the bit(s) in the peripheral frame. For example, the actual address of T1CTL2.0 is 104Ah, bit 0, in the T1CTL2 register. Figure 7. Dual-Compare Mode #### programmable timer 1 (continued) The TMS370Cx2x device includes a 24-bit WD timer, contained in the T1 module, which can be programmed as an event counter, pulse accumulator, or interval timer if the watchdog function is not used. The WD monitors software and hardware operation, and implements a system reset when the WD counter is not serviced properly (WD counter overflow or WD counter is re-initialized by an incorrect value). The WD can be configured as one of the three mask options as follows: standard watchdog, hard WD, or simple counter. - Standard watchdog configuration (see Figure 8) for 'C722 EPROM and mask-ROM devices: - Watchdog mode - Ten different WD overflow rates ranging from 6.55 ms to 3.35 s at 5-MHz SYSCLK - A WD reset key (WDRST) register clears the watchdog counter (WDCNTR) when a correct value is written. - Generates a system reset if an incorrect value is written to the watchdog reset key or if the counter overflows - A watchdog overflow flag (WD OVRFL INT FLAG) bit indicates whether the WD timer initiated a system reset. - Non-watchdog mode - Watchdog timer can be configured as an event counter, pulse accumulator or an interval timer. Figure 8. Standard Watchdog # programmable timer 1 (continued) - Hard watchdog configuration (see Figure 9) for 'C722 EPROM and mask-ROM devices: - Eight different WD overflow rates ranging from 26.2 ms to 3.35 s at 5-MHz SYSCLK - A WD reset key (WDRST) register clears the watchdog counter (WDCNTR) when a correct value is written. - Generates a system reset if an incorrect value is written to the WDRST or if the counter overflows - A WD overflow flag (WD OVRFL INT FLAG) bit indicates whether the WD timer initiated a system reset. - Automatic activation of the WD timer upon power-up reset - INT1 is enabled as a nonmaskable interrupt during low power modes. Figure 9. Hard Watchdog # programmable timer 1 (continued) - Simple counter configuration (see Figure 10) for mask-ROM devices only - Simple counter can be configured as an event counter, pulse accumulator, or internal timer. Figure 10. Simple Counter #### serial peripheral interface The SPI is a high-speed synchronous serial I/O port that allows a serial bit stream of programmed length (1 to 8 bits) to be shifted into and out of the device at a programmable bit transfer rate. The SPI normally is used for communications between the microcontroller and external peripherals or another microcontroller. Typical applications include external I/O or peripheral expansion by way of devices such as shift registers, display drivers, and A/D converters. Multi-device communications are supported by the master/slave operation of the SPI. The SPI module features include the following: - Three external pins - SPISOMI: SPI slave output/master input pin or general-purpose bidirectional I/O pin - SPISIMO: SPI slave input/master output pin or general-purpose bidirectional I/O pin - SPICLK: SPI serial clock pin or general-purpose bidirectional I/O pin - Two operational modes: Master and slave - Eight programmable baud rates - Maximum baud rate in master mode: 2.5M bps at 5 MHz SYSCLK SPI BAUD RATE = $$\frac{\text{SYSCLK}}{2 \times 2^b}$$ where b=bit rate in SPICCR.5-3 (range 0-7) - Maximum baud rate in slave mode: 625K bps at 5 MHz SYSCLK SPI BAUD RATE < SYSCLK/8</li> - Data word format: one to eight data bits - Simultaneous receiver and transmitter operations (transmit function can be disabled in software) # serial peripheral interface (continued) - Transmitter and receiver operations occur through interrupt-driven or polled algorithms. - Seven SPI module control registers located in control register frame beginning at address P030h The SPI module control registers are listed in Table 15. **Table 15. SPI Module Control Register Memory Map** | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | | | | |--------------------|---------------------|---------------------|---------------------|---------------------|--------------------|---------------------|---------------------|---------------------|--------|--|--|--|--| | P030 | SPI SW<br>RESET | CLOCK<br>POLARITY | SPI BIT<br>RATE2 | SPI BIT<br>RATE1 | SPI BIT<br>RATE0 | SPI<br>CHAR2 | SPI<br>CHAR1 | SPI<br>CHAR0 | SPICCR | | | | | | P031 | RECEIVER<br>OVERRUN | SPI INT<br>FLAG | _ | _ | _ | MASTER/<br>SLAVE | TALK | SPI INT<br>ENA | SPICTL | | | | | | P032<br>to<br>P036 | Reserved | | | | | | | | | | | | | | P037 | RCVD7 | RCVD7 RCVD6 RCVD5 | | RCVD4 | RCVD3 | RCVD2 | RCVD1 | RCVD0 | SPIBUF | | | | | | P038 | | | | Rese | erved | | | | | | | | | | P039 | SDAT7 | SDAT6 | SDAT5 | SDAT4 | SDAT3 | SDAT2 | SDAT1 | SDAT0 | SPIDAT | | | | | | P03A<br>to<br>P03C | | | | Rese | erved | | | | | | | | | | P03D | _ | _ | _ | _ | SPICLK<br>DATA IN | SPICLK<br>DATA OUT | SPICLK<br>FUNCTION | SPICLK<br>DATA DIR | SPIPC1 | | | | | | P03E | SPISIMO<br>DATA IN | SPISIMO<br>DATA OUT | SPISIMO<br>FUNCTION | SPISIMO<br>DATA DIR | SPISOMI<br>DATA IN | SPISOMI<br>DATA OUT | SPISOMI<br>FUNCTION | SPISOMI<br>DATA DIR | SPIPC2 | | | | | | P03F | SPI<br>STEST | SPI<br>PRIORITY | SPI<br>ESPEN | _ | _ | _ | _ | _ | SPIPRI | | | | | #### serial peripheral interface (continued) The SPI block diagram is listed in Figure 11. † The diagram shows slave mode. Figure 11. SPI Block Diagram #### serial communications interface 1 (SCI1) The TMS370x2x devices include a serial communications interface 1 (SCI1) module. The SCI1 module supports digital communications between the TMS370 devices and other asynchronous peripherals, and uses the standard non-return-to-zero (NRZ) format. The SCI1's receiver and transmitter are double buffered, and each has separate enable and interrupt bits. Both can operate independently or simultaneously in the full-duplex mode. To ensure data integrity, the SCI1 checks received data for break detection, parity, overrun, and framing errors. The bit rate (baud) is programmable to over 65,000 speeds through a 16-bit baud-select register. # serial communications interface 1 (SCI1) (continued) Features of the SCI1 module include: - Three external pins: - SCITXD: SCI transmit output pin or general purpose bidirectional I/O pin - SCIRXD: SCI receive input pin or general purpose bidirectional I/O pin - SCICLK: SCI bidirectional serial clock pin, or general purpose bidirectional I/O pin - Two communications modes: asynchronous and isosynchronous† - Baud rate: 64K programmable rates - Asynchronous mode: 3 bps to 156K bps at 5 MHz SYSCLK ASYNCHRONOUS BAUD = $$\frac{\text{SYSCLK}}{(\text{BAUD REG} + 1) \times 32}$$ Isosynchronous mode: 39 bps to 2.5M bps at 5 MHz SYSCLK ISOSYNCHRONOUS BAUD = $$\frac{\text{SYSCLK}}{(\text{BAUD REG} + 1) \times 2}$$ - Data word format - One start bit - Data word length programmable from 1 to 8 bits - Optional even/odd/no parity bit - One or two stop bits - Four error-detection flags: parity, overrun, framing, and break detection - Two wake-up multiprocessor modes: Idle-line and address bit - Half or full-duplex operation - Double-buffered receive and transmit functions - Interrupt driven or polled algorithms with status flags control transmitter (TX) and receiver (RX) operations. - Transmitter: TXRDY flag (transmitter buffer register is ready to receive another character) and TX EMPTY flag (transmitter shift register is empty) - Receiver: RXRDY flag (receive buffer register ready to receive another character), BRKDT flag (break condition occurred), and RX ERROR monitoring four interrupt conditions - Separate enable bits for transmitter and receiver interrupts - NRZ (non-return-to-zero) format - Eleven SCI1 module control registers are located in control register frame beginning at address P050h. <sup>†</sup> Isosynchronous = Isochronous # serial communications interface 1 (SCI1) (continued) The SCI1 module control registers are listed in Table 16. Table 16. Peripheral File Frame 5: SCI1 Module Control Registers<sup>†</sup> | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | | | | | | |------|--------------------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--------|--|--|--|--|--|--| | P050 | STOP<br>BITS | EVEN/ODD<br>PARITY | PARITY<br>ENABLE | ASYNC/<br>ISOSYNC | ADDRESS<br>IDLE WUP | SCI<br>CHAR2 | SCI<br>CHAR1 | SCI<br>CHAR0 | SCICCR | | | | | | | | P051 | - | _ | SCI SW<br>RESET | CLOCK | TXWAKE | SLEEP | TXENA | RXENA | SCICTL | | | | | | | | P052 | Bit 15 Baud Rate Select Register MSB Bit 8 | | | | | | | | | | | | | | | | P053 | Bit 7 Baud Rate Select Register LSB Bit 0 | | | | | | | | | | | | | | | | P054 | TXRDY | TX<br>EMPTY | | | 1 | 1 | | SCI TX<br>INT ENA | TXCTL | | | | | | | | P055 | RX<br>ERROR | RXRDY | BRKDT | FE | OE | OE PE | | SCI RX<br>INT ENA | RXCTL | | | | | | | | P056 | Reserved | | | | | | | | | | | | | | | | P057 | | | | Receive Data | Buffer Register | | | | RXBUF | | | | | | | | P058 | | | | Rese | erved | | | | ] | | | | | | | | P059 | | | | Transmit Data | Buffer Register | • | | | TXBUF | | | | | | | | P05A | | | | | | | | | | | | | | | | | P05B | | | | Rese | erved | | | | | | | | | | | | P05C | | | | | | | | | | | | | | | | | P05D | - | _ | _ | _ | SCICLK<br>DATA IN | SCICLK<br>DATA OUT | SCICLK<br>FUNCTION | SCICLK<br>DATA DIR | SCIPC1 | | | | | | | | P05E | SCI TXD<br>DATA IN | SCI TXD<br>DATA OUT | SCI TXD<br>FUNCTION | SCI TXD<br>DATA DIR | SCI RXD<br>DATA IN | SCI RXD<br>DATA OUT | SCI RXD<br>FUNCTION | SCI RXD<br>DATA DIR | SCIPC2 | | | | | | | | P05F | SCI<br>STEST | SCI TX<br>PRIORITY | SCI RX<br>PRIORITY | SCI<br>ESPEN | _ | _ | _ | _ | SCIPRI | | | | | | | <sup>†</sup> Privileged bits are shown in bold typeface. # serial communications interface 1 (SCI1) (continued) The SCI1 module block diagram is illustrated in Figure 12. Figure 12. SCI1 Block Diagram #### instruction set overview Table 17 provides an opcode-to-instruction cross reference of all 73 instructions and 274 opcodes of the '370Cx2x instruction set. The numbers at the top of this table represent the most significant nibble (MSN) of the opcode while the numbers at the left side of the table represent the least significant nibble (LSN). The instruction of these two opcode nibbles contains the mnemonic, operands, and byte/cycle particular to that opcode. For example, the opcode B5h points to the CLR A instruction. This instruction contains one byte and executes in eight SYSCLK cycles. # Table 17. TMS370 Family Opcode/Instruction Map† | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | А | В | С | D | E | F | |---|-------------------|-------------------------|------------------------|------------------------|--------------------------|------------------------|------------------------|--------------------------|-------------------------|-------------------------|----------------------------|------------------------|---------------------------|-----------------------|--------------------|-----------------------------| | 0 | JMP<br>#ra<br>2/7 | | | | | | | INCW<br>#ra,Rd<br>3/11 | MOV<br>Ps,A<br>2/8 | | | CLRC /<br>TST A<br>1/9 | MOV<br>A,B<br>1/9 | MOV<br>A,Rd<br>2/7 | TRAP<br>15<br>1/14 | LDST<br>n<br>2/6 | | 1 | JN<br>ra<br>2/5 | | MOV<br>A,Pd<br>2/8 | | | MOV<br>B,Pd<br>2/8 | | MOV<br>Rs,Pd<br>3/10 | | MOV<br>Ps,B<br>2/7 | | | | MOV<br>B,Rd<br>2/7 | TRAP<br>14<br>1/14 | MOV<br>#ra[SP],A<br>2/7 | | 2 | JZ<br>ra<br>2/5 | MOV<br>Rs,A<br>2/7 | MOV<br>#n,A<br>2/6 | MOV<br>Rs,B<br>2/7 | MOV<br>Rs,Rd<br>3/9 | MOV<br>#n,B<br>2/6 | MOV<br>B,A<br>1/8 | MOV<br>#n,Rd<br>3/8 | | | MOV<br>Ps,Rd<br>3/10 | DEC<br>A<br>1/8 | DEC<br>B<br>1/8 | DEC<br>Rd<br>2/6 | TRAP<br>13<br>1/14 | MOV<br>A,*ra[SP]<br>2/7 | | 3 | JC<br>ra<br>2/5 | AND<br>Rs,A<br>2/7 | AND<br>#n,A<br>2/6 | AND<br>Rs,B<br>2/7 | AND<br>Rs,Rd<br>3/9 | AND<br>#n,B<br>2/6 | AND<br>B,A<br>1/8 | AND<br>#n,Rd<br>3/8 | AND<br>A,Pd<br>2/9 | AND<br>B,Pd<br>2/9 | AND<br>#n,Pd<br>3/10 | INC<br>A<br>1/8 | INC<br>B<br>1/8 | INC<br>Rd<br>2/6 | TRAP<br>12<br>1/14 | CMP<br>*n[SP],A<br>2/8 | | 4 | JP<br>ra<br>2/5 | OR<br>Rs,A<br>2/7 | OR<br>#n,A<br>2/6 | OR<br>Rs,B<br>2/7 | OR<br>Rs,Rd<br>3/9 | OR<br>#n,B<br>2/6 | OR<br>B,A<br>1/8 | OR<br>#n,Rd<br>3/8 | OR<br>A,Pd<br>2/9 | OR<br>B,Pd<br>2/9 | OR<br>#n,Pd<br>3/10 | INV<br>A<br>1/8 | INV<br>B<br>1/8 | INV<br>Rd<br>2/6 | TRAP<br>11<br>1/14 | extend<br>inst,2<br>opcodes | | 5 | JPZ<br>ra<br>2/5 | XOR<br>Rs,A<br>2/7 | XOR<br>#n,A<br>2/6 | XOR<br>Rs,B<br>2/7 | XOR<br>Rs,Rd<br>3/9 | XOR<br>#n,B<br>2/6 | XOR<br>B,A<br>1/8 | XOR<br>#n,Rd<br>3/8 | XOR<br>A,Pd<br>2/9 | XOR<br>B,Pd<br>2/9 | XOR<br>#n,Pd<br>3/10 | CLR<br>A<br>1/8 | CLR<br>B<br>1/8 | CLR<br>Rn<br>2/6 | TRAP<br>10<br>1/14 | | | 6 | JNZ<br>ra<br>2/5 | BTJO<br>Rs,A,ra<br>3/9 | BTJO<br>#n,A,ra<br>3/8 | BTJO<br>Rs,B,ra<br>3/9 | BTJO<br>Rs,Rd,ra<br>4/11 | BTJO<br>#n,B,ra<br>3/8 | BTJO<br>B,A,ra<br>2/10 | BTJO<br>#n,Rd,ra<br>4/10 | BTJO<br>A,Pd,ra<br>3/11 | BTJO<br>B,Pd,ra<br>3/10 | BTJO<br>#n,Pd,ra<br>4/11 | XCHB<br>A<br>1/10 | XCHB A /<br>TST B<br>1/10 | XCHB<br>Rn<br>2/8 | TRAP<br>9<br>1/14 | IDLE<br>1/6 | | 7 | JNC<br>ra<br>2/5 | BTJZ<br>Rs.,A,ra<br>3/9 | BTJZ<br>#n,A,ra<br>3/8 | BTJZ<br>Rs,B,ra<br>3/9 | BTJZ<br>Rs,Rd,ra<br>4/11 | BTJZ<br>#n,B,ra<br>3/8 | BTJZ<br>B,A,ra<br>2/10 | BTJZ<br>#n,Rd,ra<br>4/10 | BTJZ<br>A,Pd,ra<br>3/10 | BTJZ<br>B,Pd,ra<br>3/10 | BTJZ<br>#n,Pd,ra<br>4/11 | SWAP<br>A<br>1/11 | SWAP<br>B<br>1/11 | SWAP<br>Rn<br>2/9 | TRAP<br>8<br>1/14 | MOV<br>#n,Pd<br>3/10 | | 8 | JV<br>ra<br>2/5 | ADD<br>Rs,A<br>2/7 | ADD<br>#n,A<br>2/6 | ADD<br>Rs,B<br>2/7 | ADD<br>Rs,Rd<br>3/9 | ADD<br>#n,B<br>2/6 | ADD<br>B,A<br>1/8 | ADD<br>#n,Rd<br>3/8 | MOVW<br>#16,Rd<br>4/13 | MOVW<br>Rs,Rd<br>3/12 | MOVW<br>#16[B],Rpd<br>4/15 | PUSH<br>A<br>1/9 | PUSH<br>B<br>1/9 | PUSH<br>Rd<br>2/7 | TRAP<br>7<br>1/14 | SETC<br>1/7 | | 9 | JL<br>ra<br>2/5 | ADC<br>Rs,A<br>2/7 | ADC<br>#n,A<br>2/6 | ADC<br>Rs,B<br>2/7 | ADC<br>Rs,Rd<br>3/9 | ADC<br>#n,B<br>2/6 | ADC<br>B,A<br>1/8 | ADC<br>#n,Rd<br>3/8 | JMPL<br>lab<br>3/9 | JMPL<br>*Rp<br>2/8 | JMPL<br>*lab[B]<br>3/11 | POP<br>A<br>1/9 | POP<br>B<br>1/9 | POP<br>Rd<br>2/7 | TRAP<br>6<br>1/14 | RTS<br>1/9 | | Α | JLE<br>ra<br>2/5 | SUB<br>Rs,A<br>2/7 | SUB<br>#n,A<br>2/6 | SUB<br>Rs,B<br>2/7 | SUB<br>Rs,Rd<br>3/9 | SUB<br>#n,B<br>2/6 | SUB<br>B,A<br>1/8 | SUB<br>#n,Rd<br>3/8 | MOV<br>& lab,A<br>3/10 | MOV<br>*Rp,A<br>2/9 | MOV<br>*lab[B],A<br>3/12 | DJNZ<br>A,#ra<br>2/10 | DJNZ<br>B,#ra<br>2/10 | DJNZ<br>Rd,#ra<br>3/8 | TRAP<br>5<br>1/14 | RTI<br>1/12 | | В | JHS<br>ra<br>2/5 | SBB<br>Rs,A<br>2/7 | SBB<br>#n,A<br>2/6 | SBB<br>Rs,B<br>2/7 | SBB<br>Rs,Rd<br>3/9 | SBB<br>#n,B<br>2/6 | SBB<br>B,A<br>1/8 | SBB<br>#n,Rd<br>3/8 | MOV<br>A, & lab<br>3/10 | MOV<br>A, *Rp<br>2/9 | MOV<br>A,*lab[B]<br>3/12 | COMPL<br>A<br>1/8 | COMPL<br>B<br>1/8 | COMPL<br>Rd<br>2/6 | TRAP<br>4<br>1/14 | PUSH<br>ST<br>1/8 | | | ra | Rs,A | #n,A | Rs,B | Rs,Rd | #n,B | B,A | #n,Rd | A, & lab | A, *Rp | A,*lab[B] | Α | В | Rd | 4 | | <sup>†</sup> All conditional jumps (opcodes 01–0F), BTJO, BTJZ, and DJNZ instructions use two additional cycles if the branch is taken. The BTJO, BTJZ, and DJNZ instructions have a relative address as the last operand. TMS370Cx2x 8-BIT MICROCONTROLLER Template Release Date: 7-11-94 SPNS018C – FEBRUARY 1993 – REVISED FEBRUARY 1997 # Table 17. TMS370 Family Opcode/Instruction Map† (Continued) | | | | | | | | | | MSN | | | | | | | | |---|------------------|---------------------|---------------------|---------------------|----------------------|---------------------|--------------------|----------------------|------------------------|----------------------|--------------------------|-----------------|-----------------|------------------|-------------------|------------------| | _ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | С | JNV<br>ra<br>2/5 | MPY<br>Rs,A<br>2/46 | MPY<br>#n,A<br>2/45 | MPY<br>Rs,B<br>2/46 | MPY<br>Rs,Rd<br>3/48 | MPY<br>#n,B<br>2/45 | MPY<br>B,A<br>1/47 | MPY<br>#n,Rs<br>3/47 | BR<br>lab<br>3/9 | BR<br>*Rp<br>2/8 | BR<br>*lab[B]<br>3/11 | RR<br>A<br>1/8 | RR<br>B<br>1/8 | RR<br>Rd<br>2/6 | TRAP<br>3<br>1/14 | POP<br>ST<br>1/8 | | D | JGE<br>ra<br>2/5 | CMP<br>Rs,A<br>2/7 | CMP<br>#n,A<br>2/6 | CMP<br>Rs,B<br>2/7 | CMP<br>Rs,Rd<br>3/9 | CMP<br>#n,B<br>2/6 | CMP<br>B,A<br>1/8 | CMP<br>#n,Rd<br>3/8 | CMP<br>& lab,A<br>3/11 | CMP<br>*Rp,A<br>2/10 | CMP<br>*lab[B],A<br>3/13 | RRC<br>A<br>1/8 | RRC<br>B<br>1/8 | RRC<br>Rd<br>2/6 | TRAP<br>2<br>1/14 | LDSP<br>1/7 | | Е | JG<br>ra<br>2/5 | DAC<br>Rs,A<br>2/9 | DAC<br>#n,A<br>2/8 | DAC<br>Rs,B<br>2/9 | DAC<br>Rs,Rd<br>3/11 | DAC<br>#n,B<br>2/8 | DAC<br>B,A<br>1/10 | DAC<br>#n,Rd<br>3/10 | CALL<br>lab<br>3/13 | CALL<br>*Rp<br>2/12 | CALL<br>*lab[B]<br>3/15 | RL<br>A<br>1/8 | RL<br>B<br>1/8 | RL<br>Rd<br>2/6 | TRAP<br>1<br>1/14 | STSP<br>1/8 | | F | JLO<br>ra<br>2/5 | DSB<br>Rs,A<br>2/9 | DSB<br>#n,A<br>2/8 | DSB<br>Rs,B<br>2/9 | DSB<br>Rs,Rd<br>3/11 | DSB<br>#n,B<br>2/8 | DSB<br>B,A<br>1/10 | DSB<br>#n,Rd<br>3/10 | CALLR<br>lab<br>3/15 | CALLR<br>*Rp<br>2/14 | CALLR<br>*lab[B]<br>3/17 | RLC<br>A<br>1/8 | RLC<br>B<br>1/8 | RLC<br>Rd<br>2/6 | TRAP<br>0<br>1/14 | NOP<br>1/7 | | | Second byte of two-byte instructions (F4xx): | F4 | 8 | MOVW<br>*n[Rn]<br>4/15 | DIV<br>Rn.A<br>3/14-63 | |------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----|---|-------------------------|------------------------| | | | F4 | 9 | JMPL<br>*n[Rn]<br>4/16 | | | Legend: * = Indirect addressing operand prefix & = Direct addressing operand prefix | | F4 | Α | MOV<br>*n[Rn],A<br>4/17 | | | # = immediate operand<br>#16 = immediate 16-bit number<br>lab = 16-label | | F4 | В | MOV<br>A,*n[Rn]<br>4/16 | | | n = immediate 8-bit number Pd = Peripheral register containing destination type Pn = Peripheral register | | F4 | С | BR<br>*n[Rn]<br>4/16 | | | Ps = Peripheral register containing source byte ra = Relative address Rd = Register containing destination type Rn = Register file | | F4 | D | CMP<br>*n[Rn],A<br>4/18 | | | Rp = Register pair Rpd = Destination register pair Rps = Source Register pair | | F4 | Е | CALL<br>*n[Rn]<br>4/20 | | | Rs = Register containing source byte | | F4 | F | CALLR<br>*n[Rn]<br>4/22 | | <sup>†</sup>All conditional jumps (opcodes 01-0F), BTJO, BTJZ, and DJNZ instructions use two additional cycles if the branch is taken. The BTJO, BTJZ, and DJNZ instructions have a relative address as the last operand. L S N #### development system support The TMS370 family development support tools include an assembler, a C compiler, a linker, an in-circuit emulator XDS/22, CDT, and an EEPROM/UVEPROM programmer. - Assembler/linker (Part No. TMDS3740850–02 for PC) - Includes extensive macro capability - Provides high-speed operation - Includes format conversion utilities for popular formats - ANSI C Compiler (Part No. TMDS3740855–02 for PC, Part No. TMDS3740555–09 for HP700<sup>™</sup>, Sun-3<sup>™</sup> or Sun-4<sup>™</sup>) - Generates assembly code for the TMS370 that can be inspected easily - Improves code execution speed and reduces code size with optional optimizer pass - Enables direct reference the TMS370's port registers by using a naming convention - Provides flexibility in specifying the storage for data objects - Interfaces C functions and assembly functions easily - Includes assembler and linker - CDT370 (Compact Development Tool) real-time in-circuit emulation - Base (Part Number EDSCDT370 for PC, requires cable) - Cable for 40-pin DIP (Part No. EDSTRG40DILX) - Cable for 44-pin PLCC (Part No. EDSTRG44PLCCX) - Cable for 40-pin SDIP (Part No. EDSTRG40SDILX) - EEPROM and EPROM programming support - Allows inspection and modification of memory locations - Includes compatibility to upload/download program and data memory - Executes programs and software routines - Includes 1024 samples trace buffer - Includes single-step executable instructions - Uses software breakpoints to halt program execution at selected address - XDS/22 in-circuit emulator - Base (Part Number TMDS3762210 for PC, requires cable) - Cable for 40-pin DIP/SDIP, 44-pin PLCC (Part No. TMDS3788844) - Contains all of the features of the CDT370 described previously but does not have the capability to program the data EEPROM and program EPROM - Contains sophisticated breakpoint trace and timing hardware that provides up to 2047 qualified trace samples with symbolic disassembly - Allows qualification of breakpoints by address and/or data on any type of memory acquisition. Up to four levels of events can be combined to cause a breakpoint. HP700 is a trademark of Hewlett-Packard Company. Sun-3 and Sun-4 are trademarks of Sun Microsystems, Incorporated. # development system support (continued) - Provides timers for analyzing total and average time in routines - Contains an eight-line logic probe for adding visibility of external signals to the breakpoint qualifier and to trace display - Microcontroller programmer - Base (Part No. TMDS3760500A for PC, requires programmer head) - Single unit head for 44-pin PLCC (Part No. TMDS3780510A) - Single unit head for 40-pin DIP/SDIP (Part No. TMDS3780511A) - PC-based, window/function-key-oriented user interface for ease of use and rapid learning environment - Starter Kit (Part No. TMDS37000 for PC) - Includes TMS370 Assembler diskette and documentation - Includes TMS370 Simulator - Includes programming adapter board and programming software - Does not include (to be supplied by the user) - + 5 V power supply - ZIF sockets - Nine-pin RS232 cable ## device numbering conventions Figure 13 illustrates the numbering and symbol nomenclature for the TMS370Cx2x family. Figure 13. TMS370Cx2x Family Nomenclature #### device part numbers Table 18 lists all of the 'x2x devices available. The device part number nomenclature is designed to assist ordering. Upon ordering, the customer must specify not only the device part number, but also the clock and watchdog timer options desired. Each device can have only one of the three possible watchdog timer options and one of the two clock options. The options to be specified pertain solely to orders involving ROM devices. **Table 18. Device Part Numbers** | DEVICE PART NUMBERS | DEVICE PART NUMBERS | DEVICE PART NUMBERS | |---------------------------|---------------------------|-----------------------------| | FOR 44 PINS (LCC) | FOR 40 PINS (DIP) | FOR 40 PINS (SDIP) | | TMS370C020AFNA | TMS370C020ANA | TMS370C020ANJA† | | TMS370C020AFNL | TMS370C020ANL | TMS370C020ANJL† | | TMS370C020AFNT | TMS370C020ANT | TMS370C020ANJT† | | TMS370C022AFNA | TMS370C022ANA | TMS370C022ANJA <sup>†</sup> | | TMS370C022AFNL | TMS370C022ANL | TMS370C022ANJL <sup>†</sup> | | TMS370C022AFNT | TMS370C022ANT | TMS370C022ANJT <sup>†</sup> | | TMS370C320AFNA | TMS370C320ANA | TMS370C320ANJA <sup>†</sup> | | TMS370C320AFNL | TMS370C320ANL | TMS370C320ANJL <sup>†</sup> | | TMS370C320AFNT | TMS370C320ANT | TMS370C320ANJT <sup>†</sup> | | TMS370C322AFNA | TMS370C322ANA | TMS370C322ANJA <sup>†</sup> | | TMS370C322AFNL | TMS370C322ANL | TMS370C322ANJL <sup>†</sup> | | TMS370C322AFNT | TMS370C322ANT | TMS370C322ANJT <sup>†</sup> | | TMS370C722FNT | TMS370C722NT | TMS370C722NJT <sup>†</sup> | | SE370C722FZT <sup>‡</sup> | SE370C722JDT <sup>‡</sup> | SE370C722JCT <sup>‡</sup> | <sup>&</sup>lt;sup>†</sup> The NJ designator for the 40-pin plastic shrink DIP package was formerly known as N2. The mechanical drawing of the NJ is identical to the N2 package and did not need to be requalified. <sup>‡</sup> System evaluators are for use only in prototype environment, and their reliability has not been characterized. ## new code release form Figure 14 shows a sample of the new code release form. | | NEW CODE RE<br>TEXAS INST<br>TMS370 MICROCONTI | RUMENTS | DATE: | |------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | To release a new customer algorithm to TI incorpora | ted into a TMS370 family m | icrocontroller, complete | e this form and submit with the following information: | | A ROM description in object form on Floppy Dis An attached specification if not using TI standar | | | | | Company Name:Street Address: | | Contact Mr./Ms.:<br>Phone: ( ) | Ext.: | | Street Address: State | Zin | | Order Number: | | | | | | | Customer Part Number:Customer Application: | | *If Yes: Customer mu<br>code processing star | ber *Yes: # | | TMS370 Device: | | | | | TI Customer ROM Number:(provided by Texas Instruments) | | CONTACT OPTIONS | S FOR THE 'A' VERSION TMS370 MICROCONTROLLERS | | OSCILLATOR FREQUENCY MIN TYP [] External Drive (CLKIN) | MAX | Low Power Modes [] Enabled [] Disabled | Watchdog counter Clock Type [] Standard [] Standard (/4) [] Hard Enabled [] PLL (/1) | | [] Crystal [] Ceramic Resonator | | | [] Simple Counter | | [] Supply Voltage MIN: MAX: MAX: | _ | "Low-power modes E options. See the TMS | devices of the TMS370 microcontrollers will have the inabled", "Divide-by-4" Clock, and "Standard" Watchdog 3370 Family User's Guide (literature number SPNU127) by Data Manual (literature number SPNS014B). | | TEMPERATURE RANGE 'L': 0° to 70°C (standard) 'A': -40° to 85°C 'T': -40° to 105°C | | PACKAGE TYPE [] 'N' 28-pin PDIF [] "FN" 28-pin PL [] "N" 40-pin PDII [] "NJ" 40-pin PS | P [] "FN" 44-pin PLCC CC [] "FN" 68-pin PLCC P [] "NM" 64-pin PSDIP DIP (formerly known as N2) | | SYMBOLIZATION | | BUS EXPANSION | | | TI standard symbolization TI standard w/customer part number Customer symbolization (per attached spec, subject to approval) | | [] YES | [] NO | | (i.e., product which must be started in process pr<br>satisfaction of both the customer and TI in time for | ior to prototype approval and<br>or a scheduled shipment, the | d full production release<br>e specification paramete | : If the customer requires expedited production material e) and non-standard spec issues are not resolved to the ers in question will be processed/tested to the standard be identified by a 'P' in the symbolization preceding the | | | | | ers placed for this TI custom device. Any changes must es when this document is signed off and the verification | | 1. Customer: | Date: | 2. TI: Field Sales: | | | | | Marketing: _ | | | | | Proto, Releas | | Figure 14. Sample New Code Release Form Table 19 is a collection of all the peripheral file frames used in the 'Cx2x (provided for a quick reference). **Table 19. Peripheral File Frame Compilation** | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | |----------------------|------------------|------------------|-------------------|-------------------------|------------------|-------------------|------------------|---------------------------------------------|--------| | | | | ; | System Config | uration Registe | ers | | | | | P010 | COLD<br>START | OSC<br>POWER | PF AUTO<br>WAIT | OSC FLT<br>FLAG | MC PIN<br>WPO | MC PIN<br>DATA | _ | μΡ/μC<br>MODE | SCCR0 | | P011 | _ | _ | _ | AUTO<br>WAIT<br>DISABLE | _ | MEMORY<br>DISABLE | _ | _ | SCCR1 | | P012 | HALT/<br>STANDBY | PWRDWN/<br>IDLE | _ | BUS<br>STEST | CPU<br>STEST | _ | INT1<br>NMI | PRIVILEGE<br>DISABLE | SCCR2 | | P013<br>to<br>P016 | | | | Res | served | | | | | | P017 | INT1<br>FLAG | INT1<br>PIN DATA | | _ | | INT1<br>POLARITY | INT1<br>PRIORITY | INT1<br>ENABLE | INT1 | | P018 | INT2<br>FLAG | INT2<br>PIN DATA | _ | INT2<br>DATA DIR | INT2<br>DATA OUT | INT2<br>POLARITY | INT2<br>PRIORITY | INT2<br>ENABLE | INT2 | | P019 | INT3<br>FLAG | INT3<br>PIN DATA | _ | INT3<br>DATA DIR | INT3<br>DATA OUT | INT3<br>POLARITY | INT3<br>PRIORITY | INT3<br>ENABLE | INT3 | | P01A | BUSY | _ | _ | _ | _ | AP | W1W0 | EXE | DEECTL | | P01B | | | | Res | served | • | | | 1 | | P01C | BUSY | VPPS | _ | _ | _ | _ | W0 | EXE | EPCTL | | P01D<br>P01E<br>P01F | | | | Res | served | | | | | | | | | | Digital Port C | ontrol Register | 's | | | | | P020 | | | | Res | served | | | | APORT1 | | P021 | | | P | ort A Control Re | gister 2 (must b | oe 0) | | | APORT2 | | P022 | | | | Port | A Data | | | | ADATA | | P023 | | | | Port A | Direction | | | | ADIR | | P024 | | | | | served | | | | BPORT1 | | P025 | | | P | ort B Control Re | | pe 0) | | | BPORT2 | | P026 | | | | | B Data | | | | BDATA | | P027 | | | | | Direction | | | | BDIR | | P028 | | | | Res | served | | | | CPORT1 | | P029 | _ | _ | _ | _ | _ | _ | _ | Port C Control<br>Register 2<br>(must be 0) | CPORT2 | | P02A | _ | _ | | | | | _ | Port C Data | CDATA | | P02B | _ | _ | _ | _ | _ | _ | _ | Port C<br>Direction | CDIR | | P02C | | Port D Cont | trol Register 1 ( | must be 0) | | _ | _ | _ | DPORT1 | | P02D | | Port D Cont | trol Register 2 ( | must be 0)† | | _ | _ | _ | DPORT2 | | P02E | | | Port D Data | | | _ | _ | _ | DDATA | | P02F | | | Port D Direction | l | | _ | _ | _ | DDIR | <sup>&</sup>lt;sup>†</sup> To configure pin D3 as SYSCLK, set port D control register 2 = 08h. ## **Table 19. Peripheral File Frame Compilation (Continued)** | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | 1 <sub>REG</sub> | |--------------------|----------------------------------|----------------------------------|---------------------------------------|----------------------------------|----------------------|---------------------|---------------------|---------------------|------------------| | | | | | lodule Control | | | | | 1 | | P030 | SPI SW<br>RESET | CLOCK<br>POLARITY | SPI BIT<br>RATE2 | SPI BIT<br>RATE1 | SPI BIT<br>RATE0 | SPI<br>CHAR2 | SPI<br>CHAR1 | SPI<br>CHAR0 | SPICCR | | P031 | RECEIVER<br>OVERRUN | SPI INT<br>FLAG | _ | _ | _ | MASTER/<br>SLAVE | TALK | SPI INT<br>ENA | SPICTL | | P032<br>to<br>P036 | Reserved | | | | | | | | | | P037 | RCVD7 | RCVD6 | RCVD5 | RCVD4 | RCVD3 | RCVD2 | RCVD1 | RCVD0 | SPIBUF | | P038 | | | | Res | served | | | | 1 | | P039 | SDAT7 | SDAT6 | SDAT5 | SDAT4 | SDAT3 | SDAT2 | SDAT1 | SDAT0 | SPIDAT | | P03A<br>to<br>P03C | | | | Res | served | | | | | | P03D | _ | _ | _ | _ | SPICLK<br>DATA IN | SPICLK<br>DATA OUT | SPICLK<br>FUNCTION | SPICLK<br>DATA DIR | SPIPC1 | | P03E | SPISIMO<br>DATA IN | SPISIMO<br>DATA OUT | SPISIMO<br>FUNCTION | SPISIMO<br>DATA DIR | SPISOMI<br>DATA IN | SPISOMI<br>DATA OUT | SPISOMI<br>FUNCTION | SPISOMI<br>DATA DIR | SPIPC2 | | P03F | SPI<br>STEST | SPI<br>PRIORITY | SPI<br>ESPEN | _ | _ | _ | _ | _ | SPIPRI | | | | | Tir | mer Module Re | gister Memory | Мар | | | ] | | | Modes: Dual- | Compare and ( | Capture/Comp | are | | | | | | | P040 | Bit 15 | | | 1Counter MSb | | | | Bit 8 | T1CNTR | | P041 | Bit 7 | | | 1 Counter LSb | | | | Bit 0 | | | P042 | Bit 15 | | | pare Register N | | | | Bit 8 | T1C | | P043 | Bit 7 | | | pare Register I | | | | Bit 0 | T400 | | P044<br>P045 | Bit 15 | | · · · · · · · · · · · · · · · · · · · | Compare Regis | | | | Bit 8 | T1CC | | P045 | Bit 15 | | <u> </u> | Compare Regis | | | | Bit 8 | WDCNTR | | P047 | Bit 7 | | | hdog Counter | | | | Bit 0 | WBONTK | | P048 | Bit 7 | | | atchdog Reset | | | | Bit 0 | WDRST | | P049 | WD OVRFL<br>TAP SEL <sup>†</sup> | WD INPUT<br>SELECT2 <sup>†</sup> | WD INPUT<br>SELECT1 <sup>†</sup> | WD INPUT<br>SELECT0 <sup>†</sup> | _ | T1 INPUT<br>SELECT2 | T1 INPUT<br>SELECT1 | T1 INPUT<br>SELECT0 | T1CTL1 | | P04A | WD OVRFL<br>RST ENA <sup>†</sup> | WD OVRFL<br>INT ENA | WD OVRFL<br>INT FLAG | T1 OVRFL<br>INT ENA | T1 OVRFL<br>INT FLAG | _ | _ | T1<br>SW RESET | T1CTL2 | | | Mode: Dual-C | ompare | | | | | | | 1 | | P04B | T1EDGE<br>INT FLAG | T1C2<br>INT FLAG | T1C1<br>INT FLAG | _ | _ | T1EDGE<br>INT ENA | T1C2<br>INT ENA | T1C1<br>INT ENA | T1CTL3 | | P04C | T1 MODE=0 | T1C1<br>OUT ENA | T1C2<br>OUT ENA | T1C1<br>RST ENA | T1CR<br>OUT ENA | T1EDGE<br>POLARITY | T1CR<br>RST ENA | T1EDGE<br>DET ENA | T1CTL4 | | | Mode: Captur | e/Compare | | | | | | | ] | | P04B | T1EDGE<br>INT FLAG | _ | T1C1<br>INT FLAG | _ | _ | T1EDGE<br>INT ENA | _ | T1C1<br>INT ENA | T1CTL3 | | P04C | T1<br>MODE = 1 | T1C1<br>OUT ENA | _ | T1C1<br>RST ENA | _ | T1EDGE<br>POLARITY | _ | T1EDGE<br>DET ENA | T1CTL4 | <sup>†</sup> Once the WD OVRFL RST ENA bit is set, these bits cannot be changed until a reset; this applies only to the standard watchdog and to simple counter. In the hard watchdog, these bits can be modified at any time; the WD INPUT SELECT2 bits are ignored. ## Table 19. Peripheral File Frame Compilation (Continued) | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | |------|--------------------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|----------| | | Modes: Dual- | Compare and ( | Capture/Comp | are | | | | | | | P04D | _ | _ | - | _ | T1EVT<br>DATA IN | T1EVT<br>DATA OUT | T1EVT<br>FUNCTION | T1EVT<br>DATA DIR | T1PC1 | | P04E | T1PWM<br>DATA IN | T1PWM<br>DATA OUT | T1PWM<br>FUNCTION | T1PWM<br>DATA DIR | T1IC/CR<br>DATA IN | T1IC/CR<br>DATA OUT | T1IC/CR<br>FUNCTION | T1IC/CR DATA<br>DIR | T1PC2 | | P04F | T1 STEST | T1<br>PRIORITY | _ | | _ | _ | _ | _ | T1PRI | | | | | SCI1 I | Module Control | Register Mem | ory Map | | | | | P050 | STOP<br>BITS | EVEN/ODD<br>PARITY | PARITY<br>ENABLE | ASYNC/<br>ISOSYNC | ADDRESS<br>IDLE WUP | SCI<br>CHAR2 | SCI<br>CHAR1 | SCI<br>CHAR0 | SCICCR | | P051 | - | _ | SCI SW<br>RESET | CLOCK | TXWAKE | SLEEP | TXENA | RXENA | SCICTL | | P052 | Rit 15 Raud Pata Salact Pagistar MSR Rit 9 | | | | | | | BAUD<br>MSB | | | P053 | Bit 7 | | | Baud Rate Sele | ct Register LSB | | | Bit 0 | BAUD LSB | | P054 | TXRDY | TX<br>EMPTY | _ | | | _ | _ | SCI TX<br>INT ENA | TXCTL | | P055 | RX<br>ERROR | RXRDY | BRKDT | FE | OE | PE | RXWAKE | SCI RX<br>INT ENA | RXCTL | | P056 | | | | Res | served | | | | | | P057 | | | | Receive Data | Buffer Register | • | | | RXBUF | | P058 | | | | Res | served | | | | | | P059 | | | | Transmit Data | Buffer Register | r | | | TXBUF | | P05A | | | | | | | | | | | P05B | | | | Res | served | | | | | | P05C | | | | | | | | | | | P05D | _ | _ | _ | _ | SCICLK<br>DATA IN | SCICLK<br>DATA OUT | SCICLK<br>FUNCTION | SCICLK<br>DATA DIR | SCIPC1 | | P05E | SCI TXD<br>DATA IN | SCI TXD<br>DATA OUT | SCI TXD<br>FUNCTION | SCI TXD<br>DATA DIR | SCI RXD<br>DATA IN | SCI RXD<br>DATA OUT | SCI RXD<br>FUNCTION | SCI RXD<br>DATA DIR | SCIPC2 | | P05F | SCI<br>STEST | SCI TX<br>PRIORITY | SCI RX<br>PRIORITY | SCI<br>ESPEN | _ | _ | _ | _ | SCIPRI | NOTES: 1. Unless otherwise noted, all voltage values are with respect to VSS. ## recommended operating conditions | | | | MIN | NOM | MAX | UNIT | | |-----|-------------------------------------------|--------------------------------------------|---------------------|------|------|------|--| | V | Supply voltage (see Note 1) | | 4.5 | 5 | 5.5 | V | | | Vcc | RAM data-retention supply voltage (see No | 3 | | 5.5 | V | | | | \/ | Low level input voltage | All pins except MC | V <sub>SS</sub> | | 0.8 | V | | | VIL | Low-level input voltage | MC, normal operation | VSS | | 0.3 | V | | | VIH | High-level input voltage | All_pins except MC, XTAL2/CLKIN, and RESET | 2 | | VCC | V | | | | | XTAL2/CLKIN | 0.8 V <sub>CC</sub> | | Vcc | | | | | | RESET | 0.7 V <sub>CC</sub> | | Vcc | | | | | | EEPROM write protect override (WPO) | 11.7 | 12 | 13 | | | | Vмс | MC (mode control) voltage | EPROM programming voltage (Vpp) | 13 | 13.2 | 13.5 | V | | | | | Microcomputer | VSS | | 0.3 | | | | | | L version | 0 | | 70 | | | | TA | Operating free-air temperature | A version | - 40 | | 85 | °C | | | | | T version | <b>- 40</b> | | 105 | | | NOTES: 1. Unless otherwise noted, all voltage values are with respect to VSS. 3. RESET must be externally activated when VCC or SYSCLK is out of the recommended operating range. <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. <sup>2.</sup> Electrical characteristics are specified with all output buffers loaded with specified I<sub>O</sub> current. Exceeding the specified I<sub>O</sub> current in any buffer can affect the levels on other buffers. # electrical characteristics over recommended operating free-air temperature range (unless otherwise noted) | | PARAMETER | | TEST CONDITIONS | MIN | TYP | MAX | UNIT | | |-----|----------------------------------------------------------------|-----------------------------------------------------|--------------------------------------------|---------------------|------|-----|------|--| | VOL | Low-level output voltage | | I <sub>OL</sub> = 1.4 mA | | | 0.4 | V | | | \/o | High-level output voltage | | I <sub>OH</sub> = -50 μA | 0.9 V <sub>CC</sub> | | | V | | | VOH | nigh-level output voltage | | $I_{OH} = -2 \text{ mA}$ | 2.4 | | | V | | | | | | 0 V < V <sub>I</sub> ≤ 0.3 V | | | 10 | μА | | | | | MC | 0.3 V < V <sub>I</sub> ≤ 13 V | | | 650 | μΑ | | | lį | Input current | Mo | See Note 4<br>12 V ≤ V <sub>I</sub> ≤ 13 V | | | 50 | mA | | | | | $0 \text{ A} \leq \text{A} \leq \text{A} \subset C$ | | | ± 10 | μΑ | | | | loL | Low-level output current | | V <sub>OL</sub> = 0.4 V | 1.4 | | | mA | | | lou | High-level output current | V <sub>OH</sub> = 0.9 V <sub>CC</sub> | - 50 | | | μΑ | | | | ЮН | High-level output current | | V <sub>OH</sub> = 2.4 V | -2 | | | mA | | | | Supply current (operating mode) OSC POWER bit = 0 (see Note 7) | | See Notes 5 and 6<br>SYSCLK = 5 MHz | | 30 | 45 | mA | | | | | | See Notes 5 and 6<br>SYSCLK = 3 MHz | | 20 | 30 | | | | | | See Notes 5 and 6<br>SYSCLK = 0.5 MHz | | 7 | 11 | | | | | | | See Notes 5 and 6<br>SYSCLK = 5 MHz | | 10 | 17 | | | | | ICC | Supply current (STANDBY mode) OSC POWER bit = 0 (see Note 8) | See Notes 5 and 6<br>SYSCLK = 3 MHz | | 8 | 11 | mA | | | | | | | See Notes 5 and 6<br>SYSCLK = 0.5 MHz | | 2 | 3.5 | | | | | Supply current (STANDBY mode) OSC POWER bit = 1 (see Note 9) | | See Notes 5 and 6<br>SYSCLK = 3 MHz | | 6 | 8.6 | A | | | | | | See Notes 5 and 6<br>SYSCLK = 0.5 MHz | | 2 | 3.0 | mA | | | | Supply current (HALT mode) | | See Note 5<br>XTAL2/CLKIN < 0.2 V | | 2 | 30 | μΑ | | NOTES: 4. Input current Ipp is a maximum of 50 mA only during EPROM programming. - 5. Single chip mode, ports configured as inputs or outputs with no load. All inputs $\leq$ 0.2 V or $\geq$ V<sub>CC</sub> 0.2V. - 6. XTAL2/CLKIN is driven with an external square wave signal with 50% duty cycle and rise and fall times less than 10 ns. Current can be higher with a crystal oscillator. At 5 MHz SYSCLK, this extra current = 0.01 mA x (total load capacitance + crystal capacitance in pF). - 7. Maximum operating current = 7.6 (SYSCLK) + 7 mA. - 8. Maximum standby current = 3 (SYSCLK) + 2 mA (OSC POWER bit = 0). - 9. Maximum standby current = 2.24 (SYSCLK) + 1.9 mA (OSC POWER bit = 1, only valid up to 3 MHz SYSCLK). NOTES: A. The crystal/ceramic resonator frequency is four times the reciprocal of the system clock period. B. The values of C1 and C2 are typically 15 pF and C3 value is typically 50 pF. See the manufacturer's recommendations for ceramic resonators. Figure 15. Recommended Crystal/Clock Connections Case 1: $V_O = V_{OH} = 2.4 \text{ V}$ ; Load Voltage = 0 V Case 2: $V_O = V_{OL} = 0.4 \text{ V}$ ; Load Voltage = 2.1 V NOTE A: All measurements are made with the pin loading as shown unless otherwise noted. All measurements are made with XTAL2/CLKIN driven by an external square wave signal with a 50% duty cycle and rise and fall times less than 10 ns unless otherwise stated. Figure 16. Typical Output Load Circuit (See Note A) Figure 17. Typical Buffer Circuitry ## PARAMETER MEASUREMENT INFORMATION ## timing parameter symbology Timing parameter symbols have been created in accordance with JEDEC Standard 100. In order to shorten the symbols, some of the pin names and other related terminology have been abbreviated as follows: | AR | Array | S | Slave mode | |-----|-------------|------|------------| | В | Byte | SC | SYSCLK | | CI | XTAL2/CLKIN | SIMO | SPISIMO | | D | DATA | SOMI | SPISOMI | | M | Master mode | SPC | SPICLK | | PGM | Program | TXD | SCITXD | | R | READ | W | WRITE | | RXD | SCIRXD | | | Lowercase subscripts and their meanings are: | С | cycle time (period) | SU | setup time | |---|---------------------|----|------------------------| | d | delay time | V | valid time | | f | fall time | W | pulse duration (width) | r rise time The following additional letters are used with these meanings: H High Low V Valid All timings are measured between high and low measurement points as indicated in Figure 18 and Figure 19. Figure 18. XTAL2/CLKIN Measurement Points **Figure 19. General Measurement Points** ## external clocking requirements for clock divided by 4 (see Note 10 and Figure 20) | NO. | | PARAMETER | MIN | MAX | UNIT | |-----|-------------------------|---------------------------------------------|-----|-----|------| | 1 | tw(CI) | Pulse duration, XTAL2/CLKIN (see Note 11) | 20 | | ns | | 2 | tr(CI) | Rise time, XTAL2/CLKIN | | 30 | ns | | 3 | t <sub>f</sub> (CI) | Fall time, XTAL2/CLKIN | | 30 | ns | | 4 | <sup>t</sup> d(CIH-SCL) | Delay time, XTAL2/CLKIN rise to SYSCLK fall | | 100 | ns | | | CLKIN | Crystal operating frequency | 2 | 20 | MHz | | | SYSCLK | Internal system clock operating frequency† | 0.5 | 5 | MHz | † SYSCLK = CLKIN/4 NOTES: 10. For $V_{IL}$ and $V_{IH}$ , refer to recommended operating conditions. 11. This pulse may be either a high pulse, which extends from the earliest valid high to the final valid high in an XTAL2/CLKIN cycle, or a low pulse, which extends from the earliest valid low to the final valid low in an XTAL2/CLKIN cycle. Figure 20. External Clock Timing for Divide-by-4 ## external clocking requirements for clock divided by 1 (PLL) (see Note 10 and Figure 21) | NO. | | PARAMETER | MIN | MAX | UNIT | |-----|-------------------------|---------------------------------------------|-----|-----|------| | 1 | tw(CI) | Pulse duration, XTAL2/CLKIN (see Note 11) | 20 | | ns | | 2 | tr(CI) | Rise time, XTAL2/CLKIN | | 30 | ns | | 3 | t <sub>f</sub> (CI) | Fall time, XTAL2/CLKIN | | 30 | ns | | 4 | <sup>t</sup> d(CIH-SCH) | Delay time, XTAL2/CLKIN rise to SYSCLK rise | | 100 | ns | | | CLKIN | Crystal operating frequency | 2 | 5 | MHz | | | SYSCLK | Internal system clock operating frequency‡ | 2 | 5 | MHz | \$\frac{1}{2} SYSCLK = CLKIN/1 NOTES: 10. For V<sub>IL</sub> and V<sub>IH</sub>, refer to recommended operating conditions. 11. This pulse can be either a high pulse, which extends from the earliest valid high to the final valid high in an XTAL2/CLKIN cycle, or a low pulse, which extends from the earliest valid low to the final valid low in an XTAL2/CLKIN cycle. Figure 21. External Clock Timing for Divide-by-1 ## switching characteristics and timing requirements (see Note 12 and Figure 22) | NO. | | PARAMETER | | MIN | MAX | UNIT | |-----|---------|--------------------------------------------------|-----|------------------------|-------------------------|------| | 5 | | t <sub>c</sub> Cycle time, SYSCLK (system clock) | | 200 | 2000 | no | | 5 | ıc | Cycle time, 313CLK (system clock) | 200 | 500 | ns | | | 6 | tw(SCL) | Pulse duration, SYSCLK low | | 0.5 t <sub>C</sub> -20 | 0.5 t <sub>C</sub> | ns | | 7 | tw(SCH) | Pulse duration, SYSCLK high | | 0.5 t <sub>C</sub> | 0.5 t <sub>C</sub> + 20 | ns | NOTE 12: $t_C$ = system-clock cycle time = 1/SYSCLK Figure 22. SYSCLK Timing ## general purpose output signal switching time requirements (see Figure 23) | | | MIN | NOM | MAX | UNIT | |----------------|-----------|-----|-----|-----|------| | t <sub>r</sub> | Rise time | | 30 | | ns | | t <sub>f</sub> | Fall time | | 30 | | ns | Figure 23. Signal Switching Timing ## recommended EEPROM timing requirements for programming | | | MIN | NOM | MAX | UNIT | |-----------|--------------------------------------------------------------------------------|-----|-----|-----|------| | tw(PGM)B | Pulse duration, programming signal to ensure valid data is stored (byte mode) | 10 | | | ms | | tw(PGM)AR | Pulse duration, programming signal to ensure valid data is stored (array mode) | 20 | | | ms | ## recommended EPROM operating conditions for programming | | | | MIN | NOM | MAX | UNIT | |--------|----------------------------------------------------------|-------------|------|------|------|------| | VCC | Supply voltage | | 4.75 | 5.5 | 6 | V | | Vpp | Supply voltage at MC pin | | 13 | 13.2 | 13.5 | V | | IPP | Supply current at MC pin during programming (Vpp = 13 V) | | | 30 | 50 | mA | | SYSCLK | Custom sleek | Divide-by-4 | 0.5 | | 50 | | | SYSCLK | System clock | Divide-by-1 | 2 | 5 | MHz | | ## recommended EPROM timing requirements for programming | | | MIN | NOM | MAX | UNIT | |----------|--------------------------------------------------|------|------|-----|------| | tw(EPGM) | Pulse duration, programming signal (see Note 13) | 0.40 | 0.50 | 3 | ms | NOTE 13: Programming pulse is active when both EXE (EPCTL.0) and VPPS (EPCTL.6) are set. ## SPI master mode external timing characteristics and requirements (see Note 12 and Figure 24) | NO. | | | MIN | MAX | UNIT | |-----|-----------------------------|-----------------------------------------------------------------|---------------------------|----------------------------|------| | 38 | tc(SPC)M | Cycle time, SPICLK | 2t <sub>C</sub> | 256t <sub>C</sub> | ns | | 39 | tw(SPCL)M | Pulse duration, SPICLK low | t <sub>C</sub> - 45 | 0.5t <sub>C</sub> (SPC)+45 | ns | | 40 | tw(SPCH)M | Pulse duration, SPICLK high | t <sub>C</sub> – 55 | 0.5t <sub>C</sub> (SPC)+45 | ns | | 41 | td(SPCL-SIMOV)M | Delay time, SPISIMO valid after SPICLK low (polarity = 1) | <b>- 65</b> | 50 | ns | | 42 | tv(SPCH-SIMO)M | Valid time, SPISIMO data valid after SPICLK high (polarity =1) | tw(SPCH) - 50 | | ns | | 43 | tsu(SOMI-SPCH)M | Setup time, SPISOMI to SPICLK high (polarity = 1) | 0.25 t <sub>C</sub> + 150 | | ns | | 44 | t <sub>V</sub> (SPCH-SOMI)M | Valid time, SPISOMI data valid after SPICLK high (polarity = 1) | 0 | | ns | NOTE 12: $t_C$ = system-clock cycle time = 1/SYSCLK NOTE A: The diagram is for polarity = 1. SPICLK is inverted when polarity = 0. Figure 24. SPI Master External Timing ## SPI slave mode external timing characteristics and requirements (see Note 12 and Figure 25) | NO. | | | MIN | MAX | UNIT | |-----|-----------------------|----------------------------------------------------------------|-----------------------|-----------------------------|------| | 45 | t <sub>C</sub> (SPC)S | Cycle time, SPICLK | 8t <sub>C</sub> | | ns | | 46 | tw(SPCL)S | Pulse duration, SPICLK low | 4t <sub>C</sub> - 45 | 0.5t <sub>C</sub> (SPC)S+45 | ns | | 47 | tw(SPCH)S | Pulse duration, SPICLK high | 4t <sub>C</sub> - 45 | 0.5t <sub>C</sub> (SPC)S+45 | ns | | 48 | td(SPCL-SOMIV)S | Delay time, SPISOMI valid after SPICLK low (polarity = 1) | | 3.25t <sub>C</sub> + 130 | ns | | 49 | tv(SPCH-SOMI)S | Valid time, SPISOMI data valid after SPICLK high (polarity =1) | tw(SPCH)S | | ns | | 50 | tsu(SIMO-SPCH)S | Setup time, SPISIMO to SPICLK high (polarity = 1) | 0 | | ns | | 51 | tv(SPCH-SIMO)S | Valid time, SPISIMO data after SPICLK high (polarity = 1) | 3t <sub>C</sub> + 100 | | ns | NOTE 12: $t_C$ = system-clock cycle time = 1/SYSCLK NOTE A: The diagram is for polarity = 1. SPICLK is inverted when polarity = 0. Figure 25. SPI Slave External Timing # SCI1 isosynchronous $^\dagger$ mode timing characteristics and requirements for internal clock (see Note 12 and Figure 26) | NO. | | | MIN | MAX | UNIT | |-----|---------------------------|-------------------------------------------------|---------------------------|----------------------------|------| | 24 | t <sub>C</sub> (SCC) | Cycle time, SCICLK | 2t <sub>C</sub> | 131 072t <sub>C</sub> | ns | | 25 | tw(SCCL) | Pulse duration, SCICLK low | t <sub>C</sub> – 45 | 0.5t <sub>C</sub> (SCC)+45 | ns | | 26 | tw(SCCH) | Pulse duration, SCICLK high | t <sub>C</sub> – 45 | 0.5t <sub>C</sub> (SCC)+45 | ns | | 27 | td(SCCL-TXDV) | Delay time, SCITXD valid after SCICLK low | - 50 | 60 | ns | | 28 | tv(SCCH-TXD) | Valid time, SCITXD data valid after SCICLK high | tw(SCCH) - 50 | | ns | | 29 | t <sub>su(RXD-SCCH)</sub> | Setup time, SCIRXD to SCICLK high | 0.25 t <sub>C</sub> + 145 | | ns | | 30 | t <sub>V</sub> (SCCH-RXD) | Valid time, SCIRXD data valid after SCICLK high | 0 | | ns | NOTE 12: t<sub>C</sub> = system-clock cycle time = 1/SYSCLK Figure 26. SCI1 Isosynchronous Mode Timing for Internal Clock <sup>†</sup> Isosynchronous = Isochronous # SCI1 isosynchronous<sup>†</sup> mode timing characteristics and requirements for external clock (see Note 12 and Figure 27) | NO. | | | MIN | MAX | UNIT | |-----|---------------------------|-------------------------------------------------|--------------------------|--------------------------|------| | 31 | t <sub>C</sub> (SCC) | Cycle time, SCICLK | 10t <sub>C</sub> | | ns | | 32 | tw(SCCL) | Pulse duration, SCICLK low | 4.25t <sub>C</sub> + 120 | | ns | | 33 | tw(SCCH) | Pulse duration, SCICLK high | t <sub>C</sub> + 120 | | ns | | 34 | td(SCCL-TXDV) | Delay time, SCITXD valid after SCICLK low | | 4.25t <sub>C</sub> + 145 | ns | | 35 | t <sub>V</sub> (SCCH-TXD) | Valid time, SCITXD data valid after SCICLK high | tw(SCCH) | | ns | | 36 | t <sub>su(RXD-SCCH)</sub> | Setup time, SCIRXD to SCICLK high | 40 | | ns | | 37 | t <sub>V</sub> (SCCH-RXD) | Valid time, SCIRXD data after SCICLK high | 2t <sub>C</sub> | | ns | NOTE 12: t<sub>C</sub> = system-clock cycle time = 1/SYSCLK Figure 27. SCI1 Isosynchronous<sup>†</sup> Timing for External Clock <sup>†</sup> Isosynchronous = Isochronous Table 20 is designed to aid the user in referencing a device part number to a mechanical drawing. The table shows a cross-reference of the device part number to the TMS370 generic package name and the associated mechanical drawing by drawing number and name. Table 20. TMS370Cx2x Family Package Type and Mechanical Cross-Reference | PKG TYPE<br>(mil pin spacing) | TMS370 GENERIC NAME | PKG TYPE NO. AND<br>MECHANICAL NAME | DEVICE PART NUMBERS | |--------------------------------------|------------------------------------------------|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | FN – 44 pin<br>(50-mil pin spacing) | PLASTIC LEADED CHIP CARRIER (PLCC) | FN(S-PQCC-J**) PLASTIC J-LEADED<br>CHIP CARRIER | TMS370C020AFNA TMS370C020AFNL TMS370C020AFNT TMS370C022AFNA TMS370C022AFNL TMS370C022AFNT TMS370C320AFNA TMS370C320AFNL TMS370C320AFNL TMS370C322AFNA TMS370C322AFNA TMS370C322AFNL TMS370C322AFNL TMS370C322AFNL TMS370C322AFNL TMS370C322AFNT TMS370C722FNT | | FZ – 44 pin<br>(50-mil pin spacing) | CERAMIC LEADED CHIP CARRIER (CLCC) | FZ(S-CQCC-J**) J-LEADED CERAMIC<br>CHIP CARRIER | SE370C722FZT | | JD – 40 pin<br>(100-mil pin spacing) | CERAMIC DUAL-IN-LINE PACKAGE (CDIP) | JD(R-CDIP-T**) CERAMIC SIDE-BRAZE<br>DUAL-IN-LINE PACKAGE | SE370C722JDT | | N – 40 pin<br>(100-mil pin spacing) | PLASTIC DUAL-IN-LINE PACKAGE<br>(PDIP) | N(R-PDIP-T**) PLASTIC DUAL-IN-LINE<br>PACKAGE | TMS370C020ANA TMS370C020ANL TMS370C020ANT TMS370C022ANA TMS370C022ANL TMS370C022ANT TMS370C320ANA TMS370C320ANL TMS370C320ANT TMS370C322ANA TMS370C322ANA TMS370C322ANL TMS370C322ANL TMS370C322ANL TMS370C322ANT TMS370C722NT | | JC – 40 pin<br>(70-mil pin spacing) | CERAMIC SHRINK DUAL-IN-LINE<br>PACKAGE (CSDIP) | JC(R-CDIP-T40) CERAMIC SIDE-BRAZE<br>DUAL-IN-LINE PACKAGE | SE370C722JCT | | NJ – 40 pin<br>(70-mil pin spacing)† | PLASTIC SHRINK DUAL-IN-LINE<br>PACKAGE (PSDIP) | NJ(R-PDIP-T**) PLASTIC SHRINK<br>DUAL-IN-LINE PACKAGE | TMS370C020ANJA TMS370C020ANJL TMS370C020ANJT TMS370C022ANJA TMS370C022ANJL TMS370C022ANJT TMS370C320ANJA TMS370C320ANJL TMS370C320ANJL TMS370C322ANJA TMS370C322ANJA TMS370C322ANJL TMS370C322ANJL TMS370C322ANJL TMS370C322ANJT TMS370C322ANJT TMS370C322ANJT | <sup>†</sup> NJ formerly known as N2; the mechanical drawing of the NJ is identical to the N2 package and did not need to be requalified. ## FN (S-PQCC-J\*\*) #### 20 PIN SHOWN #### PLASTIC J-LEADED CHIP CARRIER - B. This drawing is subject to change without notice. - C. Falls within JEDEC MS-018 ## FZ (S-CQCC-J\*\*) #### 28 LEAD SHOWN #### J-LEADED 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 ceramic lid using glass frit. 4040219/B 03/95 ## JC (R-CDIP-T40) ## **CERAMIC SIDE-BRAZE DUAL-IN-LINE PACKAGE** - 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. ## JD (R-CDIP-T\*\*) # CERAMIC SIDE-BRAZE DUAL-IN-LINE PACKAGE - 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. ## N (R-PDIP-T\*\*) #### 24 PIN SHOWN #### PLASTIC DUAL-IN-LINE PACKAGE - B. This drawing is subject to change without notice. - C. Falls within JEDEC MS-011 - D. Falls within JEDEC MS-015 (32 pin only) ## NJ (R-PDIP-T\*\*) #### PLASTIC SHRINK DUAL-IN-LINE PACKAGE #### **40 PIN SHOWN** NOTES: A. All linear dimensions are in inches (millimeters). B. This drawing is subject to change without notice. #### **IMPORTANT NOTICE** Texas Instruments and its subsidiaries (TI) reserve the right to make changes to their products or to discontinue any product or service without notice, and advise customers to obtain the latest version of relevant information to verify, before placing orders, that information being relied on is current and complete. All products are sold subject to the terms and conditions of sale supplied at the time of order acknowledgement, including those pertaining to warranty, patent infringement, and limitation of liability. TI warrants performance of its semiconductor products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems necessary to support this warranty. Specific testing of all parameters of each device is not necessarily performed, except those mandated by government requirements. CERTAIN APPLICATIONS USING SEMICONDUCTOR PRODUCTS MAY INVOLVE POTENTIAL RISKS OF DEATH, PERSONAL INJURY, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE ("CRITICAL APPLICATIONS"). TI SEMICONDUCTOR PRODUCTS ARE NOT DESIGNED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS. INCLUSION OF TI PRODUCTS IN SUCH APPLICATIONS IS UNDERSTOOD TO BE FULLY AT THE CUSTOMER'S RISK. In order to minimize risks associated with the customer's applications, adequate design and operating safeguards must be provided by the customer to minimize inherent or procedural hazards. TI assumes no liability for applications assistance or customer product design. TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor products or services might be or are used. TI's publication of information regarding any third party's products or services does not constitute TI's approval, warranty or endorsement thereof. Copyright © 1998, Texas Instruments Incorporated