

### • The MC9S12 A/D Converter

- o Introduction to A/D Converters
- Single Channel vs Multiple Channels
- Singe Conversion vs Multiple Conversions
- o MC9S12 A/C Registers
- Using the MC9S12 A/D Converter
- A C program to use the MC9S12 A/D Converter



# Analog to Digital Converters (A/D)

• An Analog-to-Digital (A/D) converter converts an analog voltage into a digital number

• There are a wide variety of methods used for A/D converters Examples are:

- Flash (Parallel)
- Successive Approximation
- Sigma-Delta
- Dual Slope Converter

• A/D converters are classified according to several characteristics

Resolution (number of bits) — typically 8 bits to 24 bits
Speed (number of samples per second) — several samples/sec to several billion samples/sec
Accuracy — how much error there is in the conversion.

• High-resolution converters are usually slower than low-resolution converters

• The MC9S12 has two 10-bit successive approximation A/D converters (which can be used in 8-bit mode)

• The MC9S12 uses an analog multiplexer to allow eight input pins to connect to any of the A/D converters.



## **A/D Sampling Rate**

• The rate at which you sample a signal depends on how rapidly the signal is changing

• If you sample a signal too slowly, the information about the signal may be inaccurate.



• A 1,050 Hz signal sampled at 500 Hz looks like a 50 Hz signal

• To get full information about a signal you must sample more than twice the highest frequency in the signal. (Nyquist theorem).

• Practical systems typically use a sampling rate of at <u>least four</u> <u>times the highest frequency in the signal.</u>



### Comparator

• A comparator is used in many types of A/D converters.

• A comparator is the simplest interface from an analog signal to a digital signal

• A comparator compares two voltage values on its two inputs

• If the voltage on the + input is greater than the voltage on the - input, the output will be a logic high

• If the voltage on the + input is less than the voltage on the - input, the output will be a logic low.



If Vin > Vref then Vout = Vcc If Vin < Vref then Vout = 0



## **Slope A/D Converter**

• A simple A/D converter can be constructed with a counter and a D/A converter

- The counter counts from **0 to 2<sup>b</sup>-1**
- The counter drives the input of the D/A converter
- The output of the D/A converter is compared to the input voltage

• When the output of the comparator switches logic level, the generated voltage passed the input voltage

• By latching the output of the counter at this time, the input voltage can be determined (with the accuracy of the quantization value of the converter)

• **Problem** with Slope A/D converter: <u>Could take 2<sup>b</sup> clock cycles to</u> <u>test possible values of reference voltages</u>





Time





### **Successive Approximation A/D Converter**

• A successive approximation (SA) A/D converter **uses an intelligent scheme** to determine the input voltage

- It first tries a voltage half way between  $V_{\text{RH}}$  and  $V_{\text{RL}}$ 

• It determines if the signal is in the **lower half** or the **upper half** of the voltage range

– If the input is in the upper half of the range, it sets the most significant bit of the output

– If the input is in the lower half of the range, it clears the most significant bit of the output

• The first clock cycle eliminates half of the possible values

• On the next clock cycle, the SA A/D tries a voltage in the middle of the remaining possible values

• The second clock cycle allows the SA A/D converter to determine the second most significant bit of the result

• <u>Each successive clock cycle reduces the range another factor of</u> <u>two</u>

• For a B-bit SA A/D converter, it takes B clock cycles to determine the value of the input voltage



#### SUCCESSIVE APPROXIMATION A/D CONVERTER

N Clock Cycles per Conversion





### **Successive Approximation A/D Converter**

• An SA A/D converter can give the wrong output if the voltage changes during a conversion

• An SA A/D converter **needs an input buffer** which holds the input voltage constant during the conversion

• This input buffer is called a **Track/Hold** or **Sample/Hold** circuit

• It usually works by charging a capacitor to the input voltage, then disconnecting the capacitor from the input voltage during conversion

- The voltage on the capacitor remains constant during conversion
- The HC12 has a Track/Hold amplifier built in
- SA A/D converters have resolutions of up to 16 bits

• SA A/D converters have speeds up to several million samples per second



#### SUCCESSIVE APPROXIMATION A/D CONVERTER



Time



## MC9S12 Analog/Digital Converter

• A 10-bit A/D converter is used to convert an input voltage. The reference voltages are  $V_{RL} = 0V$  and  $V_{RH} = 5V$ .

– What is the quantization level of the A/D converter?

 $\Delta V = (V_{RH} - V_{RL})/(2^{b} - 1) = 4.88 \text{ mV}$ 

• If the value read from the A/D converter is 0x15A, what is the input voltage?

