## Freescale Semiconductor

# ADC example in Kinetis Design Studio (KDS) with FDRM-K64f

By:

Paul Garate
Augusto Panecatl

### **Description**

In this document you will find a detailed step by step guide of how to configure the ADC on Kinetis K devices using Kinetis Design Studio, you will be reading a value from the microcontroller's internal temperature sensor.

## 1. Clock Gating

As in the previous examples, the first step is to enable the clock gate corresponding to the module we will use, in this case ADC0

## 12.2.13 System Clock Gating Control Register 6 (SIM\_SCGC6)

DAC0, FTM2, and RNGA can be accessed through both AIPS0 and AIPS1. When accessing through AIPS1, define the clock gate control bits in the SCGC2 and SCGC3. When accessing through AIPS0, define the clock gate control bits in SCGC6.

Address: 4004\_7000h base + 103Ch offset = 4004\_803Ch



**SIM\_SCGC6\_PORTn\_MASK** is defined as mask to enable the module's clock, where "n" corresponds to the specific port we wish to activate, i.e:

#### SIM\_SCGC6 = SIM\_SCGC5\_ADC0\_MASK;

By declaring the mask we are writing 0x8000000 to the SIM\_SCGC6 register, setting up the 27<sup>th</sup> bit of the System Clock Gating Control Register 6 which enables ADC0;

SIM\_SCGC6 |= SIM\_SCGC6 ADC0 MASK;

/\*Enable the ADC0 Clock\*/

## 2. ADC Configuration

The K64F's ADC contains a lot of registers; you can see the section 35.3 in the Reference Manual (page 829). In this particular case we will just use 2 registers which are **ADCx\_CFG1** and **ADC0\_SC1A**.

The first one (**ADCx\_CGF1**) selects the operation mode, clock source, clock divide, and configuration for low power and long sample time.



We will first configure the conversion mode resolution.

|             | and the second s |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 3–2<br>MODE | Conversion mode selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
|             | Selects the ADC resolution mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|             | 00 When DIFF=0:It is single-ended 8-bit conversion; when DIFF=1, it is differential 9-bit conversion with 2's complement output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
|             | 01 When DIFF=0:It is single-ended 12-bit conversion; when DIFF=1, it is differential 13-bit conversion with 2's complement output.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|             | When DIFF=0:It is single-ended 10-bit conversion.; when DIFF=1, it is differential 11-bit conversion with 2's complement output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|             | When DIFF=0:It is single-ended 16-bit conversion; when DIFF=1, it is differential 16-bit conversion with 2's complement output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |

The MODE register allows you to select the ADC's resolution, in this example we will select a 16 bits resolution, thus; we need to write 11 to the MODE field.

The second one (ADCx\_SC1n) is used to select the ADC channel input, select the single ended or differential mode, enable or disable the interrupt after conversion completion and it also contains the conversion complete flag (COCO).



The ADCH field has 5 bits to fill, and a lot of options, but we will only use it just to disable the module.

Field Description 01100 When DIFF=0, AD12 is selected as input; when DIFF=1, it is reserved. 01101 When DIFF=0, AD13 is selected as input; when DIFF=1, it is reserved. 01110 When DIFF=0, AD14 is selected as input; when DIFF=1, it is reserved. 01111 When DIFF=0, AD15 is selected as input; when DIFF=1, it is reserved. 10000 When DIFF=0, AD16 is selected as input; when DIFF=1, it is reserved. 10001 When DIFF=0, AD17 is selected as input; when DIFF=1, it is reserved. 10010 When DIFF=0, AD18 is selected as input; when DIFF=1, it is reserved. 10011 When DIFF=0, AD19 is selected as input; when DIFF=1, it is reserved. 10100 When DIFF=0, AD20 is selected as input; when DIFF=1, it is reserved. 10101 When DIFF=0, AD21 is selected as input; when DIFF=1, it is reserved. 10110 When DIFF=0, AD22 is selected as input; when DIFF=1, it is reserved. 10111 When DIFF=0, AD23 is selected as input; when DIFF=1, it is reserved. 11000 Reserved. 11001 Reserved. 11010 When DIFF=0, Temp Sensor (single-ended) is selected as input; when DIFF=1, Temp Sensor (differential) is selected as input. 11011 When DIFF=0,Bandgap (single-ended) is selected as input; when DIFF=1, Bandgap (differential) is selected as input. 11100 Reserved. 11101 When DIFF=0,V<sub>REFSH</sub> is selected as input; when DIFF=1, -V<sub>REFSH</sub> (differential) is selected as input. Voltage reference selected is determined by SC2[REFSEL]. 11110 When DIFF=0,V<sub>REFSL</sub> is selected as input; when DIFF=1, it is reserved. Voltage reference selected is determined by SC2[REFSEL]. 11111 Module is disabled.

