- CMOS/EEPROM/EPROM Technologies on a Single Device - Mask ROM Devices for High Volume Production - One-Time Programmable (OTP) Devices for Low Volume Production - Reprogrammable EPROM Devices for Prototyping Purposes - Flexible Operating Features - Power-Reduction STANDBY and HALT Modes - Commercial and Industrial Temperature Ranges - Input Clock Frequency 2 MHz to 20 MHz - Voltage (V<sub>CC</sub>) 5 V ± 10% - Internal System Memory Configurations - On-Chip Program Memory Versions - ROM, 4K-Bytes or 8K-Bytes - EPROM, 8K-Bytes - Data EEPROM, 256 Bytes - Static RAM, 256 Bytes Usable as Registers - Eight Bit A/D Converter - 4 Channels in 40-Pin Packages - 8 Channels in 44-Pin Packages - Two 16-Bit General Purpose Timers - Software Configurable as Two 16-Bit Event Counters, or Two 16-Bit Pulse Accumulators, or Three 16-Bit Input Capture Functions, or Four Compare Registers, or Two Self-Contained PWM Functions - Software Programmable Input Polarity - One Timer Has an 8-Bit Prescaler, Providing a 24-Bit Realtime Timer - On-Chip 24-Bit Watchdog Timer - Serial Communications Interface (SCI) - Asynchronous and Isosynchronous Modes - Full Duplex, Double Buffered Rx and Tx - Two Multiprocessor Communications Formats - CMOS/TTL Compatible I/O Pins - All Peripheral Function Pins Software Configurable for Digital I/O - 40-Pin Plastic and Ceramic Dual-In-Line Packages - 27 Bidirectional, 5 Input Pins - 44-Pin Plastic and Ceramic Leaded Chip Carrier Packages - 27 Bidirectional, 9 Input Pins # J, N AND N2 PACKAGES† (TOP VIEW) # FN AND FZ PACKAGES† (TOP VIEW) - † Packages are shown for pinout reference only. - Flexible Interrupt Handling - Two S/W Programmable Interrupt Levels - Global and Individual Interrupt Masking - Programmable Rising or Falling Edge Detect - TMS370 Series Compatibility - Register-to-Register Architecture - 256 General-Purpose Registers - 14 Powerful Addressing Modes - PC-Based Workstation Development Support Emphasizes Productivity, Featuring: - C Compiler Support - Realtime In-Circuit Emulation - C Source Debug - Extensive Breakpoint/Trace Capability - Software Performance Analysis - Multi-Window User Interface - EEPROM/EPROM Programming Texas 🛡 Instruments Copyright © 1992, Texas Instruments Incorporated #### description The TMS370C040, TMS370C042, TMS370C340, TMS370C342, TMS370C642, and TMS370C742 devices are members of the TMS370 family of single-chip 8-bit microcontrollers. The TMS370 family provides cost-effective realtime system control through VLSI integration of advanced peripheral function on-chip memory configurations. The TMS370Cx4x family is implemented using high-performance silicon-gate CMOS technology. The 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 TMS370Cx4x devices attractive in system designs for automotive electronics, industrial motor, computer peripheral control, and telecommunications. Unless otherwise noted, the term TMS370Cx4x refers to the TMS370C040, TMS370C042, TMS370C340, TMS370C342, TMS370C642 and TMS370C742 for all peripheral function modules available on those devices. All TMS370Cx4x devices contain a minimum of the following on-chip peripheral modules: - 256 bytes RAM (usable as registers) - 8-channel (for 44 pin device) or 4-channel (for 40 pin device) 8-bit Analog-to-Digital converter (A/D) - Serial Communications Interface (SCI) - Two 24-bit general-purpose timers, one of which can be used as a Watchdog timer - One 16-bit general-purpose timer The following table provides an overview of the various memory configurations of the TMS370Cx4x devices. #### **Memory Configurations** | DEVICES | PROGRAM MEI | MORY (BYTES) | DATA MEMO | DATA MEMORY (BYTES) | | | |------------------------|-------------|--------------|-----------|---------------------|-------------------------------------------|--| | DEVICES | ROM | OM EPROM RAM | | EEPROM | PIN/PACKAGES | | | TMS370C040 | 4K | _ | 256 | 256 | 44 / FN-PLCC<br>40 / N-DIP<br>40 / N2-DIP | | | TMS370C042 | 8K | | 256 | 256 | 44 / FN-PLCC<br>40 / N-DIP<br>40 / N2-DIP | | | TMS370C340 | 4K | _ | 256 | | 44 / FN-PLCC<br>40 / N-DIP<br>40 / N2-DIP | | | TMS370C342 | 8K | _ | 256 | _ | 44 / FN-PLCC<br>40 / N-DIP<br>40 / N2-DIP | | | TMS370C642 | | 8K | 256 | _ | 44 / FN-PLCC<br>40 / N-DIP<br>40 / N2-DIP | | | TMS370C742 | _ | 8K | 256 | 256 | 44 / FN-PLCC<br>40 / N-DIP<br>40 / N2-DIP | | | SE370C742 <sup>†</sup> | | 8K | 256 | 256 | 44 / FZ-CLCC<br>40 / J-CDIP | | <sup>†</sup> System evaluators and development tools are for use only in a prototype environment and their reliability has not been characterized. The 4K-bytes and 8K-bytes of mask-programmable ROM in the TMS370C040, TMS370C042, TMS370C340 and TMS370C342 are replaced in the TMS370C642 and TMS370C742 with 8K-bytes of EPROM while all other available memory and on-chip peripherals are identical, with the exception of no data EEPROM on the TMS370C340, TMS370C342, and TMS370C642 devices. OTP (TMS370C642 and TMS370C742) devices and the reprogrammable device (SE370C742) are the two versions of the TMS370Cx4x family that have 8K of EPROM program memory with a superset of the memory and peripherals of all the other family members with the same pin-out. TMS370C642 and TMS370C742 (OTP) devices are in plastic packages and can be programmed one time. This is an effective microcomputer to use for immediate production updates for other members of the TMS370Cx4x family or for low volume production runs that cannot satisfy minimum volume or cycle time for the low-cost mask ROM devices. The SE370C742 has a windowed ceramic package to allow reprogramming of the program EPROM memory during the development prototyping phase of design. These SE370C742 devices allow quick updates to breadboards and prototype systems while iterating initial designs. The TMS370Cx4x provides two power reduction modes (STANDBY and HALT) for applications where low power consumption is critical. Both modes stop all CPU activity (i.e., 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 powerdown modes. The TMS370Cx4x 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 TMS370Cx4x family is fully instruction-set-compatible, allowing easy transition between members. The TMS370Cx4x family offers an 8-channel with 8-bit accuracy Analog-to-Digital converter for the 44-pin PLCC packages and also offers 4-channel Analog-to-Digital for the 40-pin DIP packages. The 33-µs conversion time at 20 MHz and the variable sample period, combined with selectable positive reference voltage sources, turn real-world analog signals into digital data. The Serial Communications Interface (SCI) module is a built-in serial interface that can be programmed to be asynchronous or isosynchronous to give three methods of serial communications. The SCI allows standard RS-232-C communications with other common data transmission equipment. The CPU takes no part in serial communications except to write data to be transmitted to a register and to read received data from a register. The TMS370Cx4x family provides the system designer with very economical, efficient solutions to real time control applications. The TMS370 family eXtended Development System (XDS) solves the challenge of efficiently developing the software and hardware required to design the TMS370Cx4x into an ever-increasing number of complex applications. The application source code can be written in assembly and C languages, and the output code can be generated by the linker. The TMS370 family XDS communicates via a standard RS-232-C interface with an existing personal computer to form a PC-DOS hosted workstation. This allows the use of the PC's editors and software utilities already familiar to the designer. The TMS370 C source debugger emphasizes ease-of-use through extensive use of menus and screen windowing so that a system designer can begin developing software with minimum training. The C source debugger allows the system designers to debug their programs in the language they were written. This can be C, assembly, or both. Precise realtime in-circuit emulation and extensive symbolic debug and analysis tools ensure efficient software and hardware implementation, as well as reducing the time-to-market cycle. The TMS370Cx4x family together with the TMS370 family XDS for applications development, the SE370C742 reprogrammable devices, comprehensive product documentation, and customer support provide a complete solution for the needs of the system designer. The TMS370Cx4x family members are available in three package types: 44-pin PLCC (FN), 40-pin DIP (N) and 40-pin shrink DIP (N2). The shrink DIP package is the same width as the standard 40-pin DIP (0.600") but the space between pins is reduced from 0.100" to 0.070". This results in a 30% board space savings yielding a 40-pin package the size of a standard 28-pin DIP. # functional block diagram # **Terminal Functions** | | PIN | | | | |-----------------------|------------|--------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | N | o. | | DECODE TELEVISION | | | DIP (40) | PLCC<br>(44) | 1/0 | DESCRIPTION | | A0 | 18 | 20 | I/O | Port A pins are general purpose bidirectional I/O ports. | | A1 | 17 | 19 | 1/0 | | | A2 | 16 | 18 | I/O | | | A3 | 15 | 17 | I/O | | | A4 | 14 | 16 | 1/0 | | | A5 | 13 | 15 | 1/0 | | | A6 | 11 | 13 | 1/0 | | | A7 | 10 | 12 | 1/0 | | | B0 | 39 | 44 | 1/0 | Port B pins are general purpose bidirectional I/O ports. | | B1 | 40 | 1 | 1/0 | | | B2 | 1 | 2 | I/O | | | D3 | 21 | 23 | I/O | Port D pins are general purpose bidirectional I/O ports. | | D4 | 20 | 22 | 1/0 | D3 also configurable as CLKOUT (see Note 1) | | <b>D</b> 5 | 35 | 40 | 1/0 | | | D6 | 22 | 24 | 1/0 | | | D7 | 19 | 21 | 1/0 | | | ANO/E0 | _ | 25 | 1 | A/D analog input channels or positive reference pins. | | AN1/E1 | l <u> </u> | 26 | l i | | | AN2/E2 | 23 | 27 | li | | | AN3/E3 | 24 | 28 | | | | AN4/E4 | <b>!</b> — | 30 | 1 | | | AN5/E5 | 1 — | 31 | 1 | | | AN6/E6 | 27 | 32 | 1 | Any A/D channel may be programmed as general purpose input pins (E port) if not used | | AN7/E7 | 28 | 33 | 1 | as an analog input or reference channel. | | V <sub>CC3</sub> | 26 | 11 | | A/D converter positive supply voltage and optional positive reference input pin. | | V <sub>SS3</sub> | 25 | 29 | | A/D converter ground supply and low reference input pin. | | INT1 | 6 | 7 | | External non-maskable or maskable interrupt/General purpose input pin. | | INT2 | 7 | 8 | 1/0 | External maskable interrupt input/General purpose bidirectional pin. | | INT3 | 8 | 9 | 1/0 | External maskable interrupt input/General purpose bidirectional pin. | | T1IC/CR | 31 | 36 | 1/0 | Timer 1 input Capture/Counter Reset input pin/General purpose bidirectional pin. | | T1PWM | 30 | 35 | 1/0 | Timer 1 Pulse-Width-Modulation output pin/General purpose bidirectional pin. | | T1EVT | 29 | 34 | 1/0 | Timer 1 External Event input pin/general purpose bidirectional pin. | | T2IC1/CR | 4 | 5 | 1/0 | Timer 2 input Capture/Counter Reset input pin/General purpose bidirectional pin. | | T2IC1/CH<br>T2IC2/PWM | 1 | 4 | 1/0 | Timer 2 input Capture/Counter Reset input pin/deneral purpose bidirectional pin. Timer 2 input Capture 2/PWM output pin/General purpose bidirectional pin. | | T2EVT | 3 2 | 3 | 1/0 | Timer 2 External Event input pin/General purpose bidirectional pin. | | | | <b>-</b> | | | | SCITXD | 38 | 43 | 1/0 | SCI Transmit Data Output pin/General purpose bidirectional pin. | | SCIRXD | 37 | 42 | 1/0 | SCI Receive Data input pin/General purpose bidirectional pin. SCI bidirectional Serial Clock pin/General purpose bidirectional pin. | | SCICLK | 36 | 41 | 1/0 | | | RESET | 5 | 6 | 1/0 | System reset bidirectional pin. As input it initializes microcontroller; as open-drain output it indicates an internal failure was detected by the Watchdog or Oscillator Fault circuit. | | MC | 34 | 39 | | Mode control input pin; enables the EEPROM Write Protection Override (WPO) mode. | | XTAL1 | 32 | 37 | | Internal oscillator output for crystal | | XTAL2/CLKIN | 33 | 38 | 0 | Internal oscillator crystal input/external clock source input | | | 9 | 10 | t | Positive supply voltage. | | V <sub>CC</sub> | 12 | 14 | | Ground reference. | | V <sub>SS</sub> | 1 '2 | <u> </u> | <u></u> | Ground receive. | NOTE 1: Each pin associated with Interrupt 2, Interrupt 3, Timer 1, Timer 2 and SCI functional blocks may be individually programmed as a general purpose bidirectional pin if it is not used for its primary block function. Unused A/D input channel pins may be programmed as a general purpose input only pins. D3 may be configured as CLKOUT by appropriately programming the DPORT1 and DPORT2 registers. ## memory map The TMS370 family architecture is based on the Von Neumann 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 1, the TMS370 family provides memory-mapped RAM, ROM, EEPROM, input/output pins, and peripheral functions. The peripheral file contains all input/output port control, peripheral status and control, EPROM memory programming, and system-wide control functions. The peripheral file is located between 1010h to 107Fh and is logically divided into 6 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. The TMS370Cx4x has 5 peripheral frames and a system control frame assigned to Peripheral File Frames 1, 2, 4, 5, 6, and 7. Figure 1. TMS370Cx4x Memory Map #### memories #### RAM / register file The TMS370Cx4x has 256 bytes of static RAM, which serve as both the CPU register file and general-purpose memory. The RAM is treated as registers by the instruction set and is referenced as R0 through R255. The first two registers, R0 and R1, are also called the A and B registers, respectively. The stack is located in the RAM, and operates as a last-in first-out read/write memory. It is used to store the return address on subroutine calls and the status register during interrupts. Accessing this memory as registers is performed in one system clock cycle (t<sub>c</sub>), while general-purpose memory access is performed in two system clock cycles. Instructions may be executed from RAM. This versatility enables the internal RAM to be used for functions such as microcontroller self-test, diagnostics, or system test of the end application. The user may load external programs or data into the RAM by incorporating a simple bootstrap loader in the program memory. #### data EEPROM The TMS370Cx4x family has 256 bytes of on-chip Electrically Erasable Programmable ROM (EEPROM), addressed as 256 consecutive bytes mapped from locations 1F00h to 1FFFh. The data EEPROM provides nonvolatile programmable storage for items such as calibration constants and configuration information for personalization of a generic program ROM/EPROM algorithm for use in specific end applications. The data EEPROM supports bit, byte, and block write/erase modes. Instructions may be executed from the data EEPROM, providing additional program space and the ability to patch algorithms by placing a branch table for volatile routines in the data EEPROM. The data EEPROM uses the 5-V V<sub>CC</sub> supply voltage and provides the programming voltage via an internal dedicated generator, eliminating the need for an external high-voltage programming source. The dedicated voltage generator optimizes the programming voltage characteristics, increasing the reliability as well as extending the write/erase endurance of the array. Programming control and status monitoring are performed through the data EEPROM control register (DEECTL) in the peripheral file. An EEPROM write/erase operation is performed in the following sequence: - Perform normal memory write to the target EEPROM location. - Write to DEECTL control register to select WRITE1/WRITE0 and set the EXECUTE (EXE) bit to 1. - 3. Wait for program time to elapse $[t_{w(PGM)B} \text{ or } t_{w(PGM)AR}]$ . - 4. Write to DEECTL control register to set the EXECUTE (EXE) bit to 0. The WRITE1/WRITE0 control bit selects whether the zeros or the ones in the data byte are to be programmed into the selected EEPROM location. For example, a WRITE1 operation will program ones into all bit positions within the EEPROM byte that have ones in the data byte, while bits that are zero in the data byte will not affect the EEPROM contents. The WRITE1 operation effectively performs a logical OR of the information previously stored on the EEPROM byte with the data byte. The WRITE0 operation effectively performs a logical AND between these two bytes. Single bit programming within an EEPROM byte is performed by writing only the zeros or ones of the data byte. The EEPROM programming algorithm may use this bit-programming capability to optimize the life of the EEPROM. When a data value cannot be achieved by writing only zeros or only ones into the EEPROM byte, a WRITE1 followed by a WRITE0 will program any data value into the EEPROM byte, regardless of the previous data stored at that location. Data EEPROM read accesses are performed as normal memory read operations in two system clock cycles. A memory read cycle to any EEPROM location while EXECUTE = 1 returns the value currently being written to the EEPROM. Following an EEPROM write operation, the EEPROM voltages must stabilize prior to performing an EEPROM read operation. The BUSY FLAG indicates the status of the EEPROM voltage. When set, the EEPROM is not ready for a read operation. The BUSY FLAG is reset to 0 by the EEPROM control logic when 128 system clock cycles have elapsed following the EXECUTE bit being set to 0. If an EEPROM read operation is performed while BUSY = 1, automatic WAIT states will be generated until BUSY = 0, and then the read operation will be performed. Figure 2. Write Protect Register for TMS370x4x Devices With A 256-Byte Data EEPROM Array Bytes within the data EEPROM may be protected from inadvertent overwriting of critical information. As shown in Figure 2, the 8-bit Write Protect Register (WPR), located at 1F00h within the data EEPROM, provides write protection for the 256-byte data EEPROM, segmenting the array into eight blocks of 32 bytes each. Each of these 32-byte blocks may be individually write- and erase-protected by setting the corresponding bit to 1 in the appropriate WPR. Since the WPRs reside in the array in BLKO, the WPR may also be write-protected, thereby increasing the system reliability by preventing bytes from being reprogrammed. Bytes left unprotected may be written to by the normal EEPROM programming sequence. The Write Protection Override (WPO) mode enables data to be written to any location in the data EEPROM, regardless of the WPR contents. Enter the WPO mode by placing 12 V on the MC pin. The WPO mode is typically used in a service environment to update the protected EEPROM contents. All unprotected bytes within the data EEPROM array may be programmed during a single EEPROM programming cycle by setting the ARRAY PROG bit of DEECTL to 1 at the start of the programming cycle. #### program ROM The program ROM consists of 4K- or 8K-bytes of mask programmable read-only memory. The program ROM is used for permanent storage of data or instructions, with read operations performed in two system clock cycles. Memory addresses 7FECh through 7FFFh are reserved for interrupt and reset vectors. Trap vectors, used with TRAP0 through TRAP15 instructions, are located between addresses 7FC0h and 7FDFh. Programming of the mask ROM is performed at the time of device fabrication. # program EPROM (TMS370C642, TMS370C742, and SE370C742 only) The program EPROM of the TMS370C642, TMS370C742, and SE370C742 is an 8K electrically programmable read-only memory, addressed as 8K consecutive bytes mapped from location 6000h to 7FFFh. It provides application performance identical to the TMS370Cx4x mask ROM devices. Program instructions are read from the program EPROM in two system clock cycles, providing the prototyping capability of the mask program ROM. An external supply (V<sub>PP</sub>) is needed at the MC pin to provide the necessary programming voltage (V<sub>PP</sub>). Programming is controlled through a register (EPCTL) in the peripheral file. The TMS370C642 and TMS370C742 each come in a plastic package and cannot be erased. They are one-time-programmable (OTP) devices. The SE370C742 comes in ceramic package with a quartz window. Before programming, the SE370C742's EPROM is erased by exposing the device through the transparent window to high-intensity ultraviolet light (wavelength 2537Å). The recommended minimum exposure dose (UV intensity × exposure time) is 15 W•s/cm<sup>2</sup>. A typical 12-mW/cm<sup>2</sup>, filterless UV lamp will erase the device in 21 minutes. The lamp should be located about 2.5 cm above the chip during erasure. After erasure, the entire array is in a logic 1 state. A programmed 0 can be erased to a 1 only by exposure to ultraviolet light. It should be noted that normal ambient light contains the correct wavelength for erasure. When using the SE370C742, the window should be covered with an opaque label. All devices are erased to logic 1 when delivered from the factory. #### CAUTION Exposing the EPROM module to ultraviolet light may also cause erasure in any EEPROM module. Any useful data stored in the EEPROM must be reprogrammed after exposure to UV light. Programming 0 to the EPROM is controlled by the EPCTL register via the EXE bit and the VPPS bit. The EXE bit initiates EPROM programming when set and disables programming when cleared. The VPPS bit connects the programming voltage VPP at the MC pin to the EPROM module. VPPS (EPCTL.6) and EXE (EPCTL.0) should be set separately, and the VPPS bit should be set at least two microseconds before the EXE bit is set. After programming, the application programming should wait for four microseconds before any read attempt is made. The programming operation (see Figure 3) is performed in the following recommended sequence: - 1. Supply the programming voltage to the MC pin. - 2. Write to EPCTL register to set the VPPS bit to 1. - Perform normal memory write register to the target EPROM location. - Write to EPCTL register to set the EXE bit to 1. (Wait at least two microseconds after step 2.) - Wait for program time to elapse (one millisecond). - Write to EPCTL register to clear the EXE bit (leave VPPS bit set to 1). - Read the byte being programmed; if correct data is not read, repeat steps 4 through 6 X times up to a maximum of 25. - Write to EPCTL register to set the EXE bit to 1 for final programming. - Wait for program time to elapse (3X milliseconds duration). - 10. Write to EPCTL register to clear the EXE and VPPS bits. An external power supply at $V_{PP}$ I<sub>PP</sub> (30 mA) is required for programming operations. Programming voltage $V_{PP}$ is supplied via the MC pin. This also automatically puts the microcontroller in the Write Protection Override (WPO) mode. Programming voltage may be applied via the MC pin anytime after $\overline{RESET}$ and will remain at $V_{PP}$ after programming (after the EXECUTE bit is cleared). Applying programming voltage while $\overline{RESET}$ is active will put the microcontroller in reserved mode, where programming operation is inhibited. Figure 3. EPROM Programming Operation # write protection of program EPROM To override the EPROM write protection, the $V_{PP}$ voltage must be applied to the MC pin and the VPPS bit (EPCTL.6) must be set. This dual requirement ensures that the program EPROM will not accidentally be overwritten during the data EEPROM operations when $V_{PP}$ is applied to the MC pin. The data EEPROM may be programmed when the VPPS bit is set. ## central processing unit The central processing unit (CPU) of the TMS370 series is an enhanced version of the TMS7000 Family CPU. The enhancements include additional user instructions such as integer divide, conditional jump instructions based on the overflow status bit, and addressing modes such as stack-pointer-relative addressing for subroutine parameter passing. The efficient register-to-register architecture of the TMS7000 family has been carried over to the TMS370 family, which avoids the conventional accumulator bottleneck. The complete TMS370 family instruction set is summarized in the table, *TMS370 Instruction Set Summary*, beginning on page 39. In addition to the interpretation and execution of the user program, the CPU performs the functions of bus protocol generation and interrupt priority arbitration. While the CPU is implemented independent of the memory, input/output, and peripheral modules, it performs the central system control function through communications with these on-chip modules and external memory and peripherals. The TMS370 family CPU registers accessible to the programmer are shown in Figure 4. The register file consists of 256 general purpose registers, R0 through R255 implemented in on-chip RAM, and is used by the CPU for general purpose 8- and 16-bit source and destination operands, index registers, and indirect addressing. The first two registers, R0 and R1, are also called registers A and B and are used by the CPU as general purpose registers or for implied operands. The program counter (PC) contains the address of the next instruction to be executed. The stack pointer (SP) contains the address of the last or top entry on the stack, which is located in the on-chip register file. The status register (ST) contains four bits that reflect the outcome of the instruction just executed, and two bits that control the masking of the interrupt priority chains. Figure 4. CPU Registers #### system resets The TMS370Cx4x has three possible reset sources: a low input to the RESET pin, a programmable watchdog timer timeout, or a programmable oscillator fault failure. The RESET pin, an input/output pin, initiates TMS370Cx4x hardware initialization and ensures an orderly software startup. A low-level input of at least 50 ns initiates the reset sequence. The microcontroller is held in reset until the RESET pin goes inactive (high). If the RESET input signal is low for less than eight system clock cycles, the TMS370Cx4x will hold the external RESET pin low for eight system clock cycles to reset external system components. The RESET pin must be activated by the application at power-up, which can be accomplished by an external input or an RC power-up reset circuit. Recall that the basic operating mode, microcomputer or microprocessor, is determined by the voltage level applied to the MC pin two cycles before the RESET pin goes inactive (high). The RESET pin can be asserted at any time during operation, resulting in an immediate initiation of the reset sequence. Figure 5. Typical Reset Circuit The watchdog timer provides system integrity by detecting a program that has become lost or is not executing as expected. A system reset is generated if the watchdog timer is not properly re-initialized by a specific software sequence, or if the re-initialization does not occur before the watchdog timer times out. The watchdog timer timeout initiates the TMS370Cx4x reset sequence and drives the external RESET pin low for eight system clock cycles to reset external system components. The watchdog reset function is enabled by setting the WD OVRFL RST ENA bit of T1CTL2 to 1. Once the software enables the watchdog reset function, subsequent writes to the WD OVRFL RST ENA bit are ignored. Watchdog control bits can be initialized only following a power-up reset. The timer section discusses additional information on the watchdog timer and its configurations. The oscillator fault circuit provides the means to monitor failures of the oscillator input signal (XTAL2/CLKIN). This function is enabled under software control by setting the OSC FLT RST ENA bit of SCCR2 to 1. If the oscillator input signal frequency remains above the 90% point of the minimum operating frequency (CLKIN), the oscillator input will not to be activated. However, if the oscillator input is lost or its frequency falls below 20 kHz and the oscillator fault reset is enabled, the TMS370Cx4x is reset and the external RESET pin is driven low. #### **Reset Sources** | REGISTER | ADDRESS | PF | BIT NO. | CONTROL BIT | SOURCE OF RESET | |----------|---------|------|---------|-------------------|---------------------------| | SCCR0 | 1010h | P010 | 7 | COLD START | Cold or Warm start reset. | | SCCR0 | 1010h | P010 | 4 | OSC FLT FLAG | Oscillator out of range. | | T1CTL2 | 104Ah | P04A | 5 | WD OVRFL INT FLAG | Watchdog timer timeout. | When an oscillator input failure occurs, the internal clocks are stopped and RESET is held active until the oscillator input frequency is greater than 100 kHz typical. If the OSC FLT RST ENA bit of SCCR2 is set to 0, the fault detection circuit independently sets the OSC FLT FLAG of SCCR0 without generating a system reset. The fault detection circuit can be disabled if the OSC FLT DISABLE bit is set to 1. The OSC FLT RST ENA bit is protected during non-privileged operation and therefore should be software configured during the initialization sequence following system reset. During the HALT mode the oscillator fault circuitry will be disabled. During a microcontroller reset, the majority of the peripheral file bits are set to 0, with the exception of the bits shown in the following table. During all resets, the COLD START, OSC FLT FLAG, and the WD OVRFL FLAG are appropriately set by the active reset and may be interrogated by the program to determine the source of system reset. Registers A and B are set to zero during all resets. The other registers are not affected by a reset under power (warm reset). #### **Control Bit States Following Reset** | REGISTER | CONTROL BIT | POWERUP MICROCOMPUTER | WARM RESET MICROCOMPUTER | |----------|---------------|-----------------------|--------------------------| | SCCR0 | μΡ/μC MODE | 0 | 0 | | | MC PIN DATA | 0 | 0 | | | COLD START | 1 | † | | | OSC FLT FLAG | 0 | † | | T1CTL2 | WD OVRFL FLAG | 0 | † | | TXCTL | TX EMPTY | 1 | 1 | | TXCTL | TXRDY | 1 | 1 | | ADSTAT | AD READY | 1 | 1 | <sup>†</sup> Status bit corresponding to active reset source is set to 1. #### interrupts The TMS370 family software-programmable interrupt structure supports flexible on-chip and external interrupt configurations to meet realtime interrupt-driven application requirements. The hardware interrupt structure incorporates two priority levels as shown in Figure 6. Interrupt level 1 has a higher priority than interrupt level 2. The two priority levels can be independently enabled by the global interrupt enable bits (IE1 and IE2) of the Status Register. Each system interrupt is independently configured 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 selectively configured 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 TMS370Cx4x has nine hardware system interrupts as shown in the table on page 15. 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 may 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 to determine which interrupt source generated the associated system interrupt. Figure 6. Interrupt Control Five 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. Recall that 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). # TMS370Cx4x 8-BIT MICROCONTROLLERS SPSN016-NOVEMBER 1992 # **Hardware System Interrupts** | INTERRUPT SOURCE | INTERRUPT FLAG | SYSTEM<br>INTERRUPT | VECTOR<br>ADDRESS | PRIORITY§ | |----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|---------------------|-------------------|-----------| | External RESET Watchdog Overflow Oscillator Fault Detect | COLD START<br>WD OVRFL INT FLAG<br>OSC FLT FLAG | RESET <sup>†</sup> | 7FFEh, 7FFFh | 1 | | External INT1 | INT1 FLAG | INT1 <sup>†</sup> | 7FFCh, 7FFDh | 2 | | External INT2 | INT2 FLAG | INT2 <sup>†</sup> | 7FFAh, 7FFBh | 3 | | External INT3 | INT3 FLAG | INT3 <sup>†</sup> | 7FF8h, 7FF9h | 4 | | 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 <sup>‡</sup> | 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 | | Timer 2 Overflow Timer 2 Compare 1 Timer 2 Compare 2 Timer 2 External Edge Timer 2 Input Capture 1 Timer 2 Input Capture 2 | T2 OVRFL INT FLAG T2C1 INT FLAG T2C2 INT FLAG T2EDGE INT FLAG T2IC1 INT FLAG T2IC2 INT FLAG | T2INT | 7FEEh, 7FEFh | 9 | | A-D Conversion Complete | AD INT FLAG | ADINT | 7FECh, 7FEDh | 10 | <sup>†</sup> Releases microcontroller from STANDBY and HALT low power modes. <sup>‡</sup> Releases microcontroller from STANDBY low power mode. <sup>§</sup> Relative priority within an interrupt level. #### privileged operation and EEPROM write protection override The TMS370Cx4x family is designed with significant flexibility to enable 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 TMS370Cx4x operates in the privileged mode, where all peripheral file registers have unrestricted read/write access and the application program will configure the system during the initialization sequence following reset. As the last step of system initialization, the PRIVILEGE DISABLE bit (SCCR2.0) will be set to 1, entering the non-privileged mode and disabling write operations to specific configuration control bits within the peripheral file. The following system configuration bits are write-protected during the non-privileged mode and must be configured by software prior to exiting the privileged mode: | REGI | STER† | CONTROL DIT | | | |----------------------------------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------|--|--| | NAME | LOCATION | CONTROL BIT | | | | SCCR0<br>SCCR0 | P010.5<br>P010.6 | PF AUTO WAIT<br>OSC POWER | | | | SCCR1<br>SCCR1 | P011.2<br>P011.4 | MEMORY DISABLE<br>AUTOWAIT DISABLE | | | | SCCR2<br>SCCR2<br>SCCR2<br>SCCR2<br>SCCR2<br>SCCR2 | P012.0<br>P012.1<br>P012.2<br>P012.5<br>P012.6<br>P012.7 | PRIVILEGE DISABLE INT1 NMI OSC FLT DISABLE OSC FLT RST ENA PWRDWN/IDLE HALT/STANDBY | | | | SCIPRI<br>SCIPRI | P05F.5<br>P05F.6 | SCI RX PRIORITY<br>SCI TX PRIORITY | | | | T1PRI | P04F.6 | T1 PRIORITY | | | | T2PRI | P06F.6 | T2 PRIORITY | | | | ADPRI | P07F.6 | AD PRIORITY | | | <sup>&</sup>lt;sup>†</sup> The privileged bits are shown in a **bold typeface** in the Peripheral File Frames of the following sections. The write protection override (WPO) mode provides an external hardware method of overriding the write protection registers (WPR) of data EEPROM on the TMS370Cx4x. 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 requiring a 12-volt external input on the MC pin (normally not available in the end application except in a service or diagnostic environment). #### low-power operating modes 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 to1. The HALT/STANDBY bit in SCCR2 controls which low-power mode is entered. In the STANDBY mode (HALT/STANDBY = 0), all CPU activity and most peripheral module activity is stopped; however, the oscillator, internal clocks, Timer 1, and the receive start bit detection circuit of the serial communications interface remain active. System processing is suspended until a qualified interrupt (hardware RESET, external interrupt on INT1, INT2, INT3, Timer 1 interrupt, or a low level on the receive pin of the serial communications interface) is detected. In the HALT mode (HALT/STANDBY=1), the TMS370Cx4x is placed 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 INT1, INT2, or INT3, or low level on the receive pin of the serial communications interface) is detected. | POWERDOWN | CONTROL BITS | | |--------------------------|---------------------------|---------------| | PWRDWN/IDLE<br>(SCCR2.6) | HALT/STANDBY<br>(SCCR2.7) | MODE SELECTED | | 1 | 0 | Standby | | 1 | 1 | Halt | The following information is preserved throughout both the STANDBY and HALT modes: RAM (register file), CPU registers (stack pointer, program counter, and status register), 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 watchdog timer is inhibited. The following table, Peripheral File Frame 1, contains system configuration and control functions and registers for controlling EEPROM programming. The privileged bits are shown in a **bold typeface**. #### Peripheral File Frame 1: System Configuration and Control Registers<sup>†</sup> | ADDR | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | |-------------------------|----------------------|------------------|------------------|--------------------|---------------------|------------------|--------------------|------------------|----------------------|--------| | 1010h | 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 | | 1011h | P011 | _ | _ | _ | AUTOWAIT<br>DISABLE | ****** | MEMORY<br>DISABLE | | _ | SCCR1 | | 1012h | P012 | HALT/<br>STANDBY | PWRDWN/<br>IDLE | OSC FLT<br>RST ENA | BUS<br>STEST | CPU<br>STEST | OSC FLT<br>DISABLE | INT1<br>NMI | PRIVILEGE<br>DISABLE | SCCR2 | | 1013h<br>to<br>1016h | P013<br>to<br>P016 | RESERVED | | | | | | | | | | 1017h | P017 | INT1<br>FLAG | INT1<br>PIN DATA | _ | _ | _ | INT1<br>POLARITY | INT1<br>PRIORITY | INT1<br>ENABLE | INT1 | | 1018h | 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 | | 1019h | P019 | INT3<br>FLAG | INT3<br>PIN DATA | <u>—</u> | INT3<br>DATA DIR | INT3<br>DATA OUT | INT3<br>POLARITY | INT3<br>PRIORITY | INT3<br>ENABLE | INT3 | | 101 <b>A</b> h | P01A | BUSY | | _ | | | AP | W1W0 | EXE | DEECTL | | 101Bh | P01B | RESERVED | | | | | | | | | | 101Ch | P01C | BUSY | VPPS | _ | | | <del></del> | W0 | EXE | EPCTL | | 101Dh<br>101Eh<br>101Fh | 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. The following tables detail the specific addresses, registers, and control bits within the Peripheral File Frame. # Peripheral File Frame 2: System Configuration and Control Registers | ADDR | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | |----------------------|--------------------|----------------------------------------|---------------------------------------|------------------|-----------------|---------------|------------|------------------|-------------| | 1020h | P020 | | | | Res | erved | | | | | 1021h | P021 | | | Poi | rt A Control Re | gister 2 (mus | t be 0) | | | | 1022h | P022 | | | | Port | A Data | | | | | 1023h | P023 | | | | Port A | Direction | | | | | 1024h | P024 | | | , | Res | erved | | | | | 1025h | P025 | Х | Х | Х | Х | Х | Port B Cor | itrol Register 2 | (must be 0) | | 1026h | P026 | X X X X X Port B Data | | | | | • | | | | 1027h | P027 | Х | Х | Х | Х | Х | | Port B Direction | on | | 1028h<br>to<br>102Bh | P028<br>to<br>P02B | · | | | Res | erved | | | | | 102Ch | P02C | | Port D Control Register 1 (must be 0) | | | | | Х | Х | | 102Dh | P02D | Port D Control Register 2 (must be 0)† | | | | | Х | Х | Х | | 102Eh | P02E | | | Port D Data | | | Х | Х | Х | | 102Fh | P02F | | | Port D Direction | on | | х | Х | Х | <sup>&</sup>lt;sup>†</sup> To configure pin D3 as CLKOUT, set Port D Control Register 2 equal to 08h. # Port Configuration Register Set-up | Out q | Data In | |-------|-------------| | | | | Out q | Data In | | Out q | Data In | | | <del></del> | NOTES: 2. Each bit controls the corresponding pin; for example, bit 6 controls port pin 6. Each pin is individually configurable. 3. Only register combination 00xx is defined for TMS370Cx4x. # programmable timers The two programmable timer modules of the TMS370Cx4x provide the designer with the enhanced timer resources required to perform realtime system control. The Timer 1 module contains the general-purpose timer T1 and the watchdog timer (WD). The three independent 16-bit timers, T1, T2, and WD, allow program selection of input clock sources (realtime, external event, or pulse accumulate) with multiple 16-bit registers (input capture and compare) for special timer function control. These timers provide the capabilities for: #### **System Requirements** Realtime system control Input Pulse-Width measurement External Event Synchronization Timer Output Control Pulse-Width Modulated Output Control System Integrity #### **Timer Resource** Interval Timers with Interrupts Pulse-Accumulate or Input-Capture Functions Event Counter Function Compare Function PWM Output Function Watchdog Function #### timer 1 module The timer 1 module consists of three major blocks: - 1. Prescaler/Clock Source, which determines the independent clock sources for the general purpose timer and the watchdog timer. - 2. 16-bit General Purpose Timer, T1, which provides the event count, input capture, and compare functions. - 3. 16-bit Watchdog Timer, which may be software programmed as an event counter/pulse accumulator if the watchdog function is not desired. Figure 7. Timer 1 Module Block Diagram ## timer 1 module prescaler/clock source The clock source inputs for the general purpose timer and the watchdog timer are independently configured by the T1 and WD INPUT SELECT control bits of the T1CTL1 control register. The WD INPUT SELECT control bits cannot be changed after entering the watchdog mode (WD RST ENA = 1). Eight possible clock sources are programmable for each counter. | | T1 INPUT | • | CLOCK SOURCE | WD INPUT | | | | |----------|----------|----------|------------------|----------|----------|----------|--| | SELECT 2 | SELECT 1 | SELECT 0 | CLOCK SOURCE | SELECT 2 | SELECT 1 | SELECT 0 | | | 0 | 0 | 0 | System Clock | 0 | 0 | 0 | | | 0 | 0 | 1 | Pulse Accumulate | 0 | 0 | 1 | | | 0 | 1 | 0 | Event Input | 0 | 1 | 0 | | | 0 | 1 | 1 | No Clock Input | 0 | 1 | 1 | | | 1 | 0 | 0 | System Clock/4 | 1 | 0 | 0 | | | 1 | 0 | 1 | System Clock/16 | 1 | 0 | 1 | | | 1 | 1 | 0 | System Clock/64 | 1 | 1 | 0 | | | 1 | 1 | 1 | System Clock/256 | 1 | 1 | 1 | | For realtime control applications, both the general-purpose timer and the watchdog timer are independently programmable from 16 to 24 bits in length. The 24-bit prescaler/timer generates overflow rates ranging from 13.1 ms with 200 ns timer resolution to 3.35 seconds with 51.2 µs timer resolution (external clock = 20 MHz). In the **event counter mode**, an external high-to-low transition on the T1EVT pin is used to provide the clock for the internal timers. As shown in Figure 8, the T1EVT input provides the timer clock and is not routed through the prescaler. The T1EVT external clock frequency may not exceed the system clock frequency divided by 2. The general-purpose timer and the watchdog timer are programmable as 16-bit event counters. In the **pulse accumulate mode**, an external input on the T1EVT pin is used to gate the internal system clock to the internal timers. While T1EVT input is logic one (high), the timers will be clocked at the system clock rate and will accumulate system clock pulses until the T1EVT pin returns to a logic 0. Both the general purpose timer and the watchdog timer are programmable as 16-bit pulse accumulators. Figure 8. Timer 1 Counter Prescaler # timer 1 general purpose timer The 16-bit general purpose timer (T1) is composed of a 16-bit resettable counter, a 16-bit compare register and associated compare logic, and a 16-bit register that functions as a capture register in one mode and a compare register in the other mode. The T1 MODE bit selects whether T1 operates in the capture/compare mode or the dual compare mode. Figure 9. Timer 1 — General Purpose Timer The counter is a free-running, 16-bit up-counter, clocked by the output of the prescaler/clock source. During initialization the counter is loaded with 0000h and begins its up-count. If the counter is not reset before reaching FFFFh, the counter will roll over to 0000h and continue counting. Upon counter roll-over, the T1 OVRFL INT FLAG is set to 1, and a timer interrupt is generated if the T1 OVRFL INT ENA bit is set to 1. The counter may be reset to 0000h during counting by either; 1) writing a 1 to the T1 SW RESET bit, 2) a compare equal condition from the dedicated T1 compare function, or 3) an external pulse on the T1IC/CR pin (dual compare mode). The designer may select via software (T1EDGE POLARITY bit) which external transition, low-to-high or high-to-low, on the T1IC/CR pin will cause the counter to be reset. Special circuitry prevents the 16-bit registers, including the Counter, Compare, or Capture registers, from changing in the middle of a 16-bit read or write operation. When reading a 16-bit register, read the LSB first, then read the MSB. When writing to a 16-bit register, write the MSB first, then write the LSB. The register value will not change between reading or writing the bytes when done in this order. The timer 1 module has three I/O pins used for the functions shown in the following table. Any of these three pins not used in a timer application may be individually configured as general purpose digital I/O pins by the timer 1 module port control registers (T1PC1 and T1PC2). | PIN | DUAL COMPARE MODE | CAPTURE/COMPARE MODE | |---------|------------------------------------------------|------------------------------------------------| | T1IC/CR | Counter reset input | Input capture input | | T1PWM | PWM output | Compare output | | T1EVT | External event input or pulse accumulate input | External event input or pulse accumulate input | Timer 1 Module I/O Pin Functions The **Dual Compare mode** (T1 MODE = 0) provides two compare registers, an external resettable counter, and a timer output pin. These allow the timer to act as an interval timer, a PWM output, simple output toggle, or many other timer functions. The dual compare mode as shown in Figure 10 continuously compares the contents of the two compare registers to the current value of the 16-bit counter. If a timer compare register equals the counter, the circuit sets the associated interrupt flag to 1 and toggles the T1PWM output pin if enabled, and/or generates a Timer 1 interrupt. An output compare equal condition from the dedicated compare register can also initiate a counter reset. A programmable interval timer function, selected by using the compare equal condition to generate a system interrupt and the counter reset function, generates a periodic interrupt. Either compare function may be used to toggle the T1PWM output pin when a timer compare equal occurs, while the other compare function may be used for another system timing function. Using both compare functions to control the T1PWM pin allows direct PWM generation with minimal CPU software overhead. In typical PWM applications, the compare register is written with the periodic interval and is configured to allow counter reset on compare equal, and the capture/compare register is written with the pulse width to be generated within that interval. The program pulse width may be changed by the application program during the timer operation to alter the PWM output. For high-speed control applications, a minimum pulse width of 200 ns and a period as low as 400 ns can be maintained when using a clock of 20 MHz. NOTE 4: The numbers on the diagram, such as 4C.0, identify the register and the bit in the peripheral frame. For example, the actual address of 4C.0 is 104Ch, bit 0, in the T1CTL4 register. Figure 10. Timer 1 — Dual Compare Mode In addition, a PWM output that is initiated by a transition on an external pin is provided by the timer hardware to support time-critical control applications. Typically, in these applications an external input (T1IC/CR) is used to reset the counter, generate a timer interrupt, and toggle the T1PWM pin to start the PWM output. The compare function will then toggle the output after the programmed pulse width has elapsed. The input edge detect function is enabled under program control by the T1CR DET ENA bit, and upon the next occurrence of the selected edge transition, the T1EDGE INT FLAG bit is set to 1, a timer interrupt is generated (if T1EDGE INT ENA = 1), and the T1PWM output pin is toggled (if T1CR OUT ENA = 1). Selection of the active input transition is under control of T1EDGE POLARITY. In the dual compare mode, the edge detect function must be re-enabled after each valid edge detect. In the **Capture/Compare mode** (T1 MODE = 1), T1 is configured to provide one input capture register for external timing and pulse width measurement, and one compare register for use as a programmable interval timer. The compare register in this mode functions the same as in the dual compare mode described above, including the ability to toggle the PWM pin. The capture/compare register functions in this mode as a 16-bit input capture register, as shown in Figure 11. On the occurrence of a valid input on the T1IC/CR pin, the current counter value is loaded into the 16-bit input capture register, the T1EDGE INT FLAG is set to 1, and a timer interrupt is generated (if TIEDGE INT ENA = 1). The input detect function is enabled by the T1EDGE DET ENA bit, with T1EDGE POLARITY selecting the active input transition. In the capture/compare mode, the edge detect function, once enabled, remains enabled following a valid edge detect. NOTE 4: The numbers on the diagram, such as 4C.0, identify the register and the bit in the peripheral frame. For example, the actual address of 4C.0 is 104Ch, bit 0, in the T1CTL4 register. Figure 11. Timer 1 — Capture/Compare Mode ### timer 1 module, watchdog timer The watchdog timer, contained in the timer 1 module, is a free-running 16-bit resettable up-counter clocked by the output of the Prescaler/Clock Source. The timer is software configured as either a watchdog timer to protect against system software failures and errors, or as a general purpose timer if the watchdog function is not desired. The 16-bit up-counter is programmable (via the WD OVRFL TAP SEL bit) to set the initial count at either 0000h or 8000h. The current value of the watchdog timer may be read at any time during its operation. In the watchdog mode [WD OVRFL RST ENA = 1(high)], the timer will generate a system reset if the timer is re-initialized by an incorrect value or if the counter overflows. The required re-initialization frequency is determined by the system clock frequency, the prescaler/clock source selected, and whether the WD OVRFL TAP SEL bit is set for a 15- or a 16-bit counter rollover. With a clock = 20 MHz, the watchdog timer overflow rates range form 6.55 ms to 3.35 seconds. These values are selected prior to entering the watchdog mode because once the software enables the watchdog reset function (WD OVRFL RST ENA set to 1), subsequent writes to these control bits are ignored. Writes to these watchdog control bits can occur only following a powerup reset, which enhances watchdog timer system integrity. The watchdog timer is re-initialized by writing a predefined value to the watchdog reset key (WDRST) located in the peripheral file. The proper reset key alternates between 55h and AAh, beginning with 55h following the enable of the watchdog reset function. Writes of the correct value must occur prior to the timer overflow period. A write of any value other than the correct predefined value to the watchdog reset key will be interpreted as a lost program and a system reset will be initiated. A watchdog timer overflow or incorrect reset key will set the WD OVRFL INT FLAG bit to 1 and may be interrogated by the program following system reset to determine the source of the reset. In the non-watchdog mode (WD OVRFL RST ENA = 0), the watchdog timer may be used as an event counter, pulse accumulator, or as an interval timer. In this mode, the system reset function is disabled. The watchdog counter is re-initialized by writing any value to the watchdog reset key (WDRST). When used as an interval timer, the timer overflow interval is determined by the system clock frequency, the prescaler/clock source value selected, and the value of the WD OVRFL TAP SEL bit. If the WD counter is not reset before overflowing, the counter will roll over to either 0000h or 8000h, as determined by the WD OVRFL TAP SEL bit, and continue counting. Upon counter overflow, the WD OVRFL INT FLAG is set to 1 and a timer interrupt is generated if the WD OVRFL INT ENA bit set to 1. Alternately, an external input on the T1EVT pin may be used with the watchdog timer to provide an additional 16-bit event counter or pulse accumulator. Figure 12. Watchdog/General Purpose Timer | | | | reliplicial | i lic i iailic | 4. IIIIICI I | Module C | ondoi negi | 31013. | | | |---------|----------|----------------------------------|----------------------------------|----------------------|----------------------|----------------------|--------------------|--------------------|--------------------|--------| | ADDR | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | 1040h | P040 | Bit 15 Counter MSB | | | | | | | | 1 | | 1041h | P041 | Bit 7 | | | Counte | er LSB | | | Bit 0 | TICNTR | | 1042h | P042 | Bit 15 | | | Compare Re | egister MSB | | | Bit 8 | T1C | | 1043h | P043 | Bit 7 | | | | | | | | | | 1044h | P044 | Bit 15 | | Ca | apture/Compai | re Register MS | SB | | Bit 8 | T1CC | | 1045h | P045 | Bit 7 | | C | apture/Compa | re Register LS | В | | Bit 0 | 1 1100 | | 1046h | P046 | Bit 15 | | • | Watchdog C | ounter MSB | | | Bit 8 | WDCNTE | | 1047h | P047 | Bit 7 Watchdog Counter LSB Bit 0 | | | | | | | | 1 | | 1048h | P048 | Watchdog Reset Key | | | | | | | | WDRST | | 1049h | P049 | WD OVRFL<br>TAP SEL <sup>‡</sup> | WD INPUT<br>SELECT2 <sup>‡</sup> | WD INPUT<br>SELECT1* | WD INPUT<br>SELECTOF | _ | T1INPUT<br>SELECT2 | T1INPUT<br>SELECT1 | T1INPUT<br>SELECT0 | T1CTL1 | | 104Ah | P04A | WD OVRFL<br>RST ENA‡ | WD OVRFL<br>INT ENA | WD OVRFL<br>INT FLAG | T1 OVRFL<br>INT ENA | T1 OVRFL<br>INT FLAG | | _ | T1 SW<br>RESET | T1CTL2 | | Mode: [ | Dual Con | npare | | | | | | | | _ | | 104Bh | 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 | | 104Ch | P04C | T1 MODE<br>= 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: 0 | Capture/ | Compare | | | | | | | | _ | | 104Bh | P04B | T1EDGE<br>INT FLAG | _ | T1C1<br>INT FLAG | _ | _ | T1EDGE<br>INT ENA | _ | T1C1<br>INT ENA | T1CTL | | 104Ch | P04C | T1 MODE = | T1C1 | | T1C1 | | T1EDGE | | T1EDGE | TICTL | **RST ENA** T1PWM DATA DIR Peripheral File Frame 4: Timer 1 Module Control Registers<sup>†</sup> | | STEST | PRIORITY | _ | | |---|-----------------|----------------|----------------|--| | † | Privileged bits | are shown in I | oold typeface. | | **OUT ENA** T1PWM DATA OUT **T1** T1PWM **FUNCTION** T1EVT DATA IN T1IC/CR DATA IN POLARITY T1EVT DATA OUT T1IC/CR DATA OUT T1EVT **FUNCTION** T1IC/CR **FUNCTION** The formulas in Figure 13 show the calculations for the resulting time, given values in the compare registers T1C and T1CC. time = $$\left(\frac{\text{CLKIN}}{4}\right)$$ (prescale) (compare + 1) or time = $t_c$ (prescale) (compare + 1) Figure 13. Timer 1 Compare Register Formulas T1CTL4 T1PC1 T1PC2 T1PRI **DET ENA** T1EVT DATA DIR T1IC/CR DATA DIR 104Ch 104Dh 104Eh 104Fh P04C P04D P04E P04F T1PWM DATA IN T1 <sup>&</sup>lt;sup>‡</sup> Once the WD OVRFL RST ENA bit is set, these bits cannot be changed until after a full power-down cycle has been completed. #### timer 2 module Timer 2 consists of a clock source block and a 16-bit general purpose timer that provides the event count, input capture, and compare functions. Figure 14. Timer 2 Module Block Diagram #### timer 2 clock source The clock source input for the general purpose timer is configured by the T2 INPUT SELECT control bits of the T2CTL1 control register. The four programmable clock sources for the general purpose counter are system clock, pulse accumulate, event input, or no clock input (counter stopped). When using the system clock input, the 16-bit timer generates an overflow rate of 13.1 ms with 200 ns resolution (clock = 20 MHz). In the **event counter mode**, the general purpose timer is programmable as a 16-bit event counter. An external low-to-high transition on the T2EVT pin is used to provide the clock for the internal timer. The T2EVT external clock frequency may not exceed the system clock frequency divided by 2. In the **pulse accumulate mode**, the general purpose timer is programmable as a 16-bit pulse accumulator. An external input on the T2EVT pin is used to gate the internal system clock to the internal timers. While T2EVT input is logic 1, the timers will be clocked at the system clock rate and will count system clock pulses until the T2EVT pin returns to logic zero. Figure 15. Timer 2 Clock Select # timer 2 general purpose timer The 16-bit general purpose timer, T2, is composed of a 16-bit resettable counter, a 16-bit compare register with associated compare logic, a 16-bit capture register, and a 16-bit register that functions as a capture register in one mode and a compare register in the other mode. The T2 MODE bit selects whether T2 operates in the dual compare mode or the Dual Capture mode. The counter is a free-running 16-bit up-counter, clocked by the system clock, external event, or system clock while external event active (pulse accumulate). During initialization, the counter is loaded with 0000h and begins its up-count. If the counter is not reset before reaching FFFFh, the counter will roll over to 0000h and continue counting. Upon counter roll-over, the T2 OVRFLINT FLAG is set to 1, and a timer interrupt is generated if the T2 OVRFL INT ENA bit is set to 1. The counter may be reset to 0000h during counting by either; 1) writing a 1 (high) to the T2 SW RESET bit, 2) a compare equal condition from the dedicated T2 compare function, or 3) an external pulse on the T2IC1/CR pin (Dual Compare mode). The designer may select via software (T2CR POLARITY bit) which external transition, low-to-high or high-to-low, on the T2IC1/CR pin will cause the counter to be reset. Special circuitry prevents the 16-bit registers, including the Counter, Compare, or Capture registers, from changing in the middle of a 16-bit read or write operation. When reading a 16-bit register, read the LSB first, then read the MSB. When writing to a 16-bit register, write the MSB first, then write the LSB. The register value will not change between reading or writing the bytes when done in this order. Timer 2 has three I/O pins used for functions as shown in the table below. Any of these three pins not used in a timer application may be individually configured as general purpose digital I/O pins by the Timer 2 port control registers (T2PC1 and T2PC2). #### Timer 2 I/0 Pin Functions | PIN | DUAL COMPARE MODE | CAPTURE/COMPARE MODE | |-----------|-------------------------------------------------|-------------------------------------------------| | T2IC1/CR | Counter reset input. | Input Capture 1 input. | | T2IC2/PWM | PWM output. | Input Capture 2 input. | | T2EVT | External event input or pulse accumulate input. | External event input or pulse accumulate input. | The **Dual Compare mode** (T2 MODE = 0) provides two compare registers, an external resettable counter, and a timer output pin. These allow the timer to act as a interval timer, a PWM output, simple output toggle, or many other timer functions. In this mode, the capture/compare register functions as a 16-bit read/write compare register, as shown in Figure 16. The operation of T2 is identical to T1 while operating in the dual compare mode. In the **Dual Capture mode** (T2 MODE = 1), T2 is configured to provide one compare register for use as a programmable interval timer, and two input capture registers for external input timing and pulse width measurement. In this mode the capture/compare register functions as a 16-bit input capture register, as shown in Figure 17. Each capture input pin (T2IC1/CR and T2IC2/PWM) has an input edge detect function enabled by the associated DET ENA control bit, with the associated POLARITY bit selecting the active input transition. On the occurrence of a valid input on the T2IC1/CR or T2IC2/PWM pin, the current counter value is loaded into the 16-bit capture/compare and 16-bit input capture register, respectively. In addition, the respective input capture INT FLAG is set to 1 and a timer interrupt is generated if the respective INT ENA is set to 1. Figure 16. Timer 2 - Dual Compare Mode Figure 17. Timer 2 - Dual Capture Mode | Peripheral File | Erama 6: | Timor 2 | Madula | Cantral | Dogietart | |-------------------|--------------|---------|--------|---------|------------| | relibiletat i lie | I I allie U. | | WOULE | COLLIG | neuisiei . | | ADDR | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | |--------------------|--------------|-----------------------------|----------------------------|-----------------------|-----------------------|----------------------|----------------------|----------------------|----------------------|--------| | 1060h | P060 | Bit 15 T2 Counter MSB Bit 8 | | | | | | | T2CNTR | | | 1061h | P061 | Bit 7 | Bit 7 T2 Counter LSB Bit 0 | | | | | | | | | 1062h | P062 | Bit 15 | | | T2 Compare F | Register MSB | | | Bit 8 | T2C | | 1063h | P063 | Bit 7 | | | T2 Compare I | Register LSB | | | Bit 0 | 120 | | 1064h | P064 | Bit 15 | | T2 ( | Capture/Compa | are Register MS | SB | | Bit 8 | T2CC | | 1065h | P065 | Bit 7 | | T2 ( | Capture/Compa | are Register LS | SB | | Bit 0 | 1200 | | 1066h | P066 | Bit 15 | | | T2 Capture Re | gister 2 MSB | | | Bit 8 | T2IC | | 1067h | P067 | Bit 7 | | | T2 Capture Re | egister 2 LSB | | | Bit 0 | 1210 | | 1068h<br>1069h | P068<br>P069 | · · · - | | | Rese | rved | | | | : | | 106Ah | P06A | _ | _ | _ | T2 OVRFL<br>INT ENA | T2 OVRFL<br>INT Flag | T2 Input<br>Select1 | T2 Input<br>Select0 | T2<br>SW Reset | T2CTL1 | | Mode: Dual Compare | | | | | | | | | 1 | | | 106Bh | P06B | T2Edge1<br>INT Flag | T2C2<br>INT Flag | T2C1<br>INT Flag | _ | _ | T2Edge1<br>INT ENA | T2C2<br>INT ENA | T2C1<br>INT ENA | T2CTL2 | | 106Ch | P06C | T2 Mode<br>= 0 | T2C1<br>Out ENA | T2C1<br>OUT ENA | T2C2<br>OUT ENA | T2C1<br>RST ENA | T2Edge1<br>Polarity | T2Edge1<br>RST ENA | T2Edge1<br>DET ENA | T2CTL3 | | Mode: D | ual Cap | ture | | | | | | | | | | 106Bh | P06B | T2Edge1<br>INT Flag | T2Edge2<br>INT Flag | T2C1<br>INT Flag | - | - | T2Edge1<br>INT ENA | T2Edge2<br>INT ENA | T2C1<br>INT ENA | T2CTL2 | | 106Ch | P06C | T2 Mode<br>= 1 | _ | _ | T2C1<br>RST ENA | T2Edge2<br>Polarity | T2Edge1<br>Polarity | T2Edge2<br>DET ENA | T2Edge1<br>DET ENA | T2CTL3 | | | | | | | | | | | | _ | | 106Dh | P06D | - | | | - | T2EVT<br>Data In | T2EVT<br>Data Out | T2EVT<br>Function | T2EVT<br>Data DIR | T2PC1 | | 106Eh | P06E | T2IC2/PWM<br>Data In | T2IC2/PWM<br>Data Out | T2IC2/PWM<br>Function | T2IC2/PWM<br>Data DIR | T2IC1/CR<br>Data In | T2IC1/CR<br>Data Out | T2IC1/CR<br>Function | T2IC1/CR<br>Data DiR | T2PC2 | | 106Fh | P06F | T2<br>STEST | T2<br>Priority | _ | _ | | _ | _ | _ | T2PRI | <sup>†</sup> Privileged bits are shown in **bold typeface.** The formulas in Figure 18 show the calculations for the resulting time, given values in the compare registers T2C and T2CC. time = $$\left(\frac{\text{CLKIN}}{4}\right)$$ (prescale) (compare + 1) or time = $t_c$ (prescale) (compare + 1) Figure 18. Timer 2 Compare Register Formulas #### serial communications interface (SCI) The Serial Communications Interface (SCI) is a full-duplex serial I/O port that supports standard NRZ serial communications in a programmed data format (start bit, 1 to 8 data bits, parity even/odd/off, one or two stop bits) at a variety of programmable baud rates. High-speed isosynchronous communications, as well as standard asynchronous communications, are supported for interfacing to peripheral devices. The isosynchronous communications mode combines features of the asynchronous mode with a synchronizing clock signal. The isosynchronous mode has the same format as the asynchronous mode using start, stop, parity, and data bits, but it it uses one serial clock cycle per bit to achieve a much higher transmission speed. Multiprocessor communications using idle line wake-up and address bit wake-up protocols are also supported by the SCI transmit and receive hardware. As shown in Figure 19, the SCI receiver and transmitter are double buffered to reduce the possibility of overwriting data prior to the previous data being read or transmitted from the SCI. Figure 19. SCI Block Diagram The SCI provides independent interrupt requests and vectors for the receiver and transmitter. Interrupts requested by the SCI receiver and SCI transmitter can be software programmed onto different priority levels by the SCI RX PRIORITY and SCI TX PRIORITY control bits. When SCI interrupt requests are made on the same level, the receiver always has higher priority than the transmitter to reduce the possibility of receiver overrun. An SCI TXINT interrupt is asserted whenever TXBUF is transferred to TXSHF. An SCI RXINT interrupt is asserted whenever the SCI receives a complete frame (RXSHF transfers to RXBUF) or when a break detect condition occurs (SCIRXD is low for 10 bit periods following a stop bit). If the TMS370Cx4x has been placed in HALT or STANDBY low-power mode with the SCI RX INT ENA bit = 1 (high), the detection of the start bit (one-to-zero transition) by the SCI receiver initiates receipt of the SCI input, exits the low power mode, activates the microcontroller (CPU, clocks, on-chip peripherals), and initiates execution of the SCI RXINT interrupt service routine. To ensure valid data receipt of the first frame, the baud rate must be slow enough for the SCI to sample for a valid start bit after exiting from the power down mode, or the first data byte must be ignored. The SCI transmitter and receiver are functionally independent to support full-duplex communications; however, they use the same data format, baud rate, communications mode, and multiprocessor communications protocol. The SCICCR control register selects the transmit and receive data format. Figure 20 shows the SCI data format of one frame of information, which consists of an idle line (logic 1), one start bit (logic 0), one to eight data bits, an address bit (if in address bit wake-up mode), a parity bit (if enabled), and one or two stop bits (logic 1). The character length of one to eight data bits is selected by the SCI CHAR2, SCI CHAR1, and SCI CHAR0 control bits. Parity on/off is selected by PARITY ENABLE with the EVEN/ODD PARITY bit selecting the type. Parity generation and verification is performed in the SCI hardware, requiring no CPU calculation overhead. One or two stop bits for transmission are selected by the STOP BITS control bit. The receiver checks for one stop bit on incoming data. Address Bit Wake-up Frame Options: 1 to 8 Data Bits Even, Odd, No Parity 1-2 Stop Bits Figure 20. Frame Formats The SCI communications mode is selected by the ASYNC/ISOSYNC control bit. The transmit and receive data format as described above are identical in both communication modes. In the **asynchronous mode** (ASYNC/ISOSYNC = 1), the external communications interface consists of the SCITXD and SCIRXD pins with an optional SCICLK input for driving the internal SCICLK. The transmit baud rate is 1/16 that of the SCICLK frequency. The receiver internally samples the data input at 16 times the bit rate. The receiver uses majority vote sampling on the seventh, eighth, and ninth SCICLK periods to determine the value of the start bit, data bits, parity, and first stop bit. Asynchronous data rates are supported up to 156K baud (SYSCLK/2<sup>21</sup> to SYSCLK/32) at 20 MHz. Figure 21. Asynchronous Mode The **isosynchronous mode** (ASYNC/ISOSYNC = 0) has the same format as the asynchronous mode, consisting of a start bit, one to eight data bits, an even/odd/no parity bit, and one or two stop bits, but uses an additional synchronizing clock to support high speed serial communications. The external system interface consists of the SCITXD and SCIRXD pins and a continuous synchronizing clock on on the SCICLK pin. Isosynchronous transmit and receive data is clocked at a rate equal to the SCICLK rate, and receiver values are read on a single sample basis. Isosynchronous data rates with synchronizing SCICLK are supported up to 2.5M baud (SYSCLK/2<sup>17</sup> to SYSCLK/2) at 20 MHz. Figure 22. Isosynchronous Mode The CLOCK bit in SCICTL determines whether the SCI clocking signal comes in from an external source through the SCICLK pin or goes out through SCICLK after generation in the integral baud rate timer. The isosynchronous mode baud rate equals the SCICLK rate; the asynchronous mode baud rate 1/16 the SCICLK rate. The maximum frequency of an external clock source can be no greater than 1/10 the system clock frequency. The frequency of the SCICLK when generated by the internal baud rate timer given by the formula. SCICLK = $$\frac{\text{CLKIN}}{8 \text{ (Baud Rate Reg + 1)}}$$ The baud rate using the internal clock equals the SCICLK rate in the isosynchronous mode and equals 1/16 the SCICLK in the asynchronous mode. The 16-bit baud rate register allows the selection of many different standard baud rates. Asynchronous Baud Rate = $$\frac{\text{CLKIN}}{128 \text{ (Baud Rate Reg + 1)}}$$ Isosynchronous Baud Rate = $$\frac{\text{CLKIN}}{8 \text{ (Baud Rate Reg + 1)}}$$ #### **NOTE** When an external serial clock signal is used, the maximum SCICLK frequency is CLKIN/40. # TMS370Cx4x 8-BIT MICROCONTROLLERS SPNS016-NOVEMBER 1992 In both asynchronous and isosynchronous modes, if the transmitter is enabled (TXENA = 1), SCI transmission is initiated following a CPU write to the TXBUF register. This sets TX EMPTY to 0; TXSHF is loaded from TXBUF, TXRDY flag is set to 1, and if SCITX INT ENA is set to 1, SCI transmit interrupt (TXINT) will be asserted. Another write may then be performed to the TXBUF; if not, the transmitter idles (SCITXD outputs continuous high), and TX EMPTY is set to 1 (both TXBUF and TXSHF are empty) until the next write to TXBUF. In both asynchronous and isosynchronous modes, when a frame is fully received, RXBUF is loaded from RXSHF, the error status bits are set accordingly, RXRDY flag is set to 1, and if SCI RX INT ENA is set to 1, an SCI receiver interrupt (RXINT) will be asserted. The SCI receiver performs extensive error checking during data bit reception and provides individual error flags for parity error (PE), overrun error (OE), framing error (FE), and break detect (BRKDT) for application program querying. The SCI supports two multiprocessor communication formats to allow efficient transfer of information between many microcontrollers on the same serial data link. Information is typically transferred as a block of data from a source to a destination, with the destination address identified at the beginning of the block. The SCI has the ability to inhibit all SCI receiver flags and interrupts until a start of a block of data (a destination address) is identified. When a block start is identified, the SCI initiates the following sequence for both multiprocessor communication formats: - 1. The serial port wakes up at the start of the block and receives the first frame (containing the destination address). - 2. A software routine responds to the SCI receiver interrupt and checks the incoming byte against its address byte stored in memory. - 3. If the block is addressed to the microcontroller, the SCI remains active and the CPU reads the rest of the block. If the address does not compare, the software routine puts the serial port to sleep and the SCI will inhibit all SCI receiver flags and interrupts until the next block start. To provide system flexibility, the SCI, in both asynchronous and isosynchronous modes, recognizes the idle line wake-up and address bit wake-up multiprocessor protocols. The multiprocessor protocol is selected by the ADDRESS/IDLE WUP control bit in the SCICCR register. Both protocols use the SLEEP and TXWAKE bits to control the receive and transmit features of the wake-up mode, and the RXWAKE status bit to provide the receiver wake-up condition. In idle line wake-up, blocks are separated by having a longer idle time (logic one) between the blocks than between frames within the blocks. As shown in Figure 23, an idle time of 10 or more bits after a frame indicates a start of a new block and wakes up all receivers. Under software control, all receivers that do not recognize the address in the first frame of the message ignore the rest of the message and await the next idle line. The SCI transmitter allows an idle time of exactly one frame to be transmitted to indicate the start of the next block to maintain serial data link efficiency by minimizing the idle time between block starts. Idle line wake-up protocol has no overhead within the message frames and is typically used when transferring large blocks of data. Figure 23. Idle Line Multiprocessor Mode In address bit wake-up, each frame has an extra bit, the ADDR/DATA bit, positioned just before the parity bit (if used). As shown in Figure 24, block starts are distinguished by the ADDR/DATA bit set to 1 in the first frame of the block and all subsequent frames of the block have the ADDR/DATA bit set to 0. The start of the next block is identified by the next frame that has a 1 in ADDR/DATA. The idle line time is irrelevant in this protocol. All receivers wake up upon receiving a frame with ADDR/DATA set to 1. Under software control, all receivers that do not recognize their address in the first frame of the message ignore the rest of the message and await the next active ADDR/DATA bit. Address bit wake-up protocol eliminates interblock gaps and is efficient in transferring many small blocks of data. Figure 24. Address Bit Multiprocessor Mode # Peripheral File Frame 5: Serial Communication Interface (SCI) Control Registers<sup>†</sup> | ADDR | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | |-------|------|------------------------------|--------------------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|----------| | 1050h | 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 | | 1051h | P051 | _ | _ | SCI SW<br>RESET | CLOCK | TXWAKE | SLEEP | TXENA | RXENA | SCICTL | | 1052h | P052 | Bit 15 | Bit 15 Baud Rate Select Register MSB Bit 8 | | | | | | | | | 1053h | P053 | Bit 7 | | В | aud Rate Sele | ct Register LS | В | | Bit 0 | BAUD LSB | | 1054h | P054 | TXRDY | TX<br>EMPTY | _ | <del>_</del> | _ | <u> </u> | | SCI TX<br>INT ENA | TXCTL | | 1055h | P055 | RX<br>ERROR | RXRDY | BRKDT | FE | OE | PE | RXWAKE | SCI RX<br>INT ENA | RXCTL | | 1056h | P056 | Reserved | | | | | | | | | | 1057h | P057 | Receive Data Buffer Register | | | | | | | | RXBUF | | 1058h | P058 | | Reserved | | | | | | | | | 1059h | P059 | | Transmit Data Buffer Register | | | | | | | | | 105Ah | P05A | | | | | | | | | | | 105Bh | P05B | | | | Rese | erved | | | | | | 105Ch | P05C | | | | | | | | | | | 105Dh | P05D | _ | - | _ | - | SCICLK<br>DATA IN | SCICLK<br>DATA OUT | SCICLK<br>FUNCTION | SCICLK<br>DATA DIR | SCIPC1 | | 105Eh | 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 | | 105Fh | 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.** ### analog-to-digital converter The 8-bit analog-to-digital (A/D) converter provides the designer with eight multiplexed analog input channels for the 44-pin device and four multiplexed analog input channels for the 40-pin device. The A/D converter has internal sample and hold circuitry and uses a successive approximation conversion technique. The accuracy of the A/D conversion process is increased by providing separate analog positive supply and analog ground input pins (V<sub>CC3</sub> and V<sub>SS3</sub>). The V<sub>SS3</sub> pin also provides the low reference voltage input for the conversion process. Figure 25. A/D Converter Block Diagram The A/D converter high reference voltage input is software selectable as one of eight positive reference inputs, as shown in the table below. The A/D conversion process is ratiometric, using $V_{\rm SS3}$ and the software-selected high-reference voltage input as the limits for the selected analog input channel. An input voltage equal to or greater than the high reference input converts to FFh (full scale) with no overflow. An input voltage equal to or less than $V_{\rm SS3}$ converts to 00h. Ratiometric conversions allow analog inputs to be scaled against selected high reference inputs to achieve the greatest accuracy. | | A/D INPUT | ANALOG | | |------|-----------|--------|------------------| | SEL2 | SEL1 | SEL0 | INPUT CHANNEL | | 0 | 0 | 0 | AN0 <sup>†</sup> | | 0 | 0 | 1 1 | AN1 <sup>†</sup> | | 0 | 1 | 0 | AN2 | | 0 | 1 1 | 1 1 | AN3 | | 1 | 0 | 0 | AN4 <sup>†</sup> | | 1 | 0 | 1 1 | AN5 <sup>†</sup> | | 1 | 1 | 0 | AN6 | | 1 | 1 | 1 1 | AN7 | | REFE | RENCE VOI | -TAGE | HIGH REFERENCE | |------|-----------|-------|------------------| | SEL2 | SEL1 | SEL0 | INPUT | | 0 | 0 | 0 | V <sub>CC3</sub> | | 0 | 0 | 1 | AN1 <sup>‡</sup> | | 0 | 1 | 0 | AN2 | | 0 | 1 | 1 | AN3 | | 1 1 | 0 | 0 | AN4 <sup>‡</sup> | | 1 | 0 | 1 | AN5 <sup>‡</sup> | | 1 | 1 | 0 | AN6 | | 1 | 1 | 1 | AN7 | <sup>&</sup>lt;sup>†</sup> On the 40-pin devices AN0, AN1, AN4, and AN5 are not implemented. <sup>‡</sup> Cannot be used as a reference channel on 40-pin devices. The four analog pins (ANO, AN1, AN4 and AN5) that are not implemented on the 40-pin parts are connected to GND internally. If these pins are read as a digital input they will read 0. If they are read as an analog channel they will read 00. Channels AN1, AN4 and AN5 may not be used as the reference channel since V<sub>ref</sub> must be a minimum of 2.5 volts. #### To read an A/D channel: - 1. Write to the ADCTL peripheral file control register to: - Select the high reference voltage input (ADCTL.5-3). - Select the analog input channel for conversion (ADCTL.2-0). - Set the SAMPLE START bit to 1 (ADCTL.6). - 2. Wait for the sample time to elapse. - 3. Write to the ADCTL peripheral file control register to: - Set the CONVERT START bit to 1 and leave SAMPLE START bit set to 1. - 4. Wait for either the interrupt flag to be set or the A/D interrupt to occur. - 5. Read the conversion value from ADDATA when AD INT FLAG is set to 1 or the A/D interrupt occurs. - 6. Clear the interrupt flag (ADSTAT.1). To provide the designer with the flexibility to optimize the A/D conversion process with both high and low impedance sources, the sample time is independently defined by the application program. At the completion of the sample time, the conversion is initiated by settling the CONVERT START and SAMPLE START bits to 1. Eighteen clock cycles after the CONVERT START bit is set to 1, the CONVERT START and SAMPLE START bits will both be set to 0 by the A/D converter, indicating the conversion has started and the analog input signal can be removed. The AD READY bit is set to 0 by the A/D converter to indicate a conversion is in progress. The conversion is complete 164 system clock cycles after it is initiated by setting the CONVERT START bit to 1, and the result is located in the ADDATA result register. Upon completion of the conversion, the AD INT FLAG bit is set, and if the AD INT ENA bit is set to 1 an interrupt will be asserted. The A/D converter has eight bits of resolution with absolution with absolute accuracy of plus or minus one LSB, with (High Reference Voltage $-V_{SS3}$ ) = 5 V. To maximize I/O control capability, all analog input pins not used for an analog input or high reference voltage input may be individually configured as general purpose digital input pins. The control and input data values are contained in the ADENA and ADIN peripheral file control registers. ### Peripheral File Frame 7: A-to-D Converter Control Registers<sup>†</sup> | ADDR | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | | | |-------|------|------------------------------|---------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--------|--|--|--| | 1070h | P070 | Convert<br>START | Sample<br>Start | REF Voit<br>Select2 | REF Volt<br>Select1 | REF Volt<br>Select0 | AD Input<br>Select2 | AD Input<br>Select1 | AD Input<br>Select0 | ADCTL | | | | | 1071h | P071 | _ | _ | _ | _ | _ | AD<br>READY | AD<br>INT FLAG | AD<br>INT ENA | ADSTAT | | | | | 1072h | P072 | | A-to-D Conversion Data Register | | | | | | | | | | | | 1073h | P073 | | | | | | | | | | | | | | to | to | | | | Rese | erved | | | | | | | | | 107Ch | P07C | | | | | | | | | | | | | | 107Dh | P07D | | Port E Data Input Register A | | | | | | | | | | | | 107Eh | P07E | Port E Input Enable Register | | | | | | | | | | | | | 107Fh | P07F | AD<br>STEST | AD<br>PRIORITY | AD<br>ESPEN | _ | -Verman- | | | _ | ADPRI | | | | <sup>†</sup> Privileged bits are shown in **bold typeface**. #### instruction set The TMS370Cx4x family instruction set consists of 64 instructions that control input, output, data manipulations, data comparisons, and program flow. The instruction set is supported with 14 addressing modes to provide the flexibility to optimize programs to the user's applications. For example, the MOV instruction has 27 operand combinations supported by its addressing modes. | ADDRESSING MODE | E | XAMPLE | OPERATION | |--------------------------|-------|-----------|---------------------------------| | GENERAL: | | | | | Implied | LDSP | | $(B) \rightarrow (SP)$ | | Register | MOV | R5,R4 | (R5) → (R4) | | Peripheral | MOV | P025,A | (1025) → A | | Immediate | ADD | #123,R23 | 123 + (R3) → (R3) | | PC Relative | JMP | offset | $PCN + offset \rightarrow (PC)$ | | Stack Pointer Relative | MOV | 2(SP),(A) | (2 + (SP)) → (A) | | EXTENDED: | | | | | Absolute Direct | MOV | A,1234 | (A) → (1234) | | Absolute Indexed | MOV | 1234(B),A | (1234 + (B)) → (A) | | Absolute Indirect | MOV | @R4,A | ((R3:R4)) → (A) | | Absolute Offset Indirect | MOV | 12(R4),A | (12 + (R3:R4)) → (A) | | Relative Direct | JMPL | 1234 | PCN + 1234 → (PC) | | Relative Indexed | JMPL | 1234(B) | PCN + 1234 + (B) → (PC) | | Relative Indirect | JMPL | @R4 | PCN + (R3:R4) → (PC) | | Relative Offset Indirect | JMPL. | 12(R4) | PCN + 12 + (R3:R4) → (PC) | PCN = 16-bit address of next instruction. The CPU controls instruction execution by executing microinstructions from a dedicated control memory at a rate of one microinstruction per internal system clock cycle, $t_{\rm c}$ . The number of system clock cycles required to execute one assembly language instruction varies depending on the instruction complexity, operand addressing mode, and number of wait states. Instruction execution times are stated in terms of the number of internal system clock cycles per instruction. Instruction execution times vary from 5 to 63 internal system clock cycles, with most instructions requiring less than 10 cycles to complete. Similarly, the number of bytes of program memory required to store an instruction will vary with instruction complexity and addressing mode. TMS370 instructions require from one to five bytes of program memory space, with most instructions occupying one or two bytes. The table *TMS370 Instruction Set Summary*, beginning on page 39, shows the instruction set, the addressing modes, the program memory byte length, and the execution cycle count for each instruction. The addressing mode entries are in the format of BYTE LENGTH/CYCLE COUNT. The following symbols and abbreviations are used: | SYMBOL | DEFINITION | SYMBO | L DEFINITION | |--------|------------------------------------|-------|---------------------------------------------------------| | s | Source Operand | d/D | Destination Operand (8-bit/16-bit) | | Α | Register A or R0 in Register File | В | Register B or R1 in Register File | | Rs | Source Register in Register File | Rd | Destination Register in Register File | | Ps | Source Register in Peripheral File | Pd | Destination Register in Peripheral File | | Rps | Source Register Pair (Rn, Rn-1) | Rpd | Destination Register Pair (Rn, Rn-1) | | Rp | General Purpose Register Pair | label | 16-bit Label | | iop8 | 8-bit Immediate Operand | iop16 | 16-bit Immediate Operand | | off8 | 8-bit Signed Offset (label – PCN) | off16 | 16-bit Signed Offset | | PC | Program Counter | PCN | 16-bit Address of Next Instruction | | SP | Stack Pointer | ST | Status Register | | # | Immediate Operand | @ | Extended Addressing Operand (Direct, Indirect, Indexed) | | С | Status Register Carry Bit | → | Is Assigned to | | l () | Contents of | | - | <sup>(</sup>x) = Contents of memory at address x. <sup>((</sup>x)) = Contents of memory location designated by contents at address x. ### **TMS370 Instruction Set Summary** | | | | | | A | DDRES | SSING | MODES | · | | | | |-------------------|-------------|------|-------|------|--------|-------|-------|----------|----------|----------|-------|---------------------------------------------------| | | OPERATION | | DIREC | T | | | | EXTEN | DED | | | DESCRIPTION | | ADC B,_ | | Α | В | Rd | Pd | label | @Rp | label(B) | off8(Rp) | off8(SP) | OTHER | | | ADC | В, | 1/8 | | | | | | | | | | Add with Carry | | | Rs, | 2/7 | 2/7 | 3/9 | | | | | | | | $(s) + (d) + (C) \rightarrow (d)$ | | | #iop8, | 2/6 | 2/6 | 3/8 | | | | | | | | | | ADD | B, _ | 1/8 | | | | | | | | | | Add | | | Rs, _ | 2/7 | 2/7 | 3/9 | | | | | | | | $(s) + (d) \rightarrow (d)$ | | | #iop8,_ | 2/6 | 2/6 | 3/8 | | : | | | | | | | | AND | A, | | | | 2/9 | | | | | | | And | | | В, | 1/8 | | | 2/9 | | | | | | | (s) .AND. (d) → (d) | | | Rs, | 2/7 | 2/7 | 3/9 | 1 | | | | | | | | | | #iop8, | 2/6 | 2/6 | 3/8 | 3/10 | | | | | | | | | BR | | | | | | 3/9 | 2/8 | 3/11 | 4/16 | | | Branch; D → (PC) | | BTJ0 <sup>†</sup> | A,,off8 | | | | 3/10 | | | | | | | Bit Test and Jump If One | | | B,,off8 | 2/10 | | | 3/10 | | | | | | | If (s) .AND. (d) ≠ 0 then | | | Rs,,off8 | 3/9 | 3/9 | 4/11 | | | | | | | | $PCN + offset \rightarrow (PC)$ | | | #iop8,,off8 | 3/8 | 3/8 | 4/10 | 4/11 | | | | | | | | | BTJZ† | A,,off8 | | | | 3/10 | | | | | | | Bit Test and Jump If Zero | | | B,,off8 | 2/10 | | | 3/10 | | | | | | | If (s).AND.(not d) ≠ 0 then | | | Rs,,off8 | 3/9 | 3/9 | 4/11 | | | | | | | | $PCN + offset \rightarrow (PC)$ | | | #iop8,,off8 | 3/8 | 3/8 | 4/10 | 4/11 | | | | ÷ | | | | | CALL | _ | | | | | 3/13 | 2/12 | 3/15 | 4/20 | | | Call; Push PCN, D $\rightarrow$ (PC) | | CALLR | _ | | | | | 3/15 | 3/14 | 3/17 | 4/22 | | i | Call Relative<br>Push PCN, PCN + (d) → (PC) | | O. D. | | 4.00 | 1,50 | 0/2 | | | | | | | | | | CLR | _ | 1/8 | 1/8 | 2/6 | | | | | | | | Clear; 0 → (d) | | CLRC | | | | | | | | | | | 1/19 | Clear Carry; 0 → (C) | | СМР | ,A | | | | | 3/11 | 2/10 | 3/13 | 4/18 | 2/8 | | Compare | | | В, | 1/8 | | | | | | | | | | (d) - (s) computed and | | | Rs, | 2/7 | 2/7 | 3/9 | | | | İ | | | | Status Register flags set | | | #iop8, | 2/6 | 2/6 | 3/8 | | | | | | | | | | CMPBIT | _ | | | 3/8 | 3/10 | | | | | | | Complement Bit | | CMPL | _ | 1/8 | 1/8 | 2/6 | !<br>! | | | | | | | Twos complement;<br>0100h – (s) $\rightarrow$ (d) | <sup>†</sup> Add 2 to cycle count if jump is taken. ### TMS370 Instruction Set Summary (continued) | | | | | | A | DDRES | SSING | MODES | | | | | |-------|----------|----------|-------|------|----|-------|-------|----------|----------|----------|--------|------------------------------------------| | 0 | PERATION | | DIREC | Г | | | | EXTEN | DED | | 071150 | DESCRIPTION | | | | Α | В | Rd | Pd | label | @Rp | label(B) | off8(Rp) | off8(SP) | OTHER | | | DAC | В, | 1/10 | | | | | | | | | | Decimal Add with Carry | | | Rs, _ | 2/9 | 2/9 | 3/11 | | | | | | | | $(s) + (d) + (C) \rightarrow (d) (BCD)$ | | | #iop8, | 2/8 | 2/8 | 3/10 | | | | | | | | | | DEC | | 1/8 | 1/8 | 2/6 | | | | | | | | Decrement; (d) $-1 \rightarrow$ (d) | | DINT | | | | | | | | | | | 2/6 | Disable Interrupt; 00 → (ST) | | DIV | Rs, | 3/55/63‡ | | | | | | | | | | Integer Divide; 16 by 8-bit | | | | | | | | | | | | | | A:B/Rs → A(=quo), B(=rem) | | | | | | | | | | | | | | # cycles depends on operands | | DJNZ† | ,off8 | 2/10 | 2/10 | 3/8 | | | | | | | | Decrement and Jump If Not 0 | | | | | | | | | | | | | | (d) – 1 $\rightarrow$ (d); if (d) .NE. 0 | | | | | | | | | • | | | | | then PCN + offset $\rightarrow$ (PC) | | DSB | В, _ | 1/10 | | | | | | | | | | Decimal Subtract with Borrow | | | RS, | 2/9 | 2/9 | 3/11 | | | | | | | | (d) – (s) – 1 + (C) → (d) (BCD) | | | #iop8, | 2/8 | 2/8 | 3/10 | | | | | | | | | | EINT | | | | | | | | | | | 2/6 | Enable Interrupts; 0Ch $ ightarrow$ (ST) | | EINTH | | | | | | | | | | | 2/6 | EINT High Priority; 04h → (ST) | | EINTL | | | | | | | | | | | 2/6 | EINT Low Priority; 08h → (ST) | | IDLE | | | | | | | | ! | | | 1/6 | Idle Until Interrupt, Low Power entry | | INC | _ | 1/8 | 1/8 | 2/6 | | | | | | | | Increment; (d) + 1 $\rightarrow$ (d) | | INCW | #off8, | | | 3/11 | | | | | | | | Increment Word<br>(Rp) + offset → (Rp) | | | | | | | | | | | 1 | | | (rip) + onset => (rip) | | INV | _ | 1/8 | 1/8 | 2/6 | | | | | | | | Invert; .NOT. (d) $\rightarrow$ (d) | | JMP | _ | | | | | | | | | | 2/7 | Jump; PCN + offset8 → (PC) | | JMPL | | | 1 | | | 3/9 | 2/8 | 3/11 | 4/16 | | | Jump; PCN + (D) → (PC) | <sup>&</sup>lt;sup>†</sup> Add 2 to cycle count if jump is taken. <sup>&</sup>lt;sup>‡</sup> Actual number of cycles is 14 if the quotient is greater than 8 bits (overflow condition). # TMS370 Instruction Set Summary (concluded) | | | | | | A | DDRES | SSING | MODES | | | | | |------------------------------------------------------------|--------------------------------------------------|--------------------------|---------------------------------|-----------------------------------------|---------------------------|--------------|------------|--------------|--------------|------------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | OF | PERATION | <del></del> | DIREC | T | | <u> </u> | | EXTEN | DED | | OTUED | DESCRIPTION | | | | A | В | Rd | Pd | label | @Rp | label(B) | off8(Rp) | off8(SP) | OTHER | | | Jond† JN JZ JC JP JPZ JNZ JNC JV JNV JGE JL JG JLE JLO JHS | | | | | | | | | | | 2/5<br>2/5<br>2/5<br>2/5<br>2/5<br>2/5<br>2/5<br>2/5<br>2/5<br>2/5 | Jump Conditional Negative Zero Carry Positive Positive or Zero Negative or Zero No Carry Overflow, signed No Overflow, signed Greater Than or Equal, signed Less Than, Signed Less Than or Equal, signed Less Than or Equal, signed Less Than or Equal, signed Less Than or Equal, signed Less Than or Equal, signed Less Than or Equal, signed Lower Value Higher or Same | | JBIT0 <sup>†</sup> | _ | | | 4/10 | 4/11 | | | | | | 2/5 | Jump If Bit = 0 | | JBIT1 <sup>†</sup> | _ | | | 4/10 | 4/11 | | | | | | | Jump If Bit = 1 | | LDSP | | | | | | | | | | | 1/7 | Load Stack Pointer; (B) → (SP) | | LDST | #iop8 | | | | | | | | | | 2/6 | Load ST Register; (s) $\rightarrow$ (SP) | | MOV | A,<br>_, A<br>B, _<br>Rs, _<br>Ps, _<br>#iop8, _ | 1/8<br>2/7<br>2/8<br>2/6 | 1/9<br>1/8<br>2/7<br>2/8<br>2/6 | 2/7<br>2/7<br>2/7<br>3/9<br>3/10<br>3/8 | 2/8<br>2/8<br>2/8<br>3/10 | 3/10<br>3/10 | 2/9<br>2/9 | 3/12<br>3/12 | 4/17<br>4/17 | 2/7<br>2/7 | | Move; (s) → (d) | | MOVW | Rps,<br>#iop16,<br>#iop16(B),<br>#off8(Rp), | | | 3/12<br>4/13<br>4/15<br>5/20 | | | | | | | | Move Word; 16-bit operands (s) $\rightarrow$ (d) | | MPY | B,<br>RS,<br>#iop8, | 1/47<br>2/46<br>2/45 | 2/46<br>2/45 | 3/48<br>3/47 | | | | | | | | Multiply<br>(s) $\times$ (d) $\rightarrow$ (A:B)<br>A = MSB, B = LSB | | NOP | | | | | | | | | | | 1/7 | NOP; (PC) +1 → (PC) | | OR | A,<br>B,<br>Rs,<br>#iop8, | 1/8<br>2/7<br>2/6 | 2/7<br>2/6 | 3/9<br>3/8 | 2/9<br>2/9<br>3/10 | | | | | | | OR (s) .OR. (d) $\rightarrow$ (d) | | POP | - | 1/9 | 1/9 | 2/7 | | | | | | | 1/8 | Pop Top of Stack $((SP)) \rightarrow (d); (SP) - 1 \rightarrow (SP)$ | | PUSH | - | 1/9 | 1/9 | 2/7 | | | | | | | 1/8 | Push onto Stack (SP) + 1 $\rightarrow$ (SP); (s) $\rightarrow$ ((SP)) | # TMS370 Instruction Set Summary (concluded) | | | | | | Al | DDRES | SSING | MODES | | | | | |-------|---------------------------|-------------------|------------|------------|--------------------|-------|-------|----------|----------|----------|-------|------------------------------------------------------------| | OPI | ERATION | | DIREC | T | | | | EXTEN | ED | | OTUED | DESCRIPTION | | | : | Α | В | Rd | Pd | label | @Rp | label(B) | off8(Rp) | off8(SP) | OTHER | | | RL | _ | 1/8 | 1/8 | 2/6 | | | | | | | | Rotate Left | | RLC | _ | 1/8 | 1/8 | 2/6 | | | | | | | | Rotate Left Through Carry | | RR | _ | 1/8 | 1/8 | 2/6 | | | | : | | | | Rotate Right | | RRC | _ | 1/8 | 1/8 | 2/6 | | | | | | | | Rotate Right Through Carry | | RTI | | | | | | | | | | | 1/12 | Return from Interrupt<br>Pop PC, Pop ST | | RTS | | | | | | | | | | | 1/9 | Return from Subroutine, Pop PC | | SBIT0 | _ | | | 3/8 | 3/10 | E | | | | | | Set Bit to 0 | | SBIT1 | _ | : | | 3/8 | 3/10 | | | | | | | Set BIT to 1 | | SETC | | | | | | | | | | | 1/7 | Set Carry; A0h → (ST) | | SSB | B,<br>Rs,<br>#iop8, | 1/8<br>2/7<br>2/6 | 2/7<br>2/6 | 3/9<br>3/8 | | | | | | | | Subtract with Borrow $(d) - (s) - 1 + (C) \rightarrow (d)$ | | STSP | | | | | | | | | | | 1/8 | Store Stack Pointer; (SP) → (B) | | SUB | B,<br>Rs,<br>#iop8, | 1/8<br>2/7<br>2/6 | 2/7<br>2/6 | 3/9<br>3/8 | | | | | | | | Subtract $(d) - (s) \rightarrow (d)$ | | SWAP | _ | 1/11 | 1/11 | 2/9 | | ! | | ! | | | | Swap Nibbles<br>s(7- 4,3-0) → d(3-0,7- 4) | | TRAPn | | | | | | | | | | | 1/14 | Trap to Subroutine; Push PCN;<br>Vector n → (PC) | | тѕт | _ | 1/9 | 1/10 | | | | | | | | | Test; Set flags from register | | хснв | _ | 1/10 | 1/10 | 2/8 | | | | | | | | Exchange B; (B) ↔ (d) | | XOR | A,<br>B,<br>Rs,<br>#iop8, | 1/8<br>2/7<br>2/6 | 2/7<br>2/6 | 3/9<br>3/8 | 2/9<br>2/9<br>3/10 | | | | | | | Exclusive OR (s) .XOR. (d) $\rightarrow$ (d) | # TMS370Cx4x 8-BIT MICROCONTROLLERS SPNS016-NOVEMBER 1992 | | | | | | | | FΙ | R | S T | N | E | 3 B L | E | | | | 1 | |-----|---|------------------|----------------------|---------------------|---------------------|-----------------------|---------------------|---------------------|-----------------------|-------------------------|-----------------------|---------------------------|----------------------|-----------------------|----------------------|--------------------|-----------------------------| | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | | | 0 | JMP<br>ra<br>2/7 | | | | | | | INCW<br>#n,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,Rd<br>2/7 | | | | MOV<br>B,Rd<br>2/7 | TRAP<br>14<br>1/14 | MOV<br>n(SP),A<br>2/7 | | s | 2 | JZ<br>ra<br>2/5 | MOV<br>Rs,A<br>2/7 | MOV<br>#n,A<br>2/6 | MÖV<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>Rn<br>2/6 | TRAP<br>13<br>1/14 | MÖV<br>A,n(SP)<br>2/7 | | Ε | 3 | JC<br>ra<br>2/5 | AND<br>Rs,A<br>2/7 | AND<br>#n,A<br>2/7 | AND<br>Rs,B<br>3/9 | 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>Rn<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>Rn<br>2/6 | TRAP<br>11<br>1/14 | extend<br>inst,2<br>opcodes | | 0 | 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 | | | D D | 6 | JNZ<br>ra<br>2/5 | BTJO<br>Rs,A<br>3/9 | BTJO<br>#n,A<br>3/8 | BTJO<br>Rs,B<br>3/9 | BTJO<br>Rs,Rd<br>4/11 | BTJO<br>#n,B<br>3/8 | BTJO<br>B,A<br>2/10 | BTJO<br>#n,Rd<br>4/10 | BTJO<br>A,Pd<br>3/11 | BTJO<br>B,Pd<br>3/10 | BTJO<br>#n,Pd<br>4/11 | XCHB<br>A<br>1/10 | XCHB<br>TESTB<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<br>3/9 | BTJZ<br>#n,A<br>3/8 | BTJZ<br>Rs,B<br>3/9 | BTJZ<br>Rs,Rd<br>4/11 | BTJZ<br>#n,B<br>3/8 | BTJŽ<br>B,A<br>2/10 | BTJ2<br>#n,Rd<br>4/10 | BTJZ<br>A,Pd<br>3/10 | BTJZ<br>B,Pd<br>3/10 | BTJZ<br>#n,Pd<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 | | N | 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,Fld<br>4/13 | MOVW<br>Rs,Rd<br>3/12 | MOVW<br>#16(B),Rd<br>4/15 | PUSH<br>A<br>1/9 | PUSH<br>B<br>1/9 | PUSH<br>Rs<br>2/7 | TRAP<br>7<br>1/14 | SETC<br>1/7 | | 1 | 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>@Rd<br>2/8 | JMPL<br>iab(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 | | В | A | JLE<br>ra<br>2/5 | SUB<br>Rs,A<br>2/6 | 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>B,A<br>1/8 | MOV<br>lab,A<br>3/10 | MOV<br>@Rs,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>Rn,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 | SUB<br>Rs,Rd<br>3/9 | \$BB<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, @ Rd<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>Fin<br>2/6 | TRAP<br>4<br>1/14 | PUSH<br>ST<br>1/8 | | L | С | 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>2/46 | MPY<br>#n,B<br>2/48 | MPY<br>B,A<br>1/47 | MPY<br>#n,Rd<br>3/47 | BR<br>lab<br>3/9 | BR<br>@Rd<br>2/8 | BR<br>lab(B)<br>3/11 | RR<br>A<br>1/8 | RR<br>B<br>1/8 | RR<br>Rn<br>2/6 | TRAP<br>3<br>1/14 | POP<br>ST<br>1/8 | | E | 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>@Rs,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>Rn<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>@Rd<br>2/12 | CALL<br>lab(B)<br>3/15 | RL<br>A<br>1/8 | RL<br>B<br>1/8 | RL<br>Rn<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>@Rd<br>2/14 | CALLR<br>lab(B)<br>3/17 | RLC<br>A<br>1/8 | RLC<br>B<br>1/8 | RLC<br>Rn<br>2/6 | TRAP<br>0<br>1/14 | NOP<br>1/7 | | | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | Second byte of two-byte instructions (F4xx): ra - relative address Rn — Register Rs — Register containing source byte Rd — Register containing destination byte Ps — Peripheral register containing source byte Pd — Peripheral register containing destination byte Pd — Peripheral register contain Pn — Peripheral register #n — Immediate 8-bit number #16 — Immediate 16-bit number lab — 16-bit label @Rn - 16-bit address of contents of register pair | | E | F | |---|------------------------|------------------------| | 8 | MOVW<br>n(Rn)<br>4/15 | DIV<br>Rn,A<br>3/14-63 | | 9 | JMPL<br>n(Rn)<br>4/16 | | | A | MOV<br>n(Rn),A<br>4/17 | | | В | MOV<br>A,n(Rn)<br>4/16 | | | С | BR<br>n(Rπ)<br>4/16 | | | D | CMP<br>n(Rn)<br>4/18 | | | E | CALL<br>n(Rn)<br>4/20 | | | F | CALLR<br>n(R)<br>4/22 | | | | E | F | ### development system support The TMS370 family development support tools include an Assembler, a C Compiler, a Linker, an In-Circuit emulator (XDS – eXtended Development Support), and a microcontroller programmer. - Assembler/Linker (Part No. TMDS3740810-02 for PC, Part No. TMDS3740510-09 for Sun-3<sup>™</sup> or Sun-4<sup>™</sup>) - Extensive macro capability. - High-speed operation. - Format conversion utilities available for popular formats. - ANSI C Compiler (Part No. TMDS3740815-02 for PC, Part No. TMDS3740515-09 for Sun-3<sup>™</sup> or Sun-4<sup>™</sup>) - Generates assembly code of the TMS370 that can be easily inspected. - The compilation, assembly, and linking steps can all be performed with a single command. - Optional optimizer pass improves code execution speed and reduces code size. - Enables the user to directly reference the TMS370's port registers by using a naming convention. - Provides flexibility in specifying the storage for data objects. - C functions and assembly functions can be easily interfaced. - Includes assembler and linker. - XDX/11 (eXtended Development Support) In-Circuit Emulator - Base (Part No. TMDS3761110 For PC, requires cable) - Contains all of the features of the XDS/11 described above but does not require an external power supply. - Symbolic debugging. - Execute single/multiple instructions, single/multiple statements, until/while condition, or at full speed until breakpoint. - The user needs to provide a regulated 5-V power supply with a 3-A current capability. - XDS/22 (eXtended Development Support) In-Circuit Emulator - Base (Part No. TMDS3762210 For PC, requires cable) - Cable for 44-pin PLCC, 40-pin DIP, or shrink DIP (Part No. TMDS3788844) - Contains all of the features of the XDS/11 described above but does not require an external power supply. - Contains sophisticated breakpoint trace and timing hardware that provides up to 2047 qualified trace samples with symbolic disassembly. - Allows breakpoints to be qualified by address and/or data on any type of memory acquisition. Up to four levels of events can be combined to cause a breakpoint. - 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 the trace display. Sun-3 and Sun-4 are trademarks of Sun Microsystems, Inc. # TMS370Cx4x 8-BIT MICROCONTROLLERS ### SPNS016-NOVEMBER 1992 - Microcontroller Programmer - Base (Part No. TMDS3760500 For PC, requires programming head) - Single unit head for 44-pin PLCC (Part No. TMDS3780510) - Single unit head for 40-pin DIP or shrink DIP (Part No. TMDS3780511) - Gang programmer head supports 16 40-pin DIP parts (Part No. TMDS3780525) - Gang programmer head supports 16 40-pin shrink DIP parts (Part No. TMDS3780526) - Gang programmer head supports 16 44-pin PLCC parts (Part No. TMDS3780524) - PC-based, window/function-key oriented user interface for ease of use and a rapid learning environment. - Design Kit (Part No. TMDS3770110 For PC) - Includes TMS370 Application Board and TMS370 Assembler diskette and documentation. - Supports quick evaluation of TMS370 functionality. - Capability to upload and download code. - Capability to execute programs and software routines, and to single-step executable instructions. - Software breakpoints to halt program execution at selected addresses. - Wire-wrap prototype area. - Reverse assembler. - Requires adapter for programming 'Cx4x devices. # absolute maximum ratings over operating free-air temperature range (unless otherwise noted)† | Supply voltage, V <sub>CC</sub> , V <sub>CC3</sub> (see Note 5) | 0.6 V to 7 V | |------------------------------------------------------------------------------------------------|-----------------| | Input voltage range, All pins except MC | 0.6 V to 7 V | | MC | 0.6 V to 14 V | | Input clamp current, $I_{IK}$ ( $V_I < 0$ or $V_I > V_{CC}$ ) | ±20 mA | | Output clamp current, I <sub>OK</sub> (V <sub>O</sub> < 0 or V <sub>O</sub> > V <sub>CC)</sub> | ±20 mA | | Continuous output current per buffer, $I_O(V_O = 0 \text{ to } V_{CC})^{\ddagger}$ | | | Maximum I <sub>CC</sub> current | 170 mA | | Maximum I <sub>SS</sub> current | – 170 mA | | Continuous power dissipation | 1 W | | Storage temperature range | −65°C to 150 °C | <sup>&</sup>lt;sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. ### recommended operating conditions (see Note 5) | | | PARAMETER | MIN | NOM | MAX | UNIT | |------------------|----------------------------------------|--------------------------------------------|-----------------------|------|----------------------|------| | V <sub>CC</sub> | Digital logic supply voltage (see I | Note 5) | 4.5 | 5 | 5.5 | ٧ | | V <sub>CC</sub> | RAM data retention supply voltage | ge (see Note 6) | 3 | | 5.5 | ٧ | | V <sub>CC3</sub> | Analog supply voltage (see Note | 5) | 4.5 | 5 | 5.5 | ٧ | | V <sub>SS3</sub> | Analog supply ground | Analog supply ground | | 0 | 0.3 | ٧ | | V | Law lavel input valtage | All pins except MC | V <sub>SS</sub> | | 8.0 | V | | VIL | Low-level input voltage | MC | V <sub>SS</sub> | | 0.3 | | | | l link lovel in which there | All pins except MC, XTAL2/CLKIN, and RESET | 2 | | v <sub>cc</sub> | | | v | | MC (non-WPO mode) | V <sub>CC</sub> - 0.3 | | V <sub>CC</sub> +0.3 | v | | VIH | High-level input voltage | XTAL2/CLKIN | 0.8 V <sub>CC</sub> | | Vcc | ' | | | | RESET | 0.7 V <sub>CC</sub> | | V <sub>CC</sub> | | | | | EEPROM write protect override | 11.7 | 12 | 13 | | | V <sub>MC</sub> | MC (mode control) voltage | Microcomputer | V <sub>SS</sub> | | 0.3 | V | | | | EPROM programming voltage (VPP) | 12 | 12.5 | 13 | 1 | | _ | One water a first of its terminate was | A version | - 40 | | 85 | °C | | TA | Operating free-air temperature | L version | 0 | | 70 | °C | NOTES: 5. All voltage values are with respect to VSS. <sup>‡</sup> Electrical characteristics are specified with all output buffers loaded with the specified I<sub>O</sub> current. Exceeding the specified I<sub>O</sub> current in any buffer may affect the levels on other buffers. RESET is externally released while V<sub>CC</sub> is within the recommended operating range of 4.5 V to 5.5 V and is externally activated when V<sub>CC</sub> < 4.5 V or V<sub>CC</sub> > 5.5 V. RAM data retention is valid throughout the 2 MHz-20 MHz frequency range. An active RESET initializes (clears) RAM locations 0000h and 0001h. # electrical characteristics over recommended operating free-air temperature range (unless otherwise noted) | | PARAMETER | | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |-----------------|------------------------------------------------------------------|----------|----------------------------------------|---------------------|-----|-----|------| | V <sub>OL</sub> | Low-level digital output voltage | | I <sub>OL</sub> = 1.4 mA | | | 0.4 | ٧ | | Val | Lieb level ever treatese | | l <sub>OH</sub> = -50 μA | 0.9 V <sub>CC</sub> | | | V | | V <sub>OH</sub> | High-level output voltage | | I <sub>OH</sub> = -2 mA | 2.4 | | | V | | · | | мс | 0 V ≤ V <sub>I</sub> ≤ 0.3 V | | | 10 | | | I <sub>I</sub> | Input current | IMC _ | 0.3 V ≤ V <sub>1</sub> ≤ 13 | | | 650 | μΑ | | | | I/O pins | 0 V ≤ V <sub>I</sub> ≤ V <sub>CC</sub> | | | ±10 | | | l <sub>OL</sub> | Low-level output current | | V <sub>OL</sub> = 0.4 V | 1.4 | | | mA | | | Lieb level event event | | V <sub>OH</sub> = 0.9 V <sub>CC</sub> | - 50 | | | μΑ | | ЮН | High-level output current | Ţ. | V <sub>OH</sub> = 2.4 V | -2 | | | mA | | lcc | | | CLKIN = 20 MHz<br>(see Notes 7 and 8) | | 30 | 45 | | | | Supply current (Operating mode) Osc Power bit = 0 (see Note 9) | | CLKIN = 12 MHz<br>(see Note 7) | | 20 | 30 | mA | | | | | CLKIN = 2 MHz<br>(see Notes 7 and 8) | | 7 | 11 | | | | | | CLKIN = 20 MHz<br>(see Notes 7 and 8) | | 10 | 17 | | | Icc | Supply current (Standby mode)<br>Osc Power bit = 0 (see Note 10) | | CLKIN = 12 MHz<br>(see Notes 7 and 8) | | 8 | 11 | mA | | | | | CLKIN = 20 MHz<br>(see Notes 7 and 8) | | 2 | 3.5 | | | | Supply current (Standby mode) Osc Power bit = 0 (see Note 11) | | CLKIN = 12 MHz<br>(see Notes 7 and 8) | | 6 | 8.6 | mA | | lcc | | | CLKIN = 2 MHz<br>(see Notes 7 and 8) | | 2 | 3.0 | mA | | Icc | Supply current (Halt mode) | | XTALK2/CLKIN < 0.2 V<br>(see Note 7) | | 2 | 30 | μА | NOTES: 7. Microcontroller–Single chip mode, ports configured as inputs, or outputs with no load. All inputs ≤ 0.2 V or ≥ V<sub>CC</sub> −0.2 V. <sup>8.</sup> XTAL2/CLKIN is driven with an external square wave signal with 50% duty cycle and rise and fall times less than 10 ns. Current may be higher with a crystal oscillator. At 20 MHz this extra current = 0.01 mA × (total load capacitance + crystal capacitance in pF). <sup>9.</sup> Maximum operating current = 1.90 (CLKIN) + 7 mA. <sup>10.</sup> Maximum standby current = 0.75 (CLKIN) + 2 mA. (Osc Power bit = 0.) <sup>11.</sup> Maximum standby current = 0.56 (CLKIN) + 1.88 mA. (Osc Power bit = 1 and valid only from 2 MHz to 12 MHz.) ### RECOMMENDED CRYSTAL/CLOCK CONNECTIONS - <sup>†</sup> The crystal/ceramic resonator frequency is four times the reciprocal of the system clock period. - <sup>‡</sup> The values of C1 and C2 should be the values recommended by the crystal/ceramic resonator manufacturer. ### TYPICAL OUTPUT LOAD CIRCUIT§ Case 1: V<sub>O</sub> = V<sub>OH</sub> = 2.4 V; Load Voltage = 0 V Case 2: V<sub>O</sub> = V<sub>OL</sub> = 0.4 V; Load Voltage = 2.8 V for Ports A, B and D, and RESET Load Voltage = 2.1 for other Outputs § 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. ### **TYPICAL INPUT BUFFERS** ### 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: | Α | Address | RXD | SCIRXD | |-----|-------------|------|------------| | AR | Array | S | Slave mode | | В | Byte | SCC | SCICLK | | CI | XTAL2/CLKIN | SIMO | SPISIMO | | CO | CLKOUT | SOMI | SPISOMI | | D | Data | TXD | SCITXD | | PGM | Program | W | Write | | R | Read | | | Lowercase subscripts and their meanings are: | С | cycle time (period) | r | rise time | |---|---------------------|----|------------------------| | d | delay time | su | setup time | | f | fall time | V | valid time | | h | hold time | w | pulse duration (width) | The following additional letters are used with these meanings: | Н | High | V | Valid | |---|------|---|----------------| | L | Low | Z | High Impedance | All timings are measured between high and low measurement points as indicated in the figures below. # external clocking requirements† | NO. | | PARAMETER | MIN | NOM | MAX | UNIT | |-----|--------------------------|---------------------------------------------|-----|-----|-----|------| | 1 | t <sub>w(CI)</sub> | XTAL2/CLKIN pulse duration (see Note 12) | 20 | | | ns | | 2 | t <sub>r(Cl)</sub> | XTAL2/CLKIN rise time | | | 30 | ns | | 3 | t <sub>f(CL)</sub> | XTAL2/CLKIN fall time | | | 30 | ns | | 4 | t <sub>d</sub> (CIH-COL) | Delay time, XTAL2/CLKIN rise to CLKOUT fall | | | 100 | ns | | | CLKIN | Crystal operating frequency | 2 | | 20 | MHz | $<sup>^{\</sup>dagger}$ For $V_{IL}$ and $V_{IH}$ , refer to "recommended operating conditions". NOTE 12: This pulse may be either a high pulse, as illustrated below, 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. ### external clock timing ### **EXPANSION MODE OUTPUT** ### general purpose output signal switching time requirements | | | MIN | NOM | MAX | UNIT | |----------------|-----------|-----|-----|-----|------| | t <sub>r</sub> | Rise time | | 30 | | ns | | t <sub>f</sub> | Fall time | | 30 | | ns | ### switching characteristics and timing requirements (see Note 13) | NO. | PARAMETER | MIN | MAX | UNIT | |-----|-------------------------------------------------|------------------------|-------------------------|------| | 5 | t <sub>c</sub> CLKOUT (system clock) cycle time | 200 | 2000 | ns | | 6 | t <sub>w(COL)</sub> CLKOUT low pulse duration | 0.5 t <sub>c</sub> -20 | 0.5 t <sub>c</sub> | ns | | 7 | t <sub>w(COH)</sub> CLKOUT high pulse duration | 0.5 t <sub>c</sub> | 0.5 t <sub>c</sub> + 20 | ns | NOTE 13: $t_c$ = system clock cycle time = $4/f_x$ . ### **CLKOUT** timing ### recommended EEPROM timing requirements for programming | | | MIN | NOM | MAX | UNIT | |----------------------|-------------------------------------------------------------------------------|-----|-----|-----|------| | t <sub>w(PGM)B</sub> | Programming signal pulse duration to insure valid data is stored (byte mode) | 10 | | | ms | | tw(PGM)AR | Programming signal pulse duration to insure 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 <sub>PP</sub> | Supply voltage at MC pin | 12 | 12.5 | 13 | ٧ | | lpp | Supply current at MC pin during programming (V <sub>PP</sub> = 13 V) | | 35 | 50 | mA | | CLKIN | Operating crystal frequency | 2 | | 20 | MHz | ### recommended EPROM timing requirements for programming | | | MIN | NOM | MAX | UNIT | |-----------------------|------------------------------------------------|------|-----|-------|------| | t <sub>w(IEPGM)</sub> | Initial programming signal pulse (see Note 14) | 0.95 | 1 | 1.05 | ms | | t <sub>w(FEPGM)</sub> | Final programming signal pulse | 2.85 | | 78.75 | ms | NOTE 14: Programming pulse is active when both EXE (EPCTL.0) and V<sub>PPS</sub> (EPCTL.6) are set. # SERIAL COMMUNICATIONS INTERFACE (SCI) INTERNAL CLOCK ISOSYNCHRONOUS MODE I/O TIMING ### SCI isosynchronous mode timing characteristics for internal clock (see Note 13) | NO. | | PARAMETER | MIN | MAX | UNIT | |-----|---------------------------|-------------------------------------------|---------------------------|----------------------------|------| | 24 | t <sub>c(SCC)</sub> | SCICLK cycle time | ¹ 2t <sub>c</sub> | 131,072t <sub>c</sub> | ns | | 25 | tw(SCCL) | SCICLK low pulse duration | t <sub>c</sub> – 45 | 0.5t <sub>c(SCC)</sub> +45 | ns | | 26 | t <sub>w(SCCH)</sub> | SCICLK high pulse duration | t <sub>c</sub> - 45 | 0.5t <sub>c(SCC)</sub> +45 | ns | | 27 | t <sub>d(SCCL-TXDV)</sub> | Delay time, SCITXD valid after SCICLK low | - 50 | 50 | ns | | 28 | t <sub>v</sub> (scch-txd) | SCITXD data valid after SCICLK high | t <sub>w(SCCH)</sub> - 50 | | ns | # SCI isosynchronous mode timing requirements for internal clock (see Note 13) | NO. | | | MIN | MAX | UNIT | |-----|---------------------------|-------------------------------------|--------------------------|-----|------| | 29 | t <sub>su(RXD-SCCH)</sub> | SCIRXD setup time to SCICLK high | 0.25t <sub>c</sub> + 145 | | ns | | 30 | t <sub>v</sub> (scch-rxd) | SCIRXD data valid after SCICLK high | 0 | | ns | NOTE 13: $t_c$ = system clock cycle time = $4/f_x$ . ### SCI isosynchronous mode timing diagram for internal clock # SERIAL COMMUNICATIONS INTERFACE (SCI) EXTERNAL CLOCK ISOSYNCHRONOUS MODE I/O TIMING ### SCI isosynchronous mode timing characteristics for external clock (see Note 13) | NO. | PARAMETER | | MIN | MAX | UNIT | |-----|----------------------------|-------------------------------------------|----------|--------------------------|------| | 34 | t <sub>d</sub> (SCCL-TXDV) | Delay time, SCITXD valid after SCICLK low | | 4.25t <sub>c</sub> + 145 | ns | | 35 | t <sub>v(SCCH-TXD)</sub> | SCITXD data valid after SCICLK high | tw(SCCH) | | ns | ### SCI isosynchronous mode timing requirements for external clock (see Note 13) | NO. | | PARAMETER | MIN | MAX | UNIT | |-----|---------------------------|-------------------------------------|--------------------------|-----|------| | 31 | t <sub>c(SCC)</sub> | SCICLK cycle time | 10t <sub>c</sub> | | ns | | 32 | tw(SCCL) | SCICLK low pulse duration | 4.25t <sub>c</sub> + 120 | | ns | | 33 | t <sub>w(SCCH)</sub> | SCICLK high pulse duration | t <sub>c</sub> + 120 | | ns | | 36 | t <sub>su(RXD-SCCH)</sub> | SCIRXD setup time to SCICLK high | 40 | | ns | | 37 | t <sub>v</sub> (SCCH-RXD) | SCIRXD data valid after SCICLK high | 2t <sub>c</sub> | | ns | NOTE 13: $t_c$ = system clock cycle time = $4/f_x$ . # SCI isosynchronous mode timing diagram for external clock ### A/D converter The A/D converter has a separate power bus for its analog circuitry. These pins are referred to as $V_{CC3}$ and $V_{SS3}$ . The purpose is to enhance A/D performance by preventing digital switching noise on the logic circuitry that could be present on $V_{SS3}$ and $V_{CC}$ from coupling into the A/D analog stage. All A/D specifications are given with respect to $V_{SS3}$ unless otherwise noted. | Resolution | 8 bits (256 values) | |-----------------------------------------|---------------------------------------------------------------------| | Monotonic | Yes | | Output conversion code | 00h to FFh (00h for $V_1 \le V_{SS3}$ ; FFh for $V_1 \ge V_{ref}$ ) | | Conversion time (excluding sample time) | | # recommended operating conditions | | | MIN | NOM | MAX | UNIT | |------------------|----------------------------------------------|-----------------------|------------------|------------------------|------| | V | Analog outpely voltage | 4.5 | 5 | 5.5 | V | | V <sub>CC3</sub> | Analog supply voltage | V <sub>CC</sub> - 0.3 | | V <sub>CC</sub> + 0.3 | , v | | V <sub>SS3</sub> | Analog ground | V <sub>SS</sub> - 0.3 | | V <sub>SS</sub> + 0.3 | ٧ | | V <sub>ref</sub> | Non-V <sub>CC3</sub> reference (see Note 15) | 2.5 | V <sub>CC3</sub> | V <sub>CC3</sub> + 0.1 | ٧ | | | Analog input for conversion | V <sub>SS3</sub> | | V <sub>ref</sub> | V | NOTE 15: $V_{ref}$ must be stable, within $\pm$ 1/2 LSB of the required resolution, during the entire conversion time. ### operating characteristics over full ranges of recommended operating conditions | | PARAMETER | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |------------------|-------------------------------------------------------------|----------------------------------------------------|-----|-----|------|------------| | | Absolute accuracy (see Note 16) | V <sub>CC3</sub> = 5.5 V, V <sub>ref</sub> = 5.1 V | | | +1.5 | LSB | | 1 | Differential/integral linearity error (see Notes 16 and 17) | V <sub>CC3</sub> = 5.5 V, V <sub>ref</sub> = 5.1 V | | | ±0.9 | LSB | | | Analogouph | Converting | | | 2 | mA | | 1CC3 | Analog supply current | Not Converting | | | 5 | μA | | l <sub>j</sub> | Input current, AN0-AN7 | 0 V ≤ V <sub>i</sub> ≤ 5.5 V | | | 2 | μ <b>Α</b> | | | V <sub>ref</sub> input charge current | | | | 1 | mA | | 7 | Course impedence V | XTAL2/CLKIN ≤ 12 MHz | | | 24 | kΩ | | Z <sub>ref</sub> | Source impedance V <sub>ref</sub> | 12 MHz < XTAL2/CLKIN ≤ 20 MHz | | | 10 | kΩ | NOTES: 16. Absolute resolution = 20 mV. At V<sub>ref</sub> = 5.1 V, this is 1 LSB. As V<sub>ref</sub> decreases, LSB size decreases and thus absolute accuracy and differential / integral linearity errors in terms of LSBs increases. The A/D module allows complete freedom in design of the sources for the analog inputs. The period of the sample time is user-defined such that high impedance sources can be accommodated without penalty to low-impedance sources. The sample period begins when the SAMPLE START bit of the A/D Control Register (ADCTL) is set to 1. The end of the signal sample period occurs when the conversion bit (CONVERT START) of the ADCTL is set to 1. After a hold time, the converter will reset the SAMPLE START and CONVERT START bits, signaling that a conversion has started and the analog signal can be removed. <sup>17.</sup> Excluding quantization error of 1/2 LSB. # TMS370Cx4x 8-BIT MICROCONTROLLERS SPNS016-NOVEMBER 1992 ### analog timing requirements | | | MIN | NOM | MAX | UNIT | |--------------------|----------------------------------------------------------------------|------------------|-----|-----|-------| | t <sub>su(S)</sub> | Analog input setup to sample command | 0 | | | ns | | t <sub>h(AN)</sub> | Analog input hold from start of conversion | 18t <sub>c</sub> | | | ns | | t <sub>w(S)</sub> | Duration of sample time per kilohm of source impedance (see Note 18) | 1 | | | μs/kΩ | NOTE 18: The value given is valid for a signal with a source impedance greater than 1 k $\Omega$ . If the source impedance is less than 1 k $\Omega$ , use a minimum sampling time of 1 $\mu$ s. # analog timing # 40-pin plastic dual-in-line shrink package (N2 suffix) NOTE A: Each pin centerline is located within 0,26 (0.010) of its true longitudinal position. ### 40-pin plastic dual-in-line package (N suffix) ### 40-pin ceramic dual-in-line package (J suffix) NOTE A: Each pin centerline is located within 0,26 (0.010) of its true longitudinal position. # 44-pin plastic leaded chip carrier package (FN suffix) NOTES: A. Center line of center pin each side is within 0,10 (0.004) of package centerline as determined by dimension B. B. Location of each pin is within 0,127 (0.005) of true position with respect to center pin on each side. C. The lead contact points are planar with 0,15 (0.006). # 44-pin cerquad chip carrier package (FZ suffix) NOTES: A. Center line of center pin each side is within 0,10 (0.004) of package centerline as determined by dimension B. B. Location of each pin is within 0,127 (0.005) of true position with respect to center pin on each side. C. The lead contact points are planar with 0,15 (0.006). #### **IMPORTANT NOTICE** Texas Instruments (TI) reserves the right to make changes to its products or to discontinue any semiconductor product or service without notice, and advises its customers to obtain the latest version of relevant information to verify, before placing orders, that the information being relied on is current. TI warrants performance of its semiconductor products and related software 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, INTENDED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT APPLICATIONS, DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS. Inclusion of TI products in such applications is understood to be fully at the risk of the customer. Use of TI products in such applications requires the written approval of an appropriate TI officer. Questions concerning potential risk applications should be directed to TI through a local SC sales office. In order to minimize risks associated with the customer's applications, adequate design and operating safeguards should be provided by the customer to minimize inherent or procedural hazards. TI assumes no liability for applications assistance, customer product design, software performance, or infringement of patents or services described herein. Nor does TI 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. Copyright © 1996, Texas Instruments Incorporated Printed in U.S.A. by The Hibbert Group Denver, Colorado