

# EEL 4742 – Embedded Systems

## Module 8 – ADC

Hadi M Kamali

Department of Electrical and Computer Engineering (ECE)  
University of Central Florida

*Office Location/phone: HEC435 – (407) 823-0764  
webpage: <https://www.ece.ucf.edu/~kamali/>  
e-mail: [kamali@ucf.edu](mailto:kamali@ucf.edu)*

*HAVEN Research Group  
<https://haven.ece.ucf.edu/>*



# Why ADC

- Analog-to-Digital-Converter (ADC)
  - For encoding analog signals into digital signals

*analog:* continuously valued signal, such as temperature, speed, or voltage with infinite possible values in between

*digital:* discretely valued signal, such as integers encoded in binary



# Terminology of ADC

- Analog-to-Digital-Converter (ADC)
  - For encoding analog signals into digital signals

**analog:** continuously valued signal, such as temperature, speed, or voltage with infinite possible values in between

**digital:** discretely valued signal, such as integers encoded in binary

**Step size or resolution:** smallest analog change resulting in one increment/decrement

**Sampling time:** minimum time required per each digital value representation



# Step Size (Resolution)

- Analog-to-Digital-Converter (ADC)
  - For encoding analog signals into digital signals

*Number of steps =  $2^n$*

*Resolution = Range / (Number of steps )*

*Step size or resolution: smallest  
analog change resulting in one  
increment/decrement*

*Sampling time: minimum time  
required per each digital value  
representation*



# Step Size (Resolution)

- Analog-to-Digital-Converter (ADC)
  - For encoding analog signals into digital signals

*Number of steps =  $2^n$*

*Resolution = Range / (Number of steps )*



| Number of bits (n) | Number of steps | Step size (resolution)           |
|--------------------|-----------------|----------------------------------|
| 4                  | 16              | $(5-0)/16 = 312.5 \text{ mV}$    |
| 8                  | 256             | $(5-0)/256 = 19.53 \text{ mV}$   |
| 10                 | 1,024           | $(5-0)/1,024 = 4.88 \text{ mV}$  |
| 12                 | 4,096           | $(5-0)/4,096 = 1.2 \text{ mV}$   |
| 16                 | 65,536          | $(5-0)/65536 = 0.076 \text{ mV}$ |

# Step Size (Resolution)

- Analog-to-Digital-Converter (ADC)
  - For encoding analog signals into digital signals

*Number of steps =  $2^n$*

*Resolution = Range / (Number of steps )*



|     |          |         |          |        |          |         |          |       |          |         |          |        |          |         |          |
|-----|----------|---------|----------|--------|----------|---------|----------|-------|----------|---------|----------|--------|----------|---------|----------|
| 0 V | 0.3125 V | 0.625 V | 0.9375 V | 1.25 V | 1.5625 V | 1.875 V | 2.1875 V | 2.5 V | 2.8125 V | 3.125 V | 3.4375 V | 3.75 V | 4.0625 V | 4.375 V | 4.6875 V |
| 0h0 | 0h1      | 0h2     | 0h3      | 0h4    | 0h5      | 0h6     | 0h7      | 0h8   | 0h9      | 0hA     | 0hB      | 0hC    | 0hD      | 0hE     | 0hF      |

$$(5-0)/32 = 156.25 \text{ mV}$$

|     |           |          |           |         |           |          |           |     |        |           |          |           |         |           |          |           |
|-----|-----------|----------|-----------|---------|-----------|----------|-----------|-----|--------|-----------|----------|-----------|---------|-----------|----------|-----------|
| 0 V | 0.15625 V | 0.3125 V | 0.46875 V | 0.625 V | 0.78125 V | 0.9375 V | 1.09375 V | ... | 3.75 V | 3.90625 V | 4.0625 V | 4.21875 V | 4.375 V | 4.53125 V | 4.6875 V | 4.84375 V |
| 0h0 | 0h1       | 0h2      | 0h3       | 0h4     | 0h5       | 0h6      | 0h7       | ... | 0h18   | 0h19      | 0h1A     | 0h1B      | 0h1C    | 0h1D      | 0h1E     | 0h1F      |

# Step-by-step ADC Conceptual Flow

- Analog-to-Digital-Converter (ADC)
  - For encoding analog signals into digital signals



# Sampling Ratio

- Analog-to-Digital-Converter (ADC)
  - For encoding analog signals into digital signals



# Example of ADC Flow

- Analog-to-Digital-Converter (ADC)
  - For encoding analog signals into digital signals

*analog:* continuously valued signal, such as temperature, speed, or voltage with infinite possible values in between

*digital:* discretely valued signal, such as integers encoded in binary



# ADC Conversion Logic

- Moving bit by bit to reach to the closest value
  - Similar to Binary search
- Let's take an example of  $V_{in} = 2V$  and  $V_{ref} = 5V$  for a 5-bit ADC.

- Now, we set  $b_4$
- With  $b_4 = 1$ 
  - $V_{in} < \text{threshold}$
  - We need to clear  $b_4$



# ADC Conversion Logic

- Moving bit by bit to reach to the closest value
  - Similar to Binary search
- Let's take an example of  $V_{in} = 2V$  and  $V_{ref} = 5V$  for a 5-bit ADC.

- We clear b4
- Now, we set b3
- With  $b3=1$ 
  - $V_{in} >$  Threshold
  - We keep  $b3=1$



# ADC Conversion Logic

- Moving bit by bit to reach to the closest value
- Similar to Binary search
- Let's take an example of  $V_{in} = 2V$  and  $V_{ref} = 5V$  for a 5-bit ADC.

- With  $b_4, b_3 = 01$
- Now, we set  $b_2$
- With  $b_2=1$ 
  - $V_{in} >$  Threshold
  - We keep  $b_2=1$



# ADC Conversion Logic

- Moving bit by bit to reach to the closest value
  - Similar to Binary search
- Let's take an example of  $V_{in} = 2V$  and  $V_{ref} = 5V$  for a 5-bit ADC.
  - With  $b_4, b_3, b_2 = 011$
  - Now, we set  $b_1$
  - With  $b_1=1$ 
    - $V_{in} < \text{Threshold}$
    - We need to clear  $b_1$



# ADC Conversion Logic

- Moving bit by bit to reach to the closest value
  - Similar to Binary search
