VERSA MIX: MIXED-SIGNAL, FULLY INTEGRATED MICROCONTROLLER WITH DSP **Datasheet Rev 2.0** 1 # **Table of Contents** COAL | OVERVIEW | | |---------------------------------------------------------|----| | APPLICATIONS | | | PINS DESCRIPTION | | | | | | TABLE 1: PIN OUT DESCRIPTION | | | VMIX-1020 BLOCK DIAGRAM | | | ABSOLUTE MAXIMUM RATINGS | | | ELECTRICAL CHARACTERISTICS | 8 | | DETAILED DESCRIPTION | 11 | | INSTRUCTION SET | 13 | | SPECIAL FUNCTION REGISTERS | 14 | | PERIPHERAL ACTIVATION CONTROL | | | GENERAL PURPOSE I/O | | | I/O Port Structure | | | I/O PORTS DRIVE CAPABILITY | 17 | | VO PORT CONFIGURATION REGISTERS | | | Using General Purpose I/O Ports | | | I/O USAGE EXAMPLE | 20 | | INTERRUPT ON PORT1 CHANGE FEATURE | 20 | | MULT/ACCU - MULTIPLY ACCUMULATOR UNIT | | | MULT/ACCU FEATURES | | | MULT/ACCU Control Registers | | | MULT/ACCU UNIT DATA REGISTERS | | | MACA AND MACB MULTIPLICATION (ADDITION) INPUT REGISTERS | 22 | | MACC INPUT REGISTER | | | MACRES RESULT REGISTER | | | MACPREV REGISTER | | | MULT/ACCU UNIT SETUP AND O V32 INTERRUPT EXAMPLE | | | VERSA MIX TIMERS | | | TIMER 0 AND TIMER 1 | | | TIMER 0 AND 1 IMER 1 | | | TIMER 0 / TIMER 1 / COUNTER OPERATION | | | TIMER 0, TIMER 1 GATE CONTROL | | | SETTING UP TIMER 0 EXAMPLE | | | SETTING UP TIMER 1 EXAMPLES | 31 | | Timer 2 Registers | _ | | TIMER 2 CLOCK SOURCES | | | TIMER 2 OPERATING MODES | | | TIMER 2 CLOCK PRESCALERTIMER 2 COUNT SIZE | _ | | TIMER 2 GOON GIZE | | | TIMER 2 OVERFLOWS AND INTERRUPTS | | | TIMER 2 SPECIAL MODES | | | COMPARE / CAPTURE, RELOAD REGISTERS | 35 | | COMPARE/CAPTURE DATA LINE WIDTH | | | TIMER 2 CAPTURE MODES | 36 | Datasheet Rev 2.0 | TIMER 2 COMPARE MODES TIMER 2 COMPARE MODE INTERRUPT | | |----------------------------------------------------------|----| | USING TIMER 2 FOR PWM OUTPUTS | | | PWM CONFIGURATION EXAMPLE | | | Using the PWM as D/A Converter | | | SERIAL UART INTERFACES | 40 | | UARTO SERIAL INTERFACE | 40 | | UARTO OPERATING MODES | 40 | | UARTO - BAUD RATE GENERATOR SOURCE | 41 | | EXAMPLE OF UARTO SETUP AND USE | | | UART1 SERIAL INTERFACE | | | UART1 SERIAL INTERFACE | 44 | | UART1 CONTROL REGISTER | | | UART1: OPERATING MODES | | | UART1 - BAUD RATE GENERATORSETTING UP AND USING UART1 | | | EXAMPLE OF UART1 SETUP AND USE | | | UART1 DRIVEN DIFFERENTIAL TRANSCEIVER | | | USING THE UART 1 DIFFERENTIAL TRANSCEIVER | | | DIFFERENTIAL INTERFACE USE EXAMPLE | | | SPI INTERFACE | 48 | | SPI Transmit / Receive Buffer Structure | 48 | | SPI CONTROL REGISTERS | | | SPI MASTER CHIP SELECT CONTROL | | | SPI OPERATING MODES | | | SPI MODE 0SPI TRANSACTION SIZE | | | SPI INTERRUPTS | | | SPI MANUAL CHIP SELECT CONTROL | | | SPI Manual Load Control | | | SPI FRAME SELECT CONTROL | | | SPI INTERFACE TO 16-BIT D/A EXAMPLESPI INTERRUPT EXAMPLE | | | PC INTERFACE | | | I2C CONTROL REGISTERS | | | I2C CLOCK SPEED | | | Master I2C Operation | | | SLAVE I2C OPERATION | | | I2C EEPROM INTERFACE EXAMPLE PROGRAM | | | ANALOG SIGNAL PATH | | | ANALOG PERIPHERALS POWER CONTROL | 59 | | INTERNAL REFERENCE AND PGA | 59 | | USING THE VMIX INTERNAL REFERENCE | | | USING AN EXTERNAL REFERENCE | | | REFERENCE IMPACT ON THE PROGRAMMABLE CURRENT SOURCE | | | A/D CONVERTER | | | ADC DATA REGISTERS | | | ADC CONTROL PROJECTS | | | ADC CONTROL REGISTERADC CLOCK SOURCE CONFIGURATION | | | ADC CONVERSION RATE CONFIGURATION | | | | | Datasheet Rev 2.0 | ADC STATUS REGISTER | | |---------------------------------------------------|----| | A/D CONVERTER USE EXAMPLE | | | PROGRAMMABLE CURRENT SOURCE | 65 | | CURRENT SOURCE SETUP EXAMPLE | | | DIGITAL POTENTIOMETER SETUP EXAMPLE | | | OPERATIONAL AMPLIFIER | | | DIGITALLY CONTROLLED SWITCHES | 67 | | ANALOG OUTPUT MULTIPLEXER | 67 | | VERSA MIX INTERRUPTS | 68 | | INTERRUPT ENABLE REGISTERS | 68 | | TIMER 2 COMPARE MODE IMPACT ON INTERRUPTS | | | INTERRUPT STATUS FLAGSINTERRUPT PRIORITY REGISTER | | | SETTING UP INTO AND INT1 INTERRUPTS | | | INTERRUPT ON P1 CHANGE | 73 | | THE CLOCK CONTROL CIRCUIT | 75 | | SOFTWARE RESET | | | POWER-ON / BROWN-OUT RESET | | | PROCESSOR POWER CONTROL | | | WATCH DOG TIMER | 77 | | SETTING-UP THE WATCH DOG TIMER | | | STARTING THE WATCH DOG TIMER | 78 | | Watch Dog Timer Reset | | | VERSA MIX PROGRAMMING | | | VERSA MIX DEBUGGER | | | DEBUGGER FEATURES | | | DEBUGGER HARDWARE INTERFACE | | | VERSA MIX 64 PIN QUAD FLAT PACKAGE | | | ORDERING INFORMATION | | | Device Number Structure | | | VERSA MIX ORDERING OPTIONS | | | DISCLAIMER | 82 | ### **Overview** The VERSA MIX is a fully integrated mixed-signal microcontroller that provides a "one-chip solution" for a broad range of signal conditioning, data acquisition, processing, and control applications. The VERSA MIX is based on a powerful single-cycle, RISC-based, 8051 microprocessor with an enhanced MULT/ACCU unit that can be used to perform complex mathematical operations. On-chip analog peripherals such as: A/D converter, PWM outputs (that can be used as D/A converters), voltage reference, programmable current source, uncommitted operational amplifier, digital potentiometers and an analog switch makes the VERSA MIX ideal for analog data acquisition applications. The inclusion of a full set of digital interfaces such as an enhanced fully configurable SPI, an I<sup>2</sup>C interface, UARTs and a J1708/RS-485/RS-422 compatible differential transceiver etc. allows a total system integration. ### **Applications** - o Automotive Applications - o Industrial Controls / Instrumentation - o Consumer Products - o Intelligent Sensors - Medical Devices FIGURE 1: VERSA MIX BLOCK DIAGRAM ### Feature Set - 8051 Compatible RISC performance Processor. - Integrated Debugger - 56KB Flash Program Memory - o 1280 Bytes of RAM - MULT/ACCU unit including a Barrel Shifter - Provides DSP capabilities - o 2 UART Serial Ports - o 2 Baud Rate Generators for UARTs - o Differential Transceiver connected to UART1 - J1708/RS-485/RS-422 compatible. Enhanced SPI interface (Master/Slave) - Fully Configurable - Controls up to 4 slave devices - I2C interface 0 - o 28 General Purpose I/Os - 2 External Interrupt Inputs - Interrupt on Port 1 pin change - 3, 16bit Timers/Counters - o 4 Compare & Capture Units with 3 Capture Inputs - 4 PWM outputs, 8-bit / 16-bit resolution - 4 ext. + 3 int. Channel 12-bit A/D Converter - Conversion rate up to 10kHz - 0-2.7 Volt Input range Continuous / One-Shot operation - Single or 4-channel automatic sequential conversions - o On-Chip Voltage Reference - Programmable Current Source - Operational Amplifier - o 2 Digital Potentiometers - 1 Digitally Controlled Switch - Power Saving Features + Clock Control - o Power-on Reset with Brown-Out Detect - Watchdog Timer FIGURE 2: VMX1020 QFP-64 PACKAGE PINOUT # **Pins Description** ### Table 1: Pin out description | PIN | NAME | FUNCTION | |-----|---------------|--------------------------------------------------------------------| | 1 | OPIN- | Inverting Input of the Operational Amplifier | | 2 | OPIN+ | Non-inverting Input of the Operational Amplifier | | 3 | POT1A | Digitally Controlled Potentiometer 1A | | 4 | POT1B | Digitally Controlled Potentiometer 1B | | 5 | SW1A | Digitally Controlled Switch 1A | | 6 | SW1B | Digitally Controlled Switch 1B | | 7 | TX1D- | RS-485/RS422 compatible differential<br>Transmitter, Negative side | | 8 | RX1 D- | RS-485/RS422 compatible differential Receiver<br>Negative side | | 9 | TX1D+ | RS-485/RS422 compatible differential Transmitter, Positive side | | 10 | RX1 D+ | RS-485/RS422 compatible differential Receiver Positive side | | 11 | P0.3-RX1 | I/O - Asynchronous UART1 Receiver Input | | 12 | P0.2-TX1 | I/O - Asynchronous UART1 Transmitter Output | | 13 | P0.1-<br>T2EX | I/O -Timer/Counter 2 Input | | 14 | P0.0-T2IN | I/O -Timer/Counter 2 Input | | 15 | P1.0-<br>PWM0 | I/O - Pulse Width Modulator output 0 | | 16 | P1.1-<br>PWM1 | I/O - Pulse Width Modulator output 1 | | 17 | P1.2-<br>PWM2 | I/O - Pulse Width Modulator output 2 | | 18 | P1.3-<br>PWM3 | I/O - Pulse Width Modulator output 3 | | 19 | CCU2 | Capture and Compare Unit 2 Input | | 20 | INT1 | Interrupt Input 1 | | 21 | DGND | Digital Ground | | 22 | P2.0-CS3- | I/O - SPI Chip Enable Output (Master Mode) | | 23 | P2.1-CS2- | I/O - SPI Chip Enable Output (Master Mode) | | 24 | P2.2-CS1- | I/O - SPI Chip Enable Output (Master Mode) | | 25 | P2.3-CS0- | I/O - SPI Chip Enable Output (Master Mode) | | 26 | P2.4-SS- | I/O - SPI Chip Enable Output (Slave Mode) | | 27 | P2.5-SCK | I/O - SPI Clock (Input in Slave Mode) | | 28 | P2.6-SDO | I/O - SPI Data Output Bus | | 29 | P2.7-SDI | I/O - SPI Data Input Bus | | 30 | VDD | Digital Supply | | 31 | P1.4 | VO | | 32 | P1.5 | VO | | 33 | P1.6 | VO | | 34 | P1.7 | VO | | 35 | OSC1 | Oscillator Crystal Output | | 36 | OSC0 | Oscillator Crystal input/External Clock Source Input | | 37 | P3.0-TX0 | I/O - Asynchronous UART0 Transmitter Output | | 38 | P3.1-RX0 | I/O - Asynchronous UART0 Receiver Input | | PIN | NAME | FUNCTION | |-----|----------------|-------------------------------------------------------------| | 39 | P3.2-T0IN | I/O - Timer/Counter 0 Input | | 40 | VDD | 5V Digital | | 41 | P3.3-<br>CCU0 | I/O - Capture and Compare Unit 0 Input | | 42 | P3.4-<br>CCU1 | I/O - Capture and Compare Unit 1 Input | | 43 | P3.5-T1 IN | I/O - Timer/Counter 1 Input | | 44 | VPP | Flash Programming Voltage Input | | 45 | P3.6-SDA | I/O - I2C / Prog. interface Bi-Directional Data Bus | | 46 | NC | Not Connect, leave floating | | 47 | NC | Not Connected | | 48 | P3.7-SCL | I/O - I2C / Prog. Interface Clock | | 49 | AGND | Analog Ground | | 50 | INT0 | External interrupt Input (Negative Level or Edge Triggered) | | 51 | PM | Mode Control Input | | 52 | RES- | Hardware Reset Input (Active low) | | 53 | ISRCOUT-<br>TA | Programmable Current Source Analog Output | | 54 | ISRCIN | Programmable Current Source Input | | 55 | POT2A | Digitally Controlled Potentiometer 2A | | 56 | POT2B | Digitally Controlled Potentiometer 2B | | 57 | VDDA | Analog Supply | | 58 | ADCl3 | Analog to Digital Converter ext. Input 3 | | 59 | ADCI2 | Analog to Digital Converter ext. Input 2 | | 60 | ADCI1 | Analog to Digital Converter ext. Input 1 | | 61 | ADCI0 | Analog to Digital Converter ext. Input 0 | | 62 | XTVREF | External Reference Voltage Input | | 63 | AGND | Analog Ground | | 64 | OPOUT | Output of the Operational Amplifier | FIGURE 3: VERSA MIX PINOUT ## VMIX-1020 Block Diagram FIGURE 4: VMX1020 BLOCK DIAGRAM # **Absolute Maximum Ratings** | V <sub>DD</sub> to DGND | -0.3V, +6V | Digital Output Voltage to DGND | $-0.3V, V_{DD}+0.3V$ | |-------------------------------------------|-------------------------------|-------------------------------------|----------------------| | V <sub>DDA</sub> to DGND | -0.3V, +6V | V <sub>PP</sub> to DGND | +13V | | AGND to DGND | -0.3V, +0.3V | Power Dissipation | | | $V_{DD}$ to $V_{DDA}$ | -0.3V, +0.3V | <ul> <li>To +75 ℃</li> </ul> | 1000mW | | ADCI (0-3) to AGND | -0.3V, V <sub>DDA</sub> +0.3V | ■ Derate above +75 °C | 10mW/°C | | XTVREF to AGND | -0.3V, V <sub>DDA</sub> +0.3V | Operating Temperature Range | -40° to +85℃ | | Digital Input Voltage to DGND | $-0.3V, V_{DD} + 0.3V$ | Storage Temperature Range | –65℃ to +150℃ | | RS422/485 Minimum and<br>Maximum Voltages | -2V, +7V | Lead Temperature (soldering, 10sec) | +300℃ | 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 in the operational sections of the specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. ## **Electrical Characteristics** TABLE 2: ELECTRICAL CHARACTERISTICS | PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNITS | |-------------------------------------|---------------------------|-------------------------------------|---------------|---------------|-------------|-----------------------------------------------------------| | GENERAL CHARACTERISTIC | $S(V_{DD} = +5V, V_{DD})$ | $I_{DDA} = +5V, T_A = +25 ^{\circ}$ | , 16MHz input | clock, unless | s otherwise | noted.) | | Power Supply Voltage | V <sub>DD</sub> | | 4.5 | 5.0 | 5.5 | V | | | $V_{DDA}$ | | 4.5 | 5.0 | 5.5 | V | | Power Supply Current | I <sub>DD (16MHz)</sub> | | 5 | | 45* | mA | | | I <sub>DD (1MHz)</sub> | | 0.6 | | 6* | *Depends on clock<br>speed and peripheral<br>use and load | | | I <sub>DDA</sub> | | 0.1 | | 5* | | | Flash Programming Voltage | V <sub>PP</sub> | | 11 | | 13 | V | | DIGITAL INPUTS | | | | | | | | Minimum High-Level input | V <sub>IH</sub> | $V_{DD} = +5V$ | | 2.0 | | V | | Maximum Low-Levelinput | V <sub>IL</sub> | $V_{DD} = +5V$ | | 0.8 | | V | | Input Current | I <sub>IN</sub> | | | ±0.05 | | μΑ | | Input Capacitance | C <sub>IN</sub> | | | 5 | 10 | pF | | DIGITAL OUTPUTS | | | | | | | | Minimum High-Level Output Voltage | V <sub>OH</sub> | I <sub>SOURCE</sub> = 4mA | | 4.2 | | V | | Maximum Low-Level Output Voltage | V <sub>OL</sub> | I <sub>SINK</sub> = 4mA | | 0.2 | | V | | Output Capacitance | C <sub>OUT</sub> | | | 10 | 15 | pF | | Tri-state Output Leakage<br>Current | loz | | | | 0.25 | μА | Datasheet Rev 2.0 | PARAMETER | SYMBOL | CONDITIONS | MIN | TYP | MAX | UNITS | |---------------------------------------------------------------------|-----------------------------------------|---------------------------|-----------|-------|-----------------|----------------| | ANALOG INPUTS | • | | | | | | | ADCI(0-3) Input Voltage Range | V <sub>ADCI</sub> | | 0 | | 2.7 | V | | ADCI(0-3) Input Resistance | R <sub>ADCI</sub> | | | 100 | | Mohms (design) | | ADCI(0-3) Input Capacitance | C <sub>ADCI</sub> | | | 7 | | pF | | ADCI(0-3) Input Leakage<br>Current | I <sub>ADCI</sub> | | | TBD | | nA | | Channel-to-Channel Crosstalk | | | | | -72<br>(12 bit) | dB (design) | | ANALOG OUTPUT | | | | | | <u> </u> | | TA Output Drive Capabilities | V <sub>TA=</sub> V <sub>ADCI(0-3)</sub> | | 10 | | | kOhms | | (Maximum Load Resistance) | Others | Requires buffering | | 25M | | | | CURRENT SOURCE | | , , | | | | | | ISRC Current Drive | I <sub>ISRC</sub> | | 0 | | 530 | μΑ | | ISRC Feedback voltage 200mV | REF <sub>ISRC200</sub> | | 195 | | 205 | mV | | ISRC Feedback voltage 800mV | REF <sub>ISRC800</sub> | | 799 | | 803 | mV | | ISRC Output Resistance | R <sub>ISRC</sub> | | | 50 | | MOhms | | ISRC Output Capacitance | C <sub>ISRC</sub> | | | 25 | | pF | | ISRCIN Input Reference<br>Resistance | R <sub>RESIN</sub> | | | 100 | | Mohms | | ISRCIN Input Reference<br>Capacitance | C <sub>RESIN</sub> | | | 7 | | pF | | ISRC stability | Drift | | | | 2.5 | % | | Allowable sensor capacitance between ISRCIN & ISRCOUT | | | | | 1000 | PF | | Allowable capacitance between ISRCOUT & GND | | | | | 100 | pF | | INTERNAL REFERENCE | | | | | | | | Bandgap Reference Voltage | | | 1.18 | 1.23V | 1.28 | V | | Bandgap Reference Tempco | | | | 100 | | ppm/℃ | | EXTERNAL REFERENCE | | | | | | | | Input Impedance | R <sub>XTVREF</sub> | | | 150 | | kOhms | | PGA | | | | | | | | PGA Gain adjustment | | | 2.11 | | 2.29 | | | ANALOG TO DIGITAL CONVER<br>External Reference, TA=25C, Fosc = 16Mh | | | | | | | | ADC Resolution | | | | 12 | | Bits | | Differential Non linearity | DNL | | | | ±1.5 | LSB | | Integral Non linearity | INL | | -1 | | +4 | LSB | | Full-Scale Error (Gain Error) | | All channels, ADCI(0-3) | | ±4 | | LSB | | Offset Error | | All channels, ADCI(0-3) | | ±1 | | LSB | | Channel-to-Channel Mismatch | | All channels, ADCI(0-3) | | ±1 | | LSB | | Sampling Rate | | Single Channel 4 Channels | 1 | | 10k<br>2.5k | Hz | | UART1 DIFFERENTIAL TRANSC | CEIVER COMP | | 35/RS-422 | | | 1 | | Common mode Input Voltage | Vcı | | -2 | | +7 | V | | Input Impedance | Z <sub>IN</sub> | | | 1 | | MOhms | | Output Drive Current | | | | 30 | | mA | | Differential Input | | | | 100mV | | mV | Datasheet Rev 2.0 | OPERATIONAL AMPLIFIER | | | | | | | |-----------------------------------------|----------------------|---------------|-------|-------|-------|---------------| | Output Impedance | Zout | | | 20 | | mOhms | | Input Resistance | Zin | | 36 | | | GOhms | | Voltage Gain | G <sub>v</sub> | | | 100 | | dB | | Unit Gain Bandwidth | UGBW | | | 5 | | MHz | | Load Resistance to Ground | | | | | 1 | KOhms | | Load Capacitance | | | | 40 | | pF | | Slew rate | SR | | | 7 | | V/µs (Design) | | Input Offset Voltage | V <sub>IO</sub> | | | +/- 2 | | mV | | Input Voltage Range | V <sub>I®</sub> | | 0 | | 4 | V (Design) | | Common Mode Rejection Ratio | CMRRdc | DC | 83 | | 99 | dB | | | CMRR1kHz | Taken at 1kHz | | 75 | | dB Design) | | Power Supply Rejection Ratio | PSRR | Taken at 1kHz | -75 | | -94 | dB (Design) | | | | (20dB/decade) | (Vdd) | | (Vss) | | | Output Voltage Swing (RL=10k) | V <sub>O (P-P)</sub> | | 25mV | | 4.975 | V | | Short Circuit Current to ground | I <sub>IC</sub> | | | 86 | | mA (Design) | | DIGITAL POTENTIOMETERS | | | | | | _ | | Number of Steps (8 bit binary weighted) | | | | 256 | | steps | | Maximum Resistance | | | 28k | 30k | 32k | Ohms | | Minimum Resistance | | | 485 | 510 | 535 | Ohms | | Step size | | | 105 | 115 | 130 | Ohms | | Inter channel Matching | | | | 1 | | % | | Temperature Coefficient | | | | 0.16 | | %/℃ | | Allowable current (DC) | | | | | 5 | mA | | Inherent Capacitance | | | | 3 | | pF | | DIGITAL SWITCH | | | | | | | | Switch on Resistance | | | 50 | | 100 | Ohms (+/-10%) | | Input capacitance | | | | 4 | | pF | | Voltage range on Pin | | | 0 | | 5 | V | | Allowable current (DC) | | | | | 5 | mA | | BROWN OUT / RESET CIRCUIT | | | | | | | | Brown-out circuit Threshold | | | 3.7 | | 4.0 | V | | RES- pin internal Pull-Up | | | | 20 | - | KOhms | ## **Detailed Description** The following sections will describe the VERSA MIX's architecture and peripherals. FIGURE 5: INTERFACE DIAGRAM FOR THE VERSA MIX FIGURE 6: MEMORY ORGANIZATION OF THE VERSA MIX ### **Memory Organization** Figure 6 shows the memory organization of the VERSA MIX. At power-up/reset, the code is executed from the 56Kx8 Flash memory mapped into the processor's internal Program space. A 1Kx8 block of RAM is also mapped into the external data memory of the VERSA MIX. This block can be used as a general-purpose scratch pad or storage memory. A 256x8 block of RAM is mapped to the internal data memory space. This block of RAM is broken into 2 sub-blocks, with the upper block accessible via indirect addressing only, and the lower block accessible via both direct and indirect addressing. The following figure describes the access to the lower block of 128 bytes. FIGURE 7: LOWER 128 BYTES BLOCK INTERNAL MEMORY MAP The SFR (Special Function Register) space is also mapped into the upper 128 bytes of internal data memory space. This SFR space is only accessible using direct-access. The SFR space provides the interface to all the on-chip peripherals. This interfacing is illustrated in Figure 8. Datasheet Rev 2.0 FIGURE 8: SFR ORGANIZATION ### **Dual Data Pointers** The VERSA MIX includes two data pointers. The first data pointer (DPTR0) occupies the SFR locations 82h and 83h. The VERSA MIX have a second data pointer (DPTR1) at SFR locations 84h and 85h. The SEL bit in the data pointer select register, DPS (SFR 86h), selects which data pointer is active. When SEL = 0, instructions that use the data pointer will use DPL0 and DPH0. When SEL = 1, instructions that use the DPTR will use DPL1 and DPH1. SEL is the bit 0 of SFR location 86h. No other bits of SFR location 86h are used. All DPTR-related instructions use the currently selected data pointer. In order to switch the active pointer, toggle the SEL bit. The fastest way to do so is to use the increment instruction (INC DPS).. The use of the two data pointers can significantly increase the speed of moving large blocks of data because only one instruction is needed to switch from a source address and destination address. The SFR locations and register representations related to the dual data pointers are: TABLE 3: (DPH0) DATA POINTER HIGH 0 - SFR 83H TABLE 4: (DPL0) DATA POINTER LOW 0 - SFR 82H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|------|-------|---|---|---| | | | | DPLO | [7:0] | | | | | Bit | Mnemonic | Function | |------|----------|--------------------| | 15-8 | DPH0 | Data Pointer 0 MSB | | 7-0 | DPL0 | Data Pointer LSB. | TABLE 5: (DPH1) DATA POINTER HIGH 1 - SFR 85H | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | | | |----------------------------------------------|-----------------|----|----|----|----|---|---|--|--|--|--| | DPH1 [7:0] | | | | | | | | | | | | | Table 6: (DPL1) Data Pointer Low 1 - SFR 84h | | | | | | | | | | | | | 7 | 7 6 5 4 3 2 1 0 | | | | | | | | | | | | | DPL1 [7:0] | | | | | | | | | | | | Bit | Mnemonic | Function | |------|----------|---------------------| | 15-8 | DPH1 | Data Pointer 1 MSB. | | 7-0 | DPL1 | Data Pointer 1 LSB. | TABLE 7: (DPS) DATA POINTER SELECT REGISTER - SFR 86H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SEL | | Bit | Mnemonic | Function | |-----|----------|------------------------------------------------------------------------------------| | 7-1 | 0 | Always zero | | 0 | SEL | 0 = DPTR0 is selected<br>1 = DPTR1 is selected<br>Used to toggle between both data | | | | pointers | ### **MPAGE** Register The MPAGE register controls the upper 8 bits of the targeted address when the MOVX instruction is used for external RAM data transfer. This allows to access the entire external RAM content without using the Data Pointer. TABLE 8: (MPAGE) MEMORY PAGE - SFR CFH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|----|------|------|---|---| | | | | MF | PAGE | 7:01 | • | | ### **User Flags** The VERSA MIX provides an SFR register that gives the user the ability to define software flags. Each bit of this register is individually addressable. This register may also be used as a general-purpose storage location. Thus, the user flag feature allows the VERSA MIX to better adapt to each specific application. This register is located at SFR address F8h TABLE 9: (USERFLAGS) USER FLAG - SFR F8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|-----|-----|-----|-----|-----|-----|-----| | UF7 | UF6 | UF5 | UF4 | UF3 | UF2 | UF1 | UF0 | Datasheet Rev 2.0 ## **Instruction Set** All VERSA MIX instructions are binary code compatible and perform the same functions as the industry standard 8051. However, the timing of the instruction is different. The following two tables describe the instruction set of the VERSA MIX. TABLE 10: LEGEND FOR INSTRUCTION SET TABLE | Symbol | Function | |----------|--------------------------------------------------------| | Α | Accumulator | | Rn | Register R0-R7 | | Direct | Internal register address | | @Ri | Internal register pointed to by R0 or R1 (except MOVX) | | rel | Two's complement offset byte | | bit | Direct bit address | | #data | 8-bit constant | | #data 16 | 16-bit constant | | addr 16 | 16-bit destination address | | addr 11 | 11-bit destination address | TABLE 11: VERSA MIX INSTRUCTION SET | Mnemonic | Description | Size<br>(bytes) | Instr.<br>Cycles | | |-------------------------|-----------------------------------------|-----------------|------------------|--| | Arithmetic instructions | | | | | | ADD A, Rn | Add register to A | 1 | 1 | | | ADD A, direct | Add direct byte to A | 2 | 2 | | | ADD A, @Ri | Add data memory to A | 1 | 2 | | | ADD A, #data | Add immediate to A | 2 | 2 | | | ADDC A, Rn | Add register to A with carry | 1 | 1 | | | ADDC A, direct | Add direct byte to A with carry | 2 | 2 | | | ADDC A, @Ri | Add data memory to A with carry | 1 | 2 | | | ADDC A, #data | Add immediate to A with carry | 2 | 2 | | | SUBB A, Rn | Subtract register from A with borrow | 1 | 1 | | | SUBB A, direct | Subtract direct byte from A with borrow | 2 | 2 | | | SUBB A, @Ri | Subtract data mem from A with borrow | 1 | 2 | | | SUBB A, #data | Subtract immediate from A with borrow | 2 | 2 | | | INC A | Increment A | 1 | 1 | | | INC Rn | Increment register | 1 | 2 | | | INC direct | Increment direct byte | 2 | 3 | | | INC @Ri | Increment data memory | 1 | 3 | | | DEC A | Decrement A | 1 | 1 | | | DEC Rn | Decrement register | 1 | 2 | | | DEC direct | Decrement direct byte | 2 | 3 | | | DEC @Ri | Decrement data memory | 1 | 3 | | | INC DPTR | Increment data pointer | 1 | 1 | | | MUL AB | Multiply A by B | 1 | 5 | | | DIV AB | Divide A by B | 1 | 5 | | | DA A | Decimal adjust A | 1 | 1 | | | | Decima adjus A | ' | | | | Logical Instructions | AND register to A | 1 | 1 | | | ANL A, Rn | | | | | | ANL A, direct | AND direct byte to A | 1 | 2 | | | ANL A, @Ri | AND data memory to A | | | | | ANL A, #data | AND immediate to A | 2 | 2 | | | ANL direct, A | AND A to direct byte | 2 | 3 | | | ANL direct, #data | AND immediate data to direct byte | 3 | 4 | | | ORL A, Rn | OR register to A | 1 | 1 | | | ORL A, direct | OR direct byte to A | 2 | 2 | | | ORL A, @Ri | OR data memory to A | 1 | 2 | | | ORL A, #data | OR immediate to A | 2 | 2 | | | ORL direct, A | OR A to direct byte | 2 | 3 | | | ORL direct, #data | OR immediate data to direct byte | 3 | 4 | | | XRL A, Rn | Exclusive-OR register to A | 1 | 1 | | | XRL A, direct | Exclusive-OR direct byte to A | 2 | 2 | | | XRL A, @Ri | Exclusive-OR data memory to A | 1 | 2 | | | XRL A, #data | Exclusive-OR immediate to A | 2 | 2 | | | XRL direct, A | Exclusive-OR A to direct byte | 2 | 3 | | | XRL direct, #data | Exclusive-OR immediate to direct byte | 3 | 4 | | | CLR A | Clear A | 1 | 1 | | | CPL A | Compliment A | 1 | 1 | | | SWAP A | Swap nibbles of A | 1 | 1 | | | RL A | Rotate A left | 1 | 1 | | | RLC A | Rotate A left through carry | 1 | 1 | | | RR A | Rotate A right | 1 | 1 | | | RRC A | Rotate A right through carry | 1 | 1 | | | Mnemonic | Description | Size<br>(bytes) | Instr.<br>Cycles | |--------------------------------|---------------------------------------------------|-----------------|------------------| | Data Transfer Instruction | ns | | | | MOV A, Rn | Move register to A | 1 | 1 | | MOV A, direct | Move direct byte to A | 2 | 2 | | MOV A, @Ri | Move data memory to A | 1 | 2 | | MOV A, #data | Move immediate to A | 2 | 2 | | MOV Rn, A | Move A to register | 1 2 | 2 | | MOV Rn, direct | Move direct byte to register | 2 | 2 | | MOV Rn, #data<br>MOV direct, A | Move immediate to register Move A to direct byte | 2 | 3 | | MOV direct, A | Move register to direct byte | 2 | 3 | | MOV direct, An | Move direct byte to direct byte | 3 | 4 | | MOV direct, @Ri | Move data memory to direct byte | 2 | 4 | | MOV direct, #data | Move immediate to direct byte | 3 | 3 | | MOV @Ri, A | Move A to data memory | 1 | 3 | | MOV @Ri, direct | Move direct byte to data memory | 2 | 5 | | MOV @Ri, #data | Move immediate to data memory | 2 | 3 | | MOV DPTR, #data16 | Move immediate 16 bit to data pointer | 3 | 3 | | MOVC A, @A+DPTR | Move code byte relative DPTR to A | 1 | 3 | | MOVC A, @A+PC | Move code byte relative PC to A | 1 | 3 | | MOVX A, @Ri | Move external data (A8) to A | 1 | 3-10 | | MOVX A, @DPTR | Move external data (A16) to A | 1 | 3-10 | | MOVX @Ri, A | Move A to external data (A8) | 1 | 4-11 | | MOVX @DPTR, A | Move A to external data (A16) | 1 | 4-11 | | PUSH direct | Push direct byte onto stack | 2 | 4 | | POP direct | Pop direct byte from stack | 2 | 3 | | XCH A, Rn | Exchange A and register | 1 | 2 | | XCH A, direct | Exchange A and direct byte | 2 | 3 | | XCH A, @Ri | Exchange A and data memory | 1 | 3 | | XCHD A, @Ri | Exchange A and data memory nibble | 1 | 3 | | Branching Instructions | | | | | ACALL addr 11 | Absolute call to subroutine | 2 | 6 | | LCALL addr 16 | Long call to subroutine | 3 | 6 | | RET | Return from subroutine | 1 | 4 | | RETI | Return from interrupt | 1 | 4 | | AJMP addr 11 | Absolute jump unconditional | 2 | 3 | | LJMP addr 16 | Long jump unconditional | 3 | 4 | | SJMP rel | Short jump (relative address) | 2 | 3 | | JC rel | Jump on carry = 1 | 2 | 3 | | JNC rel | Jump on carry = 0 | 2 | 3 | | JB bit, rel | Jump on direct bit = 1 | 3 | 4 | | JNB bit, rel | Jump on direct bit = 0 | 3 | 4 | | JBC bit, rel | Jump on direct bit = 1 and dear | 3 | 4 | | JMP@A+DPTR | Jump indirect relative DPTR | 1 | 2 | | JZ rel | Jump on accumulator = 0 | 2 | 3 | | JNZ rel | Jump on accumulator 1 = 0 | 2 | 3 | | CJNE A, direct, rel | Compare A, direct JNE relative | 3 | 4 | | CJNE A, #data, rel | Compare A, immediate JNE relative | 3 | 4 | | CJNE Rn, #data, rel | Compare reg, immediate JNE relative | 3 | 4 | | CJNE @Ri, #data, rel | Compare ind, immediate JNE relative | 3 | 4 | | DJNZ Rn, rel | Decrement register, JNZ relative | 2 | 3 | | DJNZ direct, rel | Decrement direct byte, JNZ relative | 3 | 4 | | Bit Operations | | | | | CLR C | Clear carry flag | 1 | 1 | | CLR bit | Clear direct bit | 2 | 3 | | SETB C | Set carry flag | 1 | 1 | | SETB bit | Set direct bit | 2 | 3 | | CPL C | Complement carry Flag | 1 | 1 | | CPL bit | Complement direct bit | 2 | 3 | | ANL C, bit | Logical AND between hit and something | | 2 | | ANL C, /bit | Logical AND between /bit and carry flag | 2 | 2 | | ORL C,bit | Logical OR bit to carry flag | 2 | 2 | | ORL C, /bit | Logical OR /bit to carry flag | 2 | 2 | | MOC c,bit | Copy direct bit location to carry flag | 2 | | | MOV bit,C | Copy carry flag to direct bit location | 2 | 3 | | | | 1 | | | Miscellaneous Instructio | | | 4 | | NOP | No operation | 1 | 1 | ## **Special Function Registers** The Special Function Registers (SFRs) controls several features of the VERSA MIX. Many of the VERSA MIX SFRs are identical to the standard 8051 SFRs. However, there are additional SFRs that control the VERSA MIX's specific peripheral features that are not available in the standard 8051. | TARLE 1 | 12 SPECIAL | FUNCTION | REGISTERS | |---------|------------|----------|-----------| | | | | | | TABLE 12: SPECIAL F | UNCTION | I REGISTERS | | | | | | | | | |------------------------|-------------|---------------|------------|------------|------------|--------------|-------------|-------------|---------------|--------------------------| | SFR Register | SFR | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset Value | | P0 | Adrs<br>80h | | | | _ | | | - | | 1111 1111b | | SP | 80h<br>81h | - | - | - | - | - | - | - | - | 0000 0111b | | DPL0 | 82h | - | - | - | - | - | - | - | - | 0000 0111b | | DPH0 | 83h | - | - | - | - | - | - | - | - | 0000 0000b | | DPL1 | 84h | - | - | - | - | - | - | - | - | 0000 0000b | | DPH1 | 85h | - | - | - | - | - | - | - | - | 0000 0000b | | DPS | 86h | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SEL | 0000 0000b | | PCON | 87h | SMOD | - | - | - | GF1 | GF0 | STOP | IDLE | 0000 0000b | | TCON* | 88h | TF1 | TR1 | TF0 | TR0 | IE1 | IT1 | IE0 | IT0 | 0000 0000b | | TMOD | 89h | GATE1 | CT1 | M11 | M01 | GATE0 | CT0 | M10 | M00 | 0000 0000b | | TL0 | 8Ah | - | - | - | - | - | - | - | - | 0000 0000b | | TL1 | 8Bh | - | - | - | - | - | - | - | - | 0000 0000b | | TH0 | 8Ch | - | - | - | - | - | - | - | - | 0000 0000b | | TH1 | 8Dh | - | - | - | - | - | - | - | - | 0000 0000b | | Reserved | 8Eh | | | | | | | | | | | Reserved | 8Fh | | | | | | | | | | | P1* | 90h | - | - | - | - | - | - | - | - | 1111 1111b | | IRCON | 91h | T2EXIF | T2IF | ADCIF | MACIF | I2CIF | SPIRXIF | SPITXIF | Reserved | 0000 0000b | | ANALOGPWREN | 92h | OPAMPEN | DIGPOTEN | ISRCSEL | ISRCEN | TAEN | ADCEN | PGAEN | BGAPEN | 0000 0000b | | DIGPWREN | 93h | T2CLKEN | WDOGEN | MACEN | I2CEN | SPIEN | UART1DIFFEN | UART1EN | UART0EN | 0000 0000b | | CLKDIVCTRL | 94h | SOFTRST | - | - | IRQNORMSPD | MCKDIV_3 | MCKDIV_2 | MCKDIV_1 | MCKDIV_0 | 0000 0000b | | ADCCLKDIV | 95h | - | - | - | - | - | - | - | - | 0000 0000b | | S0RELL | 96h | - | - | - | - | - | - | - | - | 11011001b | | S0RELH | 97h | 0 | 0 | 0 | 0 | 0 | 0 | - | - | 0000 0011b | | S0CON* | 98h | S0M0 | S0M1 | MCPE0 | R0EN | T0B8 | R0B8 | TOI | R0I | 0000 0000b | | S0BUF | 99h | - | - | - | - | - | - | - | - | 0000 0000b | | IEN2 | 9Ah | - | - | - | - | - | - | - | S1IE | 0000 0000b | | P0PINCFG | 9Bh | P07IO | P06IO | P05IO | P04IO | | P0.2/TX1OE | | P0.0/T2INE | 0000 0000b | | P1PINCFG | 9Ch | P1.7 | P1.6 | P1.5 | P1.4 | PWM3EN | PWM2EN | PWM1EN | PWM0EN | | | P2PINCFG | 9Dh | SDIEN | SDOEN | SCKEN | SSEN | CS0EN | CS1EN | CS2EN | CS3EN | 0000 0000b | | P3PINCFG | 9Eh | MSCLEN | MSDAEN | T1INEN | CCU1EN | CCU0EN | TOINEN | RX0EN | TX0EN | 0000 0000b | | PORTIRQEN | 9Fh | P17IEN | P16IEN | P15IEN | P14IEN | P13IEN | P12IEN | P11IEN | P10IEN | 0000 0000b | | P2* | A0h | -<br>D47IOTAT | - | - | - | - | - | - | -<br>D40IOTAT | 1111 1111b | | PORTIRQSTAT | A1h | P17ISTAT | P16ISTAT | P15ISTAT | P14ISTAT | P13ISTAT | P12ISTAT | P11ISTAT | P10ISTAT | 0000 0000b | | ADCCTRL<br>ADCCONVRLOW | A2h | ADCIRQCLR | XVREFCAP | 1 - | ADCIRQ | ADCIE | ONECHAN | CONT | ONESHOT | 0000 0000b | | ADCCONVRMED | A3h | - | - | - | - | - | - | - | - | 0000 0000b | | ADCCONVRHIGH | A4h | - | | | - | | | - | - | 0000 0000b | | ADCD0LO | A5h<br>A6h | - | - | - | - | - | - | - | - | 0000 0000b<br>0000 0000b | | ADCD0LO<br>ADCD0HI | A7h | - | - | - | - | ADCDOUL 3 | ADCD0HI 2 | | ADCD0HI 0 | 0000 0000b | | IENO* | A8h | EA | WDT | T2IE | SOIE | T1IE | INT1IE | T0IE | INTOIE | 0000 0000b | | ADCD1LO | A9h | - | - | 121 | - 301L | 1111 | IINI IIL | TUIL | INTOIL | 0000 0000b | | ADCD1HI | AAh | _ | _ | _ | _ | ADCD1HL3 | ADCD1HI 2 | ADCD1HL1 | ADCD1HI 0 | 0000 0000b | | ADCD2LO | ABh | - | - | - | - | - | ADODITI_Z | ADODITI_T | - | 0000 0000b | | ADCD2HI | ACh | | | | | ADCD2HL3 | ADCD2HI 2 | ADCD2HL1 | ADCD2HI 0 | 0000 0000b | | ADCD3LO | ADh | - | - | - | - | | | | | 0000 0000b | | ADCD3HI | AEh | | | | | ADCD3HL3 | ADCD3HI 2 | ADCD3HL1 | ADCD3HI 0 | 0000 0000b | | Reserved | AFh | | | | | 7.15050111_0 | 7.DODOTII_Z | 7.DODOT1I_1 | 7.2000111_0 | 00000000 | | P3* | B0h | - | - | - | - | - | _ | - | - | 1111 1111b | | Reserved | B1h | | | | | | | | | | | Reserved | B2h | | | | | | | | | | | BGAPCAL | B3h | - | - | - | - | - | - | - | - | 0000 0000b | | PGACAL | B4h | - | - | - | - | - | - | - | - | 0000 0000b | | INMUXCTRL | B5h | - | ADCINSEL 2 | ADCINSEL_1 | ADCINSEL 0 | AINEN_3 | AINEN_2 | AINEN_1 | AINEN_0 | 0000 0000b | | OUTMUXCTRL | B6h | - | - | - | - | - | | TAOUTSEL_1 | | 0000 0000b | | SWITCHCTRL | B7h | - | - | - | - | SWITCH1 3 | SWITCH1 2 | SWITCH1 1 | SWITCH1 0 | 0000 0000b | | IP0* | B8h | UF8 | WDTSTAT | IP0.5 | IP0.4 | IP0.3 | IP0.2 | IP0.1 | IP0.0 | 0000 0000b | | IP1 | B9h | - | - | IP1.5 | IP1.4 | IP1.3 | IP1.2 | IP1.1 | IP1.0 | 0000 0000b | | DIGPOT1 | BAh | - | - | - | - | - | - | - | - | 0000 0000b | | DIGPOT2 | BBh | - | - | - | - | - | - | - | - | 0000 0000b | | | | | | | | | | | | | Datasheet Rev 2.0 | | | | | | | 1 | 1 | 1 | 1 | | |-------------------------|-------------|------------|------------|------------------|-------------|-------------|-------------|-------------|-------------|--------------------------| | SFR Register | SFR<br>Adrs | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | Reset Value | | ISRCCAL1 | BCh | PGACAL0 | ISRCCAL1_6 | ISRCCAL1_5 | ISRCCAL1_4 | ISRCCAL1_3 | ISRCCAL1_2 | ISRCCAL1_1 | ISRCCAL1_0 | 0000 0000b | | ISRCCAL2 | BDh | - | ISRCCAL2_6 | ISRCCAL2_5 | ISRCCAL2_4 | ISRCCAL2_3 | ISRCCAL2_2 | ISRCCAL2_1 | ISRCCAL2_0 | 0000 0000b | | S1RELL | BEh | - | - | - | - | - | - | - | - | 0000 0000b | | S1RELH | BFh | - | - | -<br>MODE4 | - | -<br>T4D0 | -<br>D4D0 | -<br>T41 | | 0000 0000b | | S1CON*<br>S1BUF | C0h<br>C1h | S1M<br>- | reserved | MCPE1 | R1EN | T1B8<br>- | R1B8 | T1I | R1I<br>- | 0000 0000b<br>0000 0000b | | CCL1 | C2h | - | | | - | | - | - | - | 0000 0000b | | CCH1 | C3h | - | - | - | - | - | - | _ | - | 0000 0000b | | CCL2 | C4h | - | - | - | - | - | - | - | - | 0000 0000b | | CCH2 | C5h | - | - | - | - | - | - | - | - | 0000 0000b | | CCL3 | C6h | - | - | - | - | - | - | - | - | 0000 0000b | | CCH3 | C7h | - | - | - | - | - | - | - | - | 0000 0000b | | T2CON* | C8h | T2PS | T2PSM | T2SIZE<br>COCAH2 | T2RM1 | T2RM0 | T2CM | T2IN1 | T2IN0 | 0000 0000b | | CCEN<br>CRCL | C9h<br>CAh | COCAH3 | COCAL3 | COCAH2 | COCAL2 | COCAH1 | COCAL1 | COCAH0 | COCAL0 | 0000 0000b<br>0000 0000b | | CRCH | CBh | - | - | - | - | - | - | - | - | 0000 0000b | | TL2 | CCh | - | - | - | _ | - | - | - | - | 0000 0000b | | TH2 | CDh | - | - | - | - | - | - | - | - | 0000 0000b | | Reserved | CEh | | | | | | | | | | | MPAGE | CFh | - | - | - | - | - | - | - | - | 0000 0000b | | PSW* | D0h | CY | AC | F0 | RS1 | RS0 | OV | reserved | Р | 0000 0000b | | Reserved | D1h | | | | | | | | | | | Reserved<br>Reserved | D2h<br>D3h | | 1 | | | | | | | | | Reserved | D4h | | | | | | | | | | | Reserved | D5h | | | | | | | | | | | Reserved | D6h | | | | | | | | | | | Reserved | D7h | | | | | | | | | | | U0BAUD | D8h | BAUDSRC | - | - | - | - | - | - | - | 0000 0000b | | WDTREL | D9h | PRES | | | WDTREL_4 | | WDTREL_2 | WDTREL_1 | WDTREL_0 | 0000 0000b | | I2CCONFIG | DAh | I2CMASKID | 12CRXOVIE | 12CRXDAVIE | 12CTXEMPIE | 12CMANACK | 12CACKMODE | 12CMSTOP | I2CMASTER | 0000 0010b | | I2CCLKCTRL<br>I2CCHIPID | DBh<br>DCh | 12CID 6 | 12CID 5 | 12CID 4 | 12CID 3 | 12CID 2 | 12CID 1 | 12CID 0 | I2CWID | 0000 0000b<br>0100 0010b | | I2CIRQSTAT | DDh | I2CGOTSTOP | I2CNOACK | I2CSDAS | I2CDATACK | I2CIDLE | I2CRXOV | I2CRXAV | I2CT XEMP | 0010 1001b | | I2CRXTX | DEh | _ | - | - | - | - | - | - | - | 0000 0000b | | Reserved | DFh | | | | | | | | | | | ACC* | E0h | - | - | - | - | - | - | - | - | 0000 0000b | | SPIRX3TX0 | E1h | - | - | - | - | - | - | - | - | 0000 0000b | | SPIRX2TX1 | E2h | - | - | - | - | - | - | - | - | 0000 0000b | | SPIRX1TX2<br>SPIRX0TX3 | E3h | - | - | - | - | - | - | - | - | 0000 0000b | | SPICTRL | E4h<br>E5h | SPICK 2 | SPICK 1 | SPICK 0 | SPICS 1 | SPICS 0 | SPICKPH | SPICKPOL | SPIMA SL | 0000 0000b<br>0000 0001b | | SPICONFIG | E6h | SPICSLO | - | FSONCS3 | SPI LOAD | - | SPIRXOVIE | | SPITXEMPIE | 0000 0001b | | SPISIZE | E7h | - | | | 0 | | 0 | 0 | 0 | 0000 0111b | | IEN1* | E8h | T2EXIE | SWDT | ADCPCIE | MACOVIE | I2CIE | SPIRXOVIE | SPITEIE | reserved | 0000 0000b | | SPIIRQSTAT | E9h | - | - | SPITXEMPTO | SPISLAVESEL | SPISEL | SPIOV | SPIRXAV | SPITXEMP | 00011001b | | Reserved | EAh | | | | | | | | | | | MACCTRL1 | EBh | | PREVMODE | | OVRDVAL | ADDSRC_1 | | | MULCMD_0 | 0000 0000b | | MACC0 | ECh<br>EDh | - | - | - | - | - | - | - | - | 0000 0000b<br>0000 0000b | | MACC1<br>MACC2 | EEh | - | - | - | - | - | - | - | - | 0000 0000b | | MACC3 | EFh | - | - | - | - | - | - | - | - | 0000 0000b | | B* | F0h | - | - | - | - | - | - | - | - | 0000 0000b | | MACCTRL2 | | MACCLR2_2 | MACCLR2_1 | MACCLR2_0 | MACOV32IE | - | - | MACOV16 | MACOV32 | 0000 0000b | | MACA0 | F2h | | | | - | - | - | - | - | 0000 0000b | | MACA1 | F3h | - | - | - | - | - | - | - | - | 0000 0000b | | MACRES0 | F4h | - | - | - | - | - | - | - | - | 0000 0000b | | MACRES1 | F5h | - | - | - | - | - | - | - | - | 0000 0000b | | MACRES2<br>MACRES3 | F6h<br>F7h | - | - | - | - | - | - | - | - | 0000 0000b<br>0000 0000b | | USERFLAGS* | F8h | UF7 | UF6 | UF5 | UF4 | UF3 | UF2 | UF1 | UF0 | 0000 0000b | | MACB0 | F9h | - | - | - | - | - | - | - | - | 0000 0000b | | MACB1 | FAh | - | - | - | - | - | - | - | - | 0000 0000b | | MACSHIFTCTRL | FBh | SHIFTMODE | ALSHSTYLE | SHIFTAMPL_5 | SHIFTAMPL_4 | SHIFTAMPL_3 | SHIFTAMPL_2 | SHIFTAMPL_1 | SHIFTAMPL_0 | 0000 0000b | | MACPREV0 | FCh | - | - | - | - | - | - | - | - | 0000 0000b | | MACPREV1 | FDh | - | - | - | - | - | - | - | - | 0000 0000b | | | FEh | - | - | - | - | - | - | - | - | 0000 0000b | | MACPREV2<br>MACPREV3 | FFh | - | - | - | - | _ | - | - | - | 0000 0000b | <sup>\*</sup> Bit addressable ## **Peripheral Activation Control** ### **Digital Peripherals Power Enable** In order to save power upon reset, many of the digital peripherals of the VERSA MIX are not activated. The peripherals affected by this feature are: - o Timer 2 / Port1 - o Watchdog Timer - o MULT/ACCU unit - o I2C interface - o SPI interface - UART0 - o UART1 - o Differential Transceiver Before using one of the above-mentioned peripherals, you must first enable it by setting the corresponding bit of the DIGPWREN SFR register to 1. The same rule applies to access a given peripheral's SFR register. The targeted peripheral must have been powered on (enabled) first. Otherwise the SFR register content will be irrelevant The following table shows the structure of the DIGPWREN register. TABLE 13: (DIGPWREN) DIGITAL PERIPHERALS POWER ENABLE REGISTER - SFR | • • • • | | | | |---------|--------|-------|-------| | 7 | 6 | 5 | 4 | | T2CLKEN | WDOGEN | MACEN | I2CEN | | | | | | | 3 | 2 | 1 | 0 | |-------|-------------|---------|---------| | SPIEN | UART1DIFFEN | UART1EN | UART0EN | | Bit | Mnemonic | Function | |-----|-------------|----------------------------------------------------------------------------------------| | 7 | T2CLKEN | Timer 2 / PWM Enable 0 = Timer 2 CLK stopped 1 = Timer 2 CLK Running | | 6 | WDOGEN | Watch dog Enable 0 = Watchdog Disable 1 = Watch Dog Enable | | 5 | MACEN | 1 = MULT/ACCU Unit Enable<br>0 = MULT/ACCU Unit Disable | | 4 | I2CEN | 1= I2C Interface Enable 0 = I2C Interface Disable This bit is merged with CLK STOP bit | | 3 | SPIEN | 1 = SPI interface is Enable<br>0 = SPI interface is Disable | | 2 | UART1DIFFEN | UART1 Differential mode<br>0 = Disable<br>1 = Enable | | 1 | UART1EN | 0 = UART1 Disable<br>1 = UART1 Enable | | 0 | UART0EN | 0 = UART0 Disable<br>1 = UART0 Enable | ### **Analog Peripherals Power Enable** The analog peripherals such as the op-amp digital potentiometer current source and analog to digital converter have one register dedicated to enabling and disabling them. By default, those peripherals are powered down when the device is reset. TABLE 14: (ANALOGPWREN) ANALOG PERIPHERALS POWER ENABLE REGISTER - SFR 92h | 0111 0211 | | | | | |-----------|----------|---------|--------|--| | 7 | 6 | 5 | 4 | | | OPAMPEN | DIGPOTEN | ISRCSEL | ISRCEN | | | 3 | 2 | 1 | 0 | |------|-------|-------|--------| | TAEN | ADCEN | PGAEN | BGAPEN | | Bit | Mnemonic | Function | |-----|----------|------------------------------------------------------------------------------------------------------| | 7 | OPAMPEN | 1 = User Op-Amp Enable<br>0 = User Op-Amp Disable | | 6 | DIGPOTEN | 1 = Digital Potentiometer and Switch Enable 0 = Digital Potentiometer and Switch Disable | | 5 | ISRCSEL | 0 = ISRC with 200mV feedback<br>1 = ISRC with 200mV feedback | | 4 | ISRCEN | 1 = ISRC Output Enable<br>0 = ISRC Output Disable | | 3 | TAEN | 1 = TA Output Enable<br>0 = TA Output Disable | | 2 | ADCEN | 1 = ADC Enable<br>0 = ADC Disable | | 1 | PGAEN | 1 = PGA Enable<br>0 = PGA Disable | | 0 | BGAPEN | 1 = Bandgap Enable<br>0 = Bandgap Disable | **Note**: The SFR registers associated with all analog peripherals are activated when one or more analog peripherals are enabled. ### **General Purpose I/O** The VMX1020 provide 28 general-purpose I/O pins. The I/Os are shared with the digital peripherals and can be configured individually. At Reset, all the VERSA MIX I/O ports are configured as Input. The I/O Ports are bi-directional. This means, the CPU can write or read data through any of these ports. ### I/O Port Structure The VERSA MIX I/O port structure is shown in the following figure. FIGURE 9-1/O PORT STRUCTURE Each I/O pin includes a pull-up circuitry (represented by the internal pull-up resistor) . Also a pair of internal protection diodes internally connected to VCC and ground provides ESD protection. The I/O operational configuration is defined in the I/O control logic block. ## I/O Ports Drive Capability Each I/O port pin, when configured as an output is able to source or sink up to 4mA. The following graphs show the typical I/O output voltage vs. the source and sink current respectively. FIGURE 10: TYPICAL I/O VOUT VS. SOURCE CURRENT FIGURE 11: TYPICAL I/O VOUT VS. SINK CURRENT The maximum recommended driving current of a single I/O on a given port is 10mA. The recommended limit when more than one I/O on a given port is driving current is 5mA on each I/O. The total current drive of all I/O ports should be limited to 40mA The following figure shows a typical I/O rise time when a 20pF capacitive load is driven. In that case, the rise time is about 14ns. FIGURE 12: I/O RISE TIME WITH A 20PF LOAD Datasheet Rev 2.0 ### I/O Port Configuration Registers The VERSA MIX I/O port operation is controlled by two sets of four registers which are: - The Port Pin Configuration registers - The Ports Access registers The port pin configuration registers combined with specific peripheral configuration will define if a given pin acts as a general purpose I/O or if it provides the alternate peripheral functionality. Before using a peripheral shared with I/Os, the pin corresponding to the peripheral output must be configured as output and the pins that are shared with the peripheral inputs are configured as input. The following registers are used to configure each of the ports as either a general-purpose input, output or alternate peripheral function. For example, when bit 5 of Port 2 is configured as an output, it will output the SCK signal if the SPI interface is enabled and working. The only exception to this rule is the $I^2C$ Clock and data bus signals. In these two cases, the VERSA MIX configures the pins automatically as inputs or outputs. The P0PINCFG register controls the I/O access to UART1, the Timer 2 input and output as well as defines the direction of the P0 when used as general purpose I/O. TABLE 15: (POPINCFG) PORT 0 PORT CONFIGURATION REGISTER - SFR 9BH | P07IO P06IO | P05IO | P04IO | |-------------|-------|-------| | 3 | 2 | 1 | 0 | |--------------|------------|--------------|------------| | P0.3/RX1 INE | P0.2/TX1OE | P0.1/T2EXINE | P0.0/T2INE | | Bit | Mnemonic | Function | |-----|--------------|--------------------------------------------------------------------------------------------------------------| | 7:4 | P0xIO | Unavailable on VMX1020 | | 3 | P0.3/RX1 INE | O: General purpose input or UART1 RX 1: General purpose output When using UART1 you must set this bit to 0. | | 2 | P0.2/TX1OE | 0: General purpose input 1: General purpose output or UART1 TX When using UART1 you must set this bit to 1. | | 1 | P0.1/T2EXINE | 0: General purpose input or<br>Timer 2 EX<br>1: General purpose output<br>When using Timer 2EX input | | | | | you must set this bit to 0. | | |---|---|------------|----------------------------------------------------------------------------------------------------|--| | | 0 | P0.0/T2INE | 0: General purpose input or<br>Timer 2 IN<br>1: General purpose output<br>When using Timer 2 input | | | Į | | | you must set this bit to 0. | | The P1PINCFG register controls the access from the PWM to the I/O pins as well as defines the direction of the P1 when the PWM's are not used. TABLE 16: (P1PINCFG) PORT 1 PORT CONFIGURATION REGISTER - SFR 9CH | 7 | 6 | 5 | 4 | |------|------|------|------| | P1.7 | P1.6 | P1.5 | P1.4 | | | 3 | 2 | 1 | Λ | |---|------------|-------------|-------------|-------------| | | 3 | _ | | U | | Р | 1.3/PWM3EN | P1.2/PWM2EN | P1.1/PWM1EN | P1.0/PWM0EN | | | | 1 = | |-----|-------------|---------------------------| | Bit | Mnemonic | Function | | 7 | P1.7 | 0: General purpose input | | | | 1: General purpose output | | 6 | P1.6 | 0: General purpose input | | | | 1: General purpose output | | 5 | P1.5 | 0: General purpose input | | | | 1: General purpose output | | 4 | P1.4 | 0: General purpose input | | | | 1: General purpose output | | 3 | P1.3/PWM3OE | 0: General purpose input | | | | 1: General purpose output | | | | or PWM bit 3 output | | | | | | | | When using PWM you | | | | must set this bit to 1. | | 2 | P1.2/PWM2OE | 0: General purpose input | | | | 1: General purpose output | | | | or PWM bit 2 output | | | | | | | | When using PWM you | | | | must set this bit to 1 | | 1 | P1.1/PWM1OE | 0: General purpose input | | | | 1: General purpose output | | | | or PWM bit 1 output | | | | | | | | When using PWM you | | | | must set this bit to 1 | | 0 | P1.0/PWM0OE | 0: General purpose input | | | | 1: General purpose output | | | | or PWM bit 0 output | | | | When using PWM you | | | | must set this bit to 1 | | | | | The P2PINCFG register controls the I/O access to SPI interface and defines the direction of the P2 when used as general purpose I/O TABLE 17: (P2PINCFG) PORT 2 PORT CONFIGURATION REGISTER - SFR 9DH | 7 | 6 | 5 | 4 | |------------|------------|------------|-----------| | P2.7/SDIEN | P2.6/SDOEN | P2.5/SCKEN | P2.4/SSEN | | 3 | 2 | 1 | 0 | | |-------|-------|-------|-------|--| | CS0EN | CS1EN | CS2EN | CS3EN | | | | T | le a | |-----|------------|------------------------------------------------| | Bit | Mnemonic | Function | | 7 | P2.7/SDIEN | 0: General purpose input or SDI | | | | 1: General purpose output | | | | When using SPI you must set this bit to 0. | | 6 | P2.6/SDOEN | 0: General purpose input | | | | 1: General purpose output or<br>SDO | | | | When using SPI you must set this bit to 1. | | 5 | P2.5/SCKEN | 0: General purpose input or SCK | | | | 1: General purpose output | | | | When using SPI you must set this bit to 0. | | 4 | P2.4/SSEN | 0: General purpose input or<br>Slave Select | | | | 1: General purpose output | | | | When using SPI SS you must set this bit to 0. | | 3 | P2.3/CS0EN | 0: General purpose input | | | | 1: General purpose output or | | | | Chip Select bit 0 output | | | | When using SPI CS0 you must set this bit to 1. | | 2 | P2.2/CS1EN | 0: General purpose input | | | | 1: General purpose output or | | | | Chip Select bit 1 output | | | | When using SPI CS1 you | | | | must set this bit to 1. | | 1 | P2.1/CS2EN | 0: General purpose input | | | | 1: General purpose output or | | | | Chip Select bit 2 output | | | | When using SPI CS2 you must set this bit to 1. | | 0 | P2.0/CS3EN | 0: General purpose input | | | | 1: General purpose output or | | | | Chip Select bit 3 output | | | | When using SPI CS3 you | | | | must set this bit to 1. | The P3PINCFG register controls I/O access to UART0, the I2C interface, the capture compare input0 and 1, the Timer 0 and Timer 1 inputs as well as defines the direction of P3 when used as general purpose I/O TABLE 18: (P3PINCFG) PORT 3 PORT CONFIGURATION REGISTER - SFR 9EH | 7 | 6 | 5 | 4 | | |-------------|--------------|------------------|-----------------|--| | P3.7/MSCLEN | P3.6/MSD AEN | P3.5/T1 INE<br>N | P3.4/CCU1E<br>N | | | 3 2 | | 1 | 0 | | |-------------|-------------------------|---|------------|--| | P3.3/CCU0EN | P3.3/CCU0EN P3.2/T0INEN | | P3.0/TX0EN | | | | 1 | | |-----|--------------|-------------------------------------------------| | Bit | Mnemonic | Function | | 7 | | 0: General purpose input | | | | 1: General purpose output or | | | D0 7/M001 EN | Master I2C SCL output | | | P3.7/MSCLEN | | | | | When using the I2C you must | | | | set this bit to 1. | | 6 | | 0: General purpose input | | - | | 1: General purpose output or | | | | Master I2C SDA | | | P3.6/MSDAEN | | | | | When using the I2C you must | | | | set this bit to 1. | | 5 | | 0: General purpose input or | | 5 | | Timer1 Input | | | | 1: General purpose output | | | P3.5/T1INEN | i. General purpose output | | | | When using Timer 1 you must | | | | set this bit to 0. | | 4 | | 0: General purpose input or | | _ | | CCU1 Input | | | | 1: General purpose output | | | P3.4/CCU1EN | i. General purpose output | | | 13.4/0001210 | When using the Compare and | | | | Capture unit you must set this | | | | bit to 0. | | 3 | | 0: General purpose input or | | J | | CCU0 Input | | | | | | | P3.3/CCU0EN | 1: General purpose output | | | F3.3/GGUGEN | When using the Compare and | | | | When using the Compare and | | | | Capture unit you must set this bit to 0. | | | | | | 2 | | 0: General purpose input or | | | | Timer 0 Input | | | P3.2/T0INEN | 1: General purpose output | | | | When using Times O year reset | | | | When using Timer 0 you must | | 1 | | set this bit to 0. 0: General purpose input or | | ı | | | | | | UARTO Rx | | | P3.1/RX0EN | 1: General purpose output | | | | | | | | When using UART0 you must | | _ | | set this bit to 0. | | 0 | | 0: General purpose input | | | | 1: General purpose output or | | | P3.0/TX0EN | UART0 Tx | | | 10.0/17/0214 | | | | | When using UART0 you must | | | | set this bit to 1. | ### **Using General Purpose I/O Ports** The VMX1020's 28 I/Os are grouped in four ports. For each port an SFR register location is defined. Those registers are bit addressable providing the ability to control the I/O lines individually. When the port pin configuration register value defines the pin to be an output, the value written into the port register will be reflected at the pin level. Reading the I/O pin configured as input, is done by reading the content of its associated port registers. TABLE 19: | Port 0 - | SFR 80H | | | | | | | |------------------|----------|---|----|-------|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | P0 | [7:0] | | | | | Port 1 - 9 | SFR 90H | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | P1 | [7:0] | | | | | Port 2 - 9 | SFR A0H | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | P2 [7:0] | | | | | | | | PORT 3 - SFR B0H | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | P3 [7:0] | | | | | | | | Bit | Mnemonic | Function | |-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-0 | P0, 1, 2, 3 | When the Port is configured as an output, setting a port pin to 1 will make the corresponding pin to output logic high. When set to 0, the corresponding pin will set a logic low. | #### I/O usage example }//end of main() function The following example demonstrates the configuration of the VERSA MIX I/Os $\!\!\!$ //This example continuously reads the P0 and writes its contents into //P1 and it toggle P2 and P3. #pragma TINY #pragma UNSIGNEDCHAR #include <VMIXReg.h> at 0x0000 void main (void) DIGPWREN = 0x80; // Enable Timer 2 to activate P1 //Output P1PINCFG = 0x00; // Configure all P0 as Input P1PINCFG = 0xFF; //Configure P1 as Output P2PINCFG = 0xFF; P3PINCFG = 0xFF; //Configure P2 as Output //Configure P3 as Output while(1) //Write P0 into P1 P2 = ~P2: //Toggle P2 & P3 P3 = ~P3; # Using Port1.0-3 as General Purpose Output Port1.0-P1.3 can be used as standard digital outputs. However, in order to do this the Timer 2 clock must be enabled by setting the T2CLKEN bit of the DIGPWREN register. In addition, the Timer 2 CCEN register must also have the reset value. ### **Interrupt on Port1 Change Feature** The VERSA MIX includes a feature called *Interrupt on Port1 change*. This feature can be used to monitor the activity on each I/O Port1 pins (individually) and raises an interrupt when the state of the pin on which this feature has been activated changes. This is equivalent to having eight individual external interrupt inputs. The Interrupt on Port1 change shares the interrupt vector of the ADC peripheral at address 006Bh. See *The Interrupt section* for more details on how to use this feature. # MULT/ACCU - Multiply Accumulator Unit ### **MULT/ACCU Features** The VERSA MIX includes a hardware based multiply-accumulator unit, which is intended to provide an important speed up of arithmetic operations. ### MULT/ACCU unit facts list: - Hardware Calculation Engine - Calculation result is ready as soon as the input registers are loaded - Signed mathematical calculations - Unsigned MATH operations are possible if the MUL engine operands are limited to 15-bits in size - Auto/Manual reload of MAC RES - Enhanced VERSA MIX MULT/ACCU Unit - Easy implementation of complex MATH operations - 16-bit and 32-bit Overflow Flag - 32-bit Overflow can raise an interrupt - MULT/ACCU operand registers can be cleared individually or all together - Overflow flags can be configured to stay active until manually cleared - Can store and use results from previous operations - The MULT/ACCU can be configured to perform the following operations: FIGURE 13: VERSA MIX MULT/ACCU OPERATION Where MACA (multiplier), MACB (multiplicand), MACACC (accumulator) and MACRESULT (result) are 16, 16, 32 and 32 bits, respectively. ### **MULT/ACCU Control Registers** With the exception of the Barrel Shifter, the MULT/ACCU unit operation is controlled by two SFR registers: These registers are - The MACCTRL1 - o The MACTRLC2 The following two tables describe the details of these control registers. TABLE 20: (MACCTRL1) MULT/ACCU UNIT CONTROL REGISTER - SFR EBH | 7 | 6 | 5 | 4 | |----------|----------|--------|---------| | LOADPREV | PREVMODE | OVMODE | OVRDVAL | | | | | | | 3 | 2 | 1 | 0 | |--------------|---|-------|-----------| | ADDSRC [1:0] | | MULCN | /ID [1:0] | | | 1 | | |-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Mnemonic | Function | | 7 | LOADPREV | MACPREV manual Load control | | | | 1 = Manual load of the | | | | MACPREV register content if | | | | PREVMODE = 1 | | 6 | PREVMODE | Loading method of MACPREV register | | | | 0 = Automatic load when<br>MACA0 is written.<br>1 = Manual Load when 1 is<br>written into LOADPREV | | 5 | OVMODE | 0 = Once set by math operation,<br>the OV16 and OV32 flag will<br>remain set until the overflow<br>condition is removed.<br>1 = Once set by math operation,<br>the OV16 and OV32 flag will<br>stay set until it is cleared<br>manually. | | 4 | OVRDVAL | 0 = The value on MACRES is<br>the calculation result.<br>1 = the value on MACRES is the<br>32LSB of the MACRES when<br>the OV32 overflow occurred | | 3:2 | ADDSRC[1:0] | 32-bit Addition source B Input 00 = 0 (No Add) 01 = C (std 32-bit reg) 10 = RES -1 11 = C A Input 00=Multiplication 01=Multiplication 10=Multiplication 11= Concatenation of {A, B} for 32-bit addition | | 1:0 | MULCMD[1:0] | Multiplication Command<br>00 = MACA x MACB<br>01 = MACA x MACA<br>10 = MACA x MACPREV (16 LSB)<br>11 = MACA x MACBB | Datasheet Rev 2.0 | TABLE 21: (MACCTRL2) MULT/ACCU UNIT CONTROL REGISTER 2 -SFR F1H | | | | | | | |-----------------------------------------------------------------|-----------|---|---|--|--|--| | 7 | 6 | 5 | 4 | | | | | | MACOV32IE | | | | | | | 3 | 2 | 1 | 0 | |---|---|---------|---------| | - | - | MACOV16 | MACOV32 | | Bit | Mnemonic | Function | | | |-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 7:5 | MACCLR[2:0] | MULT/ACCU Register Clear<br>000 = No Clear<br>001 = Clear MACA<br>010 = Clear MACB | | | | | | 011 = Clear MACC<br>100 = Clear MACPREV<br>101 = Clear All MAC regs +<br>Overflow Flags<br>110 = Clear Overflow Flags only | | | | 4 | MACOV32IE | MULT/ACCU 32-bit Overflow<br>IRQ Enable | | | | 3 | - | - | | | | 2 | - | - | | | | 1 | MACOV16 | 16-bit Overflow Flag 0 = No 16 overflow 1 = 16-bit MULT/ACCU Overflow occurred | | | | 0 | MACOV32 | 32-bit Overflow Flag 1 = 32-bit MULT/ACCU Overflow This automatically loads the MAC32OV register. The MACOV32 can generate a MULT/ACCU interrupt when enabled. | | | ## **MULT/ACCU Unit Data Registers** The MULT/ACCU Data registers include operand and result registers that serve to store the numbers being manipulated in mathematical operations. Some of these registers are uniquely for addition (such as MACC) while others can be used for all operations. The MULT/ACCU operation registers are represented below. # MACA and MACB Multiplication (Addition) Input Registers The MACA and MACB register serves as the 16-bit input operands when performing multiplication. When the MULT/ACCU is configured to perform 32-bit addition, the MACA and the MACB registers are concatenated to perform a 32-bit word. In that case the MACA register contains the upper 16-bit of the 32-bit operand and the MACB contains the lower 16-bit | TABLE 22: (MAC A0) MULT/ACCU UNIT A OPERAND, LOW BYTE - SFR F2H | | | | | | | | | | | | |-----------------------------------------------------------------|-------------|---|---|---|---|---|---|--|--|--|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | MACA0 [7:0] | | | | | | | | | | | | Bit | Mnemonic | Function | | | | |-----|----------|---------------------------|--|--|--| | 7:0 | MACA0 | Lower segment of the MACA | | | | | 1 | | operand | | | | | TABLE 23: (MAC A1) MULT/ACCU UNIT A OPERAND, HIGH BYTE - SFR F3H | | | | | | | | |------------------------------------------------------------------|---|---|------|----------|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | MACA | 1 [15:8] | | | | | ĺ | Bit | Mnemonic | Function | |---|------|----------|---------------------------| | ı | | | | | ı | 15:8 | MACA1 | Upper segment of the MACA | | ı | | | operand | | TABLE 24: | (MACB0) | MULT/AC | CU UNIT E | OPERAND | , Low By | E - SFR F | 9н | |-----------|---------|---------|-----------|---------|----------|-----------|----| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | MACB | 0 [7:0] | | | | | Bit | Mnemonic | Function | | | | | |-----|----------|-----------------------------------|--|--|--|--| | 7:0 | MACB0 | Lower segment of the MACB operand | | | | | | TABLE 25: (MACB1) MULT/ACCU UNIT B OPERAND, HIGH BYTE - SFR FAH | | | | | | | Ан | | |-----------------------------------------------------------------|---|---|---|------|---------|---|----|---| | ſ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | MACB | 1 [7:0] | | | | | Bit | Mnemonic | Function | | | |-----|----------|-----------------------------------|--|--| | 7:0 | MACB1 | Upper segment of the MACB operand | | | ### **MACC Input Register** The MACC register is a 32-bit register used to perform 32-bit addition. It's possible to substitute the MACPREV Register to the MACC register or 0 in the 32-bit addition. TABLE 26: (MACCO) MULT/ACCU UNIT C OPERAND, LOW BYTE - SFR ECH | / | 6 | 5 | 4 | 3 | 2 | 1 | Ü | |-------------|---|---|---|---|---|---|---| | MACC0 [7:0] | | | | | | | | | | | | | | | | | | D'i | | | | | | | | | Bit | Mnemonic | Function | |-----|----------|-----------------------------------------------| | 7:0 | MACC0 | Lower segment of the 32-bit addition register | | TABLE 27 | (MACC1) | MULT/AC | CU UNIT ( | OPERANI | , BYTE 1 | SFR EDH | ı | |-----------------|---------|---------|-----------|---------|----------|---------|---| | 7 6 5 4 3 2 1 0 | | | | | | | | | MACC1 [15:8] | | | | | | | | | Bit Mnemonic | | | Fun | ction | | | | |--------------|-----------------|---------|-----------|------------------------------------------------------|-------------|---------|--| | 15:8 | | ACC1 | add | Lower middle segment of the 32-bit addition register | | | | | TABLE 28: | (MACC2) | MULT/AC | CU UNIT ( | OPERANI | ), BYTE 2 - | SFR EEH | | | 7 | 7 6 5 4 3 2 1 0 | | | | | | | | | MACC2 [23:16] | | | | | | | | Bit | Mnemonic | Function | |-------|----------|------------------------------------------------------| | 23:16 | MACC2 | Upper middle segment of the 32-bit addition register | Datasheet Rev 2.0 | TABLE 29: | (MACC3) | MULT/AC | CU UNIT C | OPERANI | o, High By | TE - SFR I | EFΗ | |---------------|---------|---------|-----------|---------|------------|------------|-----| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | MACC3 [31:24] | | | | | | | | | Bit | Mnemonic | Function | |-------|----------|-----------------------------------------------| | 31:24 | MACC3 | Upper segment of the 32-bit addition register | ### **MACRES Result Register** The MACRES register, which is 32-bit wide, contains the result of the MULT/ACCU operation. In fact, the MACRES register is the output of the Barrel Shifter. Table 30: (MACRES0) MULT/ACCU Unit Result, Low Byte - SFR F4H 7 6 5 4 3 2 1 | 7 | , | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------------|---|---|---|---|---|---|---|---| | MACRES0 [7:0] | | | | | | | | | | | | | | | | | | | | Bit | Mnemonic | Function | |-----|----------|-------------------------------------------------------| | 7:0 | MACRES0 | Lower segment of the 32-bit MULT/ACCU result register | TABLE 31: (MACRES1) MULT/ACCU UNIT RESULT, BYTE 1 - SFR F5H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|---|---|---|---|---|---|---| | MACRES1 [15:8] | | | | | | | | | | | | | | | | | | 15:8 MACRES1 Lower middle segment of the 32-bit MULT/ACCU result register | Bit | Mnemonic | Function | |---------------------------------------------------------------------------|------|----------|----------| | | 15:8 | MACRES1 | | | TABLE 32 | TABLE 32: (MACRES2) MULT/ACCU UNIT RESULT, BYTE 2 - SFR F6H | | | | | | | |----------|-------------------------------------------------------------|--|--|--|--|--|--| | 7 | 7 6 5 4 3 2 1 0 | | | | | | | | | MACRES2 [23:16] | | | | | | | | Bit | Mnemonic | Function | |-------|----------|------------------------------------| | 23:16 | MACRES2 | Upper middle segment of the 32-bit | | TABLE 33: (MACRES3) MULT/ACCU UNIT RESULT, HIGH BYTE - SFR F7H | | | | | | | | |----------------------------------------------------------------|-----------------|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | MACRES3 [31:24] | | | | | | | | l | Bit | Mnemonic | Function | |---|-------|----------|-------------------------------------------------------| | | 31:24 | MACRES3 | Upper segment of the 32-bit MULT/ACCU result register | ### MACPREV Register The MACPREV register provides the ability to automatically or manually save the content of the MACRES register and re-inject it into the calculation. This feature is especially useful in applications where the result of a given operation serves as one of the operand of the next one. As it has been mentioned earlier, there are two ways to load the MACPREV register controlled by the PREVMODE bit value: ### PREVMODE = 0: Auto MACPREV load, by writing into the MACA0 register. Selected when PREVMODE = 0. ### PREVMODE = 1: Manual load of MACPREV when the LOADPREV bit is set to 1 A good example using the auto loading of the MACPREV feature is the implementation of a FIR Filter. In that specific case, it is possible to save a total of 8 MOV operations per node calculation. TABLE 34: (MACPRE VO) MULT/ACCU UNIT PREVIOUS OPERATION RESULT, LOW | BTIE - SINT CH | | | | | | | | | |----------------|----------------|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | MACPREV0 [7:0] | | | | | | | | | Bit | Mnemonic | Function | |-----|----------|------------------------------------------------------------| | 7:0 | MACPREV0 | Lower segment of 32-bit MULT/ACCU previous result register | TABLE 35: (MACPRE V1) MULT/ACCU UNIT PREVIOUS OPERATION RESULT, BYTE 1 - SFR FDH | 1 - 01 111 | ווט | | | | | | | | |------------|----------------|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | MACPREV1 [7:0] | | | | | | | | | Bit | Mnemonic | Function | |------|----------|------------------------------------| | 15:8 | MACPREV1 | Lower middle segment of 32-bit | | | | MULT/ACCU previous result register | Table 36: (MACPRE V2) MULT/ACCU UNIT PREVIOUS OPERATION RESULT, BYTE 2 - SFR FEH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|---|---|---|---| | MACPREV2 [15:8] | | | | | | | | | Bit | Mnemonic | Function | |-------|----------|-------------------------------------------------------------------| | 23:16 | MACPREV2 | Upper middle segment of 32-bit MULT/ACCU previous result register | Table 37: (MACPRE V3) MULT/ACCU Unit Previous Operation Result, High Byte - SFR FFH | | BALE - SE | R FFH | | | | | | | |---|----------------|-------|---|---|---|---|---|---| | ı | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ı | MACPREV3 [7:0] | | | | | | | | | Bit | Mnemonic | Function | |-------|----------|------------------------------------------------------------| | 31:24 | MACPREV3 | Upper segment of 32-bit MULT/ACCU previous result register | FIGURE 14: VERSA MIX MULT/ACCU FUNCTIONAL DIAGRAM The block diagram above shows the interaction between the registers and the other components that comprise the MULT/ACCU unit on the VERSA MIX. ### **MULT/ACCU Barrel Shifter** The MULT/ACCU includes a 32-bit Barrel Shifter at the output of the 32-bit addition unit. The Barrel Shifter can perform right/left shift operations in one cycle, which is useful to scale the output result of the MULT/ACCU. The shifting range is adjustable from 0 to 16 both ways. The "shifted" addition unit output can be routed to: - MACRES - MACPREV - o MACOV32 The barrel shifter can perform both arithmetic and logical shifts: The shift left operation can be configured as an arithmetic or logical shift. In the later, the sign bit is discarded. TABLE 38: (MACSHIFTCTRL) MULT/ACCU UNIT BARREL SHIFTER CONTROL REGISTER - SFR FBH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|-----------|---|----|-------|--------|------|---| | SHIFTMODE | ALSHSTYLE | | SH | HFTAI | MPL [5 | 5:0] | | | Bit | Mnemonic | Function | |-----|----------------|-----------------------------------------| | 7 | SHIFTMODE | 0 = Logical SHIFT | | | | 1 = Arithmetic SHIFT | | 6 | ALSHSTYLE | Arithmetic Shift Left Style | | | | 0= Arithmetic Left Shift: Logical Left | | | | 1= Arithmetic Left Shift: Keep sign bit | | 5:0 | SHIFTAMPL[5:0] | Shift Amplitude 0 to 16 (5 bits to | | | | provide 16 bits shift range) | | | | Neg. Number = Shift Right | | | | (2 complements) | | | | Pos. Number = Shift Left | # MULT/ACCU Unit Setup and OV32 Interrupt Example In order to use the MULT/ACCU unit, one must first set up and configure the module. The following lines of code can be used to perform these tasks. The first part of the code is the interrupt setup and module configuration, whereas the second part is the interrupt function. Sample C code for MULT/ACCU Unit interrupt setup and module configuration: MACA0 = 0xFFMACA1 = 0x7F;MACB0 = 0 xFF; MACB1 = 0 xFF; MACC0 = 0xFFMACC1 = 0xFFMACC2 = 0xFF; MACC3 = 0x7F//--- as soon as the MAC input registers are loaded the result is available in the MACRESx registers. // MAC 32 bit overflow Interrupt Function void int\_5\_mac (void) interrupt 12 IEN0 &= 0x7F: // Disable all interrupts //Put MAC 32 bit Overflow Interrupt code here.\*/ //Note that when a 32bit overflow occurs, the 32 least significant bit of the current //result are stored into the MAC32OVx registers and can be read at the location of MACRESx by setting to 1 the OVRD VAL bit of the MACCTRL register IRCON &= 0xEF: // Clear flag (IEX5) IEN0 = 0x80;// Enable all interrupts # MULT/ACCU Application Example: FIR Filter Function The following ASM code shows the implementation on the VERSA MIX of a FIR filter computation function for one iteration, followed by data shifting operation and the definition of the FIR filter coefficient table. The FIR computation is simple to implement, but on the other hand, it is quite demanding in terms of processing power. This is because: For each new data point, the multiplication with associated coefficients + addition operation must be performed N times (N=number of filter apps). Because it is hardware based and provides an automatic reload of the result of the previous operation feature, the VERSA MIX MULT/ACCU unit is very efficient in performing operations such as FIR filter computation. In the example below, the COMPUTEFIR loop is the "heart" of the FIR computation, One can see that because of the MULT/ACCU unit features, very few instructions are needed to perform mathematical operation and the calculation result is ready on the next instruction. The net result the MULT/ACCU features combined is a dramatic performance improvement compared to having to perform all the math operations manually using solely processor instructions. ### **VERSA MIX FIR Filter Example** The example below shows how to use the MULT/ACCU unit of the VERSA MIX to perform FIR filter computing. In order to minimize the example size, only the FIR computing function and the coefficient table are presented. ``` ;** FIR Filter Computing Function FIRCOMPUTE: MOV RO,#NPOINTSBASEADRS ;INPUT ADC RAW DATA :AT Xn LOC ATIONS... ;Saving acquired data from calling function into RAM for computation VARH,DATAH MOV MOV VARL.DATAL :(MSB) MOV @R0,VARH INC MOV @R0.VARFL (LSB) ** Prepare to compute Yn.. ;***Define Base ADRS of input values MOV R0,#NPOINTSBASEADRS ;***Define Base Address of coefficients R1,#COEFBASEADRS MOV R7,#NPOINTS ;DEFINE COUNTER ;***Configure the MULT/ACCU unit as Follow: MACCTRL,#00001000B ;BIT7 LOADPREV = 0 No manual Previous result Automatic Previous result save when MULT/ACCUA0 is loaded ;BIT6 PREVMODE = 0 ;BIT5 OVMODE = 0 Overflow flag remains ON until overflow condition exist The value of MACRES is the calculation ;BIT4 OVRD VAL = 0 MACPREV is the Addition Source :BIT3:2 ADDSRC = 10 Mul Operation = MAC AxMACB ;BIT1:0 MULCMD = 00 ;**Clear the MULT/ACCU registers content MACCTRL2,#0A0H ;** COMPUTE Yn... COMPUTEFIR: MOVMACB1,@R1 ;Put a given Coefficient into ;MULT/ACCUB INC MOV MACB0,@R1 INC MAC A1,@R0 ; Put a given Xn Input into INC MOV MACA0,@R0 ;This last instruction load the MACPREV register for next Operation ÍNC DJNZ R7,COMPUTEFIR ;Do the Computation for N taps ;*** Second part ;** SHIFT PREVIOUS INPUT VALUES TO LET PLACE FOR NEXT ONE... SHIFTPAST: MOV R7,#(NPOINTS-1)*2 :Define # of datashift :To perform (N-1)*2 ;***COMPUTE FIRST FETCH ADDRESS MOV R0,#(NPOINTSBASEADRS - 1 + 2*(NPOINTS-1)) :***COMPUTE FIRST DESTINATION ADDRESS R1,#(NPOINTSBASEADRS + 1 + 2*(NPOINTS-1)) MOV SHIFTLOOP: MOV A,@R0 ;Shift Given LSB input... MOV @R1,A :To next location R0 ;Prepare pointer for moving LSB DEC R1 R7,SHIFTLOOP DJNZ PERFORM TRANSFORMATION OF Yn HERE AND PUT INTO BINH, BINL ;** IN THIS CASE THE COEFFICIENTS HAVE BEEN MULTIPLIED BY 65536 :** SO THE RESULT IS ON 32-BITS ``` \*\*\* DIVISING YN BY 65536 MEAN ONLY TAKING THE UPPER 16-BITS DATAL,MACRES2 SENDLTC1452 LCALL MOV RET ;\* FIR Filter Coefficients Table ;FSAMPLE 480HZ, N=16, LOW PASS 0.1HZ -78DB @ 60HZ COFFTABLE: DW 023DH 049DH DW DW 086AH DW 0D2DH 1263H DW 1752H 1B30H DW $\mathsf{DW}$ 1D51H DW 1D51H DW 1B30H 1752H 1263H DW DW 0D2DH DW 086AH DW 049DH DW 023DH DW 0FFFFH END OF TABLE DATAH, MACRES3 MOV ## **VERSA MIX Timers** The VERSA MIX includes 3 general-purpose timer/counters - o Timer 0 - o Timer 1 - o Timer 2 Timer 0 and Timer 1 are general purpose timers that can operate as either a timer with a clock rate based on the system clock, or as an event counter that monitor events occurring on an external timer input pin named T0IN for Timer 0 and T1IN for Timer 1. Timers 0 and Timer 1 are very close to the standard 8051 timers. Like the Timer 0 and Timer 1, the Timer 2 can operate Timer based on a system clock or it can be used as an Event counter. The Timer 2 is quite different than the Timers 0 and Timer 1 and over the basic timer and event counter function; it is the heart of the PWM outputs and the Compare and Capture Units. Each timer of the VERSA MIX has a dedicated interrupt vector, which can be trigged when the Timer overflows. ## Timer 0 and Timer 1 The VERSA MIX Timer 0 and Timer 1 are very similar in their structure and operation. The main differences between them resides on the fact that the Timer 1 serves as a baud rate generator for the UARTO and it shares some of its resources when the Timer 0 is used in mode 3. Timer 0 and Timer 1 each consist of a 16-bit register for which the content is accessible as two independent SFR registers: TLx and THx. | Table 39: (TL0) Timer 0 Low Byte - SFR 8AH | | | | | | | | | |--------------------------------------------|------------|------------|------------|---------------------|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | TL0 [7:0] | | | | | | | | | TABLE 40: | :(ТН0) Тім | IER 0 HIGH | BYTE - SF | R 8CH | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | TH0 | [7:0] | | | | | | TABLE 41: (TL1) TIMER 1 LOW BYTE - SFR 8BH | | | | | | | | | | TABLE 41: | (TL1) TIM | ER1 LOW | BYTE - SFF | ₹ 8Вн | | | | | | TABLE 41: | (TL1) TIM | ER1 LOW I | BYTE - SFI | R 8Вн<br>3 | 2 | 1 | 0 | | | TABLE 41: | · | | 4 | R 8Вн<br>3<br>[7:0] | 2 | 1 | 0 | | | TABLE 41: | 6 | 5 | 4<br>TL1 | 3<br>[7:0] | 2 | 1 | 0 | | | 7 | 6 | 5 | 4<br>TL1 | 3<br>[7:0] | 2 | 1 | 0 | | At the exception of the associated interrupt, the configuration and control of Timer 0 and Timer 1 is performed via the TMOD and the TCON SFR registers. The table below shows the TCON special function register of the VERSA MIX. This register contains the Timer 0/1 overflow flags, Timer 0/1 run control bits; the interrupt 0/1 edge flags; and the interrupt 0/1 interrupt type control bits TABLE 43: (TCON) TIMER 0, TIMER 1 TIMER/COUNTER CONTROL - SFR 88H | 7 | 6 | 5 | 4 | |-----|-----|-----|-----| | TF1 | TR1 | TF0 | TR0 | | | | | | | 3 | 2 | 1 | 0 | | IE1 | IT1 | IE0 | IT0 | | Bit | Mnemonic | Function | | | | | |-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 7 | TF1 | Timer 1 overflow flag. Set by hardware when Timer 1 overflows. It is automatically cleared when the Timer 1 interrupt is serviced. This flag can also be cleared by software. | | | | | | 6 | TR1 | Timer 1 Run control bit. TR1 = 0, Stop Timer 1 TR1 = 1, Start Timer 1 | | | | | | 5 | TF0 | Timer 0 overflow flag. Set by hardware when Timer 0 overflows. It is automatically cleared when the Timer 0 interrupt is serviced. This flag can also be cleared by software. | | | | | | 4 | TR0 | Timer 0 Run control bit. TR0 = 0, Stop Timer 0 TR0 = 1, Start Timer 0 | | | | | | 3 | IE1 | Interrupt 1 edge flag. This flag is set by hardware when falling edge on external INT1 is observed. It is cleared when interrupt is processed. | | | | | | 2 | Π1 | INT1 interrupt event type control bit. IT1 = 0, interrupt will be caused by a Low Level on INT1 IT1 = 1, Interrupt will be caused by a High to Low transition on INT1. | | | | | | 1 | IE0 | INTO edge flag configuration Set by hardware when falling edge on external pin INT1 is observed. It is cleared when interrupt is processed. | | | | | | 0 | IT0 | INT0 interrupt event type control bit. IT0 = 0, interrupt will be caused by a Low Level on INT0 IT0 = 1, Interrupt will be caused by a High to Low transition on INT0. | | | | | The TMOD register is mainly used to set the operating mode of the timers and it allows the user to enable the external gate control as well as select a timer or counter operation. TABLE 44: (TMOD) TIMER MODE CONTROL - SER 89H | _ | TABLE 44. (TWOD) TIMER WODE CONTROL - 3FR 89H | | | | | | | |---|-----------------------------------------------|-----|------|-----|--|--|--| | I | 7 | 6 | 5 | 4 | | | | | I | GATE1 | CT1 | M1 1 | M01 | | | | | | | | | | | | | | | 3 | 2 | 1 | 0 | | | | | I | GATE0 | CT0 | M10 | M00 | | | | | Dit | Mnomonio | Function | | | | | |-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Bit | Mnemonic | | | | | | | 7 | GATE1 | GATE1 = 0,<br>The level present on the INT1 pin has<br>no effect on Timer1 operation. | | | | | | | | GATE1 = 1,<br>The level of INT1 pin serves as a Gate<br>control on to Timer/Counter operation<br>provided the TR1 bit is set. Applying a<br>Low Level on the INT1 pin makes the<br>Timer stop. | | | | | | | CT1 | Selects TIMER1 Operation. | | | | | | | | CT1 = 0, Sets the Timer 1 as a Timer which value is incremented by SYSCLK events. | | | | | | | | CT1 = 1, The Timer 1 operates as a counter which counts the High to Low transition on that occurs on the T1IN input. | | | | | | 5 | M11 | Selects mode for Timer/Counter 1, as | | | | | | 4 | M01 | shown in the Table below. | | | | | | 3 | GATE0 | GATE0 = 0, | | | | | | | | The level present on the INT1 pin has no effect on Timer1 operation. | | | | | | | | GATE0 = 1, | | | | | | | | The level of INT1 pin serves as a Gate control on to Timer/Counter operation provided the TR1 bit is set. Applying a Low Level on the INT1 pin makes the Timer stop. | | | | | | 2 | CT0 | Selects Timer 0 Operation. CT1 = 0, Sets the Timer 0 as a Timer which value is incremented by SYSCLK events. | | | | | | | | CT1 = 1, The Timer 0 operates as a counter which counts the High to Low transition on that occurs on the T1IN input. | | | | | | 1 | M10 | Selects mode for Timer/Counter 0, as | | | | | | 0 | M00 | shown in the Table below. | | | | | ### Timer 0 / Timer 1 / Counter Operation The CT0 and CT1 bits of the TMOD register controls the Clock source of the Timer 0 and the Timer 1 respectively. When the CT bit is set to 0 the Timer operates in Timer mode, which make it take its source from the System Clock divided by 12. Setting the CTx bit to 1 makes the Timer operate in event counter mode. In this mode High to Low transitions on the TxIN pin of the VERSA MIX increments the timer value. When Timer 0 and Timer 1 operate in Timer mode, they use the System Clock as the source. This means that configuring the CLKDIVCTRL register will affect the Timers operation. ### **Timer 0, Timer 1 Gate Control** The Gate control makes it possible to have an external device to be able to control the Timer 0 and Timer 1 operation through the interrupt (INTx) pins. When the GATEx and TRx bits of the TMOD register are set to 1: - INTx = Logic LOW, The Timer x Stops - INTx = Logic High, The Timer x Runs When the Gate bit equals 0, then the logic level presented on the INTx pin have no effect on the Timer Operation. FIGURE 15: TIMER 0, TIMER 1 CTx & GATE CONTROL ### **Timer 0, Timer 1 Operation Modes** The operating mode of the Timer 0 and Timer 1 is determined by the value of the M1x and M0x bits of the TMOD register. The table below summarizes the four modes of operation of Timers 0 and 1. TABLE 45: TIMER/COUNTER MODE DESCRIPTION SUMMARY | M1 | MO | Mode | Function | | | |----|----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 0 | 0 | Mode 0 | 13-bit Timer / Counter, with 5 lower bits in TL0 or TL1 register and bits in TH0 or TH1 register (for timer 0 and timer 1, respectively). The 3 high order bits of TL0 and TL1 are held at 0. | | | | 0 | 1 | Mode 1 | 16-bit Timer / Counter | | | | 1 | 0 | Mode 2 | 8-bit auto reload Timer / Counter. The reload value is kept in TH0 or TH1, while TL0 or TL1 is incremented every machine cycle. When TLx overflows, a value from THx is copied to TLx. | | | | 1 | 1 | Mode 3 | If Timer 1 M1 and M0 bits are set to 1, Timer 1 stops. If Timer 0 M1 and M0 bits are set to 1, Timer 0 acts as two independent 8-bit Timers / Counters. | | | ### Mode 0, 13-bit Timer / Counter Mode 0 operation is the same for Timer 0 and Timer 1. In Mode 0, the timer is configured as a 13-bit counter that uses bits 0-4 of TLx register and all 8-bits of THx register. The Timer Run bit (TRx) of the TCON SFR starts the timer. The value of the CTx bit defines if the Timer will operate as a Timer (CTx = 0) taking its source from the System Clock or if the Timer will count the High to Low Transitions (CTx = 1) that occurs on the External Timer input pin (TxIN). When the 13-bit count increments from 1FFFh (all ones), the counter rolls over to all zeros, the TF0 (or TF1) bit is set in the TCON SFR The state of the upper 3-bits of TLx register is indeterminate in Mode 0 and must be masked when the software evaluates the register's content. ### Mode 1 (16-bit) Mode 1 operation is the same for Timer 0 and Timer 1. In Mode 1, the timer is configured as a 16-bit counter. The counter rolls over to all zeros (0000h) upon surpassing FFFh. Otherwise; Mode 1 operation is the same as Mode 0. FIGURE 16: TIMER 0 MODE 0 & MODE 1 The Timer 0 and Timer 1 overflow rate in mode 1 can be calculated by the following equations: ### Mode 2 (8-bit) The operation of Mode 2 is the same for Timer 0 and Timer 1. In Mode 2, the timer is configured as an 8-bit counter, with automatic reload of the start value. The LSB of the Timer register, TLx is the counter itself and the MSB portion of the Timer, THx, stores the timer reload value. The Mode 2 counter control is the same as for Mode 0 and Mode 1. However, in Mode 2, when TLx surpasses FFh, the value stored in THx is reloaded into TLx. FIGURE 18: TIMER 0 MODE 2 FIGURE 19: TIMER 1 MODE 2 The Timer 0 and Timer 1 overflow rate in mode 2 can be calculated by the following equations: ### Using the Timer 1 as Baud Rate generator Using the mode 2 of Timer 1 is probably the most appropriate mode when using the Timer 1 as the UART0 baud rate generator. The reason why one would use the Timer 1 instead of the S0REL baud rate generator for UART0 is to achieve baud rate not possible to achieve with the S0REL. Note that Timer 1 can serve as a baud rate generator for UART0 in the four Timer 1 operating modes. However for UART0 operation we recommend to operate the timer in mode 2. ### Mode 3 (2 x 8-bit) In Mode 3, Timer 0 operates as two 8-bit counters and Timer 1 stops counting and holds its value. FIGURE 20: TIMERO. TIMER 1 STRUCTURE IN MODE 3 The Timer 0 overflow rate in mode 3 can be calculated by the following equations: In mode 3, the values present in the TH1 and TL1 registers as well as the value of the GATE1 and CT1 control bits have no impact on the Timer operation ### **Timer 0 and Timer 1 Interrupts** Each Timer 0 and Timer 1 have a dedicated interrupt Vector located at: - o 000Bh for the Timer 0 - o 001Bh for the Timer 1 The natural priority of the Timer 0 is higher than the one of the Timer 1. The following table gives a summary of the Interrupt control and Flag bit associated with the Timer 0 and the Timer 1 interrupts. | Bit Name | Location | Description | |----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------| | EA | IEN0.7 | General interrupt control bit<br>0, Interrupt Disabled<br>1, Enabled Interrupt active | | TOIE | IEN0.1 | Timer 0 Overflow Interrupt 1 = Enable 0 = Disable | | T1IE | IEN0.3 | Timer 1 Overflow Interrupt 1 = Enable 0 = Disable | | TF0 | TCON.5 | TF0 Flag is set when Timer 0 Overflow occurs. Automatically cleared when Timer 0 interrupt is serviced. This flag can also be cleared by software | | TF1 | TCON.7 | TF1 Flag is set when Timer 1 Overflow occurs. Automatically cleared when Timer 1 interrupt is serviced. This flag can also be cleared by software | ### **Setting Up Timer 0 Example** In order to use Timer 0, one must first set up and configure the module. The following lines of code can be used to perform these tasks. The first part of the code is the interrupt setup and module configuration whereas the second part is the interrupt function. #### Sample C code to set up Timer 0: | // | | | | | | |--------------------------------|--------------------------------------|--|--|--|--| | // Sample C code to setup | Timer 0 | | | | | | // | | | | | | | // () PROGRAM INITIALIZA | // () PROGRAM INITIALIZATION OMITTED | | | | | | AT 0X0100 VOID MAIN(VOID | )(( | | | | | | // INTERRUPT + TIMER 0 S | ETUP | | | | | | IEN0 = 0X80; | // ENABLE ALL INTERRUPTS | | | | | | IEN0 = 0x02; | // ENABLE INTERRUPT TIMER 0 | | | | | | TMOD = 0x02; // TIMER 0 MODE 2 | | | | | | | TCON = 0X10; | // START TIMER 0 | | | | | | DO{}WHILE(1); | //WAIT FOR TIMER 0 INTERRUPT | | | | | ### Setting Up Timer 1 Examples The following is the code used to configure Timer 1. The first part of the code is the interrupt setup and module configuration whereas the second part is the interrupt function. ### Example1: Delay function ``` // Sample C code using the Timer 1: Delay function VOID DELAY1MS (LINSIGNED CHAR DLAIS) { IDATA UNSIGNED CHAR X=0; TMOD = 0X10; TL1 = 0X33; TH1 = 0XFB; ://TIMER1 RELOAD VALUE FOR TCON = 0x40; WHILE (DLAIS > 0) DO{ x=TCON; X= X&0X80; }WHILE(X==0); TCON = TCON&0x7F; TL1 = 0X33; TH1 = 0XFB; ://TIMER1 RELOAD VALUE FOR DLAIS = DLAIS-1; }//END OF DELAY 1MS ``` ### Example2: Timer 1 interrupt example ``` // Sample C code using the Timer 1: Interrupt // (...) PROGRAM INITIALIZATION OMITTED at 0xo100 void main(void){ // TIMER 1 setup IEN0 |= 0x80; // Enable all interrupts IEN0 = 0x08; // Enable interrupt Timer1 TMOD = 0 x20; TCON = 0x40; // Timer 1 mode 2 // Start Timer 1 TL1 = 0xFC; // Timer1 offset }while(1); //Wait Timer 1 interrupt }//end of main() function // Timer 1 Interrupt function void int_timer_1 (void) interrupt 3 IEN0 &= 0x7F; // Disable all interrupts /* Put Interrupt code here*/ IEN0 |= 0x80; // Enable all interrupts ``` ## Timer 2 The VERSA MIX Timer 2 and its surrounding peripherals include a number of other functionalities, which are: - o 16-Bit Timer - 16-Bit Auto-Reload Timer - Compare and Capture units - o 8 / 16 PWM outputs TABLE 46: (TL2) TIMER 2, LOW BYTE - SFR CCH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------------------------------------|------------|------------|---------|--------|---|---|---| | TL2 [7:0] | | | | | | | | | TABLE 47: (TH2) TIMER 2, HIGH BYTE - SFR CDH | | | | | | | | | TABLE 47. | (ITZ) IIIV | IERZ, HIGI | IDTIE-O | FN CDH | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | TH2 [7:0] The figure 21 shows the Timer2 / Compare/ Capture unit block diagram. In the next paragraphs these functional blocks of the Timer 2 will be explained. ### **Timer 2 Registers** The heart of the Timer 2 is constituted of a 16-bit register, which upper and lower portions are accessible as two independent SFR registers. TABLE 48: (TL2) TIMER 2 LOW BYTE - SFR CCH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------------------------|---|---|---|---|---|---|---| | TL2 [7:0] | | | | | | | | | The state (THO) The specific of DOD. | | | | | | | | | TABLE 49: (TH2) TIMER 2 HIGH BYTE - SFR CDH | | | | | | | | |---------------------------------------------|-----------|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | TH2 [7:0] | | | | | | | ### **Timer 2 Control Register** Most of the basic control of the Timer 2 is done through the T2CON register located at SFR address C8h. ### The T2CON register controls: - o T2 clock source Prescaler - T2 count size (8/16-bits) - T2 reload mode - T2 Input selection TABLE 50: (T2CON) TIMER 2 CONTROL REGISTER -SFR C8H | 7 | 6 | 5 | 4 | |------|-------|--------|-------| | T2PS | T2PSM | T2SIZE | T2RM1 | | | | | | | 3 | 2 | 1 | 0 | |-------|------|-------|-------| | T2RM0 | T2CM | T2IN1 | T2IN0 | | Bit | Mnemonic | Function | |-----|----------|----------------------------------------| | 7 | T2PS | Prescaler select bit: | | | | 0 = Timer 2 is clocked with 1/12 of | | | | the oscillatory frequency | | | | 1 = Timer 2 is clocked with 1/24 of | | | | the oscillatory frequency | | 6 | T2PSM | 0 = Prescaler | | | | 1 = clock/2 | | 5 | T2SIZE | Timer 2 Size | | | | 0 = 16-bit | | | | 1 = 8-bit | | 4 | T2RM1 | Timer 2 reload mode selection | | 3 | T2RM0 | 0X = Reload disabled | | | | 10 = Mode 0 | | | | 11 = Mode 1 | | 2 | T2CM | Timer 2 compare mode selection | | | | 0 = Mode 0 | | | | 1 = Mode 1 | | 1 | T2IN1 | Timer 2 input selection | | 0 | T2IN0 | 00 = Timer 2 stops | | | | 01 = Input frequency f/2, f/12 or f/24 | | | | 10 = Timer 2 is incremented by | | | | external signal at pin T2IN | | | | 11 = Internal clock is gated to the | | | | T2IN input. | FIGURE 21: TIMER 2 AND COMPARE/CAPTURE UNIT ### **Timer 2 Clock Sources** Timer 2 can operate in Timer mode, in which case it take its source from the System Clock (SYSCLK) or it can be configured as an event counter where the High to Low transition on the T2IN input makes the Timer 2 to increment. The T2IN0 and T2IN1 bits of the T2CON register serves to define the selected Timer 2 input and the operating mode of the Timer 2 as shown in the next table: TIMER 2 CLOCK SOURCE | T2IN1 | T2IN0 | Selected Timer 2 input | | | | |-------|-------|-----------------------------------------------------------------------------|--|--|--| | 0 | 0 | Timer 2 Stop | | | | | 0 | 1 | Standard Timer mode using internal clock with or without prescaler | | | | | 1 | 0 | External T2IN pin clock Timer2 | | | | | 1 | 1 | Internal Clock is gated by the T2IN input<br>When T2IN = 0, the Timer2 stop | | | | When in Timer mode the Timer 2 take its source from the System Clock, the CLKDIVCTRL register will affect the Timer 2 operation. ### **Timer 2 Stop** When both T2IN1 and T2IN0 bit are set to 0. The Timer 2 is in STOP mode. ### **Timer 2 Operating Modes** When the T2IN1 bit equals 0 and the T2IN0 bit equals 1. The Timer 2 register takes its source from the internal clock pre-scaled or not, depending on the T2PSM bit value. #### **Event Counter Mode** When operating in the Event Counter Mode, the timer is incremented as soon as the external signal T2IN changes value from 1 to 0. A sample of the T2IN input is taken at every machine cycle. Timer 2 is incremented in the cycle following the one in which the transition was detected. ### **Gated Timer Mode** In the Gated Timer Mode, the internal clock, which serves as the Timer 2 clock source, is gated by the external signal T2IN. In other words, when T2IN is high, the internal clock is allowed to pass through the AND gate. A low value of T2IN will stop the clock pulse. This provides the ability for an external device to control the Timer 2 operation or to use the Timer 2 to monitor the duration of an event. ### **Timer 2 Clock Prescaler** When the Timer 2 is configured to take its clock source from the System Clock, the Clock prescaling value can be controlled by software using the T2PSM and the T2PS bit of the T2CON register. The different system clock prescaling values are shown below: | T2PSM | T2PS | Timer 2 input clock | | |-------|------|---------------------|--| | 1 | X | SYSCLK / 2 | | | 0 | 0 | SYSCLK / 12 | | | 0 | 1 | SYSCLK / 24 | | ### **Timer 2 Count Size** The Timer 2 can be configured to operate in 8-bit or 16-bit formats. The T2SIZE bit of the T2CON register selects the Timer 2 count size. - o If T2SIZE = 0, Timer 2 size is 16-bits - If T2SIZE = 1, Timer 2 size is 8-bits ### **Timer 2 Reload Modes** The Timer 2 reload mode is selected by the T2RM1 and T2RM0 bits of the T2CON register. The next figure shows the reload operation. The Timer 2 must be configured as a 16-bit Timer/Counter for the reload modes to be operational by clearing the T2SIZE bit. ### Timer 2 Mode 0 When the timer overflows, the T2IF overflow flag is set. Concurrently, this overflow causes the Timer 2 register to be reloaded with the 16-bit value contained in the CRCx register, (which has been preset by software). This reload operation will occur during the same clock cycle in which T2IF was set. #### Timer 2 Mode 1 In Mode 1, a 16-bit reload from the CRCx register on the falling edge of T2EX occurs. This transition will set T2EXIF if T2EXIE is set. This action will cause an interrupt (providing that the Timer 2 interrupt is enabled) and T2IF flag value will not be affected. The value of the T2SIZE does not affect the Reload in Mode 1. Also, the reload operation is performed independently of the state of the T2EXIE bit. FIGURE 22: TIMER 2 RELOAD MODE ### **Timer 2 Overflows and Interrupts** When the Timer 2 counter, the T2IF flag is set, and a Timer 2 interrupt occurs, the Timer 2 interrupt is enabled. A Timer 2 interrupt may also be raised from T2EX if T2EXIE bit of the IEN1 register is set. Finding the exact source of a Timer 2 interrupt can be verified by checking the value of the T2IF and the T2EXIF bits of the IRCON register. The interrupt vector of the Timer 2 is located at address 002Bh ### **Timer 2 Setup Example** In order to use Timer 2, one must first set up and configure the module. The following lines of code may be used to perform these tasks. | //// Sample C code to setup Timer 2 | | |-------------------------------------------------------------------------------------|---------------------------------------------------------| | // () PROGRAM INITIALIZATION OMITTE | | | at 0x100 void main(void){ | | | // TIMER 2 & Interrupt setup DIGPWREN = 0x80; T2CON = 0x01; TL2 = 0xE0; TH2 = 0xFF; | // Enable Timer2,<br>// Set timer 2 to OSC/12 | | IEN0 = 0x80;<br>IEN0 = 0x20; | // Enable all interrupts<br>// Enable interrupt Timer 2 | | do{<br>}while(1); | //wait for Timer 2 interrupt | | }//end of main() | | | // | | | void int_timer_2 (void) interrupt 5 { IEN0 &= 0x7F; | // Disable all interrupts | | /**/<br>/*Interrupt code here*/<br>/**/ | | | IEN0 = 0x80;<br>} | // Enable all interrupts | ## **Timer 2 Special Modes** Over general timing / counting operations, the VERSA MIX Timer 2 includes 4 Compare and Capture units that can be used to monitor specific events and to serve to drive PWM outputs. Each Compare and Capture unit provides three specific operating modes that are controlled by the CCEN register: - Compare Modes Enable. - Capture on write into CRCL/CCLx registers. - Capture on rising edge at CCU input pins. TABLE 51: (CCEN) COMPARE/CAPTURE ENABLE REGISTER -SFR C9H | / | 0 | 5 | 4 | |--------|---------------|--------|--------| | COCAH3 | COCAL3 | COCAH2 | COCAL2 | | | | | | | 3 | 3 2 | | 0 | | COCAH1 | COCAH1 COCAL1 | | COCAL0 | The CCEN register bits are grouped in pairs of COCAHx/COCALx bits. Each pair corresponds to one Compare and Capture Unit. The Capture and Compare unit operating mode vs. the configuration bit is defined as follows: | | n:- | 1 | | | | |----------|----------|-------------------------------|--|--|--| | | Bit | | | | | | Mnemonic | Mnemonic | Function | | | | | COCAH0 | COCAL0 | Compare and Capture mode | | | | | | | for CRC register | | | | | 0 | 0 | Compare/capture disabled | | | | | 0 | 1 | Capture on rising edge at pin | | | | | | | CCU0 (1 cycle) | | | | | 1 | 0 | Compare enabled (PWM0) | | | | | 1 | 1 | Capture on write operation | | | | | | | into register CRC1 | | | | | COCAH1 | COCAL1 | Compare/capture mode for | | | | | | | CC register 1 | | | | | 0 | 0 | Compare/capture disabled | | | | | 0 | 1 | Capture on rising edge at pin | | | | | | | CCU1 (2 cycles) | | | | | 1 | 0 | Compare enabled (PWM1) | | | | | 1 | 1 | Capture on write operation | | | | | | | into register CCL1 | | | | | COCAH2 | COCAL2 | Compare/capture mode for | | | | | | | CC register 2 | | | | | 0 | 0 | Compare/Capture disabled | | | | | 0 | 1 | Capture on rising edge at pin | | | | | | | CCU2 (2 cycles) | | | | | 1 | 0 | Compare enabled (PWM2) | | | | | 1 | 1 | Capture on write operation | | | | | | | into register CCL2 | | | | | COCAH3 | COCAL3 | Compare/Capture mode for | | | | | | | CC register 3 | | | | | 0 | 0 | Compare/capture disabled | | | | | 0 | 1 | N/A - CCU3 not pinned out | | | | | 1 | 0 | Compare enabled (PWM) | | | | | 1 | 1 | Capture on write operation | | | | | | | into register CCL3 | | | | This configuration allows configuring of each Compare and Capture Unit operation individually and independently of the three other Compare and Capture Units. ### **Compare / Capture, Reload Registers** Each Compare and Capture Unit has a specific 16-bit register accessible through two SFR addresses. Note that the CRCHx/CRCLx registers associated with the Compare/Capture unit 0 are the only ones that can be used to perform a reload of Timer 2 operation. The following tables represent the different registers that may capture or be compared to the value of Timer 2. | TABLE 52: (CRCL) COMPARE/RELOAD/CAPTURE REGISTER, LOW BYTE - SFR CAH | | | | | | | | | |----------------------------------------------------------------------|---|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CRCL [7:0] | | | | | | | | | | TABLE 53: (CRCH) COMPARE/RELOAD/CAPTURE REGISTER, HIGH BYTE - SFR CBH | | | | | | | | | |-----------------------------------------------------------------------|---|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CRCH [7:0] | | | | | | | | | | TABLE 54: | (CCL1) C | OMPARE/C | APTURE RE | GISTER 1, | LOW BYTE | - SFR C2 | Н | |-----------|----------|----------|-----------|-----------|----------|----------|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | CCI 1 | 1 [7:0] | | | | | Т | TABLE 55: (CCH1) COMPARE/CAPTURE REGISTER 1, HIGH BYTE - SFR C3H | | | | | | | | |---|------------------------------------------------------------------|---|---|---|---|---|---|---| | Ī | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CCH1 [7:0] | | | | | | | | | TABLE 56: (CCL2) COMPARE/CAPTURE REGISTER 2, LOW BYTE - SFR C4H | | | | | | | | |-----------------------------------------------------------------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | CCL 2 [7:0] | | | | | | | | | TABLE 57: (CCH2) COMPARE/CAPTURE REGISTER 2, HIGH BYTE - SFR C5H | | | | | | | | | |------------------------------------------------------------------|---|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CCH2 [7:0] | | | | | | | | | | TABLE 58: (CCL3) COMPARE/CAPTURE REGISTER 3, LOW BYTE - SFR C6H | | | | | | | | | |-----------------------------------------------------------------|---|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CCL3 [7:0] | | | | | | | | | | TABLE 59: (CCH3) COMPARE/CAPTURE REGISTER 3, HIGH BYTE - SFR C7H | | | | | | | | | |------------------------------------------------------------------|---|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | CCH3 [7:0] | | | | | | | | | ### **Compare/Capture Data Line Width** The VERSA MIX is capable of comparing and capturing data using data lines up to 16 bits wide. When comparing 2 registers or capturing 1 register, it is required to set the T2SIZE bit of the T2CON register to 1. This adjusts the lines to have an 8-bit width. On the other hand, when comparing two pairs of registers, for example CCH1 and CCL1 to TH2 and TL2, the T2SIZE bit must be set to 0. This will make the data lines 16 bits wide. ### **Timer 2 Capture Modes** The Timer 2 Capture modes permit to acquire and store the 16-bit content of the Timer 2 into a Capture/Compare Unit in one operation or upon the occurrence of an external event on one of the CCU pin. This is done without affecting the Timer 2 operation. Each individual Compare and Capture Unit can be configured into Capture mode by configuring the appropriate bit pair of the CCEN register. The two Capture modes are: ### Capture Mode 0 In Capture mode 0, an external High to Low transition on the CCU pin triggers the latching of Timer 2's data to the associated Compare/Capture register. ### Capture Mode 1 In Capture mode 1, a capture of the Timer 2 value will occur upon writing to the Low Byte of the chosen capture register. **Note:** On the VMX1020, the CCU3 input is NOT pinned out. FIGURE 23 :TIMER 2 CAPTURE MODE 0 FOR CRCL AND CRCH BLOCK DIAGRAM The Capture modes can be especially useful to perform external event duration calculation with the ability to latch the timer value at a given time and perform the computation at a later time. When operating in Capture Modes, the Compare and Capture units don't affect the VERSA MIX Interrupts. ### **Timer 2 Compare Modes** In compare mode, a Timer 2 count value is compared to a value that is stored in the CCHxx/CCLx or CRCHx/CRCLx registers. If the values compared match (i.e. when the pulse changes state), a Compare/Capture interrupt is generated, if enabled. Varying the value of the CCHx/CCLx or CRCHx/CRCLx allows a variation of the rectangular pulse generated at the output. This variation can be used to perform pulse width modulation. See PWM section in the following section. In order to activate the compare mode on one of the four Compare Capture Units, the associated COCAHx bit must be set to 1 and the associated COCALx bit must be set to 0. When the compare mode is enabled, the corresponding output pin value is under the control of the internal timer circuitry. On the VERSA MIX, two Compare modes are possible. In both modes, the new value arrives at port pin 1 in the same clock cycle during which the internal compare signal is activated. The T2CM of the T2CON register defines the compare mode as described below: #### **Compare Mode 0** The functional diagram of the compare mode 0 is shown below. A comparison is made between the 16-bit value of the Compare/Capture registers and TH2, TL2 register. When the Timer 2 value exceeds the value stored in the CRCH, CRCL / CCHx, CCLx registers, a high compare signal is generated and a Compare/Capture interrupt is raised if enabled. If T2SIZE = 1, the comparison is made between the TL2 and CRCL/CCLx register. This compare signal is then propagated to the pin corresponding P1.x Pin(s) and to the associated COMPINTx interrupt (if enabled). The corresponding P1.x pin is reset when Timer 2 overflow occurs. FIGURE 24: TIMER 2 COMPARE MODE 0 BLOCK DIAGRAM #### **Compare Mode 1** When a given Compare Capture unit is operating in Mode 1, any write operations to the corresponding output register of the port P1.x (x=0 to3) will not appear on the physical port pin until the next compare match occurs. Like the Compare Mode 0, the Compare signal in mode 1 can also generate an interrupt (if enabled). The figure below shows the operating structure of a given Capture Compare unit operating in Compare mode 1. FIGURE 25: TIMER 2 COMPARE MODE 1 BLOCK DIAGRAM # **Timer 2 Compare Mode Interrupt** The configuration of the Compare and Capture Units into the "Compare Mode" through the CCEN register has an impact on the Interrupt structure of the VERSA MIX. In that specific mode each Compare Capture Unit take the control of one interrupt line. When using the PWM output device, some care must be taken to avoid other peripherals interrupt from being blocked by this mechanism. FIGURE 26: COMPARE AND CAPTURE UNIT INTERRUPT CONTROL # **Using Timer 2 for PWM Outputs** Configuring the Compare and Capture Units in Compare mode 0 allows PWM output generation on the Port1 I/O pins There are multiple applications for PWM such as: - D/A conversion - Motor control - o Light control - o Etc. When one specific Compare and Capture unit is configured into this specific mode, its associated I/O pin is monopolized and any write operation to the associated I/O pin into the P1 register will have no effect on it. The following table shows the association between the Compare and Capture Units, the registers involved and the I/O pin TABLE 60: COMPARE AND CAPTURE UNIT PWM ASSOCIATION | Compare<br>Capture<br>Unit | Registers | I/O pin | |----------------------------|-------------|---------| | 0 | CRCH / CRCL | P1.0 | | 1 | CCH1 / CCL1 | P1.1 | | 2 | CCH2 / CCL2 | P1.2 | | 3 | CCH3 / CCL3 | P1.3 | The PWM signal generation is derived from the comparison result between the values stored into the capture compare registers and the Timer 2 value. When a digital value is written into one of the Compare and Capture registers, a comparison is performed between this register and the timer 2 value (providing that Timer 2 is in compare mode). As long as the value present in the Compare and Capture register is greater than the Timer 2 value, the compare unit will output a logical low. When the value of Timer 2 equals the value of the Compare and Capture register, the compare unit will change from a logical Low to a logical High. The clock source of the PWM is derived from the Timer 2, which is incremented at every signal pulse of the appropriate source. The source is selected by T2IN1 and T2IN0 bits of the T2CON register The T2SIZE bit of the T2CON register allows configuring the PWM output into 8-bit or 16-bit. The Timer 2 Size affects all the PWM outputs. When the Timer 2 Size is 8-bit, the comparison is performed between the Timer 2 and the LSB of the Compare and Capture Unit register. The resulting PWM resolution is 8-bit. When the Timer 2 Size is configured for 16 bit operation 16-bit, the comparison is performed between the Timer 2 and the whole content of the Compare and Capture Unit register. The resulting PWM resolution is 16-bit but the PWM frequency is consequently low. When the System clock is used as the Timer 2 clock source, the PWM output frequency equals the Timer 2 overflow rate. Note that the CLKDIVCTRL register content does affect the Timer 2 operation and thus, the PWM output frequency. | Fosc | T2CON<br>T2PSM | T2CON<br>T2PS | T2CON<br>T2SIZE | Freq<br>PWM | |----------|----------------|---------------|-----------------|-------------| | 16MHz | 1 | Х | 0 | 122.1Hz | | | 1 | Χ | 1 | 31.25KHz | | | 0 | 0-12 | 1-8 | 5.21KHz | | | 0 | 0-12 | 0-16 | 20.3Hz | | | 0 | 1-24 | 1-8 | 2.6KHz | | | 0 | 1-24 | 0-16 | 10.2Hz | | 14.74MHz | 1 | X | 0 | 112.5Hz | | | 1 | Х | 1 | 28.8KHz | | | 0 | 0-12 | 1-8 | 4.8KHz | | | 0 | 0-12 | 0-16 | 18.8Hz | | | 0 | 1-24 | 1-8 | 2.4KHz | | | 0 | 1-24 | 0-16 | 9.38Hz | The duty cycle of the PWM output is proportional to the ratio of the Compare and Capture Unit register's content vs. the Maximum Timer 2 number of cycles before overflow: 256 or 65536 depending on the T2SIZE bit value | PWM Duty Cycle Calculation: 8-bit | | | | | | | |------------------------------------|-------------------|--|--|--|--|--| | PWM duty cycle CCU0 (%) = 100% x | (256-CRCL)<br>256 | | | | | | | PWM duty cycle CCU1-3 (%) = 100% x | (256-CCLx)<br>256 | | | | | | #### **PWM Duty Cycle Calculation: 16-bit** PWM duty cycle CCU0 (%) = 100% x 65536–(CRCH, CRCL) (CRCH, CRCL) PWM duty cycle CCU1-3 (%) = 100% x 65536-(CRCH, CRCL) (CRCH, CRCL) #### **PWM Configuration Example** The following example shows how to configure the Timer 2 based PWM in 8-bit mode. From this example it is quite easy to derive 16-bit PWM configuration. (...) DIGPWREN = 0x80: T2CON = 0x61; //ENABLE TIMER 2 MODULE //BIT 7 - Select 0=1/12, 1=1/24 of Fosc //BIT 6 - T2 clk source: 0 = Presc, 1=clk/2 //BIT 5 - T2 size: 0=16-bit, 1=8-bit //BIT 4,3 - T2 Reload mode: //BIT 2 - T2 Compare mode //BIT 1,0 - T2 input select: 01= input derived from osc. //WHEN THE PWM IS CONFIGURED IN 16-BIT FORMAT, THE PWM OUTPUT FREQUENCY IS GIVEN BY //THE FOLLOWING EXPRESSION: // PWM Freq = [(FOSC/2)] / 65536 // WITH A 14.7456MHZ CRYSTAL PWM FREQUENCY = 112.5HZ //When the PWM is configured in 8-bit its output freq = [(Fosc/2)] / 256 //USING A 14.7456MHZ CRYSTAL PWM FREQUENCY = 28.8 KHz CCEN = 0x0AA: //Enable Compare on 4 PWM outputs // In 16-bit PWM resolution both LSB and MSB of compare unit are used //In 8-bit PWM Resolution, only the LSB of compare units are used // and MSB is kept to 00h CRCL = 0x0E6;//PWM0 duty = [(256-CRCL)/256]x100% CRCH = 0x000;//E6h => 10.1% CCL1 = 0x0C0; x100% //PWM1 duty = [(256-CCL1)/256] CCH1 = 0x000; CCL2 = 0x080; //C0h => 25% //PWM2 duty = [(256-CCL2)/256] x100% CCH2 = 0x000; CCL3 = 0x033; CCH3 = 0x000; //PWM3 duty = [(256-CCL3)/256] x100% //33h => 80% //Configure P1 LSQ as output to enable PWM P1PINCFG = 0x0F; (...) # Using the PWM as D/A Converter One of the uses of the PWM is to perform D/A conversion. It is possible to perform digital to analog conversion by placing the modulated signal at the input of a low pass filter. The greater the duty cycle of the square wave, the greater the DC value is at the output of the low pass filter and vice versa. A variation of the duty cycle of the PWM when filtered out allows generating analog signal. This process is equivalent to performing a digital to analog conversion. # **Serial UART Interfaces** The VERSA MIX provides two asynchronous UART interfaces: UART0 and UART1. Each serial port has a 10-bit timer devoted to baud rate generation. Both serial ports operate in full duplex asynchronous mode. The VERSA MIX buffers receive data in a holding register, enabling the UART to accept an incoming word before the software has read the previous value. # **UARTO Serial Interface** The operation of the UART0 of the VERSA MIX is close to the standard 8051 UART. The UART0 can take its clock source from a 10-bit dedicated baud rate generator or from the Timer 1 overflow. The UART0 Transmit and Receive buffers are accessed through a unique SFR register named S0BUF. The UARTO SOBUF has a double buffering feature on reception which gives the capacity to accept an incoming word before the software has read the previous value from the SOBUF. TABLE 61: (S0BUF) SERIAL PORT 0, DATA BUFFER - SFR 99H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------------|---|---|---|---|---|---|---| | S0BUF [7:0] | | | | | | | | # **UARTO Control Register** The UART0 configuration is mainly performed using the S0CON SFR register located at address 98h. TABLE 62: (S0CON) SERIAL PORT 0, CONTROL REGISTER - SFR 98H | TABLE 02: (000011) CENTAL TOTA 0, CONTROL TREGIOTER OF TOTAL | | | | | | | | |--------------------------------------------------------------|------|-------|------|--|--|--|--| | 7 | 6 | 5 | 4 | | | | | | S0M0 | S0M1 | MPCE0 | R0EN | | | | | | | | | | | | | | | 3 | 2 | 1 | 0 | | | | | | T0B8 | R0B8 | TOI | R0I | | | | | | Bit | Mnemonic | Function | | | | |-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | 7 | S0M0 | Sets Serial Port Operating Mode | | | | | 6 | S0M1 | See Table | | | | | 5 | MPCE | 1 = Enables the multiprocessor communication feature. | | | | | 4 | R0EN | 1 = Enables serial reception. Cleared by software to disable reception. | | | | | 3 | T0B8 | The 9 <sup>th</sup> transmitted data bit in Modes 2 and 3. Set or cleared by the CPU, depending on the function it performs (parity check, multiprocessor communication etc.) | | | | | 2 | R0B8 | In Modes 2 and 3, it is the 9 <sup>th</sup> data bit received. In Mode 1, if sm20 is 0, RB80 is the stop bit. In Mode 0, this bit is not used. Must be cleared by software. | | | | | 1 | TOI | Transmit interrupt flag set by hardware after completion of a serial reception. Must be cleared by software. | | | | | 0 | R0I | Receive interrupt flag set by hardware after completion of a serial reception. Must be cleared by software. | | | | # **UARTO Operating Modes** The UART0 can operate in four distinct modes, which are defined by the SM0 and SM1 bits of the S0CON register: TABLE 63: SERIAL PORT 0 MODES | SM0 | SM1 | MODE | DESCRIPTION | BAUD RATE | |-----|-----|------|----------------|----------------| | 0 | 0 | 0 | Shift Register | Fosc/12 | | 0 | 1 | 1 | 8-bit UART | Variable | | 1 | 0 | 2 | 9-bit UART | Fclk/32 or /64 | | 1 | 1 | 3 | 9-bit UART | Variable | <sup>&</sup>quot;Note that the speed in mode 2 depends on SMOD bit in the Special Function Register PCON when SMOD = 1 fclk/32 #### UART0 - Mode 0 In this mode, pin RX0 is used as an input and an output, while TX0 is used only to output the shift clock. For an operation in this mode, 8 bits are transmitted with the LSB as the first bit. In addition, the baud rate is fixed at 1/12 of the crystal oscillator frequency. In order to initialize reception in this mode, the user must set the bits R0I and R0EN in the S0CON register to 0 and 1 respectively. Note that in other modes, when R0EN=1, the interface begins to receive data. #### UART0 - Mode 1 In this mode, pin RX0 serves uniquely as an input and TX0 serves as a serial output. In this case, no external shift clock is used. In mode 0, 10-bits are transmitted: - One logical low start bit; - o 8 bits of data starting with the LSB; - One logical high stop bit. During reception, the start bit synchronizes the transmission and 8-bits of data are available by reading S0BUF. The reception is completed once the stop bit sets the R0B8 flag in the S0CON register. #### UART0 - Mode 2 In this mode, pin RX0 is used as an input and as an output while TX0 is used only to output the shift clock. For an operation in this mode, 11 bits are transmitted or received. These 11 bits are composed of: - One logical low start bit, - 8 bits of data (LSB first). - One programmable 9<sup>th</sup> bit, - o One logical high stop bit. The purpose of the 9<sup>th</sup> bit is used to control the parity of the serial interface. For a data transmission, bit TB80 of the S0CON is outputted as the 9<sup>th</sup> bit. For reception, the 9<sup>th</sup> bit will be stored into the RB80 bit of the S0CON register. #### UART0 - Mode 3 Mode 3 is essentially identical to Mode 2. However, in Mode 3, the user may use the internal baud rate generator or Timer 1 to set the baud rate. #### **UARTO - Baud Rate Generator Source** As mentioned earlier, the UARTO baud rate clock can come from either Timer 1 or the dedicated 10-bit baud rate generator The selection between these two clock sources is made using the bit BAUDSRC of the U0BAUD register shown below: TABLE 64: (U0BAUD) UARTO BAUD RATE SOURCE SELECT - SFR D8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---------|---|---|---|---|---|---|---| | BAUDSRC | - | - | - | - | - | - | - | | 7 | BAUDSRC | Baud rate generator clock source 0 = Timer 1 1 = Use UART0 dedicated Baud rate generator | |-----|---------|------------------------------------------------------------------------------------------| | 6:0 | - | - | The use of the UART0 dedicated baud rate generator permits to free up Timer 1 for other applications. The SORELH and SOREL permit to store the 10-bit reload value of the UARTO baud rate generator. TABLE 65: (SORELL) SERIAL PORT 0, RELOAD REGISTER, LOW BYTE - SFR 96H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---|--------------|---|---|---|---|---|---|--| | | S0RELL [7:0] | | | | | | | | | TABLE 66: (S0RELH) SERIAL PORT 0, RELOAD REGISTER, HIGH BYTE - SFR 97H | | | | | | | | | |------------------------------------------------------------------------|---|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | S0BFLH[15:8] | | | | | | | | | The reload value to put into the SOREL register can be calculated from the equations shown below: Mode 3: For BAUDSRC=1 $$SOREL = 1024 - \frac{2^{SMOD}x f_{clk}}{64 x Baud Rate}$$ $$Baud Rate = \frac{2^{SMOD}x f_{clk}}{64 x (1024 - SOREL)}$$ TABLE 67: SERIAL 0 BAUD RATE SAMPLE VALUES BAUDSRC = 1, SMOD = 1 | Desired<br>Baud Rate | | | S0REL @<br>f <sub>cik</sub> = 16.000<br>MHz | |----------------------|------|------|---------------------------------------------| | 500.0 kbps | - | ī | 3FFh | | 460.8 kbps | - | 3FFh | - | | 230.4 kbps | = | 3FEh | - | | 115.2 kbps | 3FDh | 3FCh | - | | 57.6 kbps | 3FAh | 3F8h | - | | 19.2 kbps | 3EEh | 3E8h | 3E6h | | 9.6 kbps | 3DCh | 3D0h | 3CCh | | 2.4 kbps | 370h | 340h | 330h | | 1.2 kbps | 2E0h | 280h | 25Fh | | 300 bps | - | - | - | TABLE 68: SERIAL 0 BAUD RATE SAMPLE VALUES BAUDSRC =1, SMOD = 0 | De sired<br>Baud Rate | S0REL @<br>f <sub>clk</sub> = 11.0592<br>MHz | cik= 11.0592 f <sub>cik</sub> = 14.746 | | |-----------------------|----------------------------------------------|----------------------------------------|------| | 115.2 kbps | - | 3FEh | - | | 57.6 kbps | 3FDh | 3FCh | - | | 19.2 kbps | 3F7h | 3F4h | 3F3h | | 9.6 kbps | 3EEh | 3E8h | 3E6h | | 2.4 kbps | 3B8h | 3A0h | 398h | | 1.2 kbps | 370h | 340h | 330 | | 300 bps | 1C0h | 100 | 0BFh | The Timer 1 can also be used as the baud rate generator for the UART0. Set BAUDSRC to 0 and assign Timer 1 output to UART0. When the baud rate clock source comes from Timer 1, the baud rate and the timer reload value can be calculated using the following formulas: TABLE 69: EQUATION TO CALCULATE BAUD RATE FOR SERIAL 0 | Serial 0: mode 1 and 3 | |--------------------------------------------------------------------------------------------------| | Mode 1: ForU0BAUD.7=0 (standard mode) | | Baud Rate = $\frac{2^{\text{SMOD}} \times f_{\text{clk}}}{32 \times 12 \times (256\text{-TH1})}$ | | TH1 = 256 - 2 <sup>SMOD</sup> x f <sub>clk</sub> | TABLE 70: UART 0 BAUD RATE SAMPLE VALUES BAUDSRC =0, SMOD = 1 | Desired<br>Baud Rate | TH1 @ f <sub>clk</sub> =<br>11.0592 MHz | TH1 @ f <sub>clk</sub> =<br>14.746 MHz | TH1 @ f <sub>clk</sub> =<br>16.000 MHz | |----------------------|-----------------------------------------|----------------------------------------|----------------------------------------| | 115.2 kbps | - | - | - | | 57.6 kbps | FFh | 1 | = | | 19.2 kbps | FDh | FCh | - | | 9.6 kbps | FAh | F8h | - | | 2.4 kbps | E8h | E0h | DDh | | 1.2 kbps | D0h | C0h | BBh | | 300 bps | 40h | - | - | TABLE 71:UART 0 BAUD RATE SAMPLE VALUES BAUDSRC =0, SMOD = 0 | Desired<br>Baud Rate | TH1 @ f <sub>clk</sub> =<br>11.0592 MHz | TH1 @ f <sub>clk</sub> =<br>14.746 MHz | TH1 @ f <sub>clk</sub> =<br>16.000 MHz | | |----------------------|-----------------------------------------|----------------------------------------|----------------------------------------|--| | 115.2 kbps | - | - | - | | | 57.6 kbps | - | - | - | | | 19.2 kbps | - | FEh | - | | | 9.6 kbps | FDh | FCh | - | | | 2.4 kbps | F4h | F0h | - | | | 1.2 kbps | E8h | E0h | DDh | | | 300 bps | A0h | 80h | 75h | | ### **Example of UARTO Setup and Use** In order to use the UARTO, the following operations must be performed: - Enable the UART0 Interface - Set I/O Pad direction TX= output, RX=Input - Enable Reception (if required) - Configure the Uart0 controller S0CON Below you will find two configuration function examples for the UARTO and an example of byte transmission function using the UARTO. ``` // UART0 CONFIG with S0REL // Configure the UART0 to operate in RS232 mode at 19200bps // with a crystal of 14.7456MHz void uart0ws0relcfg() P3PINCFG |= 0x01; // pads for uart 0 DIGPWREN |= 0x01; // enable uart0/timer1 SORELL = 0xF4; SORELH = 0x03; //com speed = 19200bps S0CON = 0x50; U0BAUD = 0x80; // Uart0 in mode1, 8 bit, var. baud rate //Set S0REL is source for UART0 //Baud rate clock }//end of uart0ws0relcfg() function // UART0 CONFIG with Timer 1 // Configure the UART0 to operate in RS232 mode at 19200bps // with a crystal of 14.7456MHz void uart0wTimer1cfg() 1 P3PINCFG |= 0x01; DIGPWREN |= 0x01; // enable uart0/timer1 TMOD &= 0x0F; TMOD =0x20; TH1 = 0xFE; //Set Timer 1, Gate 0, Mode 2 //Com Speed = 19200bps TCON &= 0x0F; TCON =0x40: //Start Timer 1 U0BAUD = 0x00; //Set Timer 1 Baud rate //generator for UART0 PCON = 0x00; //SetSMOD = 0 S0CON = 0x50; // Config Uart0 in mode 1, //8 bit, variable baud rate }//end of uart1 Config() function // Txm it0() // One Byte transmission on UART0 // - Constants definition sbit UART_TX_EMPTY = USERFLAGS^1; void txmit0( unsigned char charact){ S0BUF = charact; USERFLAGS = S0CON; //Wait TX EMPTY flag to be raised while (!UART_TX_EMPTY) {USERFLAGS = S0CON;} S0CON = //clear both R0I & T0I bits }//end of txmit0() function ``` See the Interrupt section for example of setup of UART0 interrupts # **UART1 Serial Interface** The UART1 serial interface is based on a subset of the UART0. It provides two operating modes and its clock source comes exclusively from a dedicated 10-bit baud rate generator. The UART1 Transmit and Receive buffers are accessed through a unique SFR register named S1BUF. TABLE 72: (S1BUF) SERIAL PORT 1, DATA BUFFER - SFR C1H | | ( / | | , | - | | | | |-------------|-----|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | S1BUF [7:0] | | | | | | | | As the UART0, the UART1 has a double buffering feature on reception which gives the capacity to accept an incoming data before the software has read the previous value from the S1BUF. #### **UART1 Control Register** The control of the UART1 is made using the S1CON. Table 73 explains the bit functions of the UART1 control register. TABLE 73: (S1CON) SERIAL PORT 1, CONTROL REGISTER - SFR C0H | 7 | 6 | 5 | 4 | |------|----------|-------|------| | S1M | Reserved | MPCE1 | R1EN | | | | | | | 3 | 2 | 1 | 0 | | T1B8 | R1B8 | T1I | R1I | | Bit | Mnemonic | Function | | | |-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | 7 | S1M | Operation mode Select | | | | 6 | Reserved | - | | | | 5 | MPCE1 | 1 = Enables multiprocessor communication feature. | | | | 4 | R1EN | If set, enables serial reception. Cleared by software to disable reception. | | | | 3 | T1B8 | The 9 <sup>th</sup> transmitted data bit in mode A. Set or cleared by the CPU, depending on the function it performs (parity check, multiprocessor communication, etc.) | | | | 2 | R1B8 | In Mode A, it is the 9 <sup>th</sup> data bit received. In Mode B, if SM21 is 0, RB81 is the stop bit. Must be cleared by software. | | | | 1 | T11 | Transmit interrupt flag, set by<br>hardware after completion of a serial<br>transfer. Must be cleared by software | | | | 0 | R1I | Receive interrupt flag, set by hardware after completion of a serial reception. Must be cleared by software | | | #### **UART1: Operating Modes** The VERSA MIX UART1 provides two operating modes. These modes, named Mode A and Mode B provide the ability to perform transactions in 9-bit and 8-bit data format respectively. Below is a summary table of operating modes of the UART1. TABLE 74: UART1 MODES | SM | MODE | DESCRIPTION | BAUD RATE | |----|------|-------------|-----------| | 0 | Α | 9-bit UART | Variable | | 1 | В | 8-bit UART | Variable | #### UART1 - Mode A In this mode, 11 bits are transmitted or received. These 11 bits are composed of: - One logical low start bit, - 8 bits of data (LSB first), - One programmable 9<sup>th</sup> bit, - One logical high stop bit. As in Mode 2 and 3 of UART0, this 9<sup>th</sup> bit is used for parity control. For data transmission, bit TB81 of the S1CON is used as the output for the 9<sup>th</sup> bit. For reception, the 9<sup>th</sup> bit will be stored into the R1B8 bit of the S1CON register. #### UART1 - Mode B In this mode, 10 bits are transmitted and consist of: - One logical low start bit: - 8 bits of data starting with the LSB; - One logical high stop bit. During reception, the start bit synchronizes the transmission and 8 bits of data are available by reading S1BUF. The reception is completed once the stop bit sets the R1B8 flag in the S1CON register. #### **UART1 - Baud Rate Generator** As mentioned earlier, the UART1 clock source can only come from a dedicated 10-bit baud rate generator module. The S1REL registers are used to adjust the baud rate of UART 1. TABLE 75: (S1RELL) UART1, RELOAD REGISTER, LOW BYTE - SFR BEH | 7 | <u> </u> | | 4 | 0 | 0 | - 4 | 0 | |--------------|----------|---|---|---|---|-----|---| | / | ь | ກ | 4 | 3 | 2 | | U | | S1RELL [7:0] | | | | | | | | | TABLE 76: (S1RELH) UART 1, RELOAD REGISTER, HIGH BYTE - SFR BFH | | | | | | | | |-----------------------------------------------------------------|--------------|--|--|--|--|--|--| | 7 6 5 4 3 2 1 0 | | | | | | | | | | S1RELH [7:0] | | | | | | | The formulas to calculate both the baud Rate and the S1RELL and S1RELH value are given below: | Serial 1 | |---------------------------------------------------------| | Baud Rate= <u>f<sub>clk</sub></u> 32 x (1024-S1REL) | | Note: S1REL.9-0 = S1RELH.1-0 + S1RELL.7-0 | | S1REL = 1024 - $\frac{f_{clk}}{32 \text{ x Baud Rate}}$ | TABLE 77: SERIAL 1 BAUD RATE SAMPLE VALUES | Desired<br>Baud Rate | S1REL @<br>f <sub>clk</sub> = 11.0592<br>MHz | S1REL @<br>f <sub>clk</sub> = 14.746<br>MHz | S1REL @<br>f <sub>clk</sub> = 16.000<br>MHz | |----------------------|----------------------------------------------|---------------------------------------------|---------------------------------------------| | 500.0 kbps | - | - | 3FFh | | 460.8 kbps | - | 3FFh | 1 | | 230.4 kbps | - | 3FEh | ı | | 115.2 kbps | 3FDh | 3FCh | - | | 57.6 kbps | 3FAh | 3F8h | ı | | 19.2 kbps | 3EEh | 3E8h | 3E6h | | 9.6 kbps | 3DCh | 3D0h | 3CCh | | 2.4 kbps | 370h | 34Fh | 330h | | 1.2 kbps | 2E0h | 280h | 25Fh | # **Setting Up and Using UART1** In order to use the UART1, the following operations must be performed: - Enable the UART1 Interface - Set I/O Pad direction TX= output, RX=Input - o Enable Reception (if required) - Configure the UART1 controller S1CON # **Example of UART1 Setup and Use** The following C code examples show: - The configuration of UART1 - o Example of serial byte transmission - UART1 interrupt function. ``` // UART1 CONFIG // Configure the UART1 to operate in RS232 mode at 115200bps // with a crystal of 14.7456MHz void uart1 Config(void) P0PINCFG |= 0x04; DIGPWREN |= 0x02; // pads for uart 1 S1RELL = 0xFC; S1RELH = 0x03; // Set com speed = 115200bps S1CON = 0x90; // Mode B, receive enable }//end of uart1 Config() function // TXMIT1 -- Transmit one byte on the UART1 void txmit1 (unsigned char charact){ S1BUF = charact; USERFLAGS = S1CON; while (IUART_TX_EMPTY) {USERFLAGS = S1CON;} //Wait TX EMPTY flag //clear both R1I & T1I bits S1CON = S1CON & 0xFD; }//end of txmit1() function // Interrupt configuration IEN0 |= 0x80; // Enable all interrupts IEN2 |= 0x01; // Interrupt function void int_serial_1 (void) interrupt 16 // Disable all interrupts /*Interrupt code here*/ if (S1CON&0x01==0x01) S1CON &= 0xFE; // Clear RI (it comes // before T1I) else S1CON &= 0xFD; // Clear T1I IEN0 |= 0x80;} // Enable all interrupts } ``` # <u>UART1 Driven Differential</u> <u>Transceiver</u> The VERSA MIX includes a differential transceiver compatible with the J1708/RS-485/RS-422 standards, which can be internally connected to the UART1. The Differential Transceiver's signals are differential which provide a high immunity to Electrical noise. With the VERSA MIX differential interface it is possible to transfer data over hundreds of feet on twisted pair wires. More than two devices can be connected to the differential bus to create a small network. The number of devices that can be networked depends on the bus length and configuration. The admissible common mode voltage range of the VERSA MIX's differential interface is -2.0 V to +7.0 V. If transmission over long distance in noisy environment is to be performed, it is recommended to add the appropriate protection to prevent the common mode voltage causing damage to the VERSA MIX. Figure 27: Differential Interface (J1708 config) FIGURE 28: DIFFERENTIAL INTERFACE (RS485 CONFIG) On a software point of view, the differential transceiver can be seen as a differential UART. The differential transceivers I/Os are connected to the UART1 peripheral of the VERSA MIX. So the communication parameters such as the data length, communication speed, etc are managed by the UART1 interface. # Using the UART 1 Differential Transceiver In order to use the Differential Transceiver interface, one must perform the following operations: - Enable both the UART1 <u>and</u> the differential interface by setting Bit 1 and Bit 2 of the DIGPWREN. - Configure the operating mode of UART1 using the S1CON register. - Define the Baud Rate and configure the S1RELH and S1RELL registers accordingly. - o Enable UART1 interrupt if required Use UART1 S1BUF register to transmit and receive data through the differential transceiver. If the P0.2 pin is configured as an output, the signal corresponding to the TX1 line of the UART1 peripheral will appear on this line. The P0.3-RX1 pin can be used as regular digital output. When the transceiver is connected in Half-Duplex mode (RX1D+ connected to TX1D+ and RX1D- connected to TX1D-) and UARt1 interrupts are enabled, a careful management of the UART1 interrupts will need to be performed, as every byte transmitted will generate a local Rx interrupt. #### **Differential Interface Use Example** The following program gives an example of configuration and use of the VERSA MIX Differential Interface. ``` #pragma SMALL #pragma UNSIGNEDCHAR #include <vmixreg.h> // --- function prototypes void txmit1 (unsigned char charact); void uart1 differential(void); // - global variables // - Constants definition sbit UART_TX_EMPTY = USERFLAGS^1; code char irq0msg[]="Goal Semiconductor inc"; MAIN FUNCTION at 0x0100 void main (void) { // Enable and configure the UART1 uart1differential(); //Config UART1 diff interface // Warning: The Clock Control circuit does affect the dedicated baud rate generator S0REL, S1REL and Timer1 operation //*** Configure the interrupts IEN0 |= 0x81; IEN2 |= 0x01; //Enable interrupts + Ext. 0 interrupt //Enable UART1 Interrupt Txmit1("A'); //Transmit one character on UART1 do }while(1); //Wait for UART1 Rx interrupt }// End of main()... // UART1 Differential interface interrupt // In this example, the source of UART1 interrupt would be caused // by bytes reception on the differential interface void int_uart1 (void) interrupt 16 { unsigned char charact; IEN0 &= 0x7F; // -- Put you code here... S1CON = S1CON & 0xFC; //clear both R1I & T1I bits IEN0 |= 0x80; // enable all interrupts ``` }// end of uart1 INTERRUPT ``` // EXT INT0 interrupt // when the External interrupt 0 is triggered A Message string is sent over the // the serial UART1 void int_ext_0 (void) interrupt 0 { int x=0: idata unsigned char cptr=0x01; IEN0 &= 0x7F; //disable ext0 interrupt cptr = cptr-1; while( irq0msg[cptr] != '\n') //Send a text string over the differential interface txmit1(irq0msg[cptr]); cptr = cptr +1; IEN0 = 0x81; //Enable all interrupts + int_0 ------ Individual Functions ----- // UART1 DIFFERENTIAL CONFIG // Configure the UART1 differential interface to operate in /\!/\,\text{RS}232 mode at 115200bps with a crystal of 14.7456MHz void uart1 differential(void) DIGPWREN |= 0x06; // enable uart1 & differential transceiver P0PINCFG |= 0x04; P0PINCFG = 0x00; // pads for uart1 S1RELL = 0xFC; // Set com speed = 115200bps S1RELH = 0x03; S1CON = 0x90; // Mode B, receive enable }//end of uart1differential() function // TXMIT1 // Transmit one byte on the UART1 Differential interface void txmit1 (unsigned char charact){ S1BUF = charact; USERFLAGS = S1CON; //Wait TX EMPTY flag to be raised while (!UART_TX_EMPTY) {USERFLAGS = S1CON;} S1CON = S1CON & 0xFD; //clear both R1I & T1I bits }//end of txmit1() function ``` # **SPI Interface** The VERSA MIX SPI interface is a very powerful and highly configurable interface that provides high speed data exchange with external devices such as High speed A/D, D/A, EEPROM etc. The SPI interface can operate as either a master or a slave device. In master mode, it can control up to 4 slave devices connected to the SPI bus. The following list describes some of the features of the SPI interface: - Permits synchronous serial data transfers - Transaction size is configurable from 1-32-bits and more. - Full duplex support - SPI Modes 0, 1, 2, 3, and 4 supported (Full clock polarity and phase control) - Up to four slave devices can be connected to the SPI bus when it is configured in master mode - The SPI interface can be used in slave mode - o Data transmission speed is configurable - Double 32-bit buffers in transmission and reception - 3 dedicated interrupt flags - TX-Empty - RX Data Available - RX Overrun - Automatic/Manual control of the chip selects lines. - SPI operation is not affected by the clock control unit The following figure represents the SPI Interface block diagram. FIGURE 29: SPI INTERFACE BLOCK DIAGRAM # SPI Transmit / Receive Buffer Structure When receiving bytes, the first byte received is stored in the SPIRX0 Buffer. As bits continue to be received, the data already present in the buffer are shifted towards the least significant byte end of the receive registers. For example, lets suppose the SPI is about to receive 4 consecutive bytes of data: W, X, Y and Z. The first byte to be received is byte W. This byte will be placed in the register SPIRXO. At this point, the next byte to be received is byte X. The data buffer will shift the byte that is currently in the SPIRXO register one byte position to the left, which in this case is SFR register SPIRX1. The new byte, X, will then be placed in SPIRXO. Following the same procedure, we see that bytes W, X, Y and Z will end up in RX data buffer registers SPIRXO, SPIRX1, SPIRX2 and SPIRX3 respectively. The case where the SDO and SDI pins are shorted together is represented in the following diagram. FIGURE 30 : SPI INTERFACE RECEIVE TRANSMIT SCHEMATIC BEFORE A RECEPTION First Byte Received is Placed in the least significant byte register #### AFTER A RECEPTION When using the SPI Interface, it is important to keep in mind that a transmission starts when the SPIRX3TX0 register is written into. From an SFR point of view, the transmission and the reception buffers of the SPI interface occupy the same addresses as shown below: TABLE 78: (SPIRX3TX0) SPI DATA BUFFER, LOW BYTE - SFR E1H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------------|---|---|---|---|---|---|---| | SPIRX3TX0 [7:0] | | | | | | | | | Bit | Mnemonic | Function | |-----|----------|-----------------------------| | 7-0 | SPITX0 | SPI Transmit Data Bits 7:0 | | | SPIRX3 | SPI Receive Data Bits 31:24 | TABLE 79: (SPIRX2TX1) SPI DATA BUFFER BYTE 1 - SER E2H | .,,, | TABLE 7 0. (OF TABLE 1741) OF TEXT A BOTTE II, BITTE I OF II ZETT | | | | | | | | |------|-------------------------------------------------------------------|---|---|---|---|---|---|---| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | SPIRX2TX1 [15:8] | | | | | | | | | Bit | Mnemonic | Function | |------|----------|-------------------------------| | 15:8 | SPITX1 | SPI1 Transmit Data Bits 15:8 | | | SPIRX2 | SPI Receive 1 Data Bits 22:16 | #### TABLE 80: (SPIRX1TX2) SPI DATA BUFFER, BYTE 2 - SFR E3H | TABLE GOT (GT ITATI TALE) GT TEATH EGT TELL, ETTEL GT TE EGT | | | | | | | | |--------------------------------------------------------------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SPIRX1TX2 [23:16] | | | | | | | | | Bit | Mnemonic | Function | |-------|----------|------------------------------| | 22:16 | SPITX2 | SPI Transmit Data Bits 22:16 | | | SPIRX1 | SPI Receive Data Bits 15:8 | TABLE 81: (SPIRX0TX3) SPI DATA BUFFER, HIGH BYTE - SFR E4H | TABLE OT . (OF ITAC TAC) OF TEATA BOTTER, THOSE BITE OF TEAT | | | | | | | | |--------------------------------------------------------------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SPIRX0TX3 [31:24] | | | | | | | | | Bit | Mnemonic | Function | |-------|----------|------------------------------| | 31:24 | SPITX3 | SPI Transmit Data Bits 31:24 | | | SPIRX0 | SPI Receive Data Bits 7:0 | ## **SPI Control Registers** The SPI Control registers is used to define: - The SPI operating speed (Master mode) - o The active Chip Select output (Master mode) - o The SPI clock Phase (Master/Slave modes). - The SPI clock Polarity (Master/Slave modes). TABLE 82: (SPICTRL) SPI CONTROL REGISTER - SFR E5H | 7 | 6 | 5 | 4 | | | |---|---------|---|---|--|--| | | SPICS 1 | | | | | | 3 | 2 | 1 | 0 | |---------|---------|----------|----------| | SPICS 0 | SPICKPH | SPICKPOL | SPIMA SL | | D:: | M | Le corre | |-----|------------|-------------------------------| | Bit | Mnemonic | Function | | 7:5 | SPICK[2:0] | SPI Clock control | | | | 000 = OSC Ck Div 2 | | | | 001 = OSC Ck Div 4 | | | | 010 = OSC Ck Div 8 | | | | 011 = OSC Ck Div 16 | | | | 100 = OSC Ck Div 32 | | | | 101 = OSC Ck Div 64 | | | | 110 = OSC Ck Div 128 | | | | 111 = OSC Ck Div 256 | | 4:3 | SPICS[1:0] | Active CS line in Master Mode | | | | 00 = CS0- Active | | | | 01 = CS1- Active | | | | 10 = CS2- Active | | | | 11 = CS3- Active | | 2 | SPICKPH | SPI Clock Phase | | 1 | SPICKPOL | SPI Clock Polarity | | | | 0 – CK Polarity is Low | | | | 1 – CK Polarity is High | | 0 | SPIMA_SL | Master / -Slave | | | | 1 = Master | | | | 0 = Slave | # **SPI Operating Speed** Three bits of the SPICTRL register serve to adjust the communication speed of the SPI interface. | SPICK[2:0]<br>Div Ratio | Fosc =<br>16.00MHz | Fosc =<br>14.74MHz | Fosc =<br>11.059MHz | |-------------------------|--------------------|--------------------|---------------------| | Clk Div 2 | 8 MHz | 7.37 MHz | 5.53 MHz | | Clk Div 4 | 4 MHz | 3.68 MHz | 2.76 MHz | | Clk Div 8 | 2 MHz | 1.84 MHz | 1.38 MHz | | Clk Div 16 | 1 MHz | 922 kHz | 691 kHz | | Clk Div 32 | 500 kHz | 461 kHz | 346 kHz | | Clk Div 64 | 250 kHz | 230 kHz | 173 kHz | | Clk Div 128 | 125 kHz | 115 kHz | 86 kHz | | Clk Div 256 | 62 kHz | 57.6 kHz | 43.2 kHz | # **SPI Master Chip Select Control** When the SPI is configured in Master mode, the value of the SPICS[1:0] bits will define which Chip select pins will be active during the transaction. In the following sections we will show you how the SPI Clock Polarity and Phase affect the reading and writing operations of the SPI interface. Note that when the chip select bit (CSx) goes to 0, the SCK clock begins to operate. The difference in the operating modes is in the SDO and SDI parameters. # **SPI Operating Modes** The SPI interface can operate in four distinct modes defined by the value of the SPICKPH and the SPICKPOL bits of the SPICTRL register. The SPICKPH bit value defines the SPI clock phase and the SPICKPOL bit value defines the Clock polarity for data exchange to be performed on the SPI interface | SPICKPOL bit value | SPICKPH bit value | SPI Operating Mode | |--------------------|-------------------|--------------------| | 0 | 0 | SPI Mode 0 | | 0 | 1 | SPI Mode 1 | | 1 | 0 | SPI Mode 2 | | 1 | 1 | SPI Mode 3 | #### SPI Mode 0 - Data is placed on the SDO pin at every rising edge of the clock. - Data is sampled on the SDI pin at every falling edge of the clock. #### SPI Mode 1 - Data is placed on the SDO pin at every falling edge of the clock. - Data is sampled on the SDI pin at every rising edge of the clock. #### SPI Mode 2 - Data is placed on the SDO pin at every falling edge of the clock. - Data is sampled on the SDI pin at every rising edge of the clock. FIGURE 33: SPI MODE 2 #### SPI Mode 3 - Data is placed on the SDO pin at every rising edge of the clock. - Data is sampled on the SDI pin at every falling edge of the clock. FIGURE 34: SPI MODE 3 #### **SPI Transaction Size** For many microcontrollers on the market, the SPI transaction size is fixed to 8-bits. However, most of the devices using an SPI like interface do require transactions of more than 8-bits. Generally, people overcome this issue by using an external I/O pin to manually control the Chip Select line of the device and perform successive SPI transactions. The net result is wasting extra I/O pins and processing cycles to control them. The VERSA MIX SPI interface includes a Transaction size control register named SPISIZE that gives the ability to control the size of the transactions to be performed on the SPI interface. Moreover, the SPI interface takes the total control of the Chip select line automatically. Before using the SPI interface, it is imperative to know the transaction size to be performed on the SPI interface and to adjust the SPI Size control register accordingly. TABLE 83: (SPISIZE) SPI SIZE CONTROL REGISTER - SFR E7H | <br>TABLE GO: (G. TOLLE) G. TOLLE GOTTINGE TIEGGETEN G. T. E.T. | | | | | | | | |-----------------------------------------------------------------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | SPISIZE[7:0] | | | | | | | | | Bit | Mnemonic | Function | |-----|--------------|------------------------------| | 7:0 | SPISIZE[7:0] | Value of the SPI packet size | The value to put into the SPI transaction size, SPISIZE, is calculated from the following formulas: #### For SPISIZE from 0 to 31: SPI Transaction Size = [SPISIZE + 1] #### For SPISIZE from 32 to 255\*: SPI Transaction Size = [SPISIZE\*8 - 216] SPI transaction size greater than 32 bit are possible using the VERSA MIX SPI interface. However, when performing reception of such large data packets, a careful management of the interrupt must be performed to avoid data collisions. ### **SPI Interrupts** The SPI interface provides interrupt resources for three specific events that are: - SPI RX Overrun - SPI RX Data Available - SPI TX Empty The SPIRXOVIE, SPIRXAVIE and SPITXEMPIE bits of the SPICONFIG register permits to individually enable those interrupt sources at the SPI interface level. At the processor level, two interrupt vectors are dedicated to the SPI interface: - SPI RX data available and Overrun interrupt - SPI TX empty interrupt In order to have the processor jump to the associated interrupt routine, you must also enable one or both these interrupts in the IEN1 register as well as set the EA bit of the IEN0 register (see interrupt section). TABLE 84: (SPICONFIG) SPI CONFIG REGISTER - SFR E6H | 7 | 6 | 5 | 4 | |---------|---|----------|---------| | SPICSLO | - | FSONICS3 | SPILOAD | | | | | | | 3 | 2 | 1 | 0 | |---|-----------|-----------|------------| | - | SPIRXOVIE | SPIRXAVIE | SPITXEMPIE | | Bit | Mnemonic | Function | |-----|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SPICSLO | Manual CS up (Master mode) 0 = The CSx goes low when transmission begins and returns to high when it ends. 1 = The CSx stays low after transmission ends. The user must clear this bit for the CSx line to return high. | | 6 | - | - | | 5 | FSONCS3 | This bit sends the frame select pulse on CS3. | | 4 | SPILOAD | This bit sends load pulse on CS3. | | 3 | - | = | | 2 | SPIRXOVIE | SPI Receiver overrun interrupt enable. | | 1 | SPIRXAVIE | SPI Receiver available interrupt enable. | | 0 | SPITXEMPIE | SPI Transmitter empty interrupt enable. | The SPIIRQSTAT register contains the interrupts flags associated with the SPI interface. Monitoring the different bits of this register allows the control of the SPI interface in pooling mode when the interrupts are disabled. TABLE 85: (SPIIRQSTAT) SPI INTERRUPT STATUS REGISTER - SFR E9H | 7 | 6 | 5 | 4 | |---|---|------------|-------------| | - | ı | SPITXEMPTO | SPISLAVESEL | | 3 | 2 | 1 | 0 | |--------|-------|---------|----------| | SPISEL | SPIOV | SPIRXAV | SPITXEMP | | Bit | Mnemonic | Function | |-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------| | 7:6 | - | = | | 5 | SPITXEMPTO | Flag that indicates that we have<br>not reloaded the transmit buffer<br>fast enough (only used for<br>packets greater than 32 bits.). | | 4 | SPISLAVESEL | Slave Select "NOT" (SSN) | | 3 | SPISEL | This bit is the result of the logical AND operation between CS0, CS1, CS2 and CS3. (Indicates if one chip is selected.) | | 2 | SPIOV | SPI Receiver overrun | | 1 | SPIRXAV | SPI Receiver available | | 0 | SPITXEMP | SPI Transmit buffer is ready to receive mode data. It does not flag that the transmission is completed. | # **SPI Manual Chip Select Control** In some specific applications the manual control of the active select line can be useful. Setting the SPICSLO bit of the SPICONFIG register makes the active chip select line to stay low when the SPI transaction is completed in Master mode. When the SPICSLO bit is cleared, the Chip selected line return to high. #### **SPI Manual Load Control** The SPI can generate a LOAD pulse on the CS3 pin when the SPILOAD bit is set. Some D/A converters require such a signal to latch the data that has been loaded into them and this feature can be used to do that without having to use a separate I/O pin for that purpose. #### **SPI Frame Select Control** It's also possible to generate a positive pulse on the CS3 pin of the SPI interface by setting the FSONCS3 bit of the SPICONFIG register. This feature can be used to generate a Frame Select signal required by some DSP compatible devices without requiring the use of separate I/O pin. Note that when both the SPILOAD and FSONCS3 are selected, the internal logic makes the Frame Select pulse to have priority. #### SPI Interface to 16-bit D/A Example The following example shows the configuration of the SPI interface to transfer data on a 16-bit D/A converter connected to the SPI interface. ``` // VMIX_SPI_to_dac_interface.c // This demonstration program show the how to interface a 16-bit D/A // to the VERSA MIX SPI interface. #pragma SMALL #include <vmixrea.h> // --- function prototypes //Function Prototype: Send Data to the 16 bit D/A void send16bitdac(unsigned char valhigh, unsigned char vallow); // Bit definition sbit SPI_TX_EMPTY = USERFLAGS^0; MAIN FUNCTION ----// at 0x0100 main (void) { unsigned char dacvall=0; //LSB of current DAC value unsigned char dacvalh=0; DIGPWREN = 0x08; //ENABLE SPIINTERFACE //*** Initialise the SPI interface **** P2PINCFG |= 0x68; // config I/O port to allow the SPI P2PINCFG |= 0x68; // config I/O port to allow the SPI // interface to access the pins // interface to access the pins // interface to access the pins // interface to access the pins // interface to access the pins // interface interface // interface // interface interface // interface // interface interface // interfac SPICTRL = 0x25; JXZb; "SPI ctnl: OSC/16, CS0, phase=0, pol=0, master "SPICK BIT 7:5 = 001 -> SPI CLK SPEED = OSC/2 "SPICK BIT 4:3 = 00 -> CS0 LINE IS ACTIVE "SPICKPH BIT 2 = 1 SPI CLK PHASE "SPICKPOL BIT 1 = 0 SPI CLOCK POLARITY "SPIMA_SL BIT 0 = 1 -> SET SPI IN MASTER MODE SPICONFIG = 0x00; = UXU01; If SPI CONFIG: auto CSLO, no FS, NO Load, dear IRQ flags // SPI CONFIG: BIT 7 = 0 AUTOMATIC CHIP SELECT CONTROL // UNSUSED BIT 8 = 0 // FSCNCS3 BIT 5 = 0 Do not send FrameSelect Signal on CS3 // SPILCAD BIT 4 = 0 do not Sen the Low pulse on CS3 // UNUSED BIT 3 = 0 // SPIRXOVIE BIT 2 = 0 Dont enable SPI RX Overrun IRQ // SPIRXAVIE BIT 1 = 0 Dont enable SPI RX AVAILLABLE IRQ // SPITXEMPIE BIT 0 = 0 Dont Enable SPITX EMPTY IRQ ``` ``` SPISIZE = 0x0F: // SPI SIZE: 16-bits // GENERATE A TRIANGLE WAVE ON THE DAC OUTPUT while(1){ do{ dacvall = dacvall + 1; if( dacvall==0xff) dacvalh = dacvalh +1; dacvall = 0x00: send16-bitdac(dacvalh,dacvall); }while( (dacvall != 0xff) && (dacvalh != 0xff) ); dacvall = dacvall - 1; if( dacvall==0x00) dacvalh = dacvalh - 1; dacvall = 0xff; send16-bitdac( dacvalh, dacvall): }while( (dacvall != 0x00) && (dacvalh != 0x00) ); }// End of main()... // Send16-bitdac - Send data to 16 bit D/A Converter // void send16-bitdac(unsigned char valhigh, unsigned char vallow){ USERFLAGS = 0x00: while (!SPI\_TX\_EMPTY) \{ USERFLAGS = SPIIRQSTAT; \} SPIRX2TX1 = vallow; //Put LSB of value in SPI transmit buffer //-> trigger transmission SPIRX3TX0 = valhigh; //Put MSB of value in SPI transmit buffer //-> trigger transmission //Wait SPI TX empty flag to be activated USERFLAGS = P2; do{ USERFLAGS &= 0x08; }while( USERFLAGS == 0); }//end of send16-bitdac ``` ### **SPI Interrupt Example** The following example shows the basic configuration of the SPI Interface and SPI Interrupt handling. | // | // | |------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------| | // Sample C code for SPI I | RX & TX interrupt set-up | | //<br>// | // | | #pragma SMALL<br>#include <vmixreg.h></vmixreg.h> | | | at 0x0100 main (void) { | | | DIGPWREN = 0x08;<br>P2PINCFG = 0x4F;<br>SPICONFIG = 0x03;<br>SPISIZE = 0x07; | // Enable SPI<br>// Set pads direction<br>// Enable Rx_avail + TX_emp<br>// SPI SIZE: 8 bits | | IEN0 = 0x80;<br>IEN1 = 0x06; | // Enable all interrupts<br>// Enable SPI Txempty + R Xavail interrupt | | SPIRX3TX0 = valhigh; | //Put MSB of value in SPI transmit buffer //-> trigger transmission | | Do{ | }while(1) | | }//end of main() | | | // SPI TX Empty Interrupt | //<br>function<br>// | | void int_2_spi_tx (void) int | terrupt 9 | | IEN0 &= 0x7F; | // Disable all interrupts | | /*/<br>/* Interrupt c<br>/* | ode here*/ | | IRCON &= 0xFD;<br>IEN0 = 0x80;<br>} | // Clear flag SPITXIF<br>// Enable all interrupts | | // SPI RX availlable function | //<br>on<br>// | | void int_2_spi_rx (void) int | terrupt 10 | | {<br>IEN0 &= 0x7F; | // Disable all interrupts | | /*/<br>/* Interrupt c<br>/* | ode here*/ | | IRCON &= 0xFB;<br>IEN0 = 0x80;<br>} | // Clear flag SPIRXIF<br>// Enable all interrupts | | | | Because of the double buffering of the SPI interface a SPI TX empty interrupt will be raised as soon as the value to transmit is written into the SPI interface transmit buffer. Then, if more data is written into the SPI transmit buffer before the transmission of the first data is completed the TX empty interrupt will only be raised when the first data transmission is completed. SPI also includes a double buffering for data reception, which means that once a data reception is completed RX interrupt is raised and the data is transferred into the SPI RX buffer. At this point, the SPI interface can receive another data stream. However, the processor must have retrieved the first data stream before the second data stream reception is complete. Otherwise a data collision will occur and SPI RX overrun interrupt will be raised, if enabled. # I<sup>2</sup>C Interface The VERSA MIX includes an I<sup>2</sup>C compatible communication interface that can be configured in Master mode or in Slave mode. # **I2C Control Registers** The I2CRXTX SFR register is used to retrieve and transmit data on the I2C interface. TABLE86: (I2CRXTX) I2C DATA BUFFER - SFR DEH | TABLEGO: (ILOTOAT) ILO BATA BOTT ER OTTE BETT | | | | | | | | |-----------------------------------------------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | I2CRXTX [7:0] | | | | | | | | | Bit | Mnemonic | Function | |-----|------------|----------------------------------------| | 7:0 | I2CTX[7:0] | I2C Data Receiver / Transmitter buffer | The I2CCONFIG register serves to configure the operation of the VERSA MIX I2C interface. The description of the I2CCONFIG register's bit is given below: TABLE 87: (I2CCONFIG) I2C CONFIGURATION - SFR DAH | 7 | 6 | 5 | 4 | | | |-----------|-----------|------------|------------|--|--| | I2CMASKID | I2CRXOVIE | I2CRXDAVIE | I2CTXEMPIE | | | | 3 | 2 | 1 | 0 | |-----------|------------|----------|-----------| | I2CMANACK | I2CACKMODE | I2CMSTOP | I2CMASTER | | Bit | Mnemonic | Function | | | | | |-----|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | 7 | I2CMASKID | This is used to mask the chip ID when you have only two devices. Therefore in a transaction, rather that receiving the chip ID first, you will receive the first packet of data. | | | | | | 6 | 12CRXOVIE | I2C Receiver overrun interrupt enable | | | | | | 5 | I2CRXDAVIE | I2C Receiver available interrupt enable | | | | | | 4 | I2CTXEMPIE | I2C Transmitter empty interrupt enable | | | | | | 3 | I2CMANACK | 1= Manual acknowledge line<br>goes to 0<br>0= Manual acknowledge line<br>goes to 1 | | | | | | 2 | 12CACKMODE | Used only with Master Rx, Master Tx, and Slave Rx. 1= Manual Acknowledge on 0= Manual Acknowledge off | | | | | | 1 | I2CMSTOP | I2C Master receiver stops at next acknowledge phase. (read during data phase) | | | | | | 0 | 12CMASTER | I2C Master mode enable<br>1= I2C interface is Master<br>0= I2C interface is Slave | | | | | The I2CIRQSTAT register gives the status of the I2C interface operation and monitors the I2C bus status. TABLE 88: (I2CIRQSTAT) I2C INTERRUPT STATUS - SFR DDH | TABLE 00. (ILOIT QOTA | ABEE GO. (IZGITAGOTAT) IZG INTERINGI I GTATOG GTATODI | | | | | | | |-----------------------|-------------------------------------------------------|--------|-----------|--|--|--|--| | 7 | 6 | 5 | 4 | | | | | | 12CGOTSTOP | I2CNOACK | I2CSDA | I2CDATACK | | | | | | 3 | 2 | 1 | 0 | | |----------|---------|---------|----------|--| | I2C IDLE | I2CRXOV | I2CRXAV | I2CTXEMP | | | Bit | Mnemonic | Function | |-----|-------------|------------------------------------------------------------------------------------------------------------------------------| | 7 | 12CSGOTSTOP | This means that the slave has received a stop (this bit is read only). Reset only when the master begins a new transmission. | | 6 | 12CNOACK | Flag that indicates that no acknowledge has been received. Is reset at the start of the next transaction | | 5 | 12CSDA | Value of SDA line. | | 4 | 12CDATACK | Data acknowledge phase. | | 3 | 12C IDLE | Indicates that I2C is idle | | 2 | I2CRXOV | I2C Receiver overrun | | 1 | I2CRXAV | I2C Receiver available | | 0 | 12CTXEMP | I2C Transmitter empty | The I2CCHIPID register holds the VERSA MIX I2C interface ID as well as the status bit that indicates if the last byte monitored on the I2C interface was aimed at the VERSA MIX or not. The reset value of this register is 0x42, meaning an I2C Chip ID of 0x21. The chip ID value of the VERSA MIX can be dynamically changed by writing the desired value into the I2CCHIPID register. TABLE 89: (I2CCHIPID) I2C CHIP ID - SFR DCH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|--------|---|---|---|---|---|---| | | I2CWID | | | | | | | | Bit | Mnemonic | Function | |-----|-------------|--------------------------------------------------------------------------------------------------------------| | 7:1 | I2C ID[6:0] | The value of this chip's ID | | 0 | I2WID | (Used only in slave mode) Indicates that this chip should not have received the last bit this chip received. | The I2WID bit is "read only" and will only go low the next time this chip receives a bit that should be received by this chip. #### **I2C Clock Speed** The VERSA MIX I2C interface communication speed is configurable. This provides the ability to adjust the speed to various I2C bus configurations. The control of the I2C interface communication speed is made through the I2CCLKCTRL register. The formula for calculating the I<sup>2</sup>C clock frequency in Master mode is given by the following formula: $$I^2C CIK = \frac{f_{osc}}{[8 \times (I2CCLKCTRL)]}$$ The table below gives some examples of I2C clock (on SCL pin) for various values of the I2CCLKCTRL register when using a 16MHz crystal oscillator. | I2CCLKCTRL Value | I2C Clock (SCL Value) | |------------------|-----------------------| | 01h | 1MHz | | 03h | 500KHz | | 07h | 250KHz | | 13h | 100KHz | | 27h | 50KHz | | C7h | 10KHz | When the I2C interface is configured in Slave mode, it has no control on the I2C speed because the bus is controlled by the Master device. In that case, the I2CCLKCTRL is not used TABLE 90: (I2CCLKCTRL) I2C CLOCK CONTROL - SFR DBH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |------------------|---|---|---|---|---|---|---|--|--| | 12CCLKCTRL [7:0] | | | | | | | | | | | Bit | Mnemonic | Function | |-----|------------|-------------------------| | 7:0 | 12CCLKCTRL | I2C Clock speed control | #### **I2C Interface Interrupts** The I2C interface has a dedicated interrupt vector located at address 0x5B. Three flags share the I2C interrupt vector and can be used to monitor the I2C interface status making it possible to raise the I2C interrupt. I2CTXEMP: Is set to 1 when the transmit buffer is empty I2CRXAV: Is set to 1 when data byte reception completes. I2CRXOV: Is set to 1 if a new byte reception completes before the previous data in the reception buffer is read, resulting in a data collision. These flags can all trigger the I2C interrupt if their corresponding bit in the I2CCONFIG register is set to one. In the case where more than one of these flags can raise the I2C interrupt, the interrupt routine will have to find out which condition generated the interrupt. Note that the I2CRXAV, I2CTXEMP and I2CRXOV flags remain active when their corresponding interrupt enable flag is set to 0. So they can still be used to monitor the I2C interface condition. #### **Master I2C Operation** In Master mode, the VERSA MIX I2C interface takes control of the I2C bus and dictates the transfer to occur on it. In order to configure the I2C interface in Master mode, the I2CMASTER bit of the I2CCONFIG register must be set to one. Once the I2C interface is configured, sending data to a Slave device connected on the bus is done by writing the data on the I2CRXTX register. Before sending data to a Slave device, a byte containing the target device's chip ID as well as Read/Write bit must be sent to it. Master mode data read is triggered by reading the I2CRXAV (bit 1) of the I2CIRQSTAT register. The data is present on the I2CRXTX register when the I2CRXAV bit gets set. Reading the value of the I2CRXTX register resets the I2CRXAV bit. Once started, the I2C byte read process will continue until the Master generates a STOP condition. When the I2C interface is configured in Master mode, setting to 1 the I2CMSTOP bit of the I2CCONFIG register will make the I2C interface generate a STOP condition after the reception of the next byte. In Master Mode, it's possible to manually control the operation of the acknowledged timing when receiving data. To do this, you must first set to 1 the I2CMANACK bit of the I2CCONFIG register. Then, once you received a byte, you can manually control the acknowledge level by clearing or setting the I2CMANACK bit. **Note:** The VERSA MIX I2C Interface is not compatible with the I2C multi-master mode. #### Slave I2C Operation The VERSA MIX I2C interface can be configured to operate in Slave mode by clearing the I2CMASTER bit of the I2CCONFIG register. In Slave mode, the VERSA MIX has no control on the rate or the timing of the data exchange that occurs on the I2C bus. For this reason, especially in Slave mode, it is preferable to manage the transactions using the I2C interrupts. The I2CMASKID bit, when set can make the Slave device mask the received ID byte and receive the data directly. This is useful when only two devices are present on the I2C bus. Note: When the VERSA MIX starts transmitting data in Slave mode, it will continually transmit the value present of the I2C transmit register as long as the Master provides the clock signal or until the Master device generates a STOP condition # I2C EEPROM Interface Example Program The following example program shows the use of the VERSA MIX I2C interface to perform Read and Write operations to an externally connected EEPROM device. ``` #pragma SMALL #include <vmixreg.h> // --- Function prototypes unsigned char eeread(idata unsigned char, idata unsigned char); void eewrite(idata unsigned char, idata unsigned char, unsigned char); // - Global variables idata unsigned char iracptr=0x00; sbit I2C_TX_EMPTY = USERFLAGS^0; sbit I2C_RX_AVAIL = USERFLAGS^1; sbit I2C_IS_IDLE = USERFLAGS^3; sbit I2C_NO_ACK = USERFLAGS^6; MAIN FUNCTION void main (void){ unsigned char x=0; DIGPWREN = 0x13; //Enable the I2C peripheral /*** configure I2C Speed. I2CCLKCTRL = 0x013; //...To about 100KHZ... //*** Configure the interrupts IEN0 |= 0x81: //Enable Ext INT0 interrupt + main //*** infinite loop waiting for ext IRQ while(1){ }// End of main()... // EXT INT0 interrupt // When the External interrupt 0 is triggered read and write // operations are performed on the EEPROM void int_ext_0 (void) interrupt 0 { // Local variables declaration idata unsigned char eedata; idata unsigned char adrsh =0; idata unsigned char adrsl =0; idata int adrs =0; IEN0 &= 0x7F; //disable ext0 interrupt //(Masked for debugger compatibility) //Write irqcptr into the EEPROM at adrs 0x0100 eewrite( 0x01,0x00,irqcptr); irqcptr = irqcptr + 1; //Increment the Interrupt counter //Perform an EEPROM read at address 0x100 eedata = eeread(0x01, 0x00); delay1ms(100); //Debo delay for the switch on INT0 IEN0 = 0x81; // enable all interrupts + int 0 (Removed //for debugger compatibility) ``` }// end of EXT INT 0 ``` COAL ``` ``` INDIVIDUALS FUNCTIONS // EEREAD - EEPROM Random Read // unsigned char eeread(idata unsigned char adrsh, idata unsigned char adrsl) idata unsigned char x=0; idata unsigned char readvalue=0; I2CCONFIG = 0x03; //I2C MASTER MODE NO INTERRUPT I2CRXTX = 0xA8; //SEND 24LC64 ADRS + write COMMAND USERFLAGS = 0x00; while(!!2C_TX_EMPTY){USERFLAGS = !2CIRQSTAT;} //SEND 24LC64 ADRSH USERFLAGS = 0x00; while(II2C_TX_EMPTY){USERFLAGS = I2CIRQSTAT;} I2CRXTX = adrs1; //SEND 24LC64 ADRSL USERFLAGS = 0x00; while(!I2C_TX_EMPTY){USERFLAGS = I2CIRQSTAT;} USERFLAGS = 0x00; //wait for I2C interface to be idle while(!I2C_IS_IDLE){USERFLAGS = I2CIRQSTAT;} I2CCONFIG &= 0 xFD; //set Master Rx Stop, only 1 byte to receive I2CCONFIG |= 0x02; I2CRXTX = 0xA9; // Chip ID read USERFLAGS = 0x00; while(!I2C_RX_AVAIL){USERFLAGS = I2CIRQSTAT;} readvalue = I2CRXTX; USERFLAGS = 0x00; while(!I2C_IS_IDLE){USERFLAGS = I2CIRQSTAT;} //Wait for I2C IDLE return readvalue; }//End of EEREAD // EEWRITE - EEPROM Random WRITE // void eewrite(idata unsigned char adrsh, idata unsigned char adrsl, unsigned char eedata) idata unsigned char x; I2CCONFIG = 0x01; //I2C MASTER MODE NO INTERRUPT //SEND EEPROM ADRS + READ 12CRXTX = 0xA8: //COMMAND USERFLAGS = 0x00; while(!I2C_TX_EMPTY){USERFLAGS = I2CIRQSTAT;} I2CRXTX = adrsh: //SEND ADRSH USERFLAGS = 0x00; while(!I2C_TX_EMPTY){USERFLAGS = I2CIRQSTAT;} I2CRXTX = adrs1; //SEND ADRSL USERFLAGS = 0 \times 00; while(!I2C_TX_EMPTY){USERFLAGS = I2CIRQSTAT;} //SEND 24LC64 DATA and wait I2CRXTX = eedata: //for I2C bus IDLE USERFLAGS = 0x00: while(!I2C_IS_IDLE){USERFLAGS = I2CIRQSTAT;} ///--Wait Write operation to end I2CCONFIG = 0x01; //I2C Master Mode no Interrupt I2CRXTX = 0xA8; USERFLAGS = 0x00; //Send 24LC64 Adrs +read Command while(!I2C_TX_EMPTY){USERFLAGS = I2CIRQSTAT;} USERFLAGS = I2CIRQSTAT; }while(I2C_NO_ACK); delay1ms(5); //5ms delay for EEPROM write }// End of EEPROM Write ``` # **Analog Signal Path** The VERSA MIX makes it possible to implement a complete acquisition system on one chip by integrating the following analog peripherals: - 12-bit, A/D converter having 4 external inputs as well as 3 internal connections to the Operational amplifier and Current source input and output for a total of 7 inputs. The ADC conversion rate is programmable up to 10KHz - Internal Bandgap reference and PGA - 1 Programmable current source - 2 Digital potentiometers - o 1 Digital switch Figure 35 presents a functional diagram of the VERSA MIX analog peripherals and their interaction. FIGURE 35: ANALOG SIGNAL PATH OF THE VERSA MIX The on-chip calibrated bandgap or the an external reference provides the basis for all derived on-chip voltages. These signals serve as reference for the ADC and the current source. # **Analog Peripherals Power Control** The control of the internal and external reference, the multiplexer's current source drive, the ADC and their respective power downs are all done via the $\mu$ -Processor control through the ANALOGPWREN SFR registers. # **Internal Reference and PGA** The VERSA MIX provides a temperature calibrated internal bandgap reference coupled with a programmable gain amplifier. The programmable gain amplifier's role is to amplify the bandgap output to bring it to 2.7V and provide the drive required for the ADC reference input and current source. Both the bandgap and the PGA are calibrated during production and their associated calibration registers are automatically loaded with the appropriate calibration vectors when the device is reset. The bandgap and PGA calibration vectors are stored into the BGAPCAL and PGACAL SFR registers when a reset occurs. It is possible for the user program to overwrite the content of those registers. However, overwriting the content of the VERSA MIX calibration registers is likely to degrade the VERSA MIX's internal reference performances. TABLE 91: (BGAPCAL) BAND-GAP CALIBRATION VECTOR REGISTER - SFR B3H | 7 | 6 5 4 3 2 1 | | | | | | | | | |------------------------------------------------------------|-----------------------|-------|-----|----------|-----------|---------|---|--|--| | BGAPCAL [7:0] | | | | | | | | | | | | | | | | | | | | | | Bit | Mne | monic | Fur | Function | | | | | | | 7:0 | BGA | PCAL | Bar | nd-gap o | data cali | bration | | | | | TABLE 92: (DPL1) PGA CALIBRATION VECTOR REGISTER - SFR B4H | | | | | | | | | | | 7 | 9 | E | 4 | 0 | ٥ | 4 | 0 | | | | Bit | Mnemonic | Function | |-----|----------|-------------------------------| | 7:0 | PGACAL | 8 MSBs of PGA Calibration | | | | Vector (LSBit is on ISRCCAL1) | PGACAL [7:0] # Using the VMIX Internal Reference The configuration and setup up of the VERSA MIX internal reference is very simple to do: It only requires setting to 1 the bits 0 and 1 of the ANALOGPWREN register to power-on the bandgap and the PGA respectively. On the hardware side, the use of the internal reference requires the addition of two external tank capacitors on the XTVREF pin. Those capacitors should be one 4.7uF to 10uF Tantalum capacitor in parallel with one 0.1uF Ceramic capacitor. The next figure shows the connection of the tank capacitors to the XTVREF pin FIGURE 36: TANK CAPACITORS CONNECTION TO THE XTVREF PIN The VERSA MIX internal reference can also be used as a reference for other sections of the user circuit provided that the load on the XTVREF pin is kept to a minimum. The following table shows the typical effect of loading on the XTVREF voltage. FIGURE 37: TANK CAPACITORS CONNECTION TO THE XTVREF PIN It is recommended that the external load on the XTVREF pin to be < 1mA. **Note:** A stabilization delay of more than 1 ms should be provided between the activation of the bandgap, the PGA and the first A/D conversion or measurement made on the programmable current source. #### Using an External Reference An external reference can be used to drive the VERSA MIX ADC and the programmable current source instead of using the internal reference. The external reference voltage source can be set from 0.5V to 3.5V and it must provide sufficient drive to operate the ADC load and not be affected by driving large capacitance load FIGURE 38: EXTERNAL REFERENCE CONNECTION TO THE XTVREF PIN # 1 #### Warning: When an external reference source is applied to the XTVREF pin, it is mandatory not to power-on the PGA. The internal bandgap reference should also be kept de-activated. # Reference Impact on the Programmable Current Source The Programmable Current Source uses the same reference as the ADC for its operation. Therefore, using an external reference will have a direct impact on the current source output. Basically, the 200mV and 800mV current source reference voltage, calibrated at 2.7V will change in a linear fashion according to the voltage present on the XTVREF pin. For example, in the case where the reference voltage applied to the XTVREF pin is 3V, the current source reference voltage will be scaled up by a factor of [VXTVREF/2.7V] to 222mV and 889mV respectively. Affecting the current source output accordingly. # A/D Converter The VERSA MIX includes a feature rich and highly configurable on-chip 12-bit A/D converter. The A/D conversion result is a straight, unsigned 12-bit binary number with 1 LSB = Full Scale/4096. The following figure describes the ideal transfer function for the ADC. FIGURE 39: IDEAL A/D CONVERTER TRANSFER FUNCTION The A/D converter includes a system that provides the ability to trigger conversions on a periodic and configurable basis up to 10kHz without the intervention of the processor. Once the conversion is complete, the A/D system can raise an interrupt that can wake-up the processor (if it has been put in idle mode between conversions) or bring back its operation to full speed. The VERSA MIX A/D converter can also be configured to perform the conversion on one specific channel or on four consecutive channels. These features make the A/D adaptable for many applications. The following paragraphs will describe the VERSA MIX A/D converter register features and give explanation on how to make use of them. #### **ADC Data Registers** The ADC data registers hold the ADC conversion results. The ADCDxLO registers contains the 8 Least Significant Bits (LSB) of the conversion results while the ADCDxHI registers hold the 4 Most Significant Bits (MSB) of the conversion results. | TABLE 93: (ADCD0LO) ADC CHANNEL 0 DATA REGISTER, LOW BYTE - SFR A | | | | | |-------------------------------------------------------------------|----------|----------|--|--| | Rit | Mnemonic | Function | | | | | 7:0 | ADCD0LO | ADC channel 0 low | | | | | |----------------------------------------------------------------------|-----|---------|-------------------|--|--|--|--| | | | | | | | | | | TABLE 94: (ADCD0HI) ADC CHANNEL 0 DATA REGISTER, HIGH BYTE - SFR A7H | | | | | | | | #### Bit <u>Mnemonic</u> Function 3:0 ADCD0HI ADC channel 0 high | TABLE 95: (ADCD1LO) ADC CHANNEL 1 DATA REGISTER, LOW BYTE - SFR A9H | | | | | | | | |---------------------------------------------------------------------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADCD1LO [7:0] | | | | | | | | | Bit | Mnemonic | Function | |-----|----------|-------------------| | 7:0 | ADCD1LO | ADC channel 1 low | | TABLE 96: (ADCD1HI) ADC CHANNEL 1 DATA REGISTER, HIGH BYTE - SFR AAH | | | | | | | | |----------------------------------------------------------------------|---|---|---|---|-------|----------|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | - | - | - | - | | ADCD1 | HI [3:0] | | | Bit | Mnemonic | Function | |-----|----------|--------------------| | 3:0 | ADCD1HI | ADC channel 1 high | | TABLE 97: (ADC2LO) ADC CHANNEL 2 DATA REGISTER, LOW BYTE - SFR ABH | | | | | | | | |--------------------------------------------------------------------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADCD2LO [7:0] | | | | | | | | | Bit | Mnemonic | Function | |-----|----------|-------------------| | 7:0 | ADCD2LO | ADC channel 2 low | TABLE 98: (ADCD2HI) ADC CHANNEL 2 DATA REGISTER, HIGH BYTE - SFR ACH ADCD2HI [3:0] | Bit | Mnemonic | Function | |-----|----------|--------------------| | 7:4 | = | = | | 3.0 | ADCD2HI | ADC channel 2 high | | TABLE 99: (ADCD3LO) ADC CHANNEL 3 DATA REGISTER, LOW BYTE - SFR ADH | | | | | | | | |---------------------------------------------------------------------|---|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ADCD3LO [7:0] | | | | | | | | | Bit | Mnemonic | Function | |-----|----------|-------------------| | 7:0 | ADCD3LO | ADC channel 3 low | | TABLE 100: (ADCD3HI) ADC CHANNEL 3 DATA REGISTER, HIGH BYTE - SFR AEH | | | | | | | | |-----------------------------------------------------------------------|---|---|---|---|-------|-----------|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | - | - | - | - | | ADCD3 | 3HI [3:0] | | | Bit | Mnemonic | Function | |-----|----------|--------------------| | 7:4 | - | = | | 3:0 | ADCD3HI | ADC channel 3 high | #### **ADC Input Selection** A/D conversions can be performed on one channel or they can be performed sequentially on the four lower channels or four upper channels of the ADC input multiplexer. An input buffer is present on each of the four external ADC inputs (ADIN0 to AIN3) These buffers must be enabled before a conversion can take place on the ADC AINO-AIN3 inputs. Enabling these buffers is made by setting to 1 the corresponding bits of the lower quartet (AIEN [3:0]) of the INMUXCTRL register. TABLE 101: (INMUXCTRL) ANALOG INPUT MULTIPLEXER CONTROL REGISTER - SFR B5H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|-----|-------|-------|---|------|---------|---| | - | ADC | INSEL | [2:0] | | AINE | N [3:0] | | | Bit | Mnemonic | Function | |-----|---------------|----------------------------------------------------------------------------------------------------------------------| | 7 | 1 | - | | 6:4 | ADCINSEL[2:0] | ADC Input Select<br>000 - AIN0<br>001 - AIN1<br>010 - AIN2<br>011 - AIN3<br>100 - OPOUT<br>101 - VSR<br>110 - ISRCIN | | | | 111 - ISRCOUT | | 3:0 | AINEN[3:0] | Analog Input Enable | The upper four bits of the INMUXCTRL register are used to define the channel on which the conversion will take place when the ADC is set to perform the conversion on one specific channel. # **ADC Control Register** The ADCCTRL register is the main register controlling the ADC operating mode. TABLE 102: (ADCCTRL) ADC CONTROL REGISTER - SFR A2H | 7 | 6 | 5 | 4 | |-----------|----------|---|--------| | ADCIRQCLR | XVREFCAP | 1 | ADCIRQ | | 3 | 2 | 1 | 0 | |-------|---------|------|---------| | ADCIE | ONECHAN | CONT | ONESHOT | | Bit | Mnemonic | Function | |-----|--------------|--------------------------------------------------------------------------------------------------------------------------| | 7 | ADCIRQCLR | ADC interrupt clear | | | | Writing 1 Clears interrupt | | 6 | XVREFCAP | Always keep this bit at 1 | | 5 | Reserved = 1 | Keep this bit = 1 | | 4 | ADCIRQ | Read ADC Interrupt Flag | | | | Write 1 generate ADC IRQ | | 3 | ADCIE | ADC interrupt enable | | 2 | ONECHAN | 1 = Conversion is performed on<br>one channel<br>Specified ADCINSEL 0 = Conversion is performed on<br>4 ADC channels | | 1 | CONT | 1 = Enable ADC continuous conversion | | 0 | ONESHOT | 1 = Force a single conversion<br>on 1 or 4 channels | #### **ADC Continuous / One Shot Conversion** The CONT bit sets the ADC conversion mode. When the CONT bit is set to 1, the ADC will start doing conversion in continuous mode at a rate defined by the Conversion Rate register. (See next paragraphs) When the CONT bit is set to 0, the A/D operates in "One Shot" mode. In that mode, the conversion starts when the ONESHOT bit of the ADCCONTRL register is set. #### ADC One Channel/ Four Channel Conversion The VERSA MIX ADC includes a feature that render possible to performs a conversion on one specific channel or to do it on four consecutive channels. This feature minimizes the load on the processor when reading on more than one ADC input is required. The ONECHAN bit of the ADCCTRL register controls this feature. When the ONECHAN is set to 1, the conversion will take place on the channel selected by the INMUXCTRL register. Once the conversion is completed, the result will be put into the ADCD0LO and ADCD0HI registers When the ONECHAN bit is set to 0, the conversion, once triggered, will be done sequentially on four channels and the conversion results will be placed into the ADCDxLO and ADCDxHI registers. The value of the bit 6 of the INMUXCTRL register defines whether the conversion will take place on the four upper channels of the input multiplexer or the 4 lower ones. # **ADC Clock Source Configuration** For its operation, the A/D converter requires a specific clock source derived for the VERSA MIX main clock. The frequency of the ADC clock should be set between 250kHz to 1.25MHz The configuration of the ADC clock source frequency is done by adjusting the value of the ADCCLKDIV register. The equation to get the ADC reference clock is given below. ADC Clock Reference Equation: ADC Clk ref = $$\frac{f_{OSC}}{4x (ADCCDIV + 1)}$$ The ADC conversion requires 111 ADC clock cycles to perform the conversion on one channel. Using the above equation, it is possible to derive the ADCCLKDIV register value to perform the conversion at a given rate. The following table gives recommended ADCCLKDIV register value according to conversion rate. The numbers given are conservative figures and derived from a 14.74MHz clock | ADCCLKDIV | Maximum Conv. Rate* | |------------------|---------------------| | 0x02 | 10500 Hz | | 0x03 | 8000 Hz | | 0x05 | 5000 Hz | | 0x07 | 4000 Hz | | 0x08 | 3500 Hz | | 0x09 | 3200 Hz | | 0x0B | 2500 Hz | | 0x0D, 0x0E, 0x0F | 2200 Hz | \* The maximum conversion rate is the single channel one. If the conversion is performed on 4 channels, divide the maximum conversion rate by 4. For example to perform the conversion at 2500Hz on four channels, the ADCCLKDIV register will require to be set to 0x02 because the effective conversion rate on the ADC point of view is 4x 2500Hz which is 10KHz TABLE 103: (ADCCLKDIV) ADC CLOCK DIVISION CONTROL REGISTER - SFR 95H | TABLE II | J3. (ADCCL | NDIV) ADI | J OLOGK L | TIVISION C | UNITAUL IN | GIOTEN - V | 31 N 33 N | |----------|------------|-----------|-----------|------------|------------|------------|-----------| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | Α | DCCL | (DIV [7:0 | 0] | | | | I | Bit | Mnemonic | Function | |---|-----|----------------|-------------------| | | 7:0 | ADCCLKDIV[7:0] | ADC clock divider | # **ADC Conversion Rate Configuration** The VERSA MIX ADC conversion rate when configured in continuous mode is defined by the value present in a 24-bit A/D Conversion Rate register that serves as the time base to trigger the ADC conversion process. The equation to obtain for the value to put into the ADC conversion rate is given by the formula below: Conversion Rate Equation: The conversion rate register is accessible using three SFR registers as shown below: TABLE 104: (ADCCONVRLOW) ADC CONVERSION RATE REGISTER LOW BYTE - SFR A3H | Bit | Mnemonic | Function | |-----|-------------|--------------------------| | 7:0 | ADCCONVRLOW | Conversion rate low byte | TABLE 105: (ADCCONVERMED) ADC CONVERSION RATE REGISTER MED BYTE-SER A4H | Bit | Mnemonic | Function | |-----|-------------|-----------------------------| | 7:0 | ADCCONVRMED | Conversion rate medium byte | TABLE 106: (ADCCONVRHIGH) ADC CONVERSION RATE REGISTER HIGH BYTE-SFR A5H | Bit | Mnemonic | Function | |-----|--------------|---------------------------| | 7:0 | ADCCONVRHIGH | Conversion rate high byte | The following table below gives some examples of typical value to be put into the conversion rate register for given conversion rates. | Conversion | ADC conv. rate register value. | | | | | |------------|--------------------------------|-------------|--|--|--| | Rate | Fosc= 14.74MHz | Fosc= 16MHz | | | | | 1Hz | E10000h | F42400h | | | | | 10Hz | 168000h | 186A00h | | | | | 100Hz | 024000h | 027100h | | | | | 1kHz | 003999h | 003E80h | | | | | 2.5kHz | 00170Ah | 001900h | | | | | 5kHz | 000B85h | 000C80h | | | | | 8kHz | 000733h | 0007D0h | | | | | 10kHz | 0005C2h | 000640h | | | | # **ADC Status Register** The ADC shares the interrupt vector 0x6B with the Interrupt on Port 1 Change and the Compare and Capture Unit 3. To enable the ADC interrupt, the ADCIE bit of the ADCCTRL register must be set. Before or at the same time this bit is set, the ADCIRQCLR and the ADCIRQ must be cleared. For the interrupt to reach the processor the ADCPCIE bit of the IEN1 register must be set as well as the EA bit of the IEN0 register. Once the ADC interrupt occurs, it is important to clear the ADC Interrupt by writing a '1' into the ADCINTCLR bit of the ADCCTRL register and also clear the ADCIF flag into the IRCON register ### A/D Converter Use Example The following lines of code can be used to perform these tasks. The first part of the code is the interrupt setup and module configuration whereas the second part is the interrupt function. #### Sample C code to setup the A/D converter: | // | | |------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | // MAIN FUNCTION | | | ()<br>at 0x0100 void main (void) { | | | //*** Initialize the Analog Peripherals *** | | | AN ALOGPWREN = 0x07; | //Enable the following analog<br>//peripherals: ISRC, ADC, PGA,<br>// BGAP. TA = OFF (mandatory) | | //Configure the ADC and Start it<br>ADCCLKDIV=0x0F;<br>ADCCONVRLOW=0x00;<br>ADCCONVR MED=0x40;<br>ADCCONVR HIGH =0x02; | //SET ADC CLOCK SOURCE<br>//CONFIGURE CONVERSION RATE<br>//= 100Hz @ 14.74 MHz | | INMUXCTRL=0x0F; ADCCTRL=0xEA; | //Enable All ADC External inputs //buffers and select ADCI0 //Configure the ADC as follow: //bit 7:= 1 ADCIRQ Clear //Bit 6:= 1 XVREFC AP (always) //Bit 5:= 1 (always) //Bit 4:= 0 ADCIRQ (don't care) //Bit 3:= 1 = ADC IRQ enable //Bit 2:= 0 conversion on 4 //channels //Bit 1:= 1 Continuous conversion //Bit 0:= 0 No single shot mode | //\*\*\* Configure the interrupts IEN0 |= 0x80; IEN1 |= 0x020; //enable main interrupt //Enable ADC Interrupt while(1); //Infinite loop waiting ADC interrupts }// End of main()... ADC INTERRUPT ROUTINE void int\_adc (void) interrupt 13 { idata int value = 0; IEN0 &= 0x7F; //disable ext0 interrupts ADCCTRL |=0x80; //Clear ADC interrupt // Read ADC channel 0 value = ADCD0HI; value = valeur\*256; value = valeur + ADCD0LO; // Read ADC channel 3 value = ADCD3HI; value = valeur\*256 value = valeur + ADCD3LO; (...) IRCON &= 0xDF; //Clear adc irq flag //prepare adc for next acquisition ADCCTRL |=0xFA; IEN0 |= 0x80; // enable all interrupts }// End of ADC IRQ (...) #### Warning: When using the ADC, make sure the output multiplexer controlled by the TAEN bit of the ANALOGPWREN register (92h) is powered down at all times. Otherwise, it is likely that the signal present on the ISRCOUT will be routed back to the selected ADC input, causing signal-reading error. # **Programmable Current Source** The VERSA MIX includes a programmable current source intended to provide excitation to resistive sensors connected between the ISRCOUT and ISRCIN pins To ensure current output stability, the current source provides a feedback input, ISRCIN. The feedback is voltage controlled and can be dynamically set to either 200mV or 800mV. Placing a resistor between the ISRC pin and the ground defines the output current of the current source. It is possible to adjust the ISRC output to a current of up to 530µA. FIGURE 40: PROGRAMMABLE CURRENT SOURCE TO EXCITE SENSOR As shown above, a resistive sensor must be connected between the ISRCOUT and the ISRCIN. In order to perform A/D conversion of the voltage present at the terminal of the current source, there is an internal link between each of the ISRCOUT and ISRCIN pins as well as the Input multiplexer of the A/D converter. TABLE 107: (ISRCCAL1) CURRENT SOURCE CALIBRATION VECTOR FOR 200MV FEEDBACK VALUE - SER BCH | FEEDBACK VALUE - SFR BCH | | | | | | | | |--------------------------|----------------|---|---|---|---|---|---| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | PGACAL0 | ISRCCAL1 [6:0] | | | | | | | | Bit | Mnemonic | Function | |-----|---------------|----------------------------------------------| | 7 | PGACAL0 | Bit 0 of PGACAL | | 6:0 | ISRCCAL1[6:0] | Calibration Value for ISRC feedback of 200mV | TABLE 108: (ISRCCAL2) CURRENT SOURCE CALIBRATION VECTOR FOR 800MV FEEDBACK VALUE - SFR BDH | LEDDAOI | WALUE O | ווטטוו | | | | | | | |---------|---------|--------|------|-------|-------|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | - | | | IS R | CCAL2 | [6:0] | | | | | Bit | Mnemonic | Function | |-----|---------------|----------------------------------------------| | 7 | - | - | | 6:0 | ISRCCAL2[6:0] | Calibration Value for ISRC feedback of 800mV | # **Current Source Setup Example** Enabling the Current Source using the 200mV reference: MOV ANALOGPWREN,#00110011B ;Enable Analog peripherals ;Bit 7: OPAMPEN = 0 Op-Amp OFF ;Bit 6: DIGPOTEN= 0 Dig Pot OFF ;Bit 5: ISRCSEL = 1 ISRC 800mV ;Bit 4: ISRCEN = 1 ISRC ON ;Bit 3: TAEN = 0 TA output OFF ;Bit 2: ADCEN = 0 ADC OFF ;Bit 1: PGAEN = 1 PGA ON ;Bit 0: BGAPEN = 1 BandGap ON Enabling the Current Source using the 200mV reference: ;MOV ANALOGPWREN,#00010011B ;Enable Analog peripherals ;Bit 7: OPAMPEN = 0 Op-Amp OFF ;Bit 6: DIGPOTEN= 0 Dig Pot OFF ;Bit 5: ISRCSEL = 0 ISRC 200mV ;Bit 4: ISRCEN = 1 ISRC ON ;Bit 3: TAEN = 0 TA output OFF ;Bit 2: ADCEN = 0 ADC OFF ;Bit 1: PGAEN = 1 PGA ON ;Bit 0: BGAPEN = 1 BandGap ON # **Digital Potentiometers** The VERSA MIX has two digital potentiometers that the user may control by setting the bits of either the DIGPOT1 register or DIGPOT2 register. Here is a short list of some possible applications for the digital potentiometers: - Gain control - o Offset adjustment - A/D input attenuation - Digitally controlled filter FIGURE 41: DIGITAL POTENTIOMETER FUNCTIONAL DIAGRAM | TABLE 109: (DIGPOT1) DIG. POTENTIOMETER 1 CONTROL REGISTER - SFR BAH | | | | | | | | | |----------------------------------------------------------------------|---------------|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DIGPOT1 [7:0] | | | | | | | | | Bit | Mnemonic | Function | |-----|----------|-----------------------| | 7-0 | DIGPOT1 | Potentiometer 1 Value | | TABLE 110: (DIGPOT2) DIG. POTENTIOMETER 2 CONTROL REGISTER - SFR BBH | | | | | | | | | |----------------------------------------------------------------------|---------------|---|---|---|---|---|---|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | DIGPOT2 [7:0] | | | | | | | | | Bit | Mnemonic | Function | |-----|----------|-----------------------| | 7-0 | DIGPOT2 | Potentiometer 2 Value | The digital potentiometers are floating devices, meaning that there are no restrictions on the voltage present on their terminals as long as it is within the nominal operating range of the VERSA MIX. The current flow through the potentiometers should be limited to 5mA max. The digital potentiometer maximum nominal resistance is of 30k +/- 2Kohms from device to device. On a given device the two digital potentiometer values usually match within 1%. Before using the digital potentiometers, they must first be enabled by setting to 1 the bit 6 of the ANALOGPWREN register (92h). Then the control of the digital potentiometer value is done by writing the appropriate value in the corresponding DIGPOTx register. According to the following equation: $$R_{\text{potentiometer}^*} = \underbrace{[256 - \text{DIGPOTx}[7:0]]}_{256} \times \text{Potentiometer value} \times 30k$$ #### **Digital Potentiometer Setup Example** Only two instructions are required to enable and configure the digital Potentiometers of the VERSA MIX MOV AN ALOGPWREN,#0100000B MOV DIGPOT1,#0C0h ;SET POT1 to 25% of Max Pot value MOV DIGPOT2,#040h ;SET POT2 to 75% of Max Pot value # **Operational Amplifier** The VERSA MIX is equipped with an operational amplifier. This op amp can be used for a wide array of analog applications. Here is a short list of some applications; - Gain control - Offset Control - Reference buffering - Integrator - Other standard op amp applications The op-amp on the VERSA MIX has an open-loop gain of 100 decibels; a unity gain bandwidth of 5MHz and it is able to drive a load of $1k\Omega$ and 40pF. The slew rate of the Op-Amp is $7V/\mu s$ . The output voltage can swing between 25mV and 4.975 Volts under a 10kOhms load. To activate the Operational Amplifier the OPAMPEN bit (bit 7) of the ANALOGPWREN register (SFR 92h) must be set to 1. # Warning: If the VERSA MIX Op-Amp inputs are left floating, it is recommended to keep it in power down to prevent risks of self-oscillations. # **Digitally Controlled Switches** On the VERSA MIX, there is one digital switch composed of 4 sub-switches connected in parallel. These sub-switches can be individually controlled by writing to the SFR register at B7h. FIGURE 42: SWITCH FUNCTIONAL DIAGRAM The switch "ON" resistance is between 50 and 100 Ohms depending on the number of subswitches being used. If, for example, one subswitch is closed, the switch resistance will be about 100 Ohms, and if all 4 switches are closed, the switch resistance will go down to about 50 Ohms. TABLE 111: (SWITCHCTRL) USER SWITCHES CONTROL REGISTERS - SFR B7H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------------------|---|---|---|---|-------|----------|---| | Not Used but implemented | | | | | SWTCI | H1 [3:0] | | | Bit | Mnemonic | Function | |-----|--------------|----------------------------------------------------------------------------| | 7:4 | User Flags | Not used but implemented bits<br>Can be used as general<br>purpose storage | | 3:0 | SWITCH1[3:0] | Switch 1 control (composed of 4 individual switches each bit controlled) | The upper 4 bits of the SWITCHCTRL register are not used but they are implemented. They can be used for general purpose storage # **Analog Output Multiplexer** The analog output multiplexer serves essentially for test purposes during the VERSA MIX production by providing access to some internal points of the analog signal path of the VERSA MIX. However, it can be useful for specific applications, but because of its high intrinsic impedance, care must be taken to not load it. The analog output multiplexer shares its output with the current source output and for this reason it must be disabled when the current source or the ADC is used. On the other hand, when the analog multiplexer is used, the current source must be powered down. The table below summarizes the analog output multiplexer select line combinations and their corresponding outputs. TABLE 112: (OUTMUXCTRL) ANALOG OUTPUT MULTIPLEXER CONTROL REGISTER | | - 3111 2011 | | | | | | | | | |---|-------------|---|---|---|---|------|--------|------|--| | ı | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | ı | , | - | - | - | 1 | TAOU | rsel [ | 2:0] | | | Bit | Mnemonic | Function | |-----|---------------|-----------------------------------------------------------------------------------------------------------------------| | 7:3 | Unused | Unused | | 2:0 | TAOUTSEL[2:0] | Signal output on TA | | | | 000 - AIN0<br>001 - AIN1<br>010 - AIN2<br>011 - AIN3<br>100 - VBGAP<br>101 - reserved<br>110 - unused<br>111 - unused | # **VERSA MIX Interrupts** The VERSA MIX is a highly integrated device incorporating a vast number of peripherals for which a comprehensive set of 29 interrupt sources sharing 12 interrupt vectors is available to ease system program development. Most of the VERSA MIX peripherals are able to generate a specific interrupt that can provide feedback to the MCU core in which an event has occurred or a task has been completed. Below is a list of things that one should know about the interrupts on the VERSA MIX: - Each digital peripheral on the VERSA MIX has an interrupt channel. - The SPI, UARTs and I<sup>2</sup>C all have event specific flag bits. - When the processor is in IDLE mode, an interrupt may be used to wake it up. - The processor can run at full speed during interrupt routines. The following table summarizes the interrupt sources, the natural priority and the associated interrupt vector addresses. TABLE 113: INTERRUPT SOURCES AND NATURAL PRIORITY | Interrupt | Interrupt Vector | |--------------------------------------------------------|------------------| | Reserved | 0E43h | | INT0 | 0003h | | UART1 | 0083h | | TIMER 0 | 000Bh | | SPITx | 004Bh | | INT1 | 0013h | | SPIRX & SPIRX OVERRUN<br>/ COMPINT0 | 0053h | | TIMER 1 | 001Bh | | I2C (Tx, Rx, Rx Overrun)<br>/ COMPINT1 | 005Bh | | UART0 | 0023h | | MULT/ACCU 32bit Overflow / COMPINT2 | 0063h | | TIMER 2: T2 Overflow, T2EX | 002Bh | | ADC and interrupt on Port 1 change (8 int.) / COMPINT3 | 006Bh | It is also possible to program the interrupts to wake-up the processor from IDLE mode or force it to return to full speed when an interrupt occurs. # **Interrupt Enable Registers** The following tables are the interrupt enable register representations and their bit functions: TABLE 114: (IEN0) INTERRUPT ENABLE REGISTER 0 - SFR A8H | TABLE 114: (IENU) INTERRUPT ENABLE REGISTER 0 - SFR A8H | | | | | | | |---------------------------------------------------------|---------|------|--------|--|--|--| | 7 | 6 | 5 | 4 | | | | | EA | WDT | T2IE | S0IE | | | | | | | | | | | | | 3 | 2 | 1 | 0 | | | | | T1 IE | INT1 IE | T0IE | INT0IE | | | | | Bit | Mnemonic | Function | |-----|----------|----------------------------------------| | 7 | EA | General Interrupt control | | | | 0 = Disable all Enabled interrupts | | | | 1 = Authorize all Enabled interrupts | | 6 | WDT | Watchdog timer refresh flag. This bit | | | | is used to initiate a refresh of the | | | | watchdog timer. In order to prevent | | | | an unintentional reset, the watchdog | | | | timer the user must set this bit | | | | directly before SWDT. | | 5 | T2IE | Timer 2 Overflow / external Reload | | | | interrupt | | | | 0 = Disable | | | 0015 | 1 = Enable | | 4 | S0IE | Uart0 interrupt. | | | | 0 = Disable | | _ | T1 IF | 1 = Enable | | 3 | | Timer 1 overflow interrupt 0 = Disable | | | | 0 = Disable<br>1 = Enable | | 2 | INT1 IE | | | _ | INTIE | External Interrupt 1 0 = Disable | | | | 1 = Enable | | 1 | TOIE | Timer 0 overflow interrupt | | ' | IOIL | 0 = Disable | | | | 1 = Enable | | 0 | INT0IE | External Interrupt 0 | | | 11410IL | 0 = Disable | | | | 1 = Enable | | | l | I - LIIGOIO | TABLE 115: (IEN1) INTERRUPT ENABLE 1 REGISTER -SFR E8H | - ( / | | | | |--------|------|---------|---------| | 7 | 6 | 5 | 4 | | T2EXIE | SWDT | ADCPCIE | MACOVIE | | 3 | 2 | 1 | 0 | |--------|-----------|---------|----------| | I2C IE | SPIRXOVIE | SPITEIE | reserved | | Bit | Mnemonic | Function | |-----|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | T2EXIE | T2EX interrupt Enable 0 = Disable 1 = Enable | | 6 | SWDT | Watchdog timer start/refresh flag. Set to activate/refresh the watchdog timer. When directly set after setting WDT, a watchdog timer refresh is performed. Bit SWDT is reset. | | 5 | ADCPCIE | ADC and Port change interrupt 0 = Disable 1 = Enable | | 4 | MACOVIE | MULT/ACCU Overflow 32 bits interrupt 0 = Disable 1 = Enable | | 3 | I2C IE | I2C Interrupt<br>0 = Disable<br>1 = Enable | | 2 | SPIRXOVIE | SPI Rx avail + Overrun<br>0 = Disable<br>1 = Enable | | 1 | SPITEIE | SPI Tx Empty interrupt<br>0 = Disable<br>1 = Enable | | 0 | reserved | | TABLE 116: (IEN2) INTERRUPT ENABLE 2 REGISTER - SFR 9AH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|---|---|---|------| | - | - | - | - | - | - | - | S1IE | | Bit | Mnemonic | Function | |-----|----------|--------------------------------------------------| | 7-1 | - | - | | 0 | S1IE | UART 1 Interrupt<br>0 = Disable UART 1 Interrupt | | | | 1 – Fnahle HART 1 Interrunt | # Timer 2 Compare Mode Impact on Interrupts The SPI RX (and RXOV), I2C, MULT/ACCU and ADC Interrupts are shared with the four Timer 2 Compare and Capture Unit interrupts. When the Compare and Capture Units of Timer 2 are configured in compare mode through the CCEN register, the Compare and Capture unit take control of one interrupt vector as shown in the next figure. FIGURE 43: COMPARE CAPTURE INTERRUPT STRUCUTRE The impact of this is that the corresponding peripheral interrupt, if enabled, will be blocked. The output signal remaining of the comparison module will be routed to the Interrupt system and the control lines will be dedicated to the Compare and Capture unit. This interrupt control "take over" is specific to each Compare and Capture unit individually. For example if the Compare and Capture Unit number 2 is configured to generate a PWM signal on P1.2, the MULT/ACCU overflow interrupt, if enabled, will be dedicated to the Compare and Capture Unit number 2 and the SPI, I2C and ADC interrupts won't be affected. # **Interrupt Status Flags** The IRCON register is used to identify the source of an interrupt. Before leaving the interrupt service routine, the IRCON register's bit corresponding to the serviced interrupt should be cleared. TABLE 117: (IRCON) INTERRUPT REQUEST CONTROL REGISTER - SFR 91H | 7 | 6 | 5 | 4 | |--------|---------|---------|----------| | T2EXIF | TF2IF | ADCIF | MACIF | | | | | | | 3 | 2 | 1 | 0 | | 12C IF | SPIRXIF | SPITXIF | Reserved | | Bit | Mnemonic | Function | |-----|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------| | 7 | T2EXIF | Timer 2 external reload flag This bit informs the user whether an interrupt has been generated from T2EX, if the T2EXIE is enabled. | | 6 | TF2IF | Timer 2 overflow flag | | 5 | ADCIF /<br>COMPINT3 | A/D converter interrupt request flag/ port 0 change. / COMPINT3 | | 4 | MACIF /<br>COMPINT2 | MULT/ACCU unit interrupt request flag / COMPINT2 | | 3 | I2CIF /<br>COMPINT1 | I <sup>2</sup> C interrupt request flag<br>/ COMPINT1 | | 2 | SPIRXIF /<br>COMPINT0 | RX available flag SPI + RX<br>Overrun / / COMPINT0 | | 1 | SPITXIF | TX empty flag SPI | | 0 | Reserved | Reserved | # **Interrupt Priority Register** All interrupt sources of the VERSA MIX are combined in groups. There are four priority levels defined on the VERSA MIX. These groups can be programmed individually to one of the four priority levels: from Level0 to Level3 with Level3 being the highest priority. The IPO and IP1 register serves to define the specific priority of each interrupt groups. By default, when the IPO and IP1 register are at reset state 00h, the natural priority order of the interrupts shown previously is in force. TABLE 118: (IP0) INTERRUPT PRIORITY REGISTER 0 - SFR B8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|---------|---|---|-----|---------|---|---| | UF8 | WDTSTAT | | | IP( | 0 [5:0] | | | | Bit | Mnemonic | Function | Function | | | | | |-----|----------|--------------------------------------------------------------------------------------------------------------|-----------------|---------------------|--|--|--| | 7 | UF8 | User Flag | User Flag bit | | | | | | 6 | WDTSTAT | Watchdog timer status flag. Set to 1 by hardware when the watchdog timer overflows. Must be cleared manually | | | | | | | 5 | IP0.5 | Timer 2 | Port1<br>Change | ADC | | | | | 4 | IP0.4 | UART0 | ı | MULT/ACCU | | | | | 3 | IP0.3 | Timer 1 | 1 | I2C | | | | | 2 | IP0.2 | External<br>INT1 | - | SPI RX<br>available | | | | | 1 | IP0.1 | Timer 0<br>Interrupt | - | SPITX<br>Empty | | | | | 0 | IP0.0 | External<br>INT0 | UART1 | External<br>INT 0 | | | | Table 119: (IP1) Interrupt Priority Register 1 - SFR B9h | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|---|---|---|-----|-------|---|---| | - | - | | | IP1 | [5:0] | | | | Bit | Mnemonic | Function | | | |-----|----------|----------------------|-----------------|---------------------| | 7 | - | - | | | | 6 | - | - | | | | 5 | IP1.5 | Timer 2 | Port1<br>Change | ADC | | 4 | IP1.4 | UART0 | - | MULT/ACCU | | 3 | IP1.3 | Timer 1 | - | I2C | | 2 | IP1.2 | External<br>INT1 | - | SPI RX<br>available | | 1 | IP1.1 | Timer 0<br>Interrupt | - | SPITX<br>Empty | | 0 | IP1.0 | External<br>INT0 | UART1 | External<br>INT 0 | Configuring the IPO and IP1 registers makes it possible to change the priority order of the peripheral interrupts in order give higher priority to a given interrupt that belongs to a given group. TABLE 120: INTERRUPT GROUPS | TABLE 120: INTERRUPT GROUPS | | | | | | |-----------------------------|----------------------|-----------------|---------------------|--|--| | Bit | Interrupt Group | | | | | | IP1.5, IP0.5 | Timer 2 | Port1<br>Change | ADC | | | | IP1.4, IP0.4 | UART0 | - | MULT/ACCU | | | | IP1.3, IP0.3 | Timer 1 | - | I2C | | | | IP1.2, IP0.2 | External<br>INT1 | - | SPI RX<br>available | | | | IP1.1, IP0.1 | Timer 0<br>Interrupt | - | SPITX<br>Empty | | | | IP1.0, IP0.0 | External<br>INT0 | UART1 | External<br>INT 0 | | | The respective value of the IP1.x and IP0.x bit define the priority level of the interrupt group vs. the other interrupt groups as shown below: TABLE 121: INTERRUPT PRIORITY LEVEL | IP1.x | IP0.x | Priority Level | |-------|-------|----------------| | 0 | 0 | Level 0 (Low) | | 0 | 1 | Level 1 | | 1 | 0 | Level 2 | | 1 | 1 | Level 3 (High) | The WDTSTAT bit of the IPO register is the watchdog status flag, which is set to 1 by the hardware whenever a watchdog timer overflow occurs. This bit must be cleared manually. Finally, the bit 7 of the IPO register has no specific use but it is implemented and it can be used as a general purpose user flag. # Setting up INT0 and INT1 Interrupts The IT0 and IT1 bit of the TCON register defines if the external interrupt 0 and 1 will be edge or level triggered. When an interrupt condition occurs on INT0 or INT1, the associated interrupt flag IE0 or IE1 is set. The interrupt flag is automatically cleared when the interrupt is serviced. TABLE 122: (TCON) TIMER 0, TIMER 1 TIMER/COUNTER CONTROL - SFR 88H | 7 | 6 | 5 | 4 | |-----|-----|-----|-----| | TF1 | TR1 | TF0 | TR0 | | | | | | | 3 | 2 | 1 | 0 | | IE1 | IT1 | IE0 | IT0 | | D'' | | F 2 | |-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------| | Bit | Mnemonic | Function | | 7 | TF1 | Timer 1 overflow flag set by hardware when Timer 1 overflows. This flag can be cleared by software and is automatically cleared when interrupt is processed. | | 6 | TR1 | Timer 1 Run control bit. If cleared Timer 1 stops. | | 5 | TF0 | Timer 0 overflows flag set by hardware when Timer 0 overflows. This flag can be cleared by software and is automatically cleared when interrupt is processed. | | 4 | TR0 | Timer 0 Run control bit. If cleared timer 0 stops. | | 3 | IE1 | Interrupt 1 edge flag. Set by hardware when falling edge on external INT1 is observed. Cleared when interrupt is processed. | | 2 | IT1 | Interrupt 1 type control bit. Selects falling edge or low level on input pin to cause interrupt. | | 1 | IE0 | Interrupt 0 edge flag. Set by hardware when falling edge on external pin INT1 is observed. Cleared when interrupt is processed. | | 0 | IT0 | Interrupt 0 type control bit. Selects falling edge or low level on input pin to cause interrupt. | The ITO and IT1 bits of the TCON register define the type of condition on the INTO and INT1 pin (respectively) that will raise an interrupt. When the bit value = 0 and the interrupt is enabled, the Interrupt will be raised when a Logic Low level is present on the external interrupt pin. When the bit value = 1, it is a High to Low transition on the interrupt pin that will trigger an interrupt. #### INTO example Below is the Sample C code for the INTO interrupt setup and module configuration: ``` // Sample C code to setup INT0 #pragma TINY #include <vmixreg.h> at 0x0100 void main (void) { // INT0 Config TCON |= 0x01; //Interrupt on INT0 will be caused by a High->Low //edge on the pin // Enable INT0 interrupts IEN0 |= 0x80; IEN0 |= 0x01; // Enable all interrupts // Wait for INT0... while(1); //Wait for INT0 interrupts }//end of main function // Interrupt Function void int_ext_0 (void) interrupt 0 IEN0 &= 0x7F; // Disable all interrupts /* Put the Interrupt code here*/ // Enable all interrupts ``` #### **INT1** example The following code example shows the INT1 interrupt setup and module configuration: ``` // Sample C code to setup INT1 #pragma TINY #include <vmixreg.h> at 0x0100 void main (void) { // INT1 Config TCON |= 0x04; //Interrupt on INT1 will be caused by a High->Low //edge on the pin // Enable INT1 interrupts IEN0 |= 0x80; // Enable all interrupts IEN0 |= 0x04: // Enable interrupt INT1 // Wait for INT1... }while(1); //Wait for INT1 interrupts // Interrupt function void int_ext_1 (void) interrupt 2 IEN0 &= 0x7F; // Disable all interrupts /* Put the Interrupt code here*/ IEN0 |= 0x80; // Enable all interrupts ``` #### **UARTO** and **UART1** Interrupt Example The program examples below demonstrate the initialization of UART0 and UART1 interrupts. | // Sample C | code for UART0 and UAF | RT1 interrupt ex | ample | |----------------------------------------------------------------------|------------------------------------------------------------------|--------------------------------|--------------------------------------------------------| | #pragma TIN<br>#include <vm< td=""><td></td><td></td><td></td></vm<> | | | | | void txmit1( u | unsigned char charact);<br>unsigned char charact); | | | | // - Constants<br>sbit UART_T | s definition<br>X_EMPTY = USERFLAG | GS^1; | | | | MAIN FUNCTIO | N | | | | oid main (void) { | | | | | // Enable and configure uart0ws0relcfg(); uart1 Config(); | the UART0 & U<br>//Configure l | JART0 | | //*** Configu | re the interrupts<br>IEN0 = 0x91;<br>IEN2 = 0x01;<br>do | //Enable UAI<br>//Enable UAI | RT0 Int + enable all int<br>RT1 Interrupt | | | }while(1); // End of main() | //Wait for UA | RTs interrupts | | // | INTERRUPT ROUTIN | IES | | | // U ART0 inte | errupt<br>naracter received in SOBU | | ···· | | // back on UA | | | | | | 0 (void) interrupt 4 { | | | | | IEN0 &= 0x7F; | | //disable All interrupts | | // The only | UART0 interrupt source txmit0(S0BUF); | is Rx | // Return the character<br>//received on UART0 | | | SOCON = SOCON & 0xF<br>IENO = 0x80;<br>}// end of UART0 interru | | //clear R0I & T0I bits<br>// enable all interrupts | | // UART1 inte | errupt | | | | // back on UA | | | | | | 1 (void) interrupt 16 { | | | | | IEN0 &= 0x7F; | | //disable All interrupts | | // The only | UART1 interrupt source txmit1(S1BUF); | is Rx | // Return the character<br>// received on UART1 | | | S1CON = S1CON & 0xF<br>IEN0 = 0x80; | FC; | // clear both R11 & T11 bi<br>// enable all interrupts | | }// end of UA | RT1 interrupt | | | Note: See UART0 / UART1 section for configuration examples and TXMITx functions # **Interrupt on P1 change** The VERSA MIX includes an Interrupt on Port change feature, which is available on the Port1 pins of the VERSA MIX. This feature is like having eight extra external interrupt inputs sharing the ADC interrupt vector at address 006Bhc and can be very useful for applications that require feedback from the user: For example a numeric keypad interface or switch. To activate this interrupt, the bit of the PORTIRQEN register corresponding to the pins being monitored must be set to 1 and the ADCPCIE bit of the IEN1 register must be set as well as the EA bit of IEN0 register. TABLE 123: (PORTIRQEN) PORT CHANGE IRQ CONFIGURATION - SFR 9FH | 7 | 6 | 5 | 4 | |--------|--------|--------|-------| | P17IEN | P16IEN | P15IEN | P4IEN | | 3 | 2 | 1 | 0 | |--------|--------|--------|--------| | P13IEN | P12IEN | P11IEN | P10IEN | | Bit | Mnemonic | Function | |-----|----------|-------------------------------| | 7 | P17IEN | Port 1.7 IRQ on change enable | | | | 0 = Disable | | | | 1 = Enable | | 6 | P16IEN | Port 1.6 IRQ on change enable | | | | 0 = Disable | | | | 1 = Enable | | 5 | P15IEN | Port 1.5 IRQ on change enable | | | | 0 = Disable | | | | 1 = Enable | | 4 | P14IEN | Port 1.4 IRQ on change enable | | | | 0 = Disable | | | | 1 = Enable | | 3 | P13IEN | Port 1.3 IRQ on change enable | | | | 0 = Disable | | | | 1 = Enable | | 2 | P12IEN | Port 1.2 IRQ on change enable | | | | 0 = Disable | | | | 1 = Enable | | 1 | P11IEN | Port 1.1 IRQ on change enable | | | | 0 = Disable | | | | 1 = Enable | | 0 | P10IEN | Port 1.0 IRQ on change enable | | | | 0 = Disable | | | | 1 = Enable | The PORTIRQSTAT register monitors the occurrence of the Interrupt on port change. This register serves to define which P1 pin has changed when an interrupt occurs. TABLE 124: (PORTIRQSTAT) PORT CHANGE IRQ STATUS - SFR A1H | 7 | 6 | 5 | 4 | |----------|----------|----------|----------| | P17ISTAT | P16ISTAT | P15ISTAT | P14ISTAT | ONDUCTOR | 3 | 2 | 1 | 0 | |----------|----------|----------|----------| | P13ISTAT | P12ISTAT | P11ISTAT | P10ISTAT | | Bit | Mnemonic | Function | |-----|----------|---------------------------------------| | 7 | P17ISTAT | Port 1.7 changed<br>0 = No<br>1 = Yes | | 6 | P16ISTAT | Port 1.6 changed<br>0 = No<br>1 = Yes | | 5 | P15ISTAT | Port 1.5 changed<br>0 = No<br>1 = Yes | | 4 | P14ISTAT | Port 1.4 changed<br>0 = No<br>1 = Yes | | 3 | P13ISTAT | Port 1.3 changed<br>0 = No<br>1 = Yes | | 2 | P12ISTAT | Port 1.2 changed<br>0 = No<br>1 = Yes | | 1 | P11ISTAT | Port 1.1 changed<br>0 = No<br>1 = Yes | | 0 | P10ISTAT | Port 1.0 changed<br>0 = No<br>1 = Yes | FIGURE 44: APPLICATION EXAMPLE OF PORT CHANGE INTERRUPT Example ASM Program that shows the configuration Interrupt on Port1 pin change and sharing with the ADC interrupt. ``` include VMIXreg.INC ;*** INTERRUPT VECTORS JUMP TABLE * ORG 0000H ;BOOT ORIGIN VECTOR ORG 0000H LJMP START ORG 006BH ;INT ADC and P1 change interrupt LJMP INT_ADC_P1 *** MAIN PROGRAM ORG 0100h START: MOV DIGPWREN,#01H ;ENABLE TIMER 2 MOV P2PINCFG,#0FFH ;*** Initialise Port change interrupt on P1.0 - P1.7 PORTIRQSTAT,#00H PORTIRQEN,#11111111B MOV MOV ;*** Initialise the ADC, BGAP, PGA Operation ANALOGPWREN,#07h MOV ;Select CH0 as ADC input + Enable input buffer + Adc clk INMUXCTRL,#0Fh ADCCLKDIV,#0Fh MOV ADCCONVRLOW,#000h MOV ;*** configure ADC Conversion Rate ADCCONVR MED,#080h ADCCONVRHIGH,#016h MOV MOV MOV ADCCTRL,#11111010b ;***Activate All interrupts + (serial port for debugger support) MOV ÎEN0,#090H ;*** Enable ADC interrupt MOV IEN1,#020H ;***Wait IRQ... WAITIRQ: LJMP WAITIRQ ORG 0200h ******************************* ,* IRQ ROUTINE: IRQADC + P1Change INT_ADC_P1: IEN0.#00h :DISABLE ALL INTERRUPT ;***Check if IRQ was caused by Port Change ;***If PORTIRQSTAT = 00h -> IRQ comes from ADC MOV A,PORTIRQSTAT JZ CASE_ADC *** If interrupt was caused by Port 1, change CASE_POCHG: MOV PORTIRQSTAT,#00H ;*** Perform other instructions related to Port1 change IRQ ;(...) ;*** Jump to Interrupt end AJMP ENDADCP1INT *** If interrupt was caused by ADC CASE_ADC: ANL ADCCTRL #11110011b ;***Reset ADC interrupt flags & Reset ADC for next acquisition ADCCTRL,#080h ADCCTRL,#11111010b ORL ORL *** Perform other instructions related to Port1 change IRQ ;** End of ADC and Port 1 Change interrupt ENDADCPOINT: IRCON,#11011111b ;***Enable All interrupts before exiting ; MOV IEN0,#080H RETI END ``` # **The Clock Control Circuit** The VERSA MIX clock control circuit serves to dynamically adjust the clock speed from which the processor and the peripherals take their clock source. Having the ability of dynamically lower the VERSA MIX clock frequency permits to considerably reduce the overall device's power consumption by modulating the device operating frequency according to device's processing requirements or peripheral use. A typical application for this can be found on battery operated acquisition systems in which significant power saving can be achieved by lowering the operating frequency of the VERSA MIX between A/D conversions and automatically brings it back to full speed when a A/D converter interrupt is raised. The A/D converter operation is not affected by the Clock Control Unit. The clock control circuit allows adjusting the System clock from [Fosc/1] (full speed) down to [Fosc/512]. The clock division control is done from the CLKDIVCTRL register located at address 94h of the SFR register area. TABLE 125: (CLKDIVCTRL) CLOCK DIVISION CONTROL REGISTER -SFR 94H | 7 | 6 | 5 | 4 | |---------|---|---|------------| | SOFTRST | - | - | IRQNORMSPD | | | | I | | | 3 | 2 | 1 | 0 | |---|-------|---------|---| | | MCKDI | V [3:0] | | | Bit | Mnemonic | Function | |-----|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SOFTRST | Writing 1 into this bit location provokes a reset. Read as a 0 | | 6:5 | - | - | | 4 | IRQNORMSPD | 0 = Full Speed in IRQ<br>1 = Selected speed during<br>IRQs | | 3:0 | MCKDIV [3:0] | Master Clock Divisor<br>0000 - Sys CLK<br>0001 = SYS /2<br>0010 = SYS /4<br>0011 = SYS /8<br>0100 = SYS /16<br>0101 = SYS /32<br>0110 = SYS /64<br>0111 = SYS /128<br>1000 = SYS /256<br>1001 = SYS /512<br>() | The value written into the lower quartet of the CLKDIVCTRL register, named MCKDIV [3:0] defines the clock division ratio. The IRQNORMSPD bit (4) defines the VERSA MIX operating to full speed when an interrupt occurs. When the IRQNORMSPD bit equals 0, the VERSA MIX will run at the maximum operating speed when an interrupt occurs as shown in the figure below: Once the interrupt is cleared, the VERSA MIX returns to the selected operating speed as defined by the MCKDIV [3:0] bits of the CLKDIVCTRL register. When the IRQNORMSPD bit equals 1, the VERSA MIX will continue to operate at the selected speed as defined by the MCKDIV [3:0] bits of the CLKDIVCTRL register. Note At the exception of the A/D converter and analog only peripherals such as the current source, potentiometers, op-amp, all the peripherals operating speed is affected by the Clock Control circuit # **Software Reset** Software reset can be generated by setting to 1 the SOFTRST bit of the CLKDIVCTRL register. # Power-on / Brown-Out Reset The VERSA MIX includes a Power-On-Reset/Brown-Out detector circuit that ensures the VERSA MIX goes and stays in Reset mode as long as the supply voltage is below the reset threshold voltage that is in the order of 3.7 – 4.0V Volts. In most applications, the VERSA MIX requires no external components to perform a Power-on Reset when the device is powered on. The VERSA MIX has also a RESET pin for applications in which external Reset control is required. The reset pin includes an internal pull-up resistor. When a Power-On reset occurs: - All SFR locations return to their default values and peripherals are disabled - The internal 256 byte RAM cells are reset to 00h - The external 1K RAM memory block is not affected by reset #### Errata Note: The VERSA MIX may fail to exit the reset state if the supply voltage drops below the reset threshold, but not drops below 3V. For applications where this condition can occur, use an external supply monitoring circuit to reset the device. # **Processor Power Control** The processor power management unit has two modes of operation: IDLE mode and STOP mode. #### **IDLE Mode** When the VERSA MIX is in IDLE mode, the processor clock stops. However the internal clock and peripherals continue to run. The power consumption drops because the CPU is not active. As soon as an interrupt or reset occurs, the CPU exits the IDLE state. In order to enter IDLE mode, the user must set the IDLE bit of the PCON register. Any enabled interrupts can make the $\mu P$ exit IDLE mode #### STOP Mode In order to enter STOP mode, the user must set the STOP bit of the PCON register. In this mode, in contrast to IDLE mode, all internal clocking shuts down. The CPU will exit this state only when a no-clocked external interrupt or reset occurs (internal interrupts are not possible because they require clocking activity). The following interrupts can restart the processor from STOP mode: Reset, INT0, INT1, SPI Rx/Rx Overrun, and I2C interface. FIGURE 46: POWER MANAGEMENT ON THE VERSA MIX Represented below is the power control register of the VERSA MIX. TABLE 126: (PCON) POWER CONTROL (CPU) - SFR 87H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|---|---|-----|-----|------|------| | SMOD | - | - | - | GF1 | GF0 | STOP | IDLE | | Bit | Mnemonic | Function | |-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | SMOD | The speed in Mode 2 of Serial port 0 is controlled by this bit. When SMOD= 1, f <sub>clk</sub> /32. This bit is also significant in Mode 1 and 3, as it adds a factor of 2 to the baud rate. | | 6 | - | - | | 5 | - | - | | 4 | - | - | | 3 | GF1 | Not used for power management | | 2 | GF0 | Not used for power management | | 1 | STOP | Stop mode control bit. Setting this bit turns on the STOP Mode. STOP bit is always read as 0. | | 0 | IDLE | IDLE mode control bit. Setting this bit turns on the IDLE mode. IDLE bit is always read as 0. | # **Watch Dog Timer** The VERSA MIX's Watch Dog Timer is used to monitor the program operation and reset the processor in the case where the program would not be able to refresh the Watch Dog as a result of a condition that send the Program Counter in a infinite loop caused by a coding error, a strong EMI interference or any conditions that might affect the device's operation. The Watch Dog Timer consists of a 15-bit counter composed of two registers, WDTL and WDTH, and a reload register named WDTREL as shown below. FIGURE 47: WATCH DOG TIMER The WDTL and WDTH registers are not accessible from the SFR register. However the WDTREL register makes it possible to load the upper 6 bits of the WDTH register. The seventh bit of the WDTREL, PRES selects the Clock that is fed into the Watch Dog Timer. When PRES = 0, the clock prescaler = 24 When PRES = 1, the clock prescaler = 384 TABLE 127: (WDTREL) WATCHDOG TIMER RELOAD REGISTER - SFR D9H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |------|---|---|-----|---------|-----|---|---| | PRES | | | WD1 | TREL [6 | :0] | | | | Bit | Mnemonic | Function | |-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | PRES | Pre-scaler select bit. When set, the Watch Dog is clocked through an additional divide-by-16 pre-scaler. | | 6-0 | WDTREL | 7-bit reload value for the high-byte of the Watch Dog timer. This value is loaded into the WDT when a refresh is triggered by a consecutive setting of bits WDT and SWDT. | TABLE 128: (IP0) INTERRUPT PRIORITY REGISTER 0 - SFR B8H | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----|---------|---|---|-----|---------|---|---| | UF8 | WDTSTAT | | | IP( | 0 [5:0] | | | | Bit | Mnemonic | Function | | | | |-----|----------|----------------------------------------------------------------------------------------------------------------|-----------------|----------------------|--| | 7 | UF8 | User Flag bit | | | | | 6 | WDTSTAT | Watch Dog timer status flag. Set to 1 by hardware when the watch dog timer overflows. Must be cleared manually | | | | | 5 | IP0.5 | Timer 2 | Port1<br>Change | ADC | | | 4 | IP0.4 | UART0 | - | MULT/ACCU | | | 3 | IP0.3 | Timer 1 | - | I2C | | | 2 | IP0.2 | External<br>INT1 | - | SPI RX<br>availlable | | | 1 | IP0.1 | Timer 0<br>Interrupt | - | SPITX<br>Empty | | | 0 | IP0.0 | External<br>INT0 | UART1 | External<br>INT 0 | | The WDTSTAT bit of the IPO register is the watchdog status flag, which is set to 1 by the hardware whenever a watchdog timer overflow occurs. This bit must be cleared manually. ### Setting-up the Watch Dog Timer The control of the Watch Dog timer operation is performed by the following bit; | Bit | Location | Role | |--------|------------|------------------------------| | WDOGEN | DIGPWREN.6 | Watch Dog timer Enable | | WDTR | IEN0.6 | Watch Dog timer refresh flag | | WDTS | IEN1.6 | Watch Dog Timer Start bit | In order for the Watch Dog to begin counting, the user must set the WDOGEN bit (bit 6) of DIGPWREN. The following instruction does this: MOV DIGPWREN,#x1xxxxxxB ;x=0 or 1 depending ;of other peripherals ;to enable The value written into the WDTREL register defines the Delay Time of the Watch Dog Timer as shown below: WDT delay when the WDTREL bit 7 is cleared WDT Delay = $24*[32768-(WDTREL(6:0) \times 256)]$ Fosc WDT delay when the WDTREL bit 7 is set WDT Delay = $384 \times [32768 - (WDTREL(6:0) \times 256)]$ Fosc The following table shows some WDT reload value and corresponding Example times: | Fosc | WDTREL | WDT Delay | |----------|--------|-----------| | 14.74MHz | 00h | 53.3ms | | 14.74MHz | 4Fh | 20.4ms | | 14.74MHz | CCh | 347ms | Note: The value present in the CLKDIVCTRL Register does affect the Watch Dog Timer Delay time. The above equations and examples assume that the CLKDIVCTRL register content is 00h #### Starting the Watch Dog Timer To start the Watch Dog timer using the hardware automatic start procedure, the WDTS (IEN1) and WDTR (IEN0) bit must be set. The watchdog will begin to run with default setting i.e. all registers will be set to zero. ;\*\*\* Do a Watchdog Timer Refresh / Start sequence SETB IEN0.6 ;Set the WDTR bit first SETB IEN1.6 ;Then without delay set the ;WDTS bit When the WDT registers enter the state 7FFFh, the asynchronous signal, WDTS will become active. This signal will set bit 6 in the IP0 register and trigger a reset. To prevent the Watch Dog timer from resetting the VERSA MIX, you must reset it periodically by clearing the WDTR and, immediately after, clear the WDTS bit. As a security feature to prevent inadvertent clearing of the Watch Dog timer, no delay (instruction) is allowed between the clearing of the WDTR and the WDTS bit. #### a) Watchdog Timer refresh example 1: \*\*\* The Simple way \*\*\* In the case where the program makes use of the interrupts, it is recommended to deactivate the interrupt before the Watch Dog refresh is performed and reactivate them after. #### b) Watch Dog Timer refresh example 2: \*\*\* If Interrupts are used: \*\*\* CLR MOV ;Deactivate the interrupt ;Retrieve IEN0 content IEN0.7 A, IEN0 A,#01000000B A,R1 ;set the bit 6 (WDTR) :Store IENO New Value **XCH** A, IEN1 MOV ;Retrieve IEN1 content ORL A,#01000000B ;Set bit 6, (WDTS) MOV : Set WDTR BIT IEN0.R1 IEN1,A IEN0.7 :Reactivate the Interrupts #### **Watch Dog Timer Reset** To define if the Reset condition was caused by the Watch Dog Timer on the program, one can monitor the state of the WDTSTAT bit of the IPO register. On a standard power on reset condition, this bit is cleared. # WDT Initialization and Use Example **Program** ORG 0000H :RESET & WD IRQ VECTOR LJMP ;\* MAIN PROGRAM BEGINNING 0100h \*\* Initialize WDT and other peripherals\*\* DIGPWREN,#40H ;ENABLE WDT OPERATION :\*\*\* INITIALIZE WATCHDOG TIMER RELOAD VALUE MOV WDTREL,#04FH ;The WDTREL register is used to ;define the Delay Time WDT. ;Bit 7 of WDTREL define clock ;prescalng value ;Bit 6:0 of WDTREL defines the ;upper 7 bits reload value of the ;watchdog Timer 15-bit timer \*\*\* PERFORM A WDT REFRESH/START SEQUENCE SETR IFN0 6 SETB IEN1.6 ;Set the WDTR bit first :Then without delay (instruction) set the WDTS bit right after. ;No Delays are permitted between ;setting of the WDTR bit and ;setting of the WDTS bit. :This is a security feature to ;prevent inadvertent reset/start of :the WDT ;IF other interrupt are enabled, :It is recommended to disable interrupts before refreshing the ;WDT and reactivate them after ;\*\*\* Wait WDT Interrupt WAITWDT: NOP \*\*\* If the two following code lines below are put "in-comment", the ;\*\*\*WDT will trigger a reset, and the program will restart. ;\*\*\* PERFORM A WATCHDOG TIMER REFRESH/START SEQUENCE ;SETB ;SETB IEN0.6 IEN1.6 LJMP WAITWDT ;Set the WDTR bit first ;Then without delay (instruction) ;set the WDTS bit right after. ;No Delays are permitted between ;setting of the WDTR bit and setting of WDTS bit. :This is a security feature to ;prevent inadvertent reset/start of the WDT ;It is recommended to disable interrupts before refreshing the ;WDT and reactivate them after # **VERSA MIX Programming** When the PM pin is set to 1, the I2C interface becomes the programming interface for the VERSA MIX's Flash memory. In-circuit programming interface is easy to implement at the board level. See VMIX APP-Note001. Erasing and programming the VERSA MIX's Flash memory requires external an programming voltage of 12V. This programming voltage is supplied by the programming tools. The VERSA MIX can be programmed using the Semiconductor low cost Goal In-Circuit **Programmers** FIGURE 48: VERSA MIX PROGRAMMING In-Circuit VPP 12 Programmer RES - (RESET) # **VERSA MIX Debugger** The VERSA MIX includes hardware Debugging features that can help to speed-up the embedded software development. #### **Debugger Features** The VERSA MIX Debugger makes it possible to setup breakpoints in the user program and permits to run the user program in Step-by-Step mode. Another feature of the VERSA MIX Debugger is the possibility to retrieve and edit the content of the SFR Registers and the RAM memory contents when a breakpoint is reached or when the device operates in step-by-step mode. The VERSA MIX Debugger does not affect the program operating speed when the program is in "Run Mode", before a breakpoint is reached, contrary to ROM monitor program which execute user program instructions at a much lower speed. #### **Debugger Hardware Interface** The Interface to the VERSA MIX's Debugger is done through the UART0 serial interface. The VERSA MIX Development System provides the ideal interface to run the VERSA MIX Debugger. It is possible to run the VERSA MIX Debugger on the end user PCB provided an access to the VERSA MIX UARTO is given. However a connection to a stand Alone In-Circuit Programmer (ICP) will be required to perform Flash programming, the control of the Reset line and to activate the Debugger on target VERSA MIX device. # **Debugger Software Interface** The GoalTender VERSA MIX / VERSA1 Windows<sup>™</sup> software running on Windows<sup>™</sup> provides an easy to use user interface to perform In-Circuit Debugging For more details on the VERSA MIX Debugger use, please consult the document named: "GoalTender VERSA MIX - V1 Software User Guide.pdf" is available on the Goal Semiconductor Inc. website at www.goalsemi.com **VERSA MIX** # VERSA MIX 64 pin Quad Flat Package | | | BODY +3.20mm Footprint | |--------------------------------|---------|------------------------| | PACKAGE THICKNESS Dims. TOLS. | | 2.00 | | | | 64L | | Α | MAX. | 2.35 | | A1 | | 0.25MAX | | | | 2.00 | | D | ±.25 | 17.20 | | D1 | ±.10 | 14.00 | | E | ±.25 | 17.20 | | E1 | ±.10 | 14.00 | | L | +.15/10 | .88 | | е | BASIC | .80 | | b | ±.05 | .35 | | θ | | 0º-7º | #### NOTES: - 1) ALL DIMENSIONS ARE IN MILLIMETERS - 2) DIMENSIONS SHOWN ARE NOMINAL WITH TOLERANCES AS INDICATED. - 3) FOOT LENGTH "L" IS MEASURED AT GAGE PLANE, 0.25 ABOVE SEATING PLANE #### **Device Number Structure** **Ordering Information** # **VERSA MIX Ordering Options** | Device Number | Package Option | Operating Voltage | Temperature | Frequency | |---------------|----------------|-------------------|--------------|-----------| | VMX1020-QAI16 | QFP-64 | 4.5V to 5.5V | -40℃ to +85℃ | 16MHz | #### **Disclaimer** Right to make changes - Goal Semiconductor reserves the right to make changes to its products - including circuitry, software and services - without notice at any time. Customers should obtain the most current and relevant information before placing orders. Use in applications - Goal Semiconductor assumes no responsibility or liability for the use of any of its products, and conveys no license or title under any patent, copyright or mask work right to these products and makes no representations or warranties that these products are free from patent, copyright or mask work right infringement unless otherwise specified. Customers are responsible for product design and applications using Goal Semiconductor parts. Goal Semiconductor assumes no liability for applications assistance or customer product design. **Life support** – Goal Semiconductor products are not designed for use in life support systems or devices. Goal Semiconductor customers using or selling Goal products for use in such applications do so at their own risk and agree to fully indemnify Goal Semiconductor for any damages resulting from such applications. Note: PC is a registered trademark of IBM Corp. Windows is a registered trademark of Microsoft Corp. I2C is a registered trademark of Philips Corporation. SPI is a registered trademark of Motorola Inc. All other trademarks are the property of their respective owners.