Taking into consideration the table values we need to write **0x1F** to the **ADCH** field n order to disable the module.

Here are the two lines used to configure the ADC0 CFG1 and ADC0 SC1A registers:

```
ADC0_CFG1 |= ADC_CFG1_MODE(3); /*16bits ADC*/
ADC0_SC1A |= ADC_SC1_ADCH(31); /*Disable the module, ADCH = 1111 */

*ADC_CFG1_MODE(3) = 0xC
*ADC_SC1_ADCH(31) = 0x1F
```

#### 3. Measurement function

Once the module is configured we need create a function to perform the ADC readings. The function used in the code example is shown below:

KDS ADC Baremetal code

Freescale Semiconductor

The first line assigns selects the ADC channel assigned to the internal temperature sensor (channel 26) by writing **0x1A** to the **ADCH** field.

| Field |       | Description                                                                                                                                                                         | 1 |
|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
|       | 01100 | When DIFF=0, AD12 is selected as input; when DIFF=1, it is reserved.                                                                                                                | 1 |
|       | 01101 | When DIFF=0, AD13 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 01110 | When DIFF=0, AD14 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 01111 | When DIFF=0, AD15 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 10000 | When DIFF=0, AD16 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 10001 | When DIFF=0, AD17 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 10010 | When DIFF=0, AD18 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 10011 | When DIFF=0, AD19 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 10100 | When DIFF=0, AD20 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 10101 | When DIFF=0, AD21 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 10110 | When DIFF=0, AD22 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 10111 | When DIFF=0, AD23 is selected as input; when DIFF=1, it is reserved.                                                                                                                |   |
|       | 11000 | Reserved.                                                                                                                                                                           |   |
|       | 11001 | Reserved.                                                                                                                                                                           |   |
|       | 11010 | When DIFF=0, Temp Sensor (single-ended) is selected as input; when DIFF=1, Temp Sensor (differential) is selected as input.                                                         |   |
|       | 11011 | When DIFF=0,Bandgap (single-ended) is selected as input; when DIFF=1, Bandgap (differential) is selected as input.                                                                  |   |
|       | 11100 | Reserved.                                                                                                                                                                           |   |
|       | 11101 | When DIFF=0,V <sub>REFSH</sub> is selected as input; when DIFF=1, -V <sub>REFSH</sub> (differential) is selected as input. Voltage reference selected is determined by SC2[REFSEL]. |   |
|       | 11110 | When DIFF=0,V <sub>REFSL</sub> is selected as input; when DIFF=1, it is reserved. Voltage reference selected is determined by SC2[REFSEL].                                          |   |
|       | 11111 | Module is disabled.                                                                                                                                                                 |   |

The second line is used to check if the conversion is still in progress. The code will remain in the wait cycle until the **ADACT** flag is erased.



ADCx\_SC2 field descriptions

| Field            | Description                                                                                                                                                          |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0.                                                                                 |
| 7<br>ADACT       | Conversion Active                                                                                                                                                    |
|                  | Indicates that a conversion or hardware averaging is in progress. ADACT is set when a conversion is initiated and cleared when a conversion is completed or aborted. |
|                  | Conversion not in progress.     Conversion in progress.                                                                                                              |

The third line checks if the conversion has been completed by checking the status of the conversion complete flag **COCO**.



ADCx\_SC1n field descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–8<br>Reserved | This field is reserved. This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7                | Conversion Complete Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                  | This is a read-only field that is set each time a conversion is completed when the compare function is disabled, or SC2[ACFE]=0 and the hardware average function is disabled, or SC3[AVGE]=0. When the compare function is enabled, or SC2[ACFE]=1, COCO is set upon completion of a conversion only if the compare result is true. When the hardware average function is enabled, or SC3[AVGE]=1, COCO is set upon completion of the selected number of conversions (determined by AVGS). COCO in SC1A is also set at the completion of a calibration sequence. COCO is cleared when the respective SC1n register is written or when the respective Rn register is read.  O Conversion is not completed. |

The last line reads the result register and returns the conversion data corresponding to the ADC measurement of the selected channel.





## ADCx\_Rn field descriptions

| Field     | Description                                                                          |
|-----------|--------------------------------------------------------------------------------------|
|           | This field is reserved. This read-only field is reserved and always has the value 0. |
| 15–0<br>D | Data result                                                                          |

#### 4. Code

The main code implements a call to the ADC function, the bADCData variable stores the Data Result, and the Delay function controls the time between measurements.

```
for (;;)
{
    bADCData = ADC_read16b();
    DelayFunction();
}

void DelayFunction (void)
{
    unsigned long Counter = 0xFFFFF;
    do
    {
        Counter--;
    }while(Counter);
}
```

\*The code also includes some UART configurations, to understand the UART module refer to the "Serial (UART) example in Kinetis Development Software (KDS) with FDRM-K64f" Document.