- Let's take an example of  $V_{in} = 2V$  and  $V_{ref} = 5V$  for a 5-bit ADC.
  - With  $b_4, b_3, b_2, b_1 = 0110$
  - Now, we set  $b_0$
  - With  $b_0=1$ 
    - $V_{in} < \text{Threshold}$
    - We need to clear  $b_0$



# ADC Conversion Logic

- Moving bit by bit to reach to the closest value
  - Similar to Binary search
- Let's take an example of  $V_{in} = 2V$  and  $V_{ref} = 5V$  for a 5-bit ADC.
  - With  $b_4, b_3, b_2, b_1 = 0110$
  - Now, we set  $b_0$
  - With  $b_0=1$ 
    - $V_{in} < \text{Threshold}$
    - We need to clear  $b_0$



# ADC Conversion Logic

- Moving bit by bit to reach to the closest value
  - Similar to Binary search



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - The analog voltage is sampled and stored for conversion.
  - $V_{in}$  is the input voltage to the ADC module.



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - The analog voltage is sampled and stored for conversion.
  - $V_{in}$  is the input voltage to the ADC module.
- Let's take an example of  $V_{in} = 2V$  and  $V_{ref} = 5V$  for a 5-bit ADC.



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - The analog voltage is sampled and stored for conversion.
  - $V_{in}$  is the input voltage to the ADC module.

The SAR is initialized to the first estimate  $10000b$  ( $b4 = 1$ )

The corresponding voltage  $V_{th}$  is output by the DAC.



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - The analog voltage is sampled and stored for conversion.
  - $V_{in}$  is the input voltage to the ADC module.

The comparator provides a high output if the  $V_{in}$  is greater than  $V_{out}$ , else it provides a low output.



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - The analog voltage is sampled and stored for conversion.
  - $V_{in}$  is the input voltage to the ADC module.

The SAR is updated based on the comparator output and the voltage  $V_{th}$  is updated.



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique

- The analog voltage is sampled and stored for conversion.
- $V_{in}$  is the input voltage to the ADC module.

The SAR block performs the ADC conversion logic **n-times for n-bits**. Then, the n-bit digital value corresponding to the input voltage  $V_{in}$  is output by the ADC.



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique

- The analog voltage is sampled and stored for conversion.

- DAC for converting digital to  $V_{ref}$  is required

*DAC using R series network*



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - This is a charge-redistribution SAR



The conversion takes place in three stages

1. **Sample mode**
2. **Hold mode**
3. **Redistribution mode**

*Op-amp configured  
as comparator*

# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - This is a charge-redistribution SAR



1. **Sample mode**
2. **Hold mode**
3. **Redistribution mode**

The total charge would be  $V_{IN} \cdot 2C$

# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - This is a charge-redistribution SAR



The conversion takes place in three stages

1. **Sample mode**
2. **Hold mode**
3. **Redistribution mode**

Switches are all connected to GND.

Holding  $V_{IN}$  (at the inverting comparator input)  
 $VC = 0 - V_{IN} = -V_{IN}$

# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - This is a charge-redistribution SAR



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - This is a charge-redistribution SAR



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - This is a charge-redistribution SAR



# Signal Conversion in ADC

- Using Successive approximation register (SAR) technique
  - This is a charge-redistribution SAR



*Procedure*

$SB = V_{ref};$   
 $SA = open;$   
 For capacitor in  $\{S_4, S_3, S_2, S_1, S_0\}$   
 Connect capacitor to  $V_{ref}$ .  
 If Comparator output is high  
     Connect capacitor to gnd.  
 Else  
     Connect capacitor to  $V_{ref}$ .

The conversion takes place in three stages

1. **Sample mode**
2. **Hold mode**
3. **Redistribution mode**

| Comparator output           | Capacitor status               |
|-----------------------------|--------------------------------|
| High ( $V_{IN} < V_{ref}$ ) | Retain (connect to $V_{ref}$ ) |
| Low ( $V_{IN} > V_{ref}$ )  | Discharge (connect to ground)  |

# Signal Conversion in ADC - Example

- With the same 5-bit SAR-ADC
- Assuming that  $V_{IN} = 3V$  and  $V_{ref} = 5V$



The conversion takes place in three stages

- Sample mode**
- Hold mode**
- Redistribution mode**

# Signal Conversion in ADC - Example

- With the same 5-bit SAR-ADC
  - Assuming that  $V_{IN} = 3V$  and  $V_{ref} = 5V$



The conversion takes place in three stages

1. **Sample mode**
2. **Hold mode**
3. **Redistribution mode**

# Signal Conversion in ADC - Example

- With the same 5-bit SAR-ADC
  - Assuming that  $V_{IN} = 3V$  and  $V_{ref} = 5V$



The conversion takes place in three stages

- Sample mode
- Hold mode
- Redistribution mode (bit 4)

# Signal Conversion in ADC - Example

- With the same 5-bit SAR-ADC
  - Assuming that  $V_{IN} = 3V$  and  $V_{ref} = 5V$



The conversion takes place in three stages

- Sample mode
- Hold mode
- Redistribution mode (bit 3)

# Signal Conversion in ADC - Example

- With the same 5-bit SAR-ADC
  - Assuming that  $V_{IN} = 3V$  and  $V_{ref} = 5V$



The conversion takes place in three stages

- Sample mode
- Hold mode
- Redistribution mode (bit 2)

# Signal Conversion in ADC - Example

- With the same 5-bit SAR-ADC
  - Assuming that  $V_{IN} = 3V$  and  $V_{ref} = 5V$



The conversion takes place in three stages

- Sample mode
- Hold mode
- Redistribution mode (bit 1)

# Signal Conversion in ADC - Example

- With the same 5-bit SAR-ADC
  - Assuming that  $V_{IN} = 3V$  and  $V_{ref} = 5V$



The conversion takes place in three stages

- Sample mode
- Hold mode
- Redistribution mode (bit 0)

# Signal Conversion in ADC - Example

- With the same 5-bit SAR-ADC
  - Assuming that  $V_{IN} = 3V$  and  $V_{ref} = 5V$



The conversion takes place in three stages

- Sample mode**
- Hold mode**
- Redistribution mode**

# ADC – Reference Voltage

- Reference Voltage (limit)
  - Reference voltages define the voltage range where ADC performs the conversion.
  - When the voltage exceeds this range → max/min will be considered.



Similarly,

$If V_{IN} \geq V_{REF+}$   
 $If V_{IN} \leq V_{REF-}$