Vin =  $V_{RL}$  + [( $V_{RH} - V_{RL}$ )/(2<sup>b</sup>-1)]\*ADvalue = 0 V + 4.88 mV × 346 = 1.6894 V

• The MC9S12 has two 10-bit A/D converters (ATD0 and ATD1).

-Each A/D converter has an 8-channel analog mulitplexer in front of it, so each channel can convert 8 analog inputs (but not at exactly the same time).

• ATD0 uses the eight bits of Port AD0, called PAD00 through PAD07

- PAD00 and PAD01 of ATD0 are used by DBug-12 at startup to determine whether to execute DBug-12, or to run code from EEPROM of the bootloader.

• ATD1 uses the eight bits of Port AD1, called PAD08 through PAD15



|                                                    | •                                                                                                                                                                                  |                                                                                                                                                              |          |                                        |                                                  |                                                                                                                                                                                                                                                          |                                                                                  |                              |                    |                                                                                                       |                                                               |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------|--------------------|-------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|
|                                                    | 256K Byte Flash EEPROM                                                                                                                                                             |                                                                                                                                                              |          | TD0                                    | VRH<br>VRL<br>VDDA                               |                                                                                                                                                                                                                                                          | AT                                                                               |                              | VRH<br>VRL<br>VDDA |                                                                                                       |                                                               |
|                                                    | 12K Byte RAM                                                                                                                                                                       |                                                                                                                                                              |          | ANO                                    |                                                  | -<br>I≼—PAD                                                                                                                                                                                                                                              |                                                                                  |                              |                    |                                                                                                       |                                                               |
|                                                    | 4K Byte                                                                                                                                                                            | EEPROM                                                                                                                                                       |          | AN1<br>AN2                             | -                                                | <—PAD<br><—PAD                                                                                                                                                                                                                                           | 01 A<br>02 A                                                                     | N1 -                         |                    | -PAD0                                                                                                 | 9                                                             |
| VDDR-+<br>VSSR-+<br>VREGEN-+<br>VDD1,2-<br>VSS1,2- | Voltage I                                                                                                                                                                          | Regulator                                                                                                                                                    |          | AN3<br>AN4<br>AN5<br>AN6<br>AN7        |                                                  | <pad<br><pad<br><pad<br><pad<br><pad< td=""><td>04 A<br/>05 A<br/>06 A</td><td>N3 -<br/>N4 -<br/>N5 -<br/>N6 -</td><td></td><td>← PAD1<br/>← PAD1<br/>← PAD1<br/>← PAD1<br/>← PAD1</td><td>2<br/>3<br/>4</td></pad<></pad<br></pad<br></pad<br></pad<br> | 04 A<br>05 A<br>06 A                                                             | N3 -<br>N4 -<br>N5 -<br>N6 - |                    | ← PAD1<br>← PAD1<br>← PAD1<br>← PAD1<br>← PAD1                                                        | 2<br>3<br>4                                                   |
| BKGD ↔                                             | Single-wire Background<br>Debug Module                                                                                                                                             | CPU12                                                                                                                                                        |          | Р                                      | PAGE                                             |                                                                                                                                                                                                                                                          | PIX0<br>PIX1<br>PIX2<br>PIX3                                                     | * * * *                      | PTK                | ↔ PK1<br>↔ PK2                                                                                        | XADDR14<br>XADDR15<br>XADDR16<br>XADDR17                      |
| VDDPLL                                             | Clock and<br>Reset<br>PLL Generation<br>Module                                                                                                                                     | Periodic Interrupt<br>COP Watchdog<br>Clock Monitor                                                                                                          |          |                                        |                                                  |                                                                                                                                                                                                                                                          | PIX4<br>PIX5<br>ECS                                                              | * * * *                      |                    | PK4                                                                                                   | XADDR18<br>XADDR19                                            |
| RESET<br>PE0                                       |                                                                                                                                                                                    | Breakpoints<br>Breakpoints<br>System<br>Integration<br>Module<br>(SIM)                                                                                       |          | Enha<br>Time                           | anced (<br>Pr                                    | Capture                                                                                                                                                                                                                                                  | 10C0<br>10C1<br>10C2<br>10C3<br>10C4<br>10C5<br>10C6<br>10C7                     |                              | DORT<br>PTT        | <ul> <li>PT0</li> <li>PT1</li> <li>PT2</li> <li>PT3</li> <li>PT4</li> <li>PT6</li> <li>PT7</li> </ul> |                                                               |
| PE7                                                |                                                                                                                                                                                    |                                                                                                                                                              |          | SCI0<br>SCI1                           |                                                  |                                                                                                                                                                                                                                                          | RXD<br>TXD<br>RXD                                                                | 4 4                          | 20                 | ↔ PS0<br>↔ PS1<br>↔ PS2                                                                               |                                                               |
|                                                    | * * * * * * * * *                                                                                                                                                                  | dress/Data Bus                                                                                                                                               | $\vdash$ | SPIO                                   | MISC<br>MOS<br>SCK<br>SS                         |                                                                                                                                                                                                                                                          |                                                                                  |                              | PTS                | ↔ PS3<br>↔ PS4<br>↔ PS5<br>↔ PS6<br>↔ PS7                                                             | )                                                             |
|                                                    | DMA16 ADDR15 PAT ++<br>DMA12 ADDR13 PA5 ++<br>DMA12 ADDR13 PA5 ++<br>DMA12 ADDR13 PA5 ++<br>DMA12 ADDR10 PA2 ++<br>DMA12 ADDR10 PA2 ++<br>DMA2 ADDR10 PA2 ++<br>DMA2 ADDR10 PA2 ++ | DATAR<br>DATAR<br>DATAR<br>DATAR<br>DATAR<br>DATAR<br>DATAR<br>DATAR<br>DATAR<br>ADDR3<br>PES<br>PES<br>PES<br>PES<br>PES<br>PES<br>PES<br>PES<br>PES<br>PES |          | BDLC<br>(J1850<br>CAN0<br>CAN1<br>CAN4 | RXE<br>RXCAN<br>TXCAN<br>RXCAN<br>TXCAN<br>RXCAN |                                                                                                                                                                                                                                                          | Module to Port Routing                                                           | * * * * * *                  | PTM                | PM0     PM1     PM2     PM3     PM4     PM5     PM6     PM6     PM7                                   | Signals shown in Boktlaren ot available on the 80 Fin Package |
| Multiplexed<br>Narrow Bus                          | DATA7<br>DATA6<br>DATA6<br>DATA6<br>DATA2<br>DATA2<br>DATA2<br>DATA2                                                                                                               |                                                                                                                                                              |          | lic                                    | SD/                                              |                                                                                                                                                                                                                                                          | KWJ0<br>KWJ1<br>KWJ6<br>KWJ7                                                     |                              | PTJ DOR            | ↔ PJ0<br>↔ PJ1<br>↔ PJ6<br>↔ PJ7                                                                      | Signals sho                                                   |
| VDD1,2<br>VSS1,2<br>PLL 2.5<br>VDDPLL<br>VSSPLL    | ✓ VI<br>✓ VS<br>✓ A/D Con<br>V Voltage I<br>✓ VC                                                                                                                                   | Driver 5V<br>DDX                                                                                                                                             | 1        | PWM                                    | PWM<br>PWM<br>PWM<br>PWM<br>PWM<br>PWM<br>PWM    |                                                                                                                                                                                                                                                          | KWP0<br>KWP1<br>KWP2<br>KWP3<br>KWP4<br>KWP5<br>KWP6<br>KWP7                     |                              | PTP                |                                                                                                       |                                                               |
|                                                    | VC                                                                                                                                                                                 | ÷<br>e Regulator 5V & I/O<br>DDR —►<br>SSR —⊥                                                                                                                | 1        | SPI1                                   | MISC<br>MOS<br>SCH<br>SS<br>MISC                 |                                                                                                                                                                                                                                                          | <ul> <li>KWH0</li> <li>KWH1</li> <li>KWH2</li> <li>KWH3</li> <li>KWH4</li> </ul> | * * * * *                    | PTH<br>PTH         | ↔ PH0<br>↔ PH1<br>↔ PH2<br>↔ PH3<br>↔ PH4                                                             |                                                               |
|                                                    |                                                                                                                                                                                    | =                                                                                                                                                            | 4        | SPI2                                   | MOS                                              | :                                                                                                                                                                                                                                                        | KWH5<br>KWH6<br>KWH7                                                             | **                           |                    | PH5     PH6     PH7                                                                                   |                                                               |

#### Figure 1-1 MC9S12DT256 Block Diagram



## The MC9S12 Analog/Digital Converter

• We will discuss only ATD0. ATD1 is identical.

• ATD0 is an eight-channel 10-bit A/D converter.

– The A/D converter can also be used in 8-bit mode.

• There are eight inputs to the A/D converter.

• The inputs are fed through a multiplexer to the single A/D converter.

 $\bullet$  There are inputs on the HCS12 for the reference voltages  $V_{\text{RL}}$  and  $V_{\text{RH}}$ 

– In normal operation  $V_{RL} = 0$  V and  $V_{RH} = 5$  V.

- You must have  $V_{SS} \leq V_{RL} < V_{RH} \leq V_{DD}$ .

– The accuracy of the A/D converter is guaranteed only for  $V_{RH}$  –  $V_{RL}$  =5 V.

• When using the A/D converter, you can choose between performing single or continuous conversion on a single channel, or multiple channels.

• The AD conversion results are stored in the registers ATD0DR0 through ATD0DR7

– You can choose whether to have the results left-justified or right justified.



• To program the HCS12 A/D converter you need to set up the A/D control registers **ATD0CTL2**, **ATD0CTL3**, **ATD0CTL4** and **ATD0CTL5**.

• The registers ATD0CTL0 and ATD0CTL1 are used for factory test, and not used in normal operation.

• When the AD converter is not used, Port AD0 can be used for a general purpose input (not as a GPIO – General Purpose I/O like the other ports).

- Register ATD0DIEN is used to set up Port AD0 pins for use as a general purpose inputs.

- The values on the pins are read from PORTAD0.



## MC9S12 A/D Converter Setup

MULT = 0



MULT = 1



Several Channels. Starting channel determined by CC CB CA

1 to 8 conversions, number determined by S1C, S2C, S4C, S8C



| ATD0CTL2  | ADPU  | AFFC | ASWAI | ETRIGLE | ETRIGLP | 0    | ASCIE | ASCIF | 0x0082 |
|-----------|-------|------|-------|---------|---------|------|-------|-------|--------|
| ATD0CTL3  | 0     | SaC  | S4C   | S2C     | S1C     | FIFO | FRZ1  | FRZ0  | 0x0083 |
| ATD0CTL4  | SRES8 | SMP1 | SMP0  | PRS4    | PRS3    | PRS2 | PRS1  | PRS0  | 0x0084 |
| ATD0CTL5  | DJM   | DSGN | SCAN  | MULT    | 0       | CC   | СВ    | CA    | 0x0085 |
| ATDOSTATO | SCF   | 0    | ETORF | FIFOR   | 0       | CC2  | CC1   | CC0   | 0x0086 |
| ATD0STAT1 | CCF7  | CCF6 | CCF5  | CCF4    | OCF3    | CCF2 | CCF1  | CCF0  | 0x008B |

### To Use A/D Converter:

ADPU = 1 (Power up A/D)

SCAN = 0 => Single conversion sequence SCAN = 1 => Convert continuously

S8C, S4C, S2C, S1C: Number of conversions per sequence: 0001 -- 0111 (1 to 7) 0000 or 1xxx (8) SRES8 = 0 = > 10 Bit Mode

SRES8 =  $1 \Rightarrow 8$  Bit Mode

 $DJM = 0 \Rightarrow$  Left justified data in the result registers  $DJM = 1 \Rightarrow$  Right justified data in the result registers

DSGN = 0 => Unsigned data in the result registers



DSGN = 1 => Signed data representation in the result registers (only for left justified)

ATDCTL4=  $0x85 \Rightarrow 2$  MHz AD clock, 12 cycles per conversion, 8 bit mode ATDCTL4=  $0x05 \Rightarrow 2$  MHz AD clock, 14 cycles per conversion, 10 bit mode

-<u>Other values of ATDCTL4 will not work, or will result in</u> <u>slower operation of A/D</u>

SCF Flag is set after a sequence of conversions is complete -The SCF Flag is cleared when ATD0CTL5 is written, or by writing a 1 to the SCF bit

After writing to ATD0CTL5, SCF flag cleared and conversions start



## Using the HCS12 A/D converter

1. Power up A/D Converter (ADPU = 1 in ATD0CTL2)

2. Select number of conversions per sequence (S8C S4C S2C S1C in ATD0CTL3)

S8C S4C S2C S1C = 0001 to 0111 for 1 to 7 conversions S8C S4C S2C S1C = 0000 or 1xxx for 8 conversions

- 3. Set up ATD0CTL4
  - For 8-bit mode write 0x85 to ATD0CTL4
  - For 10-bit mode write 0x05 to ATD0CTL4

• Other values of ATD0CTL4 either will not work or will result in slower A/D conversion rates

4. Select DJM in ATD0CTL5

(a) DJM = 0 => Left justified data in the result registers
(b) DJM = 1 => Right justified data in the result registers

- 5. Select DSGN in ATD0CTL5
  - (a) DSGN = 0 => Unsigned data representation in the result register
  - (b) DSGN = 1 => Signed data representation in the result register

The Available Result Data Formats are shown in the following table:



| SRES8 | DJM | DSGN | RESULT DATA FORMAT                         |
|-------|-----|------|--------------------------------------------|
| 1     | 0   | 0    | 8-bit/left justified/unsigned – Bits 15-8  |
| 1     | 0   | 1    | 8-bit/left justified/signed – Bits 15-8    |
| 1     | 1   | Х    | 8-bit/right justified/unsigned – Bits 7-0  |
| 0     | 0   | 0    | 10-bit/left justified/unsigned – Bits 15-6 |
| 0     | 0   | 1    | 10-bit/left justified/signed – Bits 15-6   |
| 0     | 1   | Х    | 10-bit/right justified/unsigned – Bits 9-0 |

- 6. Select MULT in ATD0CTL5:
  - MULT = 0: Convert one channel the specified number of times

– Choose channel to convert with CC, CB, CA of ATD0CTL5.

- MULT = 1: Convert across several channels. CC, CB, CA of ATD0CTL is the first channel to be converted.
- 7. Select SCAN in ATD0CTL5:
  - SCAN = 0: Convert one sequence, then stop
  - SCAN = 1: Convert continuously

8. After writing to ATD0CTL5, the A/D converter starts, and the SCF bit is cleared. After a sequence of conversions is completed, the SCF flag in ATD0STAT0 is set.

• You can read the results in ATD0DRx.



9. If SCAN = 0, you need to write to ATD0CTL5 to start a new sequence. If SCAN = 1, the conversions continue automatically, and you can read new values in ATD0DRx.

10. To get an interrupt after the sequence of conversions are completed, set ASCIE bit of ATD0CTL2. After the sequence of conversions, the ASCIF bit in ATD0CTL2 will be set, and an interrupt will be generated.

11. With 24 MHz bus clock and ATD0CTL4 = 0x05, it takes 7 µs to make one conversion, 56 µs to make eight conversions.

12. On MC9S12 EVBU, AD0 channels 0 and 1 are used to determine start-up program (D-Bug12, EEPROM or bootloader). Do not use AD0 channels 0 or 1, unless absolutely necessary (if you need more than 14 A/D channels).

13.

$$ATD0DRx = (V_{in} - V_{RL})/(V_{RH} - V_{RL}) \times 1024$$

Normally,  $V_{RL} = 0$  V, and  $V_{RH} = 5$  V, so

ATD0DRx = $V_{in}/5 V \times 1024$ 

Example: ATD0DR0 =  $448 => V_{in} = 2.19 V$ 

14. To use 10-bit result, set ATD0CTL4 = 0x05 (Gives 2 MHz AD clock with 24 MHz bus clock, 10-bit mode).



15. You can get more accuracy by averaging multiple conversions. If you need only one channel, set MULT = 0, set S8C, S4C, S2C, S1C, bits for eight conversions, then average all eight result registers. The following assumes the data was right justified:

### int avg;

avg = (ATD0DR0 + ATD0DR1 ATD0DR2 + ATD0DR3 ATD0DR4 + ATD0DR5 ATD0DR6 + ATD0DR7) >> 3;



/\* Read temperature from PAD4. Turn on heater if temp too low, turn off heater if temp too high. Heater connected to Bit 0 of Port A. \*/

```
#include "hcs12.h"
#define TRUE 1
#define SET_POINT 72 /* Temp at which to turn heater */
                   /* on or off */
main() {
    ATD0CTL2 = 0x80; /* Power up A/D, no interrupts */
    ATD0CTL3 = 0x00; /* Do eight conversions */
    ATD0CTL4 = 0x85; /* 8-bit mode */
    ATD0CTL5 = 0xA4; /* 1 0 1 0 0 1 0 0
                                \ Bit 4 of Port AD
                            MULT = 0 \Rightarrow one channel only
                             ___ Scan = 1 => continuous conversion
                               DSGN = 0 \Rightarrow unsigned
                               DJM = 1 => right justified
                      */
     DDRA = 0xff; /* Make Port A output */
    PORTA = 0x00; /* Turn off heater */
     while (TRUE) {
         if (ATD0DR0 > SET_POINT)
               PORTA &= \simBIT0;
         else
              PORTA |= BIT0;
     }
}
```



/\* Convert signals on Channels AD08 through AD15. Set up for 10-bit, multi-channel do one set of scans, save values in variables \*/

while ((ATD1STAT0 & BIT7) == 0 ) ; // Wait for sequence to finish

ch[0] = ATD1DR0; ch[1] = ATD1DR1; ch[2] = ATD1DR2; ch[3] = ATD1DR3; ch[4] = ATD1DR3; ch[5] = ATD1DR4; ch[5] = ATD1DR5; ch[6] = ATD1DR6; ch[7] = ATD1DR7;

}