- CMOS/EEPROM/EPROM Technologies on a Single Device - Mask-ROM Devices for High-Volume Production - One-Time-Programmable (OTP) EPROM Devices for Low-Volume Production - Reprogrammable-EPROM Devices for Prototyping Purposes - Internal System Memory Configurations - On-Chip Program Memory Versions - ROM: 16K Bytes - EPROM: 16K Bytes - Data EEPROM: 256 Bytes - Static RAM: 256 Bytes Usable as Registers - Standby RAM With Separate Power Supply Pin: 256 Bytes - Flexible Operating Features - Low-Power Modes: STANDBY and HALT - Commercial, Industrial, and Automotive Temperature Ranges - Clock Options - Divide-by-1 (2 MHz-5 MHz SYSCLK) Phase-Locked Loop (PLL) - Divide-by-4 (0.5 MHz-5 MHz SYSCLK) - Supply Voltage (V<sub>CC</sub>) 5 V ±10% - Programmable Acquisition and Control Timer (PACT) Module - Input Capture on up to Six Pins, Four of Which Can Have a Programmable Prescaler - One Input Capture Pin Can Drive an 8-Bit Event Counter - Up to Eight Timer-Driven Outputs - Interaction Between Event Counter and Timer Activity - 18 Independent Interrupt Vectors - Watchdog With Selectable Time-Out Period - Asynchronous Mini Serial Communication Interface (Mini SCI) - Flexible Interrupt Handling - Two Software-Programmable Interrupt Levels - Global- and Individual-Interrupt Masking - Programmable Rising- or Falling-Edge Detect - Individual-Interrupt Vectors - Serial Peripheral Interface (SPI) - Variable-Length High-Speed Shift Register - Synchronous Master/Slave Operation - Eight Channel 8-Bit Analog-to-Digital Converter 1 (ADC1) - TMS370 Series Compatibility - Register-to-Register Architecture - 256 General-Purpose Registers - 14 Powerful Addressing Modes - Instructions Upwardly Compatible With All TMS370 Devices - CMOS/TTL Compatible I/O Pins/Packages - All Peripheral Function Pins Software Configurable for Digital I/O - 16 Bidirectional Pins, Nine Input Pins - 44-Pin Plastic and Ceramic Leaded Chip Carrier (LCC) Packages - Workstation/PC-Based Development System - C Compiler and C Source Debugger - Real-Time In-Circuit Emulation - Multi-Window User Interface - Microcontroller Programmer Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet. # **Pin Descriptions** | 44 PINS | | c+ | DESCRIPTION | | | | | |------------------------------------------------------------------------------|----------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | NAME | NO. | 1/0† | DESCRIPTION | | | | | | A0<br>A1<br>A2<br>A3<br>A4<br>A5<br>A6<br>A7 | 34<br>35<br>36<br>37<br>38<br>39<br>40<br>41 | 1/0 | Port A is a general-purpose bidirectional I/O port. | | | | | | D3<br>D4/CP4<br>D5/CP1<br>D6/CP6<br>D7/CP5 | 27<br>14<br>15<br>12<br>13 | 1/0 | Port D is a general-purpose bidirectional port. Also configurable as SYSCLK (see Note 1) PACT input capture 4 (see Note 2) PACT input capture 1 (see Note 2) PACT input capture 6 (see Note 2) PACT input capture 5 (see Note 2) | | | | | | AN0/E0<br>AN1/E1<br>AN2/E2<br>AN3/E3<br>AN4/E4<br>AN5/E5<br>AN6/E6<br>AN7/E7 | 4<br>5<br>6<br>7<br>8<br>9<br>10 | ı | ADC1 analog input pins (AN0-AN7)/port E digital input pins (E0-E7) Port E can be programmed individually as a general-purpose digital input pin if it is not used as ADC1 analog input or positive reference input. | | | | | | INT1 | 28 | I | External interrupt (non-maskable or maskable)/general-purpose input pin | | | | | | OP1/CP3<br>OP2/CP2<br>OP3<br>OP4<br>OP5<br>OP6<br>OP7<br>OP8 | 16<br>17<br>21<br>22<br>23<br>24<br>25<br>26 | 0 | PACT PWM output 1/input capture 3 (see Note 3) PACT output pin 2/input capture 2 (see Note 3) PACT PWM output 3 PACT PWM output 4 PACT PWM output 5 PACT PWM output 6 PACT PWM output 7 PACT PWM output 8 | | | | | | SCIRXD<br>SCITXD | 19<br>20 | I<br>О | PACT mini SCI data receive input pin PACT mini SCI data transmit output pin | | | | | | SPISOMI<br>SPISIMO<br>SPICLK | 30<br>29<br>31 | 1/0 | SPI slave output pin, master input pin/general-purpose bidirectional pin SPI slave input pin, master output pin/general-purpose bidirectional pin SPI bidirectional serial clock pin/general-purpose bidirectional pin | | | | | | RESET | 32 | 1/0 | System reset bidirectional pin; as input pin, RESET initializes the microcontroller; as open-drain output, RESET indicates that an internal failure was detected by watchdog or oscillator fault circuit. | | | | | | MC | 33 | I | Mode control input pin; enables EEPROM write protection override (WPO) mode, also EPROM Vpp | | | | | | XTAL2/CLKIN<br>XTAL1 | 43<br>44 | I<br>О | Internal oscillator crystal input/External clock source input Internal oscillator output for crystal | | | | | | VCC1<br>VSS1<br>VCC3<br>VSS3<br>VCCSTBY | 1<br>18<br>2<br>3<br>42 | | Positive supply voltage for digital logic and digital I/O pins Ground reference for digital logic and digital I/O pins ADC1 positive supply voltage and optional positive reference input ADC1 ground supply and low reference input pin Positive supply voltage pin for standby RAM | | | | | $\dagger$ I = input, O = output NOTES: 1. D3 can be configured as SYSCLK by appropriately programming the DPORT1 and DPORT2 registers. - 2. These digital I/O buffers are connected internally to some of the PACT module's input capture pins. This allows the microcontroller to read the level on the input capture pin, or if the port D pin is configured as an output, to generate a capture. Be careful to leave the port D pin configured as an input if the corresponding input capture pin is being driven by external circuitry. - the port D pin configured as an input if the corresponding input capture pin is being driven by external circuitry. 3. CP2 and CP3 are connected internally to OP2 and OP1. CP2 and CP3 can be used only to capture OP2 and OP1, respectively and not as external capture inputs. # functional block diagram #### description The TMS370C036, TMS370C736, and SE370C736 devices are members of the TMS370 family of single-chip 8-bit microcontrollers. Unless otherwise noted, the term TMS370Cx36 refers to these devices. The TMS370 family provides cost-effective real-time system control through advanced peripheral-function modules and various on-chip memory configurations. The TMS370Cx36 family of devices uses high-performance silicon-gate CMOS EPROM and EEPROM technologies. 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 TMS370Cx36 devices attractive for system designs for automotive electronics, industrial motors, computer peripheral controls, telecommunications, and consumer applications. All TMS370Cx36 devices contain the following on-chip peripheral modules: - Programmable acquisition and control timer (PACT) - Asynchronous mini SCI - PACT watchdog timer - Serial peripheral interface (SPI) - Eight channel, 8-bit analog-to-digital converter 1 (ADC1) # description (continued) Table 1 provides a memory configuration overview of the TMS370Cx36 devices. **Table 1. Memory Configurations** | DEVICE | PROGRAM<br>(BY) | | DATA M<br>(BY) | | 44 PIN PACKAGES | | |-------------------------|-----------------|-------|----------------|--------|-----------------|--| | | ROM | EPROM | RAM | EEPROM | | | | TMS370C036A | 16K | _ | 512 | 256 | FN – PLCC | | | TMS370C736A | _ | 16K | 512 | 256 | FN – PLCC | | | SE370C736A <sup>†</sup> | _ | 16K | 512 | 256 | FZ – CLCC | | <sup>†</sup> System evaluators and development are for use only in prototype environment, and their reliability has not been characterized. The suffix letter A appended to the device names in Table 1 indicates the configuration of the devices. ROM or EPROM devices have different configurations as indicated in Table 2. ROM devices with the suffix letter A are configured through a programmable contact during manufacture. **Table 2. Suffix Letter Configuration** | DEVICE <sup>‡</sup> | CLOCK | LOW-POWER MODE | | | |---------------------|-----------------------------------|---------------------|--|--| | EPROM A | Divide-by-4 (Standard oscillator) | Enabled | | | | ROM A | Divide-by-4 or Divide-by-1 (PLL) | Enabled or disabled | | | <sup>‡</sup>Refer to the "device numbering conventions" section for device nomenclature and to the "device part numbers" section for ordering. The 16K bytes of mask-programmable ROM in the associated TMS370Cx36 devices are replaced in the TMS370C736 with 16K bytes of EPROM. All other available memory and on-chip peripherals are identical. The OTP (TMS370C736) and reprogrammable (SE370C736) devices are available. The TMS370C736 OTP device is available in a plastic package. This microcontroller is effective to use for immediate production updates for other members of the TMS370Cx36 family or for low-volume production runs when the mask charge or cycle time for the low-cost mask ROM devices is not practical. The SE370C736 has a windowed ceramic package to allow reprogramming of the program EPROM memory during the development/prototyping phase of design. The SE370C736 device allows quick updates to breadboards and prototype systems while iterating initial designs. The TMS370Cx36 family provides two low-power modes (STANDBY and HALT) for applications where low-power consumption is critical. Both modes stop all CPU activity (that is, no instructions are executed). In the STANDBY mode, the internal oscillator, the PACT counter, and PACT's first command/definition entry remain active. This allows the PACT module to bring the device out of STANDBY mode. In the HALT mode, all device activity is stopped. The device retains all RAM data and peripheral configuration bits throughout both low-power modes. The TMS370Cx36 features advanced register-to-register architecture that allows direct arithmetic and logical operations without requiring an accumulator (for example, ADD R24, R47; add the contents of register 24 to the contents of register 47 and store the result in register 47). The TMS370Cx36 family is fully instruction-set-compatible, providing easy transition between members of the family. The TMS370Cx36 has a PACT module that acts as a timer coprocessor by gathering timing information on input signals and controlling output signals with little or no intervention by the CPU. The coprocessor nature of this module allows for levels of flexibility and power not found in traditional microcontroller timers. # description (continued) The TMS370Cx36 family provides the system designer with an economical, efficient solution to real-time control applications. The PACT compact development tool (CDT™) meets the challenge of efficiently developing the software and hardware required to design the TMS370Cx36 into an ever-increasing number of complex applications. The application source code can be written in assembly and C language, and the output code can be generated by the linker. Precise real-time in-circuit emulation and extensive symbolic debug and analysis tools ensure efficient software and hardware implementation as well as a reduced time-to-market cycle. The TMS370Cx36 family together with the TMS370 PACT CDT370, BP programmer, software tools, SE370C736 reprogrammable devices, comprehensive product documentation, and customer support provides a complete solution to the needs of the system designer. # central processing unit (CPU) The CPU on the TMS370Cx36 device is the high-performance 8-bit TMS370 CPU module. The 'x36 implements an efficient register-to-register architecture that eliminates the conventional accumulator bottleneck. The complete 'x36 instruction map is shown in Table 16. The '370Cx36 CPU architecture provides the following components: #### CPU registers: - A stack pointer (SP) that points to the last entry in the memory stack - A status register (ST) that monitors the operation of the instructions and contains the global interrupt-enable bits - A program counter (PC) that points to the memory location of the next instruction to be executed A memory map that includes: - 256-byte general-purpose RAM that can be used for data memory storage, program instructions, general purpose register, or the stack - 256-byte general-purpose standby RAM, which is powered through a separate V<sub>CCSTBY</sub> pin to protect the memory against power failures on the main V<sub>CC1</sub> pins - 128-byte dual-port RAM that contains the capture registers, the circular buffer, and a command/definition area - A peripheral file that provides access to all internal peripheral modules, system-wide control functions, and EEPROM/EPROM programming control - 256-byte EEPROM module, that provides in-circuit programmability and data retention in power-off conditions - 16K-byte ROM or 16K-byte EPROM # central processing unit (CPU) (continued) Figure 1 Illustrates the CPU registers and memory blocks. <sup>†</sup> Reserved means the address space is reserved for future expansion. Figure 1. Programmer's Model #### stack pointer (SP) The SP is an 8-bit CPU register. Stack operates as a last-in, first-out, read/write memory. Typically, the stack is used to store the return address on subroutine calls as well as the ST contents during interrupt sequences. The SP points to the last entry or top of the stack. The SP is incremented automatically before data is pushed onto the stack and decremented after data is popped from the stack. The stack can be placed anywhere in the on-chip RAM. #### status register (ST) The ST monitors the operation of the instructions and contains the global interrupt-enable bits. The ST includes four status bits (condition flags) and two interrupt-enable bits. - The four status bits indicate the outcome of the previous instruction; conditional instructions (for example, the conditional-jump instructions) use the status bits to determine program flow. - The two interrupt-enable bits control the two interrupt levels. # central processing unit (CPU) (continued) The ST, status-bit notation, and status-bit definitions are shown in Table 3. **Table 3. Status Registers** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|------|------|------|------|------|----------|----------| | С | N | Z | V | IE2 | IE1 | Reserved | Reserved | | RW-0 | RW-0 | RW-0 | RW-0 | RW-0 | RW-0 | | | R = read, W = write, 0 = value after reset #### program counter (PC) The contents of the PC point to the memory location of the next instruction to be executed. The PC consists of two 8-bit registers in the CPU: the program counter high (PCH) and program counter low (PCL). These registers contain the most significant byte (MSbyte) and least significant byte (LSbyte) of a 16-bit address. During reset, the contents of the reset vector (7FFEh, 7FFFh) are loaded into the PC. The PCH (MSbyte of the PC) is loaded with the contents of memory location 7FFEh, and the PCL (LSbyte of the PC) is loaded with the contents of memory location 7FFFh. Figure 2 shows this operation using an example value of 4000h as the contents of the reset vector. Figure 2. Program Counter After Reset #### memory map The TMS370Cx36 architecture is based on the Von Neuman architecture, where the program memory and data memory share a common address space. All peripheral input/output is memory mapped in this same common address space. As shown in Figure 3, the TMS370Cx36 provides memory-mapped RAM, ROM, EPROM, data EEPROM, I/O pins, peripheral functions, and system-interrupt vectors. The peripheral file contains all I/O port control, peripheral status and control, EEPROM, EPROM, and system-wide control functions. The peripheral file is located between 1000h to 107Fh and is divided logically into eight peripheral file frames of 16 bytes each. The eight PF frames consist of five control frames and three reserved frames. Each on-chip peripheral is assigned to a separate frame through which peripheral control and data information are passed. # central processing unit (CPU) (continued) <sup>†</sup> Reserved means that the address space is reserved for future expansion. Figure 3. TMS370Cx36 Memory Map #### RAM/register file (RF) Locations within the RAM address space can serve as the RF, general-purpose read/write memory, program memory, or the stack instructions. The TMS370Cx36 devices contain 256 bytes of internal RAM, memory-mapped beginning at location 0000h (R0) and continuing through location 00FFh (R255) which is shown in Figure 1. The first two registers, R0 and R1, are also called register A and B, respectively. Some instructions implicitly use register A or B; for example, the instruction LDSP (load SP) assumes that the value to be loaded into the stack pointer is contained in register B. Registers A and B are the only registers cleared on reset. #### dual-port RAM The upper 128 bytes of the register files can be used by the PACT module to contain commands and definitions as well as timer values. Any RAM not used by PACT can be used as an additional CPU register or as general-purpose memory. #### standby RAM module The 256 byte standby RAM is general-purpose and powered through a separate $V_{CCSTBY}$ pin. The data stored in this memory is protected against power failures on the main $V_{CC1}$ pins. The standby RAM data is saved if the power failure on the main $V_{CC1}$ pins is detected externally and an external reset is generated when $V_{CC1}$ falls below 4.3 V (see Figure 4). The external reset must remain low during the entire power failures. The falling edge of the reset signal is internally detected to set the standby RAM in low-power HALT mode. After the next power up, the $\overline{RESET}$ pin must be pulled high to get out of the HALT mode of the standby RAM. In halt mode, the standby RAM consumes only leakage current. Figure 4. Standby RAM Locked in Halt Mode #### peripheral file (PF) The TMS370Cx36 control registers contain all the registers necessary to operate the system and peripheral modules on the device. The instruction set includes some instructions that access the PF directly. These instructions designate the register by the number of the PF relative to 1000h, preceded by P0 for a hexadecimal designator or P for a decimal designator. For example, the system-control register 0 (SCCR0) is located at address 1010h; its peripheral file hexadecimal designator is P010, and its decimal designator is P16. Table 4 lists the TMS370Cx36 PF address map. | ADDRESS RANGE | PERIPHERAL FILE<br>DESIGNATOR | DESCRIPTION | |---------------|-------------------------------|-------------------------------------------| | 1000h-100Fh | P000-P00F | Reserved | | 1010h-101Fh | P010-P01F | System and EPROM/EEPROM control registers | | 1020h-102Fh | P020-P02F | Digital I/O port control registers | | 1030h-103Fh | P030-P03F | SPI registers | | 1040h-104Fh | P040-P04F | PACT registers | | 1050h-106Fh | P050-P06F | Reserved | | 1070h-107Fh | P070-P07F | Analog-to-digital converter 1 registers | | 1080h-10FFh | P080-P0FF | Reserved | Table 4. TMS370Cx36 Peripheral File Address Map #### data EEPROM The TMS370Cx36 devices, containing 256 bytes of data EEPROM, have a memory mapped beginning at location 1F00h and continuing through location 1FFFh. Writing to the data EEPROM module is controlled by the data EEPROM control register (DEECTL) and the write-protection register (WPR). Programming algorithm examples are available in the *TMS370 Family User's Guide* (literature number SPNU127) or the *TMS370 Family Data Manual* (literature number SPNS014B). The data EEPROM features include the following: #### Programming: - Bit-, byte-, and block-write/erase modes. - Internal charge pump circuitry. No external EEPROM programming voltage supply is needed. - Control register: Data EEPROM programming is controlled by the DEECTL located in the PF frame beginning at location P01A. See Table 5. - In-circuit programming capability. There is no need to remove the device to program. - Write protection. Writes to the data EEPROM are disabled during the following conditions. - Reset. All programming of the data EEPROM module is halted. - Write protection active. There is one write-protect bit per 32-byte EEPROM block. - Low-power mode operation - Write protection can be overridden by applying 12 V to MC. Table 5. Data EEPROM and PROGRAM EPROM Control Registers Memory Map | ADDRESS | SYMBOL | NAME | |---------|--------|--------------------------------------------| | P01A | DEECTL | Data EEPROM Control Register | | P01B | _ | Reserved | | P01C | EPCTLL | Program EPROM Control Register – Low Array | # program EPROM† The TMS370C736 device contains 16K bytes of EPROM mapped, beginning at location 4000h and continuing through location 7FFFh as shown in Figure 3. Reading the program EPROM modules is identical to reading other internal memory. During programming, the EPROM is controlled by the EPROM control register (EPCTLL). The program EPROM module features include: #### Programming - In-circuit programming capability if V<sub>PP</sub> is applied to MC - Control register: EPROM programming is controlled by the EPROM control register (EPCTLL) located in the peripheral file (PF) frame at location P01C as shown in Table 5. - Write protection: Writes to the program EPROM are disabled under the following conditions: - Reset: All programming to the EPROM module is halted - Low-power modes - 13 V not applied to MC TI is a trademark of Texas Instruments Incorporated. <sup>&</sup>lt;sup>†</sup> Memory addresses 7FE0h through 7FEBh are reserved for Texas Instruments (TI™), and 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. # program ROM† The program ROM consists of 16K bytes of mask programmable read-only memory. The program ROM is used for permanent storage of data or instructions. Programming of the mask ROM is performed at the time of device fabrication. Refer to Figure 3 for ROM memory map. #### system reset The system-reset operation ensures an orderly start-up sequence for the TMS370Cx36 CPU-based device. There are up to three different actions that can cause a system reset to the device. Two of these actions are generated internally, while one (RESET pin) is controlled externally. These actions are as follows: - PACT watchdog (WD) timer. A watchdog-generated reset occurs if an improper value is written to the WD key register, or if the re-initialization does not occur before the watchdog timer timeout. See the TMS370 User's Guide (literature number SPNU127) for more information. - Oscillator reset. Reset occurs when the oscillator operates outside of the recommended operating range. See the *TMS370 User's Guide* (literature number SPNU127) for more information. - External RESET pin. A low level signal can trigger an external reset. To ensure a reset, the external signal should be held low for one SYSCLK cycle. Signals of less than one SYSCLK can generate a reset. See the *TMS370 User's Guide* (literature number SPNU127) for more information. Once a reset source is activated, the external $\overline{\text{RESET}}$ pin is driven (active) low for a minimum of eight SYSCLK cycles. This allows the 'x36 device to reset external system components. Additionally, if a cold start ( $V_{CC}$ is off for several hundred milliseconds) condition or oscillator failure occurs or the $\overline{\text{RESET}}$ pin is held low, then the reset logic holds the device in a reset state for as long as these actions are active. After a reset, the program can check the oscillator-fault flag (OSC FLT FLAG, SCCR0.4) and the cold-start flag (COLD START, SCCR0.7) to determine the source of the reset. A reset does not clear these flags. Table 6 lists the reset sources. If none of the sources indicated in Table 6 caused the reset, then the $\overline{\text{RESET}}$ pin was pulled low by the external hardware or the PACT module's watchdog. Table 6. Reset Sources | REGISTER | ADDRESS | PF | BIT NO. | CONTROL BIT | SOURCE OF RESET | |----------|---------|------|---------|--------------|-------------------------| | SCCR0 | 1010h | P010 | 7 | COLD START | Cold (power-up) | | SCCR0 | 1010h | P010 | 4 | OSC FLT FLAG | Oscillator out of range | Once a reset is activated, the following sequence of events occurs: - 1. The CPU registers are initialized: ST = 00h, SP = 01h (reset state). - 2. Registers A and B are initialized to 00h (no other RAM is changed). - 3. The contents of the LSbyte of the reset vector (07FFh) are read and stored in the PCL. - 4. The contents of the MSbyte of the reset vector (07FEh) are read and stored in the PCH. - 5. Program execution begins with an opcode fetch from the address pointed to the PC. The reset sequence takes 20 SYSCLK cycles from the time the reset pulse is released until the first opcode fetch. During a reset, RAM contents (except for registers A and B) remain unchanged, and the module control register bits are initialized to their reset state. <sup>†</sup> Memory addresses 7FE0h through 7FEBh are reserved for Texas Instruments, and 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. #### interrupts The TMS370 family software-programmable interrupt structure permits flexible on-chip and external interrupt configurations to meet real-time interrupt-driven application requirements. The hardware interrupt structure incorporates two priority levels as shown in Figure 5. Interrupt level 1 has a higher priority than interrupt level 2. The two priority levels can be masked independently by the global interrupt mask bits (IE1 and IE2) of the ST. Figure 5. Interrupt Control Each system interrupt is configured independently to 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 SPNS039B - JANUARY 1996 - REVISED FEBRUARY 1997 # interrupts (continued) chains is performed within the peripheral modules to support interrupt expansion for future modules. Pending interrupts are serviced upon completion of current instruction execution, depending on their interrupt mask and priority conditions. The TMS370Cx36 has 21 hardware system interrupts (plus RESET) as shown in Table 7. Each system interrupt has a dedicated vector located in program memory through which control is passed to the interrupt service routines. A system interrupt may have multiple interrupt sources. All of the interrupt sources are individually maskable by local interrupt enable control bits in the associated peripheral file. Each interrupt source FLAG bit is individually readable for software polling or for determining which interrupt source generated the associated system interrupt. Twenty of the system interrupts are generated by on-chip peripheral functions, and one external interrupt is supported. Software configuration of the external interrupts is performed through the INT1 control register in peripheral file frame 1. Each external interrupt is individually software configurable for input polarity (rising or falling edge) for ease of system interface. External interrupt INT1 is software configurable as either a maskable or non-maskable interrupt. When INT1 is configured as non-maskable, it cannot be masked by the individual-or global-enable mask bits. The INT1 NMI bit is protected during non-privileged operation and, therefore, should be configured during the initialization sequence following reset. To maximize pin flexibility, external interrupt INT1 can be software configured as a general-purpose input pin if the interrupt function is not required. # interrupts (continued) **Table 7. Hardware System Interrupts** | INTERRUPT<br>SOURCE | INTERRUPT<br>FLAG | OSC FLT FLG | SYSTEM<br>INTERRUPT | VECTOR<br>ADDRESS | MODULE<br>PRIORITY† | PRIORITY<br>IN<br>GROUP | |--------------------------------|---------------------------------------------------|-----------------------------------------|---------------------|-------------------|---------------------|-------------------------| | RESET | External RESET Watchdog Overflow Oscillator Fault | COLD START<br>(No Flag)<br>OSC FLT FLAG | RESET† | 7FFEh, 7FFFh | 1 | | | INT1 | External Interrupt 1 | INT1 FLAG | INT1 <sup>‡</sup> | 7FFCh, 7FFDh | 2 | | | SPI | SPI RX/TX Complete | SPI INT FLAG | SPIINT | 7FF6h, 7FF7h | 3 | | | | PACT Circular Buffer | Buffer Half/Full<br>Interrupt Flag | BUFINT | 7FB0h, 7FB1h | | 1 | | | PACT CP6 Event | CP6 INT FLAG | CP6INT | 7FB2h, 7FB3h | 1 | 2 | | | PACT CP5 Event | CP5 INT FLAG | CP5INT | 7FB4h, 7FB5h | 1 | 3 | | DACT (Croup 1) | PACT CP4 Event | CP4 INT FLAG | CP4INT | 7FB6h, 7FB7h | 4 | 4 | | PACI (Group 1) | PACT CP3 Event | CP3 INT FLAG | CP3INT | 7FB8h, 7FB9h | 1 4 | 5 | | | PACT CP2 Event | CP2 INT FLAG | CP2INT | 7FBAh, 7FBBh | ] | 6 | | | PACT CP1 Event | CP1 INT FLAG | CP1INT | 7FBCh, 7FBDh | | 7 | | | Default Timer<br>Overflow | DEFTIM OVRFL INT<br>FLAG | POVRL<br>INT | 7FBEh, 7FBFh | | 8 | | DACT (Croup 2) | PACT SCI Rx Int | PACT RX RDY | PRXINT | 7F9Eh, 7F9Fh | 5 | 1 | | PACT (Group 2) | PACT SCI Tx Int | PACT TX RDY | PTXINT | 7F9Ch, 7F9Dh | | 2 | | PACT (Group 1) PACT (Group 2) | PACT Cmd/Def Entry 0 | CMD/DEF INT 0 FLAG | CDINT 0 | 7FA0h, 7FA1h | | 1 | | | PACT Cmd/Def Entry 1 | CMD/DEF INT 1 FLAG | CDINT 1 | 7FA2h, 7FA3h | ] | 2 | | | PACT Cmd/Def Entry 2 | CMD/DEF INT 2 FLAG | CDINT 2 | 7FA4h, 7FA5h | | 3 | | PACT (Group 3) | PACT Cmd/Def Entry 3 | CMD/DEF INT 3 FLAG | CDINT 3 | 7FA6h, 7FA7h | 6 | 4 | | FACT (Group 3) | PACT Cmd/Def Entry 4 | CMD/DEF INT 4 FLAG | CDINT 4 | 7FA8h, 7FA9h | | 5 | | | PACT Cmd/Def Entry 5 | CMD/DEF INT 5 FLAG | CDINT 5 | 7FAAh, 7FABh | ] | 6 | | | PACT Cmd/Def Entry 6 | CMD/DEF INT 6 FLAG | CDINT 6 | 7FACh, 7FADh | ] | 7 | | | PACT Cmd/Def Entry 7 | CMD/DEF INT 7 FLAG | CDINT 7 | 7FAEh, 7FAFh | | 8 | | ADC1 | ADC1 Conversion Complete | AD INT FLAG | ADINT | 7FECh, 7FEDh | 7 | | <sup>†</sup> Relative priority within an interrupt level # privileged operation and EEPROM write protection override The TMS370Cx36 family is designed with significant flexibility to enable the designer to software-configure the system and peripherals to meet the requirements of a variety of applications. The nonprivileged mode of operation ensures the integrity of the system configuration, once it is defined for an application. Following a hardware reset, the TMS370Cx36 operates in the privileged mode, where all peripheral file registers have unrestricted read/write access, and the application program configures the system during the initialization sequence following reset. As the last step of system initialization, the PRIVILEGE DISABLE bit (SCCR2.0) is set to 1 to enter the nonprivileged mode, disabling write operations to specific configuration-control bits within the PF. Table 8 lists the control bits shown in the table which are write-protected during the nonprivileged mode and must be configured by software prior to exiting the privileged mode. <sup>‡</sup> Release microcontroller from STANDBY and HALT low-power modes # privileged operation and EEPROM write protection override (continued) **Table 8. Privilege Bits** | REGIS | TER† | CONTROL BIT | | | |---------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | NAME | LOCATION | CONTROL BIT | | | | SCCRO | P010.5<br>P010.6 | PF AUTO WAIT<br>OSC POWER | | | | SCCR1 | P011.2<br>P011.4 | MEMORY DISABLE<br>AUTOWAIT DISABLE | | | | SCCR2 | P012.0<br>P012.1<br>P012.3<br>P012.4<br>P012.6<br>P012.7 | PRIVILEGE DISABLE INT1 NMI CPU STEST BUS STEST PWRDWN/IDLE HALT/STANDBY | | | | SPIPRI | P03F.5<br>P03F.6<br>P03F.7 | SPI ESPEN<br>SPI PRIORITY<br>SPI STEST | | | | PACTSCR | P040.0<br>P040.1<br>P040.2<br>P040.3<br>P040.4 | PACT PRESCALE SELECT 0 PACT PRESCALE SELECT 1 PACT PRESCALE SELECT 2 PACT PRESCALE SELECT 3 FAST MODE SELECT | | | | PACTPRI | P04F.0<br>P04F.1<br>P04F.2<br>P04F.3<br>P04F.4<br>P04F.5<br>P04F.7 | PACT WD PRESCALE SELECT 0 PACT WD PRESCALE SELECT 1 PACT MODE SELECT PACT GROUP 3 PRIORITY PACT GROUP 2 PRIORITY PACT GROUP 1 PRIORITY PACT STEST | | | | ADPRI | P07F.5<br>P07F.6<br>P07F.7 | AD ESPEN AD PRIORITY AD STEST | | | <sup>†</sup> The privilege bits are shown in a bold typeface and shaded areas in the system configuration registers section of Table 10. #### low-power and IDLE modes The TMS370Cx36 devices have two low-power modes (STANDBY and HALT) and an IDLE mode. For mask-ROM devices, low-power modes can be disabled permanently through a programmable contact when the mask is manufactured. The STANDBY and HALT low-power modes significantly reduce power consumption by reducing or stopping the activity of the various on-chip peripherals when processing is not required. Each of the low-power modes is entered by executing the IDLE instruction when the PWRDWN/IDLE bit in SCCR2 has been set to 1. The HALT/STANDBY bit in SCCR2 controls the low-power mode selection. In the STANDBY mode (HALT/STANDBY = 0), all CPU activity and most peripheral module activity is stopped; however, the oscillator, internal clocks, the PACT counter, and the first PACT command entry remain active in all modules. System processing is suspended until a qualified interrupt (hardware $\overline{\text{RESET}}$ or external interrupt on INT1) is detected. In the HALT mode (HALT/STANDBY = 1), the TMS370Cx36 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 $\overline{\text{RESET}}$ or external interrupt on the INT1) is detected. The power-down mode-selection bits are summarized in Table 9. # low-power and IDLE modes (continued) Table 9. Low-Power/Idle Control Bits | POWER-DOWN | | | | |--------------------------|---------------------------|---------------|--| | PWRDWN/IDLE<br>(SCCR2.6) | HALT/STANDBY<br>(SCCR2.7) | MODE SELECTED | | | 1 | 0 | STANDBY | | | 1 | 1 | HALT | | | 0 | χ† | IDLE | | † X = Don't care When low-power modes are disabled through a programmable contact in the mask-ROM devices, writing to the SCCR2.6-7 bits is ignored. In addition, if an IDLE instruction is executed when low-power modes are disabled through a programmable contact, the device always enters the IDLE mode. To provide a method for always exiting low-power modes for mask-ROM devices, INT1 is enabled automatically as a nonmaskable interrupt (NMI) during low-power modes when the hard watchdog mode is selected. This means that the NMI is generated always, regardless of the interrupt enable flags. The following information is preserved throughout both the STANDBY and HALT modes: RAM (register file), CPU registers (SP, PC, and ST), I/O pin direction and output data, and status registers of all on-chip peripheral functions. Since all CPU instruction processing is stopped during the STANDBY and HALT modes, the clocking of the WD timer is inhibited. #### clock modules The 'x36 family provides two clock options that are referred to as divide-by-1 (phase-locked loop) and divide-by-4 (standard oscillator). Both the divide-by-1 and divide-by-4 options are configurable during the manufacturing process of a TMS370 microcontroller. The 'x36 masked-ROM devices offer both options to meet system engineering requirements. Only one of the two clock options is allowed on each ROM device. The '736A EPROM has only the divide-by-4. The divide-by-1 clock module option provides the capability for reduced electromagnetic interference (EMI) with no added cost. The divide-by-1 provides a one-to-one match of the external resonator frequency (CLKIN) to the internal system clock (SYSCLK) frequency, whereas the divide-by-4 produces a SYSCLK which is one-fourth the frequency of the external resonator. Inside of the divide-by-1 module, the frequency of the external resonator is multiplied by four, and the clock module then divides the resulting signal by four to provide the four-phased internal system clock signals. The resulting SYSCLK is equal to the resonator frequency. These are formulated as follows: Divide-by-4 option : SYSCLK = $$\frac{\text{external resonator frequency}}{4} = \frac{\text{CLKIN}}{4}$$ Divide-by-1 option : SYSCLK = $\frac{\text{external resonator frequency}}{4} = \text{CLKIN}$ The main advantage of choosing a divide-by-1 oscillator is the reduced EMI. The harmonics of low-speed resonators extend through fewer of the emissions spectrum than the harmonics of faster resonators. The divide-by-1 provides the capability of reducing the resonator speed by four times, and this results in a steeper decay of emissions produced by the oscillator. # system configuration registers Table 10 contains system-configuration and control functions and registers for controlling EEPROM programming. The privileged bits are shown in a bold typeface and shaded areas. Table 10. Peripheral File Frame 1: System-Configuration Registers | 1 | | | | | | | | | 1 | | |----------------------|------------------|-----------------|-----------------|-------------------------|---------------|-------------------|-------------|----------------------|--------|--| | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | | P010 | COLD<br>START | OSC<br>POWER | PF AUTO<br>WAIT | OSC FLT<br>FLAG | MC PIN<br>WPO | MC PIN<br>DATA | 1 | μΡ/μC<br>MODE | SCCR0 | | | P011 | _ | _ | _ | AUTO<br>WAIT<br>DISABLE | _ | MEMORY<br>DISABLE | _ | _ | SCCR1 | | | P012 | HALT/<br>STANDBY | PWRDWN/<br>IDLE | _ | BUS<br>STEST | CPU<br>STEST | _ | INT1<br>NMI | PRIVILEGE<br>DISABLE | SCCR2 | | | P013 | | | | | | | | | | | | to | Reserved | | | | | | | | | | | P016 | | | | | | _ | | | ] | | | P017 | INT1 | INT1 | | _ | | INT1 | INT1 | INT1 | INT1 | | | 1017 | FLAG | PIN DATA | | | | POLARITY | PRIORITY | ENABLE | ]'''' | | | P018 | | | | Res | erved | | | | | | | P019 | | | | Res | erved | | | | ] | | | P01A | BUSY | _ | _ | _ | _ | AP | W1W0 | EXE | DEECTL | | | P01B | Reserved | | | | | | | | | | | P01C | BUSY | VPPS | _ | _ | _ | _ | W0 | EXE | EPCTLL | | | P01D<br>P01E<br>P01F | Reserved | | | | | | | | | | # digital port control registers Peripheral file frame 2 contains the digital I/O pin configuration and control registers. Table 11 shows the specific addresses, registers, and control bits within this peripheral file frame. Table 12 shows the port configuration register setup. Table 11. Peripheral File Frame 2: Digital Port-Control Registers | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | | | | |------------|----------------------------------------------------|-------------|------------------|-------------|-------|-------|-------|-------|--------|--|--| | P020 | Reserved | | | | | | | | | | | | P021 | Port A Control Register 2 (must be 0) | | | | | | | | | | | | P022 | Port A Data | | | | | | | | | | | | P023 | Port A Direction | | | | | | | | | | | | P024 | · | | | | | | | | | | | | to<br>P02B | Reserved | | | | | | | | | | | | P02C | | Port D Cont | trol Register 1 | (must be 0) | | _ | _ | _ | DPORT1 | | | | P02D | Port D Control Register 2 (must be 0) <sup>†</sup> | | | | | _ | _ | _ | DPORT2 | | | | P02E | Port D Data | | | | | _ | _ | _ | DDATA | | | | P02F | | F | Port D Direction | ١ | 0 | _ | _ | _ | DDIR | | | <sup>&</sup>lt;sup>†</sup> To configure pin D3 as SYSCLK, set port D control register 2 = 08h. Table 12. Port Configuration Register Setup | PORT | PIN | abcd<br>00q1 | abcd<br>00y0 | | | | | | |------------------------------------------------------------------------------------|-------|--------------|--------------|--|--|--|--|--| | А | 0 – 7 | Data out q | Data In y | | | | | | | D | 3 – 7 | Data out q | Data In y | | | | | | | a = Port x Control Register 1 b = Port x Control Register 2 c = Data d = Direction | | | | | | | | | #### serial peripheral interface The SPI is a high-speed synchronous serial I/O port that allows a serial bit stream of programmed length (one to eight bits) to be shifted into and out of the device at a programmable bit transfer rate. The SPI normally is used for communications between the microcontroller and external peripherals or another microcontroller. Typical applications include external I/O or peripheral expansion by way of devices such as shift registers, display drivers, and A/D converters. Multi-device communications are supported by the master/slave operation of the SPI. The SPI module features include the following: - Three external pins - SPISOMI: SPI slave output/master input pin or general-purpose bidirectional I/O pin - SPISIMO: SPI slave input/master output pin or general-purpose bidirectional I/O pin - SPICLK: SPI serial clock pin or general-purpose bidirectional I/O pin - Two operational modes: Master and slave # serial peripheral interface (continued) Baud rate: Eight different programmable rates Maximum baud rate in master mode: 2.5M bps at 5-MHz SYSCLK SPI BAUD RATE = $$\frac{\text{SYSCLK}}{2 \times 2^{\text{b}}}$$ where b=bit rate in SPICCR.5-3 (range 0-7) Maximum baud rate in slave mode: 625K bps at 5-MHz SYSCLK for maximum slave SPI BAUD RATE < SYSCLK/8</li> Data word format: one to eight data bits • Simultaneous receiver and transmitter operations (transmit function can be disabled in software) • Transmitter and receiver operations are accomplished through either interrupt-driven or polled algorithms. Seven SPI module control registers located in control register frame beginning at address P030h The SPI module-control registers are listed in Table 13. Table 13. SPI Module-Control Register Memory Map | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | | |--------------------|---------------------|---------------------|---------------------|---------------------|--------------------|---------------------|---------------------|---------------------|--------|--|--| | P030 | SPI SW<br>RESET | CLOCK<br>POLARITY | SPI BIT<br>RATE2 | SPI BIT<br>RATE1 | SPI BIT<br>RATE0 | SPI<br>CHAR2 | SPI<br>CHAR1 | SPI<br>CHAR0 | SPICCR | | | | P031 | RECEIVER<br>OVERRUN | SPI INT<br>FLAG | _ | _ | _ | MASTER/<br>SLAVE | TALK | SPI INT<br>ENA | SPICTL | | | | P032<br>to<br>P036 | | | | Rese | erved | | | | | | | | P037 | RCVD7 | RCVD6 | RCVD5 | RCVD4 | RCVD3 | RCVD2 | RCVD1 | RCVD0 | SPIBUF | | | | P038 | RESERVED | | | | | | | | | | | | P039 | SDAT7 | SDAT6 | SDAT5 | SDAT4 | SDAT3 | SDAT2 | SDAT1 | SDAT0 | SPIDAT | | | | P03A<br>to<br>P03C | | | | Rese | erved | | | | | | | | P03D | | _ | _ | | SPICLK<br>DATA IN | SPICLK<br>DATA OUT | SPICLK<br>FUNCTION | SPICLK<br>DATA DIR | SPIPC1 | | | | P03E | SPISIMO<br>DATA IN | SPISIMO<br>DATA OUT | SPISIMO<br>FUNCTION | SPISIMO<br>DATA DIR | SPISOMI<br>DATA IN | SPISOMI<br>DATA OUT | SPISOMI<br>FUNCTION | SPISOMI<br>DATA DIR | SPIPC2 | | | | P03F | SPI<br>STEST | SPI<br>PRIORITY | SPI<br>ESPEN | _ | _ | _ | _ | _ | SPIPRI | | | # serial peripheral interface (continued) The SPI block diagram is illustrated in Figure 6. † The block diagram is shown in slave mode. Figure 6. SPI Block Diagram #### programmable acquisition and control timer (PACT) module Traditionally, timers in microcontrollers provide limited capture and compare functions consuming significant CPU processing power and leading to inaccurate timings due to interrupt latencies. The programmable acquisition and control timer (PACT) acts as a coprocessor combining configurable capture and compare features, within a flexible dual-port RAM, able to run real-time tasks with little or no CPU intervention. The PACT structure allows concatenation of tasks, thus enabling the CPU to perform data manipulation while the PACT module both captures and outputs real-time-related information. Since all the PACT control information is held within the dual-port Ram, the CPU can access these parameters quickly. To use the PACT, the user must set up three distinct areas of memory. The first is the dual-port RAM, which contains the capture area, the commands, and the timer definitions. The second is the peripheral frame. The third is an area near the end of the program memory which holds the interrupt vectors of PACT. # programmable acquisition and control timer (PACT) module (continued) The PACT module features include the following: - Input-capture functions on up to six input pins (CP1 to CP6), depending on the mode selected: - Mode A: CP1-2 are dedicated capture, CP3-6 are circular buffer capture, and CP6 is also an event pin. - Mode B: CP1-4 are dedicated capture, CP5-6 are circular buffer capture, and CP6 is also an event pin. - Multiple timer-driven outputs on eight pins (OP1 to OP8) - Standard compare command: set or clear an output pin whenever the timer/counter is equal to a certain value - Virtual timers: enable variations of the PWM's period and provides periodic interrupts to the processor. - Double event-compare command: comparisons of the 8-bit event counter with two event-compare values and the actions that can be performed are based on each value: - Event-compare 1 matching the event counter: sets or resets the selected output pin (OP1–OP8), generates interrupt, and generates a 32-bit capture into the circular buffer. - Event-compare 2 matching the event counter: sets or resets the selected output pin (OP1–OP8), generates interrupt, generates a 32-bit capture into the circular buffer, and resets the 20-bit default timer. - Offset timer definition-time from last event: - Generates an interrupt when the maximum event count is reached - Stores the 16-bit virtual timer in the circular buffer on each event - Stores the 20-bit default timer and 8-bit event counter in the circular buffer when the maximum event count is reached - Resets the 20-bit hardware default timer when the maximum event count is reached. - Conditional-compare command has a timer-compare value and an event-compare value. - Generates an interrupt when the event-compare value equals the event counter and the timer-compare value equals the last defined timer - Sets or clears one of the seven output pins (OP1–OP7) when the event compare value equals the event counter and the timer-compare value equals the last defined timer - Baud rate timer definition: runs the mini-serial communications port built into the PACT module. - Configurable timer overflow rates - One 8-bit event counter driven by CP6 - Up to 20-bit timer capability - Interaction between event counter and timer activity - Register-based organization allowing direct access to timer parameters by the CPU - 18 independent interrupt vectors with two priority levels - Integrated, configurable watchdog with selectable time-out period # programmable acquisition and control timer (PACT) module (continued) - Mini-serial communications interface works as a simplified full duplex universal asychronous receiver/transmitter (UART) with independent setup of baud rate for receive and transmit lines. - $\quad \text{Asynchronous communications mode} \\ \quad \text{Asynchronous Baud} = \frac{1}{(\text{Max Virtual Timer Value}) \times (4) \times (\text{PACT Resolution})} 2 \\ \quad \text{where PACT Resolution} = \text{SYSCLK} \times \text{Prescale Value}$ # PACT block diagram The PACT module block diagram is illustrated in Figure 7. Figure 7. PACT Block diagram # **PACT** control registers The PACT module is controlled and accessed through registers in peripheral frame 4. These registers are listed in Table 14. The bits in shaded boxes are privileged mode bits; that is, they can be written to only in the privileged mode. **Table 14. PACT Control Registers** | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | |------|--------------------------------|---------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|--------------------------------|---------------------------------|---------------------------------|---------| | P040 | DEFTIM<br>OVRFL<br>INT ENA | DEFTIM<br>OVRFL<br>INT FLAG | CMD/DEF<br>AREA ENA | FAST<br>MODE<br>SELECT | PACT<br>PRESCALE<br>SELECT3 | PACT<br>PRESCALE<br>SELECT2 | PACT<br>PRESCALE<br>SELECT1 | PACT<br>PRESCALE<br>SELECT0 | PACTSCR | | P041 | CMD/DEF<br>AREA<br>INT ENA | ı | CMD/DEF<br>AREA<br>START BIT 5 | CMD/DEF<br>AREA<br>START BIT 4 | CMD/DEF<br>AREA<br>START BIT 3 | CMD/DEF<br>AREA<br>START BIT 2 | | | CDSTART | | P042 | | CMD/DEF<br>AREA<br>END BIT 6 | CMD/DEF<br>AREA<br>END BIT 5 | CMD/DEF<br>AREA<br>END BIT 4 | CMD/DEF<br>AREA<br>END BIT 3 | CMD/DEF<br>AREA END<br>BIT 2 | | | CDEND | | P043 | 1 | 1 | BUFFER<br>POINTER<br>BIT 5 | BUFFER<br>POINTER<br>BIT 4 | BUFFER<br>POINTER<br>BIT 3 | BUFFER<br>POINTER<br>BIT 2 | BUFFER<br>POINTER<br>BIT 1 | _ | BUFPTR | | P044 | | | | Rese | erved | | | | | | P045 | PACT<br>RXRDY | PACT<br>TXRDY | PACT<br>PARITY | PACT FE | PACT SCI<br>RX INT ENA | PACT SCI<br>TX INT ENA | _ | PACT SCI<br>SW RESET | SCICTLP | | P046 | PACT<br>RXDT7 | PACT<br>RXDT6 | PACT<br>RXDT5 | PACT<br>RXDT4 | PACT<br>RXDT3 | PACT<br>RXDT2 | PACT<br>RXDT1 | PACT<br>RXDT0 | RXBUFP | | P047 | PACT<br>TXDT7 | PACT<br>TXDT6 | PACT<br>TXDT5 | PACT<br>TXDT4 | PACT<br>TXDT3 | PACT<br>TXDT2 | PACT<br>TXDT1 | PACT<br>TXDT0 | TXBUFP | | P048 | PACT OP8<br>STATE | PACT OP7<br>STATE | PACT OP6<br>STATE | PACT OP5<br>STATE | PACT OP4<br>STATE | PACT OP3<br>STATE | PACT OP2<br>STATE | PACT OP1<br>STATE | PSTATE | | P049 | CMD/DEF<br>INT 7 FLAG | CMD/DEF<br>INT 6 FLAG | CMD/DEF<br>INT 5 FLAG | CMD/DEF<br>INT 4 FLAG | CMD/DEF<br>INT 3 FLAG | CMD/DEF<br>INT 2 FLAG | CMD/DEF<br>INT 1 FLAG | CMD/DEF<br>INT 0 FLAG | CDFLAGS | | P04A | CP2 INT<br>ENA | CP2 INT<br>FLAG | CP2 CAPT<br>RISING<br>EDGE | CP2 CAPT<br>FALLING<br>EDGE | CP1 INT<br>ENA | CP1 INT<br>FLAG | CP1 CAPT<br>RISING<br>EDGE | CP1 CAPT<br>FALLING<br>EDGE | CPCTL1 | | P04B | CP4 INT<br>ENA | CP4 INT<br>FLAG | CP4 CAPT<br>RISING<br>EDGE | CP4 CAPT<br>FALLING<br>EDGE | CP3 INT<br>ENA | CP3 INT<br>FLAG | CP3 CAPT<br>RISING<br>EDGE | CP3 CAPT<br>FALLING<br>EDGE | CPCTL2 | | P04C | CP6 INT<br>ENA | CP6 INT<br>FLAG | CP6 CAPT<br>RISING<br>EDGE | CP6 CAPT<br>FALLING<br>EDGE | CP5 INT<br>ENA | CP5 INT<br>FLAG | CP5 CAPT<br>RISING<br>EDGE | CP5 CAPT<br>FALLING<br>EDGE | CPCTL3 | | P04D | BUFFER<br>HALF/FULL<br>INT ENA | BUFFER<br>HALF/FULL<br>INT FLAG | INPUT<br>CAPT<br>PRESCALE<br>SELECT 3 | INPUT<br>CAPT<br>PRESCALE<br>SELECT 2 | INPUT<br>CAPT<br>PRESCALE<br>SELECT 1 | CP6 EVENT<br>ONLY | EVENT<br>COUNTER<br>SW RESET | OP/ SET/CLR<br>SELECT | CPPRE | | P04E | | | | WATCHDOO | REST KEY | | | | WDRST | | P04F | PACT<br>STEST | PACT<br>SUSPEND | PACT<br>GROUP 1<br>PRIORITY | PACT<br>GROUP 2<br>PRIORITY | PACT<br>GROUP 3<br>PRIORITY | PACT<br>MODE<br>SELECT | PACT WD<br>PRESCALE<br>SELECT 1 | PACT WD<br>PRESCALE<br>SELECT 0 | PACTPRI | # analog-to-digital converter 1 module The analog-to-digital converter 1 (ADC1) module is an 8-bit, successive approximation converter with internal sample-and-hold circuitry. The module has four multiplexed analog input channels that allow the processor to convert the voltage levels from up to eight different sources. The ADC1 module features include the following: - Minimum conversion time: 32.8 μs at 5-MHz SYSCLK - Ten external pins: - Eight analog-input channels (AN0-AN7), any of which can be software-configured as digital inputs (E0-E7) when not needed as analog channels - AN1-AN7 also can be configured as positive-input voltage reference. - V<sub>CC3</sub>: ADC1 module high-voltage reference input - V<sub>SS3</sub>: ADC1 module low-voltage reference input - The ADDATA register, which contains the digital result of the last ADC1 conversion. - ADC1 operations can be accomplished through either interrupt-driven or polled algorithms. - Six ADC1 module control registers located in the control-register frame beginning at address 1070h The ADC1 module control registers are listed in Table 15. **Table 15. ADC1 Module Control Register Memory Map** | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | | |--------------------|------------------------------|-----------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--------|--|--| | P070 | CONVERT<br>START | SAMPLE<br>START | REF VOLT<br>SELECT2 | REF VOLT<br>SELECT1 | REF VOLT<br>SELECT0 | AD INPUT<br>SELECT2 | AD INPUT<br>SELECT1 | AD INPUT<br>SELECT0 | ADCTL | | | | P071 | _ | | - | | - | AD READY | AD INT<br>FLAG | AD INT<br>ENA | ADSTAT | | | | P072 | A/D Conversion Data Register | | | | | | | | | | | | P073<br>to<br>P07C | RESERVED | | | | | | | | | | | | P07D | | | | Port E Data I | nput Register | | | | ADIN | | | | P07E | Port E Input Enable Register | | | | | | | | | | | | P07F | AD STEST | AD<br>PRIORITY | AD ESPEN | _ | _ | _ | _ | _ | ADPRI | | | # analog-to-digital converter 1 module (continued) The ADC1 module block diagram is illustrated in Figure 8. Figure 8. ADC1 Block Diagram # TMS370Cx36 8-BIT MICROCONTROLLER SPNS039B - JANUARY 1996 - REVISED FEBRUARY 1997 #### instruction set overview Table 16 provides an opcode to instruction cross reference of all 73 instructions and 274 opcodes of the '370Cx36 instruction set. The numbers at the top of this table represent the most significant nibble (MSN) of the opcode while the numbers at the left side of the table represent the least significant nibble (LSN). The instruction of these two opcode nibbles contains the mnemonic, operands, and byte/cycle particular to that opcode. For example, the opcode B5h points to the CLR A instruction. This instruction contains one byte and executes in eight SYSCLK cycles. # Table 16. TMS370 Family Opcode/Instruction Map† | | | | | | | | | | IVIOIN | | | | | | | | |---|-------------------|-------------------------|------------------------|------------------------|--------------------------|------------------------|------------------------|--------------------------|-------------------------|-------------------------|----------------------------|------------------------|---------------------------|-----------------------|--------------------|-----------------------------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | Е | F | | 0 | JMP<br>#ra<br>2/7 | | | | | | | INCW<br>#ra,Rd<br>3/11 | MOV<br>Ps,A<br>2/8 | | | CLRC /<br>TST A<br>1/9 | MOV<br>A,B<br>1/9 | MOV<br>A,Rd<br>2/7 | TRAP<br>15<br>1/14 | LDST<br>n<br>2/6 | | 1 | JN<br>ra<br>2/5 | | MOV<br>A,Pd<br>2/8 | | | MOV<br>B,Pd<br>2/8 | | MOV<br>Rs,Pd<br>3/10 | | MOV<br>Ps,B<br>2/7 | | | | MOV<br>B,Rd<br>2/7 | TRAP<br>14<br>1/14 | MOV<br>#ra[SP],A<br>2/7 | | 2 | JZ<br>ra<br>2/5 | MOV<br>Rs,A<br>2/7 | MOV<br>#n,A<br>2/6 | MOV<br>Rs,B<br>2/7 | MOV<br>Rs,Rd<br>3/9 | MOV<br>#n,B<br>2/6 | MOV<br>B,A<br>1/8 | MOV<br>#n,Rd<br>3/8 | | | MOV<br>Ps,Rd<br>3/10 | DEC<br>A<br>1/8 | DEC<br>B<br>1/8 | DEC<br>Rd<br>2/6 | TRAP<br>13<br>1/14 | MOV<br>A,*ra[SP]<br>2/7 | | 3 | JC<br>ra<br>2/5 | AND<br>Rs,A<br>2/7 | AND<br>#n,A<br>2/6 | AND<br>Rs,B<br>2/7 | AND<br>Rs,Rd<br>3/9 | AND<br>#n,B<br>2/6 | AND<br>B,A<br>1/8 | AND<br>#n,Rd<br>3/8 | AND<br>A,Pd<br>2/9 | AND<br>B,Pd<br>2/9 | AND<br>#n,Pd<br>3/10 | INC<br>A<br>1/8 | INC<br>B<br>1/8 | INC<br>Rd<br>2/6 | TRAP<br>12<br>1/14 | CMP<br>*n[SP],A<br>2/8 | | 4 | JP<br>ra<br>2/5 | OR<br>Rs,A<br>2/7 | OR<br>#n,A<br>2/6 | OR<br>Rs,B<br>2/7 | OR<br>Rs,Rd<br>3/9 | OR<br>#n,B<br>2/6 | OR<br>B,A<br>1/8 | OR<br>#n,Rd<br>3/8 | OR<br>A,Pd<br>2/9 | OR<br>B,Pd<br>2/9 | OR<br>#n,Pd<br>3/10 | INV<br>A<br>1/8 | INV<br>B<br>1/8 | INV<br>Rd<br>2/6 | TRAP<br>11<br>1/14 | extend<br>inst,2<br>opcodes | | 5 | JPZ<br>ra<br>2/5 | XOR<br>Rs,A<br>2/7 | XOR<br>#n,A<br>2/6 | XOR<br>Rs,B<br>2/7 | XOR<br>Rs,Rd<br>3/9 | XOR<br>#n,B<br>2/6 | XOR<br>B,A<br>1/8 | XOR<br>#n,Rd<br>3/8 | XOR<br>A,Pd<br>2/9 | XOR<br>B,Pd<br>2/9 | XOR<br>#n,Pd<br>3/10 | CLR<br>A<br>1/8 | CLR<br>B<br>1/8 | CLR<br>Rn<br>2/6 | TRAP<br>10<br>1/14 | | | 6 | JNZ<br>ra<br>2/5 | BTJO<br>Rs,A,ra<br>3/9 | BTJO<br>#n,A,ra<br>3/8 | BTJO<br>Rs,B,ra<br>3/9 | BTJO<br>Rs,Rd,ra<br>4/11 | BTJO<br>#n,B,ra<br>3/8 | BTJO<br>B,A,ra<br>2/10 | BTJO<br>#n,Rd,ra<br>4/10 | BTJO<br>A,Pd,ra<br>3/11 | BTJO<br>B,Pd,ra<br>3/10 | BTJO<br>#n,Pd,ra<br>4/11 | XCHB<br>A<br>1/10 | XCHB A /<br>TST B<br>1/10 | XCHB<br>Rn<br>2/8 | TRAP<br>9<br>1/14 | IDLE<br>1/6 | | 7 | JNC<br>ra<br>2/5 | BTJZ<br>Rs.,A,ra<br>3/9 | BTJZ<br>#n,A,ra<br>3/8 | BTJZ<br>Rs,B,ra<br>3/9 | BTJZ<br>Rs,Rd,ra<br>4/11 | BTJZ<br>#n,B,ra<br>3/8 | BTJZ<br>B,A,ra<br>2/10 | BTJZ<br>#n,Rd,ra<br>4/10 | BTJZ<br>A,Pd,ra<br>3/10 | BTJZ<br>B,Pd,ra<br>3/10 | BTJZ<br>#n,Pd,ra<br>4/11 | SWAP<br>A<br>1/11 | SWAP<br>B<br>1/11 | SWAP<br>Rn<br>2/9 | TRAP<br>8<br>1/14 | MOV<br>#n,Pd<br>3/10 | | 8 | JV<br>ra<br>2/5 | ADD<br>Rs,A<br>2/7 | ADD<br>#n,A<br>2/6 | ADD<br>Rs,B<br>2/7 | ADD<br>Rs,Rd<br>3/9 | ADD<br>#n,B<br>2/6 | ADD<br>B,A<br>1/8 | ADD<br>#n,Rd<br>3/8 | MOVW<br>#16,Rd<br>4/13 | MOVW<br>Rs,Rd<br>3/12 | MOVW<br>#16[B],Rpd<br>4/15 | PUSH<br>A<br>1/9 | PUSH<br>B<br>1/9 | PUSH<br>Rd<br>2/7 | TRAP<br>7<br>1/14 | SETC<br>1/7 | | 9 | JL<br>ra<br>2/5 | ADC<br>Rs,A<br>2/7 | ADC<br>#n,A<br>2/6 | ADC<br>Rs,B<br>2/7 | ADC<br>Rs,Rd<br>3/9 | ADC<br>#n,B<br>2/6 | ADC<br>B,A<br>1/8 | ADC<br>#n,Rd<br>3/8 | JMPL<br>lab<br>3/9 | JMPL<br>*Rp<br>2/8 | JMPL<br>*lab[B]<br>3/11 | POP<br>A<br>1/9 | POP<br>B<br>1/9 | POP<br>Rd<br>2/7 | TRAP<br>6<br>1/14 | RTS<br>1/9 | | Α | JLE<br>ra<br>2/5 | SUB<br>Rs,A<br>2/7 | SUB<br>#n,A<br>2/6 | SUB<br>Rs,B<br>2/7 | SUB<br>Rs,Rd<br>3/9 | SUB<br>#n,B<br>2/6 | SUB<br>B,A<br>1/8 | SUB<br>#n,Rd<br>3/8 | MOV<br>& lab,A<br>3/10 | MOV<br>*Rp,A<br>2/9 | MOV<br>*lab[B],A<br>3/12 | DJNZ<br>A,#ra<br>2/10 | DJNZ<br>B,#ra<br>2/10 | DJNZ<br>Rd,#ra<br>3/8 | TRAP<br>5<br>1/14 | RTI<br>1/12 | | В | JHS<br>ra<br>2/5 | SBB<br>Rs,A<br>2/7 | SBB<br>#n,A<br>2/6 | SBB<br>Rs,B<br>2/7 | SBB<br>Rs,Rd<br>3/9 | SBB<br>#n,B<br>2/6 | SBB<br>B,A<br>1/8 | SBB<br>#n,Rd<br>3/8 | MOV<br>A, & lab<br>3/10 | MOV<br>A, *Rp<br>2/9 | MOV<br>A,*lab[B]<br>3/12 | COMPL<br>A<br>1/8 | COMPL<br>B<br>1/8 | COMPL<br>Rd<br>2/6 | TRAP<br>4<br>1/14 | PUSH<br>ST<br>1/8 | <sup>&</sup>lt;sup>†</sup> All conditional jumps (opcodes 01-0F), BTJO, BTJZ, and DJNZ instructions use two additional cycles if the branch is taken. The BTJO, BTJZ, and DJNZ instructions have a relative address as the last operand. TMS370Cx36 8-BIT MICROCONTROLLER SPNS039B – JANUARY 1996 – REVISED FEBRUARY 1997 # lemplate Release Date: /-11-94 # TEXAS INSTRUMENT POST OFFICE BOX 1443\* HOUSTON, TEX L S N # Table 16. TMS370 Family Opcode/Instruction Map† (Continued) | | | | | | | | | | MSN | | | | | | | | |---|------------------|---------------------|---------------------|---------------------|----------------------|---------------------|--------------------|----------------------|------------------------|----------------------|--------------------------|-----------------|-----------------|------------------|-------------------|------------------| | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Α | В | С | D | E | F | | С | JNV<br>ra<br>2/5 | MPY<br>Rs,A<br>2/46 | MPY<br>#n,A<br>2/45 | MPY<br>Rs,B<br>2/46 | MPY<br>Rs,Rd<br>3/48 | MPY<br>#n,B<br>2/45 | MPY<br>B,A<br>1/47 | MPY<br>#n,Rs<br>3/47 | BR<br>lab<br>3/9 | BR<br>*Rp<br>2/8 | BR<br>*lab[B]<br>3/11 | RR<br>A<br>1/8 | RR<br>B<br>1/8 | RR<br>Rd<br>2/6 | TRAP<br>3<br>1/14 | POP<br>ST<br>1/8 | | D | JGE<br>ra<br>2/5 | CMP<br>Rs,A<br>2/7 | CMP<br>#n,A<br>2/6 | CMP<br>Rs,B<br>2/7 | CMP<br>Rs,Rd<br>3/9 | CMP<br>#n,B<br>2/6 | CMP<br>B,A<br>1/8 | CMP<br>#n,Rd<br>3/8 | CMP<br>& lab,A<br>3/11 | CMP<br>*Rp,A<br>2/10 | CMP<br>*lab[B],A<br>3/13 | RRC<br>A<br>1/8 | RRC<br>B<br>1/8 | RRC<br>Rd<br>2/6 | TRAP<br>2<br>1/14 | LDSP<br>1/7 | | Е | JG<br>ra<br>2/5 | DAC<br>Rs,A<br>2/9 | DAC<br>#n,A<br>2/8 | DAC<br>Rs,B<br>2/9 | DAC<br>Rs,Rd<br>3/11 | DAC<br>#n,B<br>2/8 | DAC<br>B,A<br>1/10 | DAC<br>#n,Rd<br>3/10 | CALL<br>lab<br>3/13 | CALL<br>*Rp<br>2/12 | CALL<br>*lab[B]<br>3/15 | RL<br>A<br>1/8 | RL<br>B<br>1/8 | RL<br>Rd<br>2/6 | TRAP<br>1<br>1/14 | STSP<br>1/8 | | F | JLO<br>ra<br>2/5 | DSB<br>Rs,A<br>2/9 | DSB<br>#n,A<br>2/8 | DSB<br>Rs,B<br>2/9 | DSB<br>Rs,Rd<br>3/11 | DSB<br>#n,B<br>2/8 | DSB<br>B,A<br>1/10 | DSB<br>#n,Rd<br>3/10 | CALLR<br>lab<br>3/15 | CALLR<br>*Rp<br>2/14 | CALLR<br>*lab[B]<br>3/17 | RLC<br>A<br>1/8 | RLC<br>B<br>1/8 | RLC<br>Rd<br>2/6 | TRAP<br>0<br>1/14 | NOP<br>1/7 | | | Second byte of two-byte instructions (F4xx): | F4 | 8 | MOVW<br>*n[Rn]<br>4/15 | DIV<br>Rn.A<br>3/14-63 | |-----------------------------------------------------------------------------|----------------------------------------------|----|-----|------------------------|------------------------| | | | F4 | 9 | JMPL<br>*n[Rn]<br>4/16 | | | Legend: | | E4 | Δ. | MOV<br>*=[D=] A | | | * = Indirect addressing operand prefix & = Direct addressing operand prefix | | F4 | Α | *n[Rn],A<br>4/17 | | | # = immediate operand | | | | MOV | | | #16 = immediate 16-bit number | | F4 | В | A,*n[Rn] | l | | lab = 16-label | | | | 4/16 | | | n = immediate 8-bit number | | | | BR | | | Pd = Peripheral register containing destination type | | F4 | С | *n[Rn] | | | Pn = Peripheral register | | | , i | 4/16 | | | Ps = Peripheral register containing source byte | | | | OMP | | | ra = Relative address | | F4 | D | CMP<br>*n[Rn],A | | | Rd = Register containing destination type | | 17 | 5 | 4/18 | | | Rn = Register file | | | | | | | Rp = Register pair | | | _ | CALL | | | Rpd = Destination register pair | | F4 | Е | *n[Rn] | | | Rps = Source Register pair | | | | 4/20 | | | Rs = Register containing source byte | | | | CALLR | | | | | F4 | F | *n[Rn]<br>4/22 | | <sup>&</sup>lt;sup>†</sup> All conditional jumps (opcodes 01-0F), BTJO, BTJZ, and DJNZ instructions use two additional cycles if the branch is taken. The BTJO, BTJZ, and DJNZ instructions have a relative address as the last operand. #### development system support The TMS370 family development support tools include an assembler, a C-compiler, a linker, CDT and an EEPROM/UVEPROM programmer. - Assembler/linker (Part No. TMDS3740850–02 for PC) - Includes extensive macro capability - Provides high-speed operation - Includes format conversion utilities for popular formats - ANSI C Compiler (Part No. TMDS3740855–02 for PC, Part No. TMDS3740555–09 for HP700<sup>™</sup>, Sun-3<sup>™</sup> or Sun-4<sup>™</sup>) - Generate assembly code for the TMS370 that can be inspected easily - Improves code execution speed and reduces code size with optional optimizer pass - Enables direct reference the TMS370's port registers by using a naming convention - Provides flexibility in specifying the storage for data objects - Interfaces C functions and assembly functions easily - Includes assembler and linker - CDT370 (Compact Development Tool) PACT real-time in-circuit emulation - Base (Part Number EDSCDT37P for PC, requires cable) - Cable for 44-pin PLCC (Part No. EDSTRG44PLCC36) - EEPROM and EPROM programming support - Allows inspection and modification of memory locations - Includes compatibility to upload/download program and data memory - Execute programs and software routines - Includes 1024-sample trace buffer - Includes single-step executable instructions - Uses software breakpoints to halt program execution at selected address - Microcontroller programmer - Base (Part No. TMDS3760500A for PC, requires programmer head) - Single unit head for 44-pin PLCC (Part No. TMDS3780512A) - PC-based, window/function-key-oriented user interface for ease of use and rapid learning environment TEXAS INSTRUMENTS POST OFFICE BOX 1443 • HOUSTON, TEXAS 77251–1443 # device numbering conventions Figure 9 illustrates the numbering and symbol nomenclature for the TMS370Cx36 family. Figure 9. TMS370Cx36 Family Nomenclature # device part numbers Table 17 provides a listing of all the 'x36 devices available. The device part number nomenclature is designed to assist ordering. Upon ordering, the customer must specify not only the device part number, but also the clock and watchdog timer options desired. Each device can have only one of the three possible watchdog timer options and one of the two clock options. The options to be specified pertain solely to orders involving ROM devices. **Table 17. Device Part Numbers** | DEVICE PART NUMBERS<br>FOR 44 PINS (LCC) | |----------------------------------------------------| | TMS370C036AFNA<br>TMS370C036AFNL<br>TMS370C036AFNT | | TMS370C736AFNT | | SE370C736AFZT <sup>†</sup> | <sup>†</sup> System evaluators are for use in prototype environment, and their reliability has not been characterized. # new code release form Figure 10 shows a sample of the new code release form. | | TEXAS INS | EELEASE FORM STRUMENTS DATE: TROLLER PRODUCTS | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | To release a new customer algorithm to T | I incorporated into a TMS370 family | microcontroller, complete this form and submit with the following information: | | | | OM (Verification file will be returned via same media) prated in TI's applicable device data book. | | Company Name: Street Address: | | Contact Mr./Ms.: Ext.: | | Street Address: State | Zip | Customer Purchase Order Number: | | Customer Part Number:Customer Application: | | Customer Print Number *Yes: # No: (Std. spec to be followed) *If Yes: Customer must provide "print" to TI w/NCRF for approval before ROM code processing starts. | | TMS370 Device: | | | | TI Customer ROM Number: (provided by Texas Instruments) | | CONTACT OPTIONS FOR THE 'A' VERSION TMS370 MICROCONTROLLERS | | OSCILLATOR FREQUENCY | TYP MAX | Low Power Modes Watchdog counter Clock Type [] Enabled [] Standard [] Standard (/4) [] Disabled [] Hard Enabled [] PLL (/1) [] Simple Counter | | [] Supply Voltage MIN: Note that the state of o | лах: | NOTE: Non 'A' version ROM devices of the TMS370 microcontrollers will have the "Low-power modes Enabled", "Divide-by-4" Clock, and "Standard" Watchdog options. See the <i>TMS370 Family User's Guide</i> (literature number SPNU127) or the <i>TMS370 Family Data Manual</i> (literature number SPNS014B). | | TEMPERATURE RANGE [] 'L': 0° to 70°C (standard) [] 'A': -40° to 85°C [] 'T': -40° to 105°C | | PACKAGE TYPE [] "N' 28-pin PDIP [] "FN" 28-pin PLCC [] "N" 40-pin PDIP [] "NJ" 40-pin PSDIP (formerly known as N2) | | SYMBOLIZATION | | BUS EXPANSION | | TI standard symbolization TI standard w/customer part number Customer symbolization (per attached spec, subject to app | | [] YES [] NO | | (i.e., product which must be started in<br>satisfaction of both the customer and | process prior to prototype approval a<br>TI in time for a scheduled shipment, t | T ENGINEERING STAFF: If the customer requires expedited production material and full production release) and non-standard spec issues are not resolved to the the specification parameters in question will be processed/tested to the standard tually approved spec, will be identified by a 'P' in the symbolization preceding the | | | | olling document for all orders placed for this TI custom device. Any changes must<br>stype cycletime commences when this document is signed off and the verification | | 1. Customer: | Date: | 2. TI: Field Sales: Marketing: Prod. Eng.: Proto. Release: | Figure 10. Sample New Code Release Form # **Table 18. Peripheral File Frame Compilation** Table 18 is a collection of all the peripheral file frames used in the 'Cx36 (provided for a quick reference). | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | | | | |----------------------|--------------------------------|------------------------------------------------------|------------------|-------------------------|------------------|-------------------|------------------|----------------------|--------|--|--|--|--| | | | | | System Config | uration Regist | ers | | | ] | | | | | | P010 | COLD<br>START | OSC<br>POWER | PF AUTO<br>WAIT | OSC FLT<br>FLAG | MC PIN<br>WPO | MC PIN<br>DATA | _ | μΡ/μC<br>MODE | SCCR0 | | | | | | P011 | _ | _ | _ | AUTO<br>WAIT<br>DISABLE | _ | MEMORY<br>DISABLE | _ | _ | SCCR1 | | | | | | P012 | HALT/<br>STANDBY | PWRDWN/<br>IDLE | _ | BUS<br>STEST | CPU<br>STEST | _ | INT1<br>NMI | PRIVILEGE<br>DISABLE | SCCR2 | | | | | | P013<br>to<br>P016 | | | | Res | erved | | | | | | | | | | P017 | INT1<br>FLAG | INT1<br>PIN DATA | _ | _ | _ | INT1<br>POLARITY | INT1<br>PRIORITY | INT1<br>ENABLE | INT1 | | | | | | P018<br>P019 | | | | Res | erved | | | | | | | | | | P01A | BUSY | _ | _ | _ | _ | AP | W1W0 | EXE | DEECTL | | | | | | P01B | Reserved | | | | | | | | | | | | | | P01C | BUSY | VPPS | _ | _ | _ | _ | W0 | EXE | EPCTLL | | | | | | P01D<br>P01E<br>P01F | Reserved | | | | | | | | | | | | | | | Digital Port Control Registers | | | | | | | | | | | | | | P020 | | | | Res | erved | | | | APORT1 | | | | | | P021 | | | Po | ort A Control Re | | be 0) | | | APORT2 | | | | | | P022 | | | | | A Data | | | | ADATA | | | | | | P023 | | | | Port A | Direction | | | | ADIR | | | | | | P024<br>to<br>P02B | | | | Res | erved | | | | | | | | | | P02C | | Port D Con | trol Register 1 | (must be 0) | | _ | _ | _ | DPORT1 | | | | | | P02D | | Port D Cont | rol Register 2 ( | must be 0)† | | _ | _ | _ | DPORT2 | | | | | | P02E | | | Port D Data | | | _ | _ | _ | DDATA | | | | | | P02F | | F | Port D Direction | 1 | | _ | _ | _ | DDIR | | | | | | | | | SPI M | odule Control | Register Mem | ory Map | | | ] | | | | | | P030 | SPI SW<br>RESET | CLOCK<br>POLARITY | SPI BIT<br>RATE2 | SPI BIT<br>RATE1 | SPI BIT<br>RATE0 | SPI<br>CHAR2 | SPI<br>CHAR1 | SPI<br>CHAR0 | SPICCR | | | | | | P031 | RECEIVER<br>OVERRUN | SPI INT<br>FLAG | _ | _ | _ | MASTER/<br>SLAVE | TALK | SPI INT<br>ENA | SPICTL | | | | | | P032<br>to<br>P036 | Reserved | | | | | | | | | | | | | | P037 | RCVD7 | RCVD7 RCVD6 RCVD5 RCVD4 RCVD3 RCVD2 RCVD1 RCVD0 SPIB | | | | | | | | | | | | | P038 | | | | Res | erved | | | | ] | | | | | | P039 | SDAT7 | SDAT6 | SDAT5 | SDAT4 | SDAT3 | SDAT2 | SDAT1 | SDAT0 | SPIDAT | | | | | <sup>&</sup>lt;sup>†</sup> To configure D3 as SYSCLK, set port D register 2 = 08h. Table 18. Peripheral File Frame Compilation (Continued) | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | |------------|--------------------------------|---------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|-----------------------------------|------------------------------|-----------------------------|---------| | | | | SPI Module | Control Regist | ter Memory Ma | p (Continued) | | | | | to<br>P03C | | | | Res | served | | | | | | P03D | _ | _ | _ | _ | SPICLK<br>DATA IN | SPICLK<br>DATA OUT | SPICLK<br>FUNCTION | SPICLK<br>DATA DIR | SPIPC1 | | P03E | SPISIMO<br>DATA IN | SPISIMO<br>DATA OUT | SPISIMO<br>FUNCTION | SPISIMO<br>DATA DIR | SPISOMI<br>DATA IN | SPISOMI<br>DATA OUT | SPISOMI<br>FUNCTION | SPISOMI<br>DATA DIR | SPIPC2 | | P03F | SPI<br>STEST | SPI<br>PRIORITY | SPI<br>ESPEN | _ | _ | _ | _ | _ | SPIPRI | | | | | PA | CT Module Re | gister Memory | Мар | | | 1 | | P040 | DEFTIM<br>OVRFL<br>INT ENA | DEFTIM<br>OVRFL<br>INT FLAG | CMD/DEF<br>AREA ENA | FAST<br>MODE<br>SELECT | PACT<br>PRESCALE<br>SELECT3 | PACT<br>PRESCALE<br>SELECT2 | PACT<br>PRESCALE<br>SELECT1 | PACT<br>PRESCALE<br>SELECT0 | PACTSCR | | P041 | CMD/DEF<br>AREA<br>INT ENA | _ | CMD/DEF<br>AREA<br>START<br>BIT 5 | CMD/DEF<br>AREA<br>START<br>BIT 4 | CMD/DEF<br>AREA<br>START<br>BIT 3 | CMD/DEF<br>AREA<br>START<br>BIT 2 | _ | _ | CDSTART | | P042 | _ | CMD/DEF<br>AREA<br>END BIT 6 | CMD/DEF<br>AREA<br>END BIT 5 | CMD/DEF<br>AREA<br>END BIT 4 | CMD/DEF<br>AREA<br>END BIT 3 | CMD/DEF<br>AREA END<br>BIT 2 | _ | _ | CDEND | | P043 | 1 | 1 | BUFFER<br>POINTER<br>BIT 5 | BUFFER<br>POINTER<br>BIT 4 | BUFFER<br>POINTER<br>BIT 3 | BUFFER<br>POINTER<br>BIT 2 | BUFFER<br>POINTER<br>BIT 1 | _ | BUFPTR | | P044 | | | | Res | served | | | | 1 | | P045 | PACT<br>RXRDY | PACT<br>TXRDY | PACT<br>PARITY | PACT FE | PACT SCI<br>RX INT ENA | PACT SCI<br>TX INT ENA | _ | PACT SCI SW<br>RESET | SCICTLP | | P046 | PACT<br>RXDT7 | PACT<br>RXDT6 | PACT<br>RXDT5 | PACT<br>RXDT4 | PACT<br>RXDT3 | PACT<br>RXDT2 | PACT<br>RXDT1 | PACT RXDT0 | RXBUFP | | P047 | PACT<br>TXDT7 | PACT<br>TXDT6 | PACT<br>TXDT5 | PACT<br>TXDT4 | PACT<br>TXDT3 | PACT<br>TXDT2 | PACT<br>TXDT1 | PACT TXDT0 | TXBUFP | | P048 | PACT OP8<br>STATE | PACT OP7<br>STATE | PACT OP6<br>STATE | PACT OP5<br>STATE | PACT OP4<br>STATE | PACT OP3<br>STATE | PACT OP2<br>STATE | PACT OP1<br>STATE | PSTATE | | P049 | CMD/DEF<br>INT 7 FLAG | CMD/DEF<br>INT 6 FLAG | CMD/DEF<br>INT 5 FLAG | CMD/DEF<br>INT 4 FLAG | CMD/DEF<br>INT 3 FLAG | CMD/DEF<br>INT 2 FLAG | CMD/DEF<br>INT 1 FLAG | CMD/DEF<br>INT 0 FLAG | CDFLAGS | | P04A | CP2 INT<br>ENA | CP2 INT<br>FLAG | CP2 CAPT<br>RISING<br>EDGE | CP2 CAPT<br>FALLING<br>EDGE | CP1 INT<br>ENA | CP1 INT<br>FLAG | CP1 CAPT<br>RISING<br>EDGE | CP1 CAPT<br>FALLING<br>EDGE | CPCTL1 | | P04B | CP4 INT<br>ENA | CP4 INT<br>FLAG | CP4 CAPT<br>RISING<br>EDGE | CP4 CAPT<br>FALLING<br>EDGE | CP3 INT<br>ENA | CP3 INT<br>FLAG | CP3 CAPT<br>RISING<br>EDGE | CP3 CAPT<br>FALLING<br>EDGE | CPCTL2 | | P04C | CP6 INT<br>ENA | CP6 INT<br>FLAG | CP6 CAPT<br>RISING<br>EDGE | CP6 CAPT<br>FALLING<br>EDGE | CP5 INT<br>ENA | CP5 INT<br>FLAG | CP5 CAPT<br>RISING<br>EDGE | CP5 CAPT<br>FALLING<br>EDGE | CPCTL3 | | P04D | BUFFER<br>HALF/FULL<br>INT ENA | BUFFER<br>HALF/FULL<br>INT FLAG | INPUT<br>CAPT<br>PRESCALE<br>SELECT 3 | INPUT<br>CAPT<br>PRESCALE<br>SELECT 2 | INPUT<br>CAPT<br>PRESCALE<br>SELECT 1 | CP6 EVENT<br>ONLY | EVENT<br>COUNTER<br>SW RESET | OP/ SET/CLR<br>SELECT | CPPRE | # Table 18. Peripheral File Frame Compilation (Continued) | PF | DIT 7 | DITC | DIT 5 | DIT 4 | DIT 2 | DIT 0 | DIT 4 | DITA | 1,000 | | | |--------------------|-----------------------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|------------------------|---------------------------------|---------------------------------|---------|--|--| | PF | BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT 0 | REG | | | | | | | PACT Mo | odule Register | Memory Map ( | Continued) | | | | | | | P04E | | | | WATCHDO | G RESET KEY | | | | WDRST | | | | P04F | PACT<br>STEST | PACT<br>SUSPEND | PACT<br>GROUP 1<br>PRIORITY | PACT<br>GROUP 2<br>PRIORITY | PACT<br>GROUP 3<br>PRIORITY | PACT<br>MODE<br>SELECT | PACT WD<br>PRESCALE<br>SELECT 1 | PACT WD<br>PRESCALE<br>SELECT 0 | PACTPRI | | | | | ADC1 Module Control Register Memory Map | | | | | | | | | | | | P070 | CONVERT<br>START | | | | | | | | | | | | P071 | ı | — — — AD READY AD INT ENA A | | | | | | | ADSTAT | | | | P072 | | | | ADC1 Convers | ion Data Regist | er | | | ADDATA | | | | P073<br>to<br>P07C | | | | RES | ERVED | | | | | | | | P07D | Port E Data Input Register | | | | | | | | | | | | P07E | Port E Input Enable Register | | | | | | | | | | | | P07F | AD STEST | AD<br>PRIORITY | AD ESPEN | _ | _ | _ | _ | _ | ADPRI | | | SPNS039B - JANUARY 1996 - REVISED FEBRUARY 1997 absolute maximum ratings over operating free-air temperature range (unless otherwise noted)† | Supply voltage range, V <sub>CC1</sub> (see Note 4) | $-0.6\ V$ to 7 V | |-------------------------------------------------------------------------------------------------|---------------------------------| | Input voltage range, All pins except MC | 0.6 V to7 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)})$ (see Note 5) | $\dots \dots \pm 10 \text{ mA}$ | | Maximum I <sub>CC</sub> current | | | Maximum I <sub>SS</sub> current | – 170 mA | | Continuous power dissipation | 1 W | | Operating free-air temperature, T <sub>A</sub> : L version | 0°C to 70°C | | A version | 40°C to 85°C | | T version | –40°C to 105°C | | Storage temperature range, T <sub>stq</sub> | 65°C to 150°C | <sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability. NOTES: 4. Unless otherwise noted, all voltage values are with respect to VSS1. # recommended operating conditions | | | | MIN | NOM | MAX | UNIT | |------------------|-----------------------------------------------------------------------------------|--------------------------------------------|----------------------|------|------------------|------| | V <sub>CC1</sub> | Supply voltage (see Note 4) | | 4.5 | 5 | 5.5 | V | | | RAM data-retention supply voltage (see Note 6) | | 3 | | 5.5 | V | | VCCSTBY | Standby RAM supply voltage Standby RAM data retention supply voltage (see Note 6) | | 4.5 | 5 | 5.5 | V | | | | | 3 | | 5.5 | | | V <sub>CC3</sub> | Analog supply voltage (see Note 4) | | | 5 | 5.5 | V | | V <sub>SS3</sub> | Analog supply ground | | | 0 | 0.3 | V | | VIL | Low-level input voltage | All pins except MC | V <sub>SS1</sub> | | 0.8 | V | | | | MC, normal operation | Vss1 | | 0.3 | V | | V <sub>IH</sub> | High-level input voltage | All pins except MC, XTAL2/CLKIN, and RESET | 2 | | V <sub>CC1</sub> | V | | | | XTAL2/CLKIN | 0.8 VCC1 | | VCC1 | | | | | RESET | 0.7 V <sub>CC1</sub> | | VCC1 | | | VMC | MC (mode control) voltage | EEPROM write protect override (WPO) | 11.7 | 12 | 13 | V | | | | EPROM programming voltage (Vpp) | 13 | 13.2 | 13.5 | | | | | Microcomputer | V <sub>SS1</sub> | | 0.3 | | | TA | Operating free-air temperature | L version | 0 | | 70 | °C | | | | A version | - 40 | | 85 | | | | | T version | - 40 | | 105 | | NOTES: 4. <u>Unless</u> otherwise noted, all voltage values are with respect to V<sub>SS1</sub>. <sup>5.</sup> Electrical characteristics are specified with all output buffers loaded with specified I<sub>O</sub> current. Exceeding the specified I<sub>O</sub> current in any buffer can affect the levels on other buffers. <sup>6.</sup> RESET must be externally activated when V<sub>CC1</sub> or SYSCLK is not within the recommended operating range. # electrical characteristics over recommended operating free-air temperature range (unless otherwise noted) | | PARAMETER | | TEST CONDITIONS | MIN | TYP | MAX | UNIT | |------------------|---------------------------------------------------|---------------------------------------|-----------------------------------------------------------------------------|----------------------|-----|------|------| | VOL | Low-level output voltage | All outputs | I <sub>OL</sub> = 1.4 mA | | | 0.4 | V | | VOH | High-level output voltage | All outputs<br>except PACT<br>outputs | ΙΟΗ = -50 μΑ | 0.9 V <sub>CC1</sub> | | | V | | -011 | g | PACT outputs | I <sub>OH</sub> = -50 μA | 0.7 V <sub>CC1</sub> | | | _ | | | | All outputs | $I_{OH} = -2 \text{ mA}$ | 2.4 | | | | | | | | 0 V ≤ V <sub>I</sub> ≤ 0.3 V | | | 10 | μΑ | | | Input current I/O pi | MC | 0.3 V < V <sub>I</sub> < V <sub>CC1</sub> - 0.3 V | | | 50 | μΑ | | l <sub>l</sub> | | IVIC | V <sub>CC1</sub> -0.3 < V <sub>I</sub> < V <sub>CC1</sub> +0.3 V | | | 10 | μΑ | | | | | V <sub>CC1</sub> +0.3 V < V <sub>I</sub> < 13 V | | | 650 | μΑ | | | | I/O pins | 0 V <vi <="" td="" vcc1<=""><td></td><td></td><td>± 10</td><td>μΑ</td></vi> | | | ± 10 | μΑ | | loL | Low-level output current | All outputs | V <sub>OL</sub> = 0.4 V | 1.4 | | | mA | | | Libert Level autout account | All outputs | V <sub>OH</sub> = 0.9 V <sub>CC1</sub> | - 50 | | | μΑ | | IOH | High-level output current | All outputs | V <sub>OH</sub> = 2.4 V | -2 | | | mA | | | Supply current (operating mode) OSC POWER bit = 0 | | See Notes 7 and 8<br>SYSCLK = 5 MHz | | 36 | 45 | mA | | I <sub>CC1</sub> | Supply current (STANDBY mode) OSC POWER bit = 0 | | See Notes 7 and 8<br>SYSCLK = 5 MHz | | 7 | 12 | mA | | | Supply current (HALT mode) | | See Notes 7 and 8<br>XTAL2/CLKIN < 0.2 V | | 5 | 30 | μА | | ICCSTBY | Standby RAM supply current (opera POWER bit = 0) | ating mode OSC | SYSCLK = 5 MHz<br>VCCSTBY = 4.5 V | | 1 | 1.5 | mA | NOTES: 7. Single chip mode, ports configured as inputs or outputs with no load. All inputs $\leq$ 0.2 V or $\geq$ V<sub>CC1</sub> - 0.2V. <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 can be higher with a crystal oscillator. At 5-MHz SYSCLK, this extra current = 0.01 mA x (total load capacitance + crystal capacitance in pF). - NOTES: A. The values of C1 and C2 are typically 15 pF and C3 value is typically 50 pF. See the manufacturer's recommendations for ceramic resonators. - B. The crystal/ceramic resonator frequency is four times the reciprocal of the system clock period. Figure 11. Recommended Crystal/Clock Connections Case 1: $V_O = V_{OH} = 2.4 \text{ V}$ ; Load Voltage = 0 V Case 2: $V_O = V_{OL} = 0.4 \text{ V}$ ; Load Voltage = 2.1 V NOTE A: All measurements are made with the pin loading as shown unless otherwise noted. All measurements are made with XTAL2/CLKIN driven by an external square wave signal with a 50% duty cycle and rise and fall times less than 10 ns unless otherwise stated. Figure 12. Typical Output Load Circuit (See Note A) Figure 13. Typical Buffer Circuitry #### PARAMETER MEASUREMENT INFORMATION ## timing parameter symbology Timing parameter symbols have been created in accordance with JEDEC Standard 100. In order to shorten the symbols, some of the pin names and other related terminology have been abbreviated as follows: | AR | Array | SC | SYSCLK | |-----|-------------|------|---------| | AIN | Allay | 30 | STOCK | | В | Byte | SIMO | SPISIMO | | CI | XTAL2/CLKIN | SOMI | SPISOMI | | M | Master mode | SPC | SPICLK | | S | Slave mode | | | Lowercase subscripts and their meanings are: | С | cycle time (period) | su | setup time | |---|---------------------|----|------------| | d | delay time | V | valid time | f fall time w pulse duration (width) r rise time The following additional letters are used with these meanings: H High Low V Valid All timings are measured between high and low measurement points as indicated in Figure 14 and Figure 15. Figure 14. XTAL2/CLKIN Measurement Points **Figure 15. General Measurement Points** ## external clocking requirements for clock divided by 4 (see Note 9 and Figure 16) | NO. | | PARAMETER | MIN | MAX | UNIT | |-----|-------------------------|--------------------------------------------------------|-----|-----|------| | 1 | tw(CI) | Pulse duration, XTAL2/CLKIN (see Note 10) | 20 | | ns | | 2 | <sup>t</sup> r(Cl) | Rise time, XTAL2/CLKIN | | 30 | ns | | 3 | t <sub>f</sub> (CI) | Fall time, XTAL2/CLKIN | | 30 | ns | | 4 | <sup>t</sup> d(CIH-SCL) | Delay time, XTAL2/CLKIN rise to SYSCLK fall | | 100 | ns | | | CLKIN | Crystal operating frequency | 2 | 20 | MHz | | | SYSCLK | Internal system clock operating frequency <sup>†</sup> | 0.5 | 5 | MHz | †SYSCLK = CLKIN/4 NOTES: 9. For VIL and VIH, refer to recommended operating conditions. 10. 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. Figure 16. External Clock Timing for Divide-by-4 ## external clocking requirements for clock divided by 1 (PLL) (see Note 9 and Figure 17) | NO. | | PARAMETER | MIN | MAX | UNIT | |-----|-------------------------|---------------------------------------------|-----|-----|------| | 1 | tw(CI) | Pulse duration, XTAL2/CLKIN (see Note 10) | 20 | | ns | | 2 | <sup>t</sup> r(Cl) | Rise time, XTAL2/CLKIN | | 30 | ns | | 3 | t <sub>f</sub> (CI) | Fall time, XTAL2/CLKIN | | 30 | ns | | 4 | <sup>t</sup> d(CIH-SCH) | Delay time, XTAL2/CLKIN rise to SYSCLK rise | | 100 | ns | | | CLKIN | Crystal operating frequency | 2 | 5 | MHz | | | SYSCLK | Internal system clock operating frequency‡ | 2 | 5 | MHz | \$SYSCLK = CLKIN/1 NOTES: 9. For V<sub>IL</sub> and V<sub>IH</sub>, refer to recommended operating conditions. 10. This pulse can 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. Figure 17. External Clock Timing for Divide-by-1 ## switching characteristics and timing requirements (see Note 11 and Figure 18) | NO. | PARAMETER | | | MIN | MAX | UNIT | |-----|--------------------------------------------------|------------------------------|-------------|------------------------|-------------------------|------| | _ | t Cycle | a tima SVSCLK (ayatam alaak) | Divide by 4 | 200 | 2000 | no | | 5 | t <sub>C</sub> Cycle time, SYSCLK (system clock) | | Divide by 1 | 200 | 500 | ns | | 6 | t <sub>w(SCL)</sub> Pulse | e duration, SYSCLK low | | 0.5 t <sub>C</sub> -20 | 0.5 t <sub>C</sub> | ns | | 7 | tw(SCH) Pulse | e duration, SYSCLK high | | 0.5 t <sub>C</sub> | 0.5 t <sub>C</sub> + 20 | ns | NOTE 11: $t_C$ = system clock cycle time = 1/SYSCLK Figure 18. SYSCLK Timing ## general purpose output signal switching time requirements (see Figure 19) | | MIN | TYP | MAX | UNIT | |--------------------------|-----|-----|-----|------| | t <sub>r</sub> Rise time | | 30 | | ns | | t <sub>f</sub> Fall time | | 30 | | ns | Figure 19. Signal Switching Timing ## recommended EEPROM timing requirements for programming | | | MIN | MAX | UNIT | |-----------|--------------------------------------------------------------------------------|-----|-----|------| | tw(PGM)B | Pulse duration, programming signal to ensure valid data is stored (byte mode) | 10 | | ms | | tw(PGM)AR | Pulse duration, programming signal to ensure valid data is stored (array mode) | 20 | | ms | ## recommended EPROM operating conditions for programming | | | | MIN | TYP | MAX | UNIT | |------------------------------|----------------------------------------------------------|-------------|------|------|------|--------| | Vcc | Supply voltage | | 4.75 | 5.5 | 6 | V | | VPP Supply voltage at MC pin | | | 13 | 13.2 | 13.5 | V | | Ірр | Supply current at MC pin during programming (Vpp = 13 V) | | | 30 | 50 | mA | | CVCCLV | Custom alask | Divide by 4 | 0.5 | | 5 | NAL I- | | SYSCLK | System clock | Divide by 1 | 2 | | 5 | MHz | ## recommended EPROM timing requirements for programming | | | MIN | TYP | MAX | UNIT | |----------|--------------------------------------------------|------|------|-----|------| | tw(EPGM) | Pulse duration, programming signal (see Note 12) | 0.40 | 0.50 | 3 | ms | NOTE 12: Programming pulse is active when both EXE (EPCTL.0) and Vpps (EPCTL.6) are set. # SPI master mode external timing characteristics and requirements (see Note 11 and Figure 20) | NO. | | | MIN | MAX | UNIT | |-----|-----------------------|-----------------------------------------------------------------|---------------------------|----------------------------|------| | 38 | t <sub>c</sub> (SPC)M | Cycle time, SPICLK | 2t <sub>C</sub> | 256t <sub>C</sub> | ns | | 39 | tw(SPCL)M | Pulse duration, SPICLK low | t <sub>C</sub> - 45 | 0.5t <sub>C</sub> (SPC)+45 | ns | | 40 | tw(SPCH)M | Pulse duration, SPICLK high | t <sub>C</sub> – 55 | 0.5t <sub>C</sub> (SPC)+45 | ns | | 41 | td(SPCL-SIMOV)M | Delay time, SPISIMO valid after SPICLK low (polarity = 1) | <b>- 65</b> | 50 | ns | | 42 | tv(SPCH-SIMO)M | Valid time, SPISIMO data valid after SPICLK high (polarity =1) | tw(SPCH) - 50 | | ns | | 43 | tsu(SOMI-SPCH)M | Setup time, SPISOMI to SPICLK high (polarity = 1) | 0.25 t <sub>C</sub> + 150 | | ns | | 44 | tv(SPCH-SOMI)M | Valid time, SPISOMI data valid after SPICLK high (polarity = 1) | 0 | | ns | NOTE 11: $t_C$ = system clock cycle time = 1/SYSCLK <sup>†</sup> The diagram is for polarity = 1. SPICLK is inverted when polarity = 0. Figure 20. SPI Master External Timing<sup>†</sup> ## SPI slave mode external timing characteristics and requirements (see Note 11 and Figure 21) | NO. | | | MIN | MAX | UNIT | |-----|-----------------------------|----------------------------------------------------------------|-----------------------|-----------------------------|------| | 45 | t <sub>C</sub> (SPC)S | Cycle time, SPICLK | 8t <sub>C</sub> | | ns | | 46 | tw(SPCL)S | Pulse duration, SPICLK low | 4t <sub>C</sub> – 45 | 0.5t <sub>C</sub> (SPC)S+45 | ns | | 47 | tw(SPCH)S | Pulse duration, SPICLK high | 4t <sub>C</sub> – 45 | 0.5t <sub>C</sub> (SPC)S+45 | ns | | 48 | td(SPCL-SOMIV)S | Delay time, SPISOMI valid after SPICLK low (polarity = 1) | | 3.25t <sub>C</sub> + 130 | ns | | 49 | tv(SPCH-SOMI)S | Valid time, SPISOMI data valid after SPICLK high (polarity =1) | tw(SPCH)S | | ns | | 50 | tsu(SIMO-SPCH)S | Setup time, SPISIMO to SPICLK high (polarity = 1) | 0 | | ns | | 51 | t <sub>V</sub> (SPCH-SIMO)S | Valid time, SPISIMO data after SPICLK high (polarity = 1) | 3t <sub>C</sub> + 100 | | ns | NOTE 11: t<sub>C</sub> = system clock cycle time = 1/SYSCLK <sup>†</sup> The diagram is for polarity = 1. SPICLK is inverted when polarity = 0. Figure 21. SPI Slave External Timing<sup>†</sup> #### **ADC1** converter The ADC1 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 ADC1 performance by preventing digital switching noise of the logic circuitry that can be present on $V_{SS1}$ and $V_{CC1}$ from coupling into the ADC1 analog stage. All ADC1 specifications are given with respect to $V_{SS3}$ unless otherwise noted. | Resolution | 8-bits (256 values) | |-----------------------------------------|-------------------------------------------------------------------------| | Monotonic | Yes | | Output conversion mode | . 00h to FFh (00 for $V_1 \le V_{SS3} \le$ ; FF for $V_1 \le V_{ref}$ ) | | Conversion time (excluding sample time) | 164 t <sub>c</sub> | ## recommended operating conditions | | | MIN | NOM | MAX | UNIT | | |------------------|---------------------------------------------|-----------------------|------------------|------------------------|------|--| | VCC3 | Analog supply voltage | 4.5 | 5 | 5.5 | V | | | | | V <sub>CC1</sub> -0.3 | | V <sub>CC1</sub> +0.3 | | | | V <sub>SS3</sub> | Analog ground | V <sub>SS1</sub> -0.3 | | V <sub>SS1</sub> +0.3 | V | | | V <sub>ref</sub> | Non-V <sub>CC3</sub> reference <sup>†</sup> | 2.5 | V <sub>CC3</sub> | V <sub>CC3</sub> + 0.1 | V | | | | Analog input for conversion | V <sub>SS3</sub> | | $V_{ref}$ | V | | $<sup>\</sup>dagger$ V<sub>ref</sub> must be stable, within $\pm$ 1/2 LSB of the required resolution, during the entire conversion time. ## operating characteristics over recommended ranges operating conditions | | PARAMETER | | MIN | MAX | UNIT | |------------------|-----------------------------------------------------|-----------------------------------------------------|-----|------|------| | | Absolute accuracy <sup>‡</sup> | $V_{CC3} = 5.5 \text{ V}$ $V_{ref} = 5.1 \text{ V}$ | | ±1.5 | LSB | | | Differential/integral linearity error <sup>‡§</sup> | $V_{CC3} = 5.5 \text{ V}$ $V_{ref} = 5.1 \text{ V}$ | | ±0.9 | LSB | | lCC3 | Analog supply current | Converting | | 2 | mA | | | | Nonconverting | | 5 | μΑ | | lį | Input current, AN0-AN7 | 0 V ≤ V <sub>I</sub> ≤ 5.5 V | | 2 | μΑ | | I <sub>ref</sub> | Input charge current | | | 1 | mA | | Z <sub>ref</sub> | Source impedance of V <sub>ref</sub> | SYSCLK ≤ 3 MHz | | 24 | kΩ | | | | 3 MHz < SYSCLK ≤ 5 MHz | | 10 | kΩ | Absolute resolution = 20 mV. At V<sub>ref</sub> = 5 V, this is one LSB. As V<sub>ref</sub> decreases, LSB size decreases; therefore, the absolute accuracy and differential/integral linearity errors in terms of LSBs increase. <sup>§</sup> Excluding quantization error of 1/2 LSB ## **ADC1** converter (continued) The ADC1 module allows complete freedom in design of the sources for the analog inputs. The period of the sample time is user-defined so that the high-impedance can be accommodated without penalty to the low-impedance sources. The sample period begins when the SAMPLE START bit of the ADC1 control register (ADCTL.6) is set to 1. The end of the signal sample period occurs when the conversion bit (CONVERT START, ADCTL.7) 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 that the analog signal can be removed. #### analog timing requirements (see Figure 22) | | | MIN | MAX | UNIT | |--------------------|---------------------------------------------------------------------------------|------------------|-----|-------| | t <sub>su(S)</sub> | Setup time, analog to sample command | 0 | | ns | | th(AN) | Hold time, analog input from start of conversion | 18t <sub>C</sub> | | ns | | tw(S) | Pulse duration, sample time per kilo- $\Omega$ of source impedance <sup>†</sup> | 1 | | μs/kΩ | <sup>†</sup> The value given is valid for a signal with a source impedance > 1 k\Omega. If the source impedance is < 1 k\Omega, use a minimum sampling time of 1\mus. Figure 22. Analog Timing Table 19 is designed to aid the user in referencing a device part number to a mechanical drawing. The table shows a cross-reference of the device part number to the TMS370 generic package name and the associated mechanical drawing by drawing number and name. Table 19. TMS370Cx36 Family Package Type and Mechanical Cross-Reference | PKG TYPE<br>(mil pin spacing) | TMS370 GENERIC NAME | PKG TYPE NO. AND<br>MECHANICAL NAME | DEVICE PART NUMBERS | |-------------------------------------|------------------------------------|-------------------------------------------------|----------------------------------------------------------------------| | FN – 44 pin<br>(50-mil pin spacing) | PLASTIC LEADED CHIP CARRIER (PLCC) | FN(S-PQCC-J**) PLASTIC J-LEADED<br>CHIP CARRIER | TMS370C036AFNA<br>TMS370C036AFNL<br>TMS370C036AFNT<br>TMS370C736AFNT | | FZ – 44 pin<br>(50-mil pin spacing) | CERAMIC LEADED CHIP CARRIER (CLCC) | FZ(S-CQCC-J**) J-LEADED CERAMIC<br>CHIP CARRIER | SE370C736AFZT† | #### **MECHANICAL DATA** ## FN (S-PQCC-J\*\*) #### **20 PIN SHOWN** #### PLASTIC J-LEADED CHIP CARRIER NOTES: A. All linear dimensions are in inches (millimeters). - B. This drawing is subject to change without notice. - C. Falls within JEDEC MS-018 #### **MECHANICAL DATA** ## FZ (S-CQCC-J\*\*) #### 28 LEAD SHOWN #### J-LEADED CERAMIC CHIP CARRIER NOTES: A. All linear dimensions are in inches (millimeters). B. This drawing is subject to change without notice. C. This package can be hermetically sealed with a ceramic lid using glass frit. 4040219/B 03/95 #### **IMPORTANT NOTICE** Texas Instruments and its subsidiaries (TI) reserve the right to make changes to their products or to discontinue any product or service without notice, and advise customers to obtain the latest version of relevant information to verify, before placing orders, that information being relied on is current and complete. All products are sold subject to the terms and conditions of sale supplied at the time of order acknowledgement, including those pertaining to warranty, patent infringement, and limitation of liability. TI warrants performance of its semiconductor products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are utilized to the extent TI deems necessary to support this warranty. Specific testing of all parameters of each device is not necessarily performed, except those mandated by government requirements. CERTAIN APPLICATIONS USING SEMICONDUCTOR PRODUCTS MAY INVOLVE POTENTIAL RISKS OF DEATH, PERSONAL INJURY, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE ("CRITICAL APPLICATIONS"). TI SEMICONDUCTOR PRODUCTS ARE NOT DESIGNED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS. INCLUSION OF TI PRODUCTS IN SUCH APPLICATIONS IS UNDERSTOOD TO BE FULLY AT THE CUSTOMER'S RISK. In order to minimize risks associated with the customer's applications, adequate design and operating safeguards must be provided by the customer to minimize inherent or procedural hazards. TI assumes no liability for applications assistance or customer product design. TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor products or services might be or are used. TI's publication of information regarding any third party's products or services does not constitute TI's approval, warranty or endorsement thereof. Copyright © 1998, Texas Instruments Incorporated