*then ADC output = max. value i.e. 0x0FFF  
 then ADC output = min. value i.e. 0x0000*

# Signal Conversion in ADC

- Sampling time in SAR
  - The RC circuit in the SAR takes time to charge and discharge. The total amount of time taken is

$$\text{Sampling time } t_{sample} \geq (R_I + R_S) \cdot (C_I + C_S) \cdot \ln(2^{n+2})$$



# Signal Conversion in ADC

- Sampling time in SAR
  - The RC circuit in the SAR takes time to charge and discharge. The total amount of time taken is

$$\text{Sampling time } t_{sample} \geq (R_I + R_S) \cdot (C_I + C_S) \cdot \ln(2^{n+2})$$

where,

$R_s$  is the external source resistance

$R_i$  is the internal input resistance

$C_s$  is the external parasitic capacitance

$C_i$  is the input capacitance

$n$ : # of bits

The sampling time is typically in the range of  $\mu\text{s}$ .



Refer datasheet for device specific values.  
(Table 5-25 in device datasheet)



# Signal Conversion in ADC

- Sampling time in SAR (SHT)
  - The RC circuit in the SAR takes time to charge and discharge. The total amount of time taken is

$$\text{Sampling time } t_{\text{sample}} \geq (R_I + R_S) \cdot (C_I + C_S) \cdot \ln(2^{n+2})$$

where,

$R_s$  is the external source resistance

$R_I$  is the internal input resistance

$C_s$  is the external parasitic capacitance

$C_I$  is the input capacitance

$n$ : # of bits

The sampling time is typically in the range of  $\mu s$ .

| PARAMETER              | TEST CONDITIONS                                                                                                                                                                                                                                                                                                         | MIN    | TYP | MAX | UNIT            |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----|-----|-----------------|
| $f_{\text{ADC12CLK}}$  | Frequency for specified performance<br>For specified performance of ADC12 linearity parameters with ADC12PWRMD = 0.<br>If ADC12PWRMD = 1, the maximum is 1/4 of the value shown here.                                                                                                                                   | 0.45   | 5.4 |     | MHz             |
| $f_{\text{ADC12SCLK}}$ | Frequency for reduced linearity parameters have reduced performance                                                                                                                                                                                                                                                     | 32 768 |     |     | kH <sub>Z</sub> |
| $t_{\text{Sample}}$    | $R_S = 400 \Omega, R_I = 4 k\Omega, C_I = 15 pF, C_{\text{pext}} = 8 pF^{(4)}$<br><br>Extended sample mode (ADC12SHP = 0) with buffered reference (ADC12VRSEL = 0x1, 0x3, 0x5, 0x7, 0x9, 0xB, 0xD, 0xF)<br><br>Extended sample mode (ADC12SHP = 0) with unbuffered reference (ADC12VRSEL= 0x0, 0x2, 0x4, 0x6, 0xC, 0xE) | 1      |     |     | $\mu s$         |
|                        | See <sup>(5)</sup>                                                                                                                                                                                                                                                                                                      |        |     |     | $\mu s$         |



# ADC in MSP430

- ADC12\_B module performs the ADC operation
  - Has a single 12-bit ADC core ——————> *supports 8-bit, 10-bit, and 12-bit resolution modes*
  - 32 different analog signals can be sampled at a time
  - Multiple reference voltages ( $V_{ref}$ )
    - 1.2 V, 2.0 V, 5.0 V
- Configuration requirements
  - Clock source
  - Sampling time
  - Reference voltages
  - ADC channels



# ADC in MSP430

- ADC12\_B module performs the ADC operation
  - Has a single 12-bit ADC core
  - 32 different analog signals can be sampled at a time
  - Multiple reference voltages ( $V_{ref}$ )
    - 1.2 V, 2.0 V, 5.0 V
- Configuration requirements
  - Clock source
  - Sampling time
  - Reference voltages
  - ADC channels

- *ACLK*  
- *SMCLK*  
- *MCLK*  
- ***MODCLK***



# ADC in MSP430

- ADC12\_B module performs the ADC operation
  - Has a single 12-bit ADC core
  - 32 different analog signals can be sampled at a time
  - Multiple reference voltages ( $V_{ref}$ )
    - 1.2 V, 2.0 V, 5.0 V

## • Configuration requirements

- Clock source
- Sampling time
- Reference voltages
- ADC channels

- $ACLK$
- $SMCLK$
- $MCLK$
- **$MODCLK$**

*Modulator oscillator (MODOSC) generates MODCLK.*

*The frequency varies between 3.7 MHz and 6.3 MHz with a typical value of 4.8 MHz.*

*The frequency can be further divided by 1,2,3,4,5,6,7 or 8.*

*MODCLK is a cheap clock made of RC circuit.*

*Since timing precision is not very important, we will be using the MODOSC*

# ADC in MSP430

- ADC timing (required time)
  - Includes sampling time and conversion time

- Sampling time
  - Depending on the application  
(size of data)
- Conversion time
  - 10 cycles (for 8-bit)
  - 12 cycles (for 10-bit)
  - 14 cycles (for 12-bit)



# ADC in MSP430

- ADC timing (required time)
  - Includes sampling time and conversion time

*depends on the sensor*

$$\text{Sampling time } t_{\text{sample}} \geq (R_I + R_S) \cdot (C_I + C_S) \cdot \ln(2^{n+2})$$

- Sampling time

- Depending on the application  
(size of data)

- Conversion time
  - 14 clock cycles





# ADC in MSP430

- ADC timing (required time)
  - Includes sampling time and conversion time

*depends on the sensor*

$$\text{Sampling time } t_{\text{sample}} \geq (R_I + R_S) \cdot (C_I + C_S) \cdot \ln(2^{n+2})$$

- Sampling time

- Depending on the application  
(size of data)

- Conversion time

- 14 clock cycles

Minimum values for  
MSP430FR6989

The sampling time is typically in the range of  $\mu\text{s}$ .

$R_s$  is the external source resistance

$R_i$  is the internal input resistance

$C_s$  is the external parasitic capacitance

$C_i$  is the input capacitance

$n$ : # of bits

$$R_I = 4 \text{ K}\Omega; C_I = 15 \text{ pF}$$
$$R_S = 400 \Omega; C_S = 8 \text{ pF}$$

$$\text{minimum } t_{\text{sample}} \geq 1 \mu\text{s}$$

For the inbuilt temperature sensor in MSP430,  $R_S = 250 \text{ K}\Omega$



# ADC in MSP430

- Sampling time → in clock cycles
  - The ADC module requires the sample time to be provided in number of clock cycles.
  - Different applications need different amount of sampling time
    - e.g., the temperature sensor needs a minimum sample time of  $30\mu s$
- Clock source → MODOSC → frequency varies between 3.7 MHz and 6.3 MHz

*Minimum sampling time*           *Maximum possible frequency*

- Example: to achieve  $t_{sampling}=30\mu s$ , (at 6.3 MHz)

$$1 \text{ s} = 6.3 \times 10^6 \text{ cycles} \rightarrow 30 \mu s = 30 \times 6.3 \text{ cycles} = 189 \text{ cycles}$$

- Example: to achieve  $t_{sampling}=30\mu s$ , (at 6.3/8 MHz) – with /8 divider

$$1 \text{ s} = 6.3/8 \times 10^6 \text{ cycles} \rightarrow 30 \mu s = 30 \times 6.3/8 \text{ cycles} \approx 24 \text{ cycles}$$



# ADC in MSP430

- Sampling time → in clock cycles

The number of clock cycles can be configured to  
4 cycles,  
8 cycles,  
16 cycles,  
**32 cycles**,  
64 cycles,  
128 cycles,  
**192 cycles**,  
256 cycles,  
384 cycles  
or 512 cycles.

- Example: to achieve  $t_{sampling} = 30\mu s$ , (at 6.3 MHz)

$$1 s = 6.3 \times 10^6 \text{ cycles} \rightarrow 30 \mu s = 30 \times 6.3 \text{ cycles} = 189 \text{ cycles} \leq \textcolor{blue}{192 \text{ clock cycles}}$$

- Example: to achieve  $t_{sampling} = 30\mu s$ , (at 6.3/8 MHz) – with /8 divider

$$1 s = 6.3/8 \times 10^6 \text{ cycles} \rightarrow 30 \mu s = 30 \times 6.3/8 \text{ cycles} \approx 24 \text{ cycles} \leq \textcolor{red}{32 \text{ clock cycles}}$$

# ADC in MSP430 - Channels

- 32 different channels in ADC12\_B
  - Each channel with an input and a corresponded fixed memory register to store the output!



# ADC in MSP430 - Channels

- 32 different channels in ADC12\_B
  - Each channel with an input and a corresponded fixed memory register to store the output!





# ADC in MSP430 - Registers

- ADC12 Control Register 0

*ADC12CTL0*

|            |        |                                                                                              |
|------------|--------|----------------------------------------------------------------------------------------------|
| ADC12SHT1x | 4 bits | Configures the number of clock cycles for channels 8 to 23                                   |
| ADC12SHT0x | 4 bits | Configures the number of clock cycles for channels 0 to 7 and 24 to 31.                      |
| ADC12ON    | 1 bit  | Turns on the ADC_12 module                                                                   |
| ADC12MSC   | 1 bit  | Enables converting multiple channels at a time                                               |
| ADC12ENC   | 1 bit  | Enables conversion                                                                           |
| ADC12SC    | 1 bit  | Setting it, starts the ADC conversion.<br>Reset by hardware automatically, after conversion. |

*Two set of channels can have two different sampling periods*



*All ADC12 module configuration must be done only when ADC12ENC is 0.*



# ADC in MSP430 - Registers

- ADC12 Control Register 0

| ADC12CTL0                               |          |        |         |          |        |            |         |
|-----------------------------------------|----------|--------|---------|----------|--------|------------|---------|
| 15                                      | 14       | 13     | 12      | 11       | 10     | 9          | 8       |
| ADC12SHT1x                              |          |        |         |          |        | ADC12SHT0x |         |
| rw-(0)                                  | rw-(0)   | rw-(0) | rw-(0)  | rw-(0)   | rw-(0) | rw-(0)     | rw-(0)  |
| Can be modified only when ADC12ENC = 0. |          |        |         |          |        |            |         |
| 7                                       | 6        | 5      | 4       | 3        | 2      | 1          | 0       |
| ADC12MSC                                | Reserved |        | ADC12ON | Reserved |        | ADC12ENC   | ADC12SC |
| rw-(0)                                  | r-0      | r-0    | rw-(0)  | r-0      | r-0    | rw-(0)     | rw-(0)  |

**channels 8-23**

0000b = 4 ADC12CLK cycles  
 0001b = 8 ADC12CLK cycles  
 0010b = 16 ADC12CLK cycles  
 0011b = 32 ADC12CLK cycles  
 0100b = 64 ADC12CLK cycles  
 0101b = 96 ADC12CLK cycles  
 0110b = 128 ADC12CLK cycles  
 0111b = 192 ADC12CLK cycles  
 1000b = 256 ADC12CLK cycles  
 1001b = 384 ADC12CLK cycles  
 1010b = 512 ADC12CLK cycles  
 1011b = Reserved  
 1100b = Reserved  
 1101b = Reserved  
 1110b = Reserved  
 1111b = Reserved

**channels 0-7 & 24-31**

0000b = 4 ADC12CLK cycles  
 0001b = 8 ADC12CLK cycles  
 0010b = 16 ADC12CLK cycles  
 0011b = 32 ADC12CLK cycles  
 0100b = 64 ADC12CLK cycles  
 0101b = 96 ADC12CLK cycles  
 0110b = 128 ADC12CLK cycles  
 0111b = 192 ADC12CLK cycles  
 1000b = 256 ADC12CLK cycles  
 1001b = 384 ADC12CLK cycles  
 1010b = 512 ADC12CLK cycles  
 1011b = Reserved  
 1100b = Reserved  
 1101b = Reserved  
 1110b = Reserved  
 1111b = Reserved

| Field    | Type | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADC12MSC | RW   | 0     | ADC12_B multiple sample and conversion. Valid only for sequence or repeated modes. Can be modified only when ADC12ENC = 0.<br>0b = The sampling timer requires a rising edge of the SHI signal to trigger each sample-and-convert.<br>1b = The incidence of the first rising edge of the SHI signal triggers the sampling timer, but further sample-and-conversions are performed automatically as soon as the prior conversion is completed. |
| Reserved | R    | 0     | Reserved. Always reads as 0.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ADC12ON  | RW   | 0     | ADC12_B on. Can be modified only when ADC12ENC = 0.<br>0b = ADC12_B off<br>1b = ADC12_B on                                                                                                                                                                                                                                                                                                                                                    |
| Reserved | R    | 0     | Reserved. Always reads as 0.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| ADC12ENC | RW   | 0     | ADC12_B enable conversion.<br>0b = ADC12_B disabled<br>1b = ADC12_B enabled                                                                                                                                                                                                                                                                                                                                                                   |
| ADC12SC  | RW   | 0     | ADC12_B start conversion. Software-controlled sample-and-conversion start. ADC12SC and ADC12ENC may be set together with one instruction. ADC12SC is reset automatically.<br>0b = No sample-and-conversion-start<br>1b = Start sample-and-conversion                                                                                                                                                                                          |



# ADC in MSP430 - Registers

- ADC12 Control Registers 1 & 2

*ADC12CTL1*

|                    |        |                                                                   |
|--------------------|--------|-------------------------------------------------------------------|
| <i>ADC12SEL</i>    | 2 bits | <i>Selects the clock source</i>                                   |
| <i>ADC12DIV</i>    | 3 bits | <i>Clock divider</i>                                              |
| <i>ADC12BUSY</i>   | 1 bit  | <i>Indicates whether the ADC module is busy with conversions.</i> |
| <i>ADC12SHS</i>    | 3 bits | <i>Trigger for sample and hold operation</i>                      |
| <i>ADC12SHP</i>    | 1 bit  | <i>Sampling signal source select</i>                              |
| <i>ADC12CONSEQ</i> | 2 bits | <i>Conversion mode</i>                                            |

*ADC12CTL2*

|                       |        |                                                                        |
|-----------------------|--------|------------------------------------------------------------------------|
| <i>ADC12RES</i>       | 2 bits | <i>Selects the resolution of the ADC<br/>(8 bit, 10 bit or 12 bit)</i> |
| <i>ADC12DF</i>        | 1 bit  | <i>Data format</i>                                                     |
| <i>ADC12CSTARTADD</i> | 5 bits | <i>Starting channel for conversion</i>                                 |



# ADC in MSP430 - Registers

- ADC12 Control Registers 1

*ADC12CTL1*

| 15                                      | 14        | 13     | 12         | 11     | 10           | 9         | 8      |
|-----------------------------------------|-----------|--------|------------|--------|--------------|-----------|--------|
| Reserved                                | ADC12PDIV |        | ADC12SHSx  |        | ADC12SHP     | ADC12ISSH |        |
| r-0                                     | rw-(0)    | rw-(0) | rw-(0)     | rw-(0) | rw-(0)       | rw-(0)    | rw-(0) |
| 7                                       | 6         | 5      | 4          | 3      | 2            | 1         | 0      |
|                                         | ADC12DIVx |        | ADC12SSELx |        | ADC12CONSEQx | ADC12BUSY |        |
| rw-(0)                                  | rw-(0)    | rw-(0) | rw-(0)     | rw-(0) | rw-(0)       | rw-(0)    | r-(0)  |
| Can be modified only when ADC12ENC = 0. |           |        |            |        |              |           |        |

| Bit   | Field     | Type | Reset | Description                                                                                                                                                                  |
|-------|-----------|------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | Reserved  | R    | 0h    | Reserved. Always reads as 0.                                                                                                                                                 |
| 14-13 | ADC12PDIV | RW   | 0h    | ADC12_B predivider. This bit predivides the selected ADC12_B clock source.<br>00b = Predivide by 1<br>01b = Predivide by 4<br>10b = Predivide by 32<br>11b = Predivide by 64 |
| 8     | ADC12ISSH | RW   | 0h    | ADC12_B invert signal sample-and-hold.<br>0b = The sample-input signal is not inverted.<br>1b = The sample-input signal is inverted.                                         |

| Bit | Field      | Type | Reset | Description                                                                                                                   |
|-----|------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------|
| 7-5 | ADC12DIVx  | RW   | 0h    | ADC12_B clock divider<br>000b = /1<br>001b = /2<br>010b = /3<br>011b = /4<br>100b = /5<br>101b = /6<br>110b = /7<br>111b = /8 |
| 4-3 | ADC12SSELx | RW   | 0h    | ADC12_B clock source select<br>00b = ADC12OSC (MODOSC)<br>01b = ACLK<br>10b = MCLK<br>11b = SMCLK                             |



# ADC in MSP430 - Registers

- ADC12 Control Registers 2

**ADC12CTL2**

| 15       | 14 | 13     | 12     | 11      | 10       | 9  | 8          |
|----------|----|--------|--------|---------|----------|----|------------|
| Reserved |    |        |        |         |          |    |            |
| r0       | r0 | r0     | r0     | r0      | r0       | r0 | r0         |
| 7        | 6  | 5      | 4      | 3       | 2        | 1  | 0          |
| Reserved |    |        |        |         |          |    |            |
| r0       | r0 | rw-(1) | rw-(0) | rw-(0)  | r0       | r0 | rw-(0)     |
| ADC12RES |    |        |        | ADC12DF | Reserved |    | ADC12PWRMD |

| Bit  | Field      | Type | Reset | Description                                                                                                                                                                                                                                                                                                                                           |
|------|------------|------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-6 | Reserved   | R    | 0h    | Reserved. Always reads as 0.                                                                                                                                                                                                                                                                                                                          |
| 5-4  | ADC12RES   | RW   | 2h    | ADC12_B resolution. This bit defines the conversion result resolution. This bit should only be modified when ADC12ENC=0.<br>00b = 8 bit (10 clock cycle conversion time)<br>01b = 10 bit (12 clock cycle conversion time)<br>10b = 12 bit (14 clock cycle conversion time)<br>11b = Reserved                                                          |
| 3    | ADC12DF    | RW   | 0h    | ADC12_B data read-back format. Data is always stored in the binary unsigned format.<br>0b = Binary unsigned.<br>1b = Signed binary (2s complement), left aligned.                                                                                                                                                                                     |
| 0    | ADC12PWRMD | RW   | 0h    | Enables ADC low-power mode for ADC12CLK with 1/4 the specified maximum for ADC12PWRMD = 0. This bit should only be modified when ADC12ENC = 0.<br>0b = Regular power mode where sample rate is not restricted<br>1b = Low power mode enable, ADC12CLK can not be greater than 1/4 the device-specific data sheet specified maximum for ADC12PWRMD = 0 |

# ADC in MSP430 - Registers

- ADC12 Conversion memory control register – channel x

*ADC12MCTLx*

|            |        |                                                                   |
|------------|--------|-------------------------------------------------------------------|
| ADC12VRSEL | 4 bits | Selects the reference voltages                                    |
| ADC12INCH  | 5 bits | Selects one source from 32 available analog voltage input sources |

| Bit  | Field      | Type | Reset | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------|------------|------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11-8 | ADC12VRSEL | RW   | 0h    | <p>Selects combinations of VR+ and VR- sources as well as the buffer selection. Note: there is only one buffer so it can be used for either VR+ or VR-, but not both. Can be modified only when ADC12ENC = 0.</p> <p>0000b = VR+ = AVCC, VR- = AVSS<br/>           0001b = VR+ = VREF buffered, VR- = AVSS<br/>           0010b = VR+ = VeREF-, VR- = AVSS<br/>           0011b = VR+ = VeREF+ buffered, VR- = AVSS</p>                                                                                                                                                          |
| 4-0  | ADC12INCHx | RW   | 0h    | <p>Input channel select. If even channels are set as differential, then odd channel configuration is ignored. Can be modified only when ADC12ENC = 0.</p> <p>00000b = If ADC12DIF = 0: A0; If ADC12DIF = 1: Ain+ = A0, Ain- = A1<br/>           00001b = If ADC12DIF = 0: A1; If ADC12DIF = 1: Ain+ = A0, Ain- = A1<br/>           00010b = If ADC12DIF = 0: A2; If ADC12DIF = 1: Ain+ = A2, Ain- = A3<br/>           00011b = If ADC12DIF = 0: A3; If ADC12DIF = 1: Ain+ = A2, Ain- = A3<br/>           00100b = If ADC12DIF = 0: A4; If ADC12DIF = 1: Ain+ = A4, Ain- = A5</p> |





# ADC in MSP430 - Registers

- Interrupt flag (Optional)
  - ADC12IERx – ADC12 Interrupt enable registers.
  - ADC12IFGRx – ADC12 Interrupt flag registers.

*ADC12IER0*

| 15        | 14        | 13        | 12        | 11        | 10        | 9        | 8        |
|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|
| ADC12IE15 | ADC12IE14 | ADC12IE13 | ADC12IE12 | ADC12IE11 | ADC12IE10 | ADC12IE9 | ADC12IE8 |
| rw-(0)    | rw-(0)    | rw-(0)    | rw-(0)    | rw-(0)    | rw-(0)    | rw-(0)   | rw-(0)   |
| 7         | 6         | 5         | 4         | 3         | 2         | 1        | 0        |
| ADC12IE7  | ADC12IE6  | ADC12IE5  | ADC12IE4  | ADC12IE3  | ADC12IE2  | ADC12IE1 | ADC12IE0 |
| rw-(0)    | rw-(0)    | rw-(0)    | rw-(0)    | rw-(0)    | rw-(0)    | rw-(0)   | rw-(0)   |

0b: interrupt disabled  
1b: interrupt enabled

*ADC12IER1*

| 15        | 14        | 13        | 12        | 11        | 10        | 9         | 8         |
|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| ADC12IE31 | ADC12IE30 | ADC12IE29 | ADC12IE28 | ADC12IE27 | ADC12IE26 | ADC12IE25 | ADC12IE24 |
| rw-(0)    |
| 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| ADC12IE23 | ADC12IE22 | ADC12IE21 | ADC12IE20 | ADC12IE19 | ADC12IE18 | ADC12IE17 | ADC12IE16 |
| rw-(0)    |

0b: interrupt disabled  
1b: interrupt enabled

# ADC in MSP430 - Registers

- Interrupt flag (Optional)
  - ADC12IERx – ADC12 Interrupt enable registers.
  - ADC12IFGRx – ADC12 Interrupt flag registers.

*This bit is set when ADC12MEMx is loaded with a conversion result.*

*The ADC12IFGx bit is reset if ADC12MEM31 is accessed, or it can be reset with software*



*ADC12IFGR0*

| 15         | 14         | 13         | 12         | 11         | 10         | 9         | 8         |
|------------|------------|------------|------------|------------|------------|-----------|-----------|
| ADC12IFG15 | ADC12IFG14 | ADC12IFG13 | ADC12IFG12 | ADC12IFG11 | ADC12IFG10 | ADC12IFG9 | ADC12IFG8 |
| rw-(0)     | rw-(0)     | rw-(0)     | rw-(0)     | rw-(0)     | rw-(0)     | rw-(0)    | rw-(0)    |
| 7          | 6          | 5          | 4          | 3          | 2          | 1         | 0         |
| ADC12IFG7  | ADC12IFG6  | ADC12IFG5  | ADC12IFG4  | ADC12IFG3  | ADC12IFG2  | ADC12IFG1 | ADC12IFG0 |
| rw-(0)     | rw-(0)     | rw-(0)     | rw-(0)     | rw-(0)     | rw-(0)     | rw-(0)    | rw-(0)    |

*0b: NO interrupt pending  
1b: interrupt pending*

*ADC12IFGR1*

| 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8          |
|------------|------------|------------|------------|------------|------------|------------|------------|
| ADC12IFG31 | ADC12IFG30 | ADC12IFG29 | ADC12IFG28 | ADC12IFG27 | ADC12IFG26 | ADC12IFG25 | ADC12IFG24 |
| rw-(0)     |
| 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
| ADC12IFG23 | ADC12IFG22 | ADC12IFG21 | ADC12IFG20 | ADC12IFG19 | ADC12IFG18 | ADC12IFG17 | ADC12IFG16 |
| rw-(0)     |

*0b: NO interrupt pending  
1b: interrupt pending*



# ADC in MSP430 - Programming

- Determining the register values for SHT and conversion time

$$\text{Sampling time } t_{\text{sample}} \geq (R_I + R_S) \cdot (C_I + C_S) \cdot \ln(2^{n+2})$$

The number of clock cycles can be configured to

$$\begin{aligned} R_I &= 4 \text{ k}\Omega \\ R_E &= 10 \text{ k}\Omega \\ C_I &= 15 \text{ pF} \\ C_E &= 1 \text{ pF} \\ n \text{ (in ADC12\_B)} &= 12 \end{aligned}$$

$$\begin{aligned} (4\text{k}\Omega + 10\text{k}\Omega) \cdot (15\text{pF} + 1\text{pF}) \cdot \ln(2^{12+2}) \\ \approx 2.2 \mu\text{s} \end{aligned}$$

| PARAMETER             | TEST CONDITIONS                                                                                                                                                                                                                                                                                                               | MIN                | TYP | MAX | UNIT          |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|-----|-----|---------------|
| $f_{\text{ADC12CLK}}$ | For specified performance of ADC12 linearity parameters with ADC12PWRMD = 0.<br>If ADC12PWRMD = 1, the maximum is 1/4 of the value shown here.                                                                                                                                                                                | 0.45               |     | 5.4 | MHz           |
| $f_{\text{ADC12CLK}}$ | Linearity parameters have reduced performance                                                                                                                                                                                                                                                                                 | 32.768             |     |     | kHz           |
| $t_{\text{sample}}$   | $R_S = 400 \Omega, R_I = 4 \text{ k}\Omega, C_I = 15 \text{ pF}, C_{\text{pext}} = 8 \text{ pF}^{(4)}$<br>(ADC12SHP = 0) with buffered reference<br>(ADC12VRSEL = 0x1, 0x3, 0x5, 0x7, 0x9, 0xB, 0xD, 0xF)<br><br>Extended sample mode (ADC12SHP = 0) with unbuffered reference<br>(ADC12VRSEL = 0x0, 0x2, 0x4, 0x6, 0xC, 0xE) | 1                  |     |     | $\mu\text{s}$ |
|                       |                                                                                                                                                                                                                                                                                                                               | See <sup>(5)</sup> |     |     | $\mu\text{s}$ |

4 cycles,  
8 cycles,  
16 cycles,  
**32 cycles**,  
64 cycles,  
128 cycles,  
192 cycles,  
256 cycles,  
384 cycles  
or 512 cycles.

Using **MODCLK** at the frequency

- varies between 3.7 MHz and 6.3 MHz
- with a typical value of 4.8 MHz

$$1 \text{ s} = 6.3 \times 10^6 \text{ cycles} \rightarrow 3 \mu\text{s} = 3 \times 6.3 \text{ cycles} = 18.9 \text{ cycles} \leq \text{32 cycles}$$

**Divider is required in case it is more than 512!**

# ADC in MSP430 - Programming

- Determining the register values for SHT and conversion time

- SHT in clock cycles

- Based on the clock source, divider, and RC model of the ADC

$$R_I = 4 \text{ K}\Omega$$

$$R_E = 10 \text{ K}\Omega$$

$$C_I = 15 \text{ pF}$$

$$C_E = 1 \text{ pF}$$

$$n (\text{in } \text{ADC12\_B}) = 12$$



$$(4\text{K}\Omega + 10\text{K}\Omega) \cdot (15\text{pF} + 1\text{pF}) \cdot \ln(2^{12+2}) \\ \approx 2.2 \mu\text{s}$$

$1 \text{ s} = 6.3 \times 10^6 \text{ cycles} \rightarrow 3 \mu\text{s} = 3 \times 6.3 \text{ cycles} \\ = 18.9 \text{ cycles} <= \text{32 cycles}$

*channels 8-23*

|                                       |
|---------------------------------------|
| 0000b = 4 ADC12CLK cycles             |
| 0001b = 8 ADC12CLK cycles             |
| 0010b = 16 ADC12CLK cycles            |
| <del>0011b = 32 ADC12CLK cycles</del> |
| 0100b = 64 ADC12CLK cycles            |
| 0101b = 96 ADC12CLK cycles            |
| 0110b = 128 ADC12CLK cycles           |
| 0111b = 192 ADC12CLK cycles           |
| 1000b = 256 ADC12CLK cycles           |
| 1001b = 384 ADC12CLK cycles           |
| 1010b = 512 ADC12CLK cycles           |
| 1011b = Reserved                      |
| 1100b = Reserved                      |
| 1101b = Reserved                      |
| 1110b = Reserved                      |
| 1111b = Reserved                      |

*channels 0-7 & 24-31*

|                                       |
|---------------------------------------|
| 0000b = 4 ADC12CLK cycles             |
| 0001b = 8 ADC12CLK cycles             |
| 0010b = 16 ADC12CLK cycles            |
| <del>0011b = 32 ADC12CLK cycles</del> |
| 0100b = 64 ADC12CLK cycles            |
| 0101b = 96 ADC12CLK cycles            |
| 0110b = 128 ADC12CLK cycles           |
| 0111b = 192 ADC12CLK cycles           |
| 1000b = 256 ADC12CLK cycles           |
| 1001b = 384 ADC12CLK cycles           |
| 1010b = 512 ADC12CLK cycles           |
| 1011b = Reserved                      |
| 1100b = Reserved                      |
| 1101b = Reserved                      |
| 1110b = Reserved                      |
| 1111b = Reserved                      |

| 15                                          | 14       | 13     | 12      | 11                                                     | 10       | 9       | 8      |
|---------------------------------------------|----------|--------|---------|--------------------------------------------------------|----------|---------|--------|
| <b>ADC12SHT1x      <i>channels 8-23</i></b> |          |        |         | <b>ADC12SHT0x      <i>channels 0-7 &amp; 24-31</i></b> |          |         |        |
| rw-(0)                                      | rw-(0)   | rw-(0) | rw-(0)  | rw-(0)                                                 | rw-(0)   | rw-(0)  | rw-(0) |
| 7                                           | 6        | 5      | 4       | 3                                                      | 2        | 1       | 0      |
| ADC12MSC                                    | Reserved |        | ADC12ON | Reserved                                               | ADC12ENC | ADC12SC |        |
| rw-(0)                                      | r-0      | r-0    | rw-(0)  | r-0                                                    | r-0      | rw-(0)  | rw-(0) |
| Can be modified only when ADC12ENC = 0.     |          |        |         |                                                        |          |         |        |

# ADC in MSP430 - Programming

- Implementation – for joystick X-axis and Y-axis

*From the Boosterpack for joystick pinout*

| BoosterPack Plug-in Module Header Connection | Pin Function      |
|----------------------------------------------|-------------------|
| J1.2                                         | Horizontal X-axis |
| J1.5                                         | Select button     |
| J3.26                                        | Vertical Y-axis   |

*HorAxis → connected to p9.2*

*VerAxis → connected to p8.7*

*From the Launchpad (Full schematic)*

|                              |                  |
|------------------------------|------------------|
| P8.3/MCLK/S18                | 47 S18           |
| P8.4/A7/C7                   | 59 P8.4 A7 J3.23 |
| P8.5/A6/C6                   | 60 P8.5 A6 J3.24 |
| P8.6/A5/C5                   | 61 P8.6 A5 J3.25 |
| P8.7/A4/C4                   | 62 P8.7 A4 J3.26 |
| P9.0/ESICH0/ESITEST0/A8/C8   | 67 P9.0 A8 J3.27 |
| P9.1/ESICH1/ESITEST1/A9/C9   | 68 P9.1 A9 J3.28 |
| P9.2/ESICH2/ESITEST2/A10/C10 | 69 P9.2 A10 J1.2 |
| P9.3/ESICH3/ESITEST3/A11/C11 | 70 P9.3 A11 J1.6 |
| P9.4/ESICI0/A12/C12          | 71 P9.4 I0 J2.17 |
| P9.5/ESICI1/A13/C13          | 72 P9.5 J3.29    |
| P9.6/ESICI2/A14/C14          | 73 P9.6 J3.30    |
| P9.7/ESICI3/A15/C15          | 74 P9.7 LFD2     |

## • Default is GPIO

- configure this pin to the A10/A4 function

P9.2/ESICH2/ESITEST2/A10/C10

*x-axis*

| P9.2 (I/O) <i>default</i>           |  | I: 0; O: 1 | 0 | 0 |
|-------------------------------------|--|------------|---|---|
| N/A                                 |  | 0          |   |   |
| Internally tied to DVSS             |  | 1          | 0 | 1 |
| ESITEST2 <sup>(2)</sup>             |  | X          | 1 | 0 |
| ESICH2/A10/C10 <sup>(2)(3)(4)</sup> |  | X          | 1 | 1 |

P8.7/A4/C4

*y-axis*

| P8.7 (I/O) <i>default</i> |  | I: 0; O: 1 | 0 | 0 |
|---------------------------|--|------------|---|---|
| N/A                       |  | 0          |   |   |
| Internally tied to DVSS   |  | 1          | 0 | 1 |
| N/A                       |  | 0          | 1 | 0 |
| Internally tied to DVSS   |  | 1          |   |   |
| A4/C4 <sup>(2) (3)</sup>  |  | X          | 1 | 1 |

// X-axis: A10/P9.2, for A10 (P9DIR=x, P9SEL1=1, P9SEL0=1)

P9SEL1 |= BIT2; // bit 2 of P9

P9SEL0 |= BIT2; // bit 2 of P9

// Y-axis: A4/P8.7, for A4 (P8DIR=x, P8SEL1=1, P8SEL0=1)

P9SEL1 |= BIT7; // bit 7 of P8

P9SEL0 |= BIT7; // bit 7 of P8



# ADC in MSP430 - Programming

- Implementation – for joystick X-axis only

*Setting the pins for joystick  
(x-axis through P9.2)*

*Turning on the ADC module*

*Turning off the (Enable Conversion) bit while  
modifying the configuration*

*select the number of cycles based on the  
sampling time (here it is 10 → 512)*

*select the sample-and-hold source and determine the  
pulse-mode select, clock source, and clock divider*

*Determine the resolution (12-bit) and data  
format (unsigned binary)*

```
void Initialize_ADC(void){  
    // X-Axis of the Joystick is connected to pin P9.2  
    // X-Axis: A10/P9.2, for A10 (P9DIR=x, P9SEL1=1, P9SEL0=1)  
    P9SEL0 |= BIT2;  
    P9SEL1 |= BIT2;  
  
    // Turn on the ADC module  
    ADC12CTL0 |= ADC12ON;  
  
    // Turn OFF ENC  
    ADC12CTL0 &= ~ADC12ENC;  
  
    // Configure ADC12CTLx registers  
    ADC12CTL0 |= ADC12SHT1_10;  
    ADC12CTL1 = ADC12SHS_0 | ADC12SHP | ADC12DIV_7 | ADC12SSSEL_0;  
    ADC12CTL2 = ADC12RES_2;  
  
    ADC12MCTL0 |= ADC12INCH_10 | ADC12VRSEL_0;  
  
    // Turn ON ENC  
    ADC12CTL0 |= ADC12ENC;  
    return;  
}
```

*Turning on the EC bit after all configurations*

*Determine the voltage  
range and channel  
selection*



# ADC in MSP430 - Programming

- Implementation – for joystick X-axis only

```
void main(void){  
  
    WDTCTL = WDTPW | WDTHOLD;  
    PM5CTL0 &= ~LOCKLPM5;  
    Initialize_ADC(); ——————  
    Initialize_UART();  
  
    while (1) {  
        ADC12CTL0 |= ADC12SC; // start the conversion  
  
        // wait until busy flag is set  
        while((ADC12CTL1 & ADC12BUSY) != 0); }  
        uart_write_uint16(ADC12MEM0)  
    }  
}
```

*Write data to UART (from ADC)*

```
void Initialize_ADC(void){  
    // X-Axis of the Joystick is connected to pin P9.2  
    // X-Axis: A10/P9.2, for A10 (P9DIR=x, P9SEL1=1, P9SEL0=1)  
    P9SEL0 |= BIT2;  
    P9SEL1 |= BIT2;  
  
    // Turn on the ADC module  
    ADC12CTL0 |= ADC12ON;  
  
    // Turn OFF ENC  
    ADC12CTL0 &= ~ADC12ENC;  
  
    // Configure ADC12CTLx registers  
    ADC12CTL0 |= ADC12SHT1_10;  
    ADC12CTL1 = ADC12SHS_0 | ADC12SHP | ADC12DIV_7 | ADC12SEL_0;  
    ADC12CTL2 = ADC12RES_2;  
  
    ADC12MCTL0 |= ADC12INCH_10 | ADC12VRSEL_0;  
  
    // Turn ON ENC  
    ADC12CTL0 |= ADC12ENC;  
  
    return; }  
    Turning on the EC bit after all configurations
```

# Thank You!

# Questions?

Email: [kamali@ucf.edu](mailto:kamali@ucf.edu)

UCF HEC 435                    (407) 823 - 0764

<https://www.ece.ucf.edu/~kamali/>

HAVEN Research Group

<https://haven.ece.ucf.edu/>



UNIVERSITY OF  
CENTRAL FLORIDA