

# **ADC - Analog to Digital Converter (Conversor Analógico Digital)**

Electrónica Digital II



Escuela de  
Ciencia y Tecnología  
ECyT\_UNSAM

## ADC - Analog to Digital Converter

- Conversor de aproximaciones sucesivas de 12 bits
- Canales: hasta 18, multiplexados (16 señales externas y 2 internas)
- Modo de conversión: simple, continuo, scan o discontinuo
- Almacena el resultado en un registro de 16 bits (alineado a izquierda o derecha)
- Generación de interrupción al finalizar una conversión
- El reloj ADCCLK es sincrónico con el APB2 clock. No puede superar los 14 MHz

## Aproximaciones sucesivas (SAR)



## Aproximaciones sucesivas (SAR)



La resolución de un ADC de N bits es igual a  $V_{MAX}/2^N$

Para un ADC de N bits el proceso de conversión demandará al menos N ciclos de reloj

## Tiempos de un ADC

$$T_{ADC} = T_{muestreo} + T_{conversión}$$

Suponiendo un ADC de 12 bits y tiempo de muestreo de 3 ciclos de reloj, con una frecuencia de operación de 10 MHz:

$$T_{ADC} = T_{muestreo} + T_{conversión} = 3 + 12 = 15 \text{ ciclos} = 1.5 \mu\text{s}$$

# ADC - Analog to Digital Converter



## Selección de canal

- Las conversiones pueden organizarse en dos grupos:

### Grupo Regular

- Compuesto por hasta 16 conversiones
- Los canales regulares y su orden en la secuencia de conversión se seleccionan en el registro ADC\_SQRx
- La cantidad de conversiones debe ser escrita en los bits L[3:0] del registro ADC\_SQR1

### Grupo Inyectado

- Compuesto por hasta 4 conversiones
- Los canales inyectados y su orden en la secuencia de conversión se seleccionan en el registro ADC\_JSQRx
- La cantidad de conversiones debe ser escrita en los bits L[1:0] del registro ADC\_JCSR

## Modo de conversión simple

- El ADC sólo realiza una conversión
- La adquisición inicia colocando en '1' el bit ADON en el registro ADC\_CR2 (sólo para canal regular) o por un trigger externo (para canal regular o inyectado).
- Canal regular convertido:
  - El dato se guarda en el registro de 16 bits ADC\_DR
  - El flag EOC (End Of Conversion) se coloca en '1' y la interrupción es generada si el bit EOCIE (EOC Interrupt Enable) está activo
- Canal inyectado:
  - El dato se guarda en el registro de 16 bits ADC\_DRJ1
  - El flag JEOC (End Of Conversion Injected) se coloca en '1' y la interrupción es generada si el bit JEOCIE está activo

Finalmente el ADC se detiene

## Modo de conversión continua

- **El ADC inicia otra conversión apenas termina la actual**
- La adquisición inicia colocando en '1' el bit ADON en el registro ADC\_CR2 (sólo para canal regular) o por un trigger externo (para canal regular o inyectado).
- Canal regular convertido:
  - El dato se guarda en el registro de 16 bits ADC\_DR
  - El flag EOC (End Of Conversion) se coloca en '1' y la interrupción es generada si el bit EOCIE (EOC Interrupt Enable) está activo
- Canal inyectado:
  - El dato se guarda en el registro de 16 bits ADC\_DRJ1
  - El flag JEOC (End Of Conversion Injected) se coloca en '1' y la interrupción es generada si el bit JEOCIE está activo

## Modo Scan

- **Se adquiere un grupo de canales analógicos**
- Se selecciona configurando el bit SCAN en el registro ADC\_CR1.
- Cuando se lo selecciona el ADC escanea todos los canales seleccionados en el registro ADC\_SQRx (para canales regulares) o en el ADC\_JSQR (para inyectados)
- Cada vez que finaliza una conversión continúa automáticamente con el siguiente canal del grupo.
- Al usar este modo el DMA debe estar activo ya que es usado para transferir los datos convertidos de los canales de un grupo regular a la SRAM cada vez que se actualiza el registro ADC\_DR.
- Los datos de los canales inyectados siempre se almacenan en los registro ADC\_JDRx.

## Modos de operación

### Canal único



Conversión simple



Conversión continua

### Múltiples canales (Scan)



Conversión simple



Conversión continua

## Registros

- Status Register (**ADC\_SR**)
- Control Register 1 / 2 (**ADC\_CR1 / ADC\_CR2**)
- Sample Time Register 1 / 2 (**ADC\_SMPR1 / ADC\_SMPR2**)
- Injected channel data offset register x (**ADC\_JOFRx**) (x=1..4)
- Regular sequence register 1 / 2 / 3 (**ADC\_SQR1 / ADC\_SQR2 / ADC\_SQR3**)
- Injected sequence register (**ADC\_JSQR**)
- Injected data register x (**ADC\_JDRx**) (x= 1..4)
- Regular data register (**ADC\_DR**)
- Watchdog high threshold register (**ADC\_HTR**)
- Watchdog low threshold register (**ADC\_LTR**)

## ADC\_SR (Registro de Estado)



## ADC\_CR1 (Registro de Control 1)

Cuando es '1' el ADC automáticamente realiza las conversiones inyectadas inmediatamente después de que se completa cada conversión regular, sin necesidad de un disparador externo o de intervención manual

Habilitación del modo scan

Habilitación del watchdog analógico para los canales regulares

Habilitación del watchdog analógico para los canales inyectados

Modos de funcionamiento dual del ADC



Número de canales regulares a ser convertidos en modo discontinuo

Habilitación del modo discontinuo en los canales regulares (11) / inyectados (12)

Habilitación del watchdog para un solo canal ('1') o para todos ('0')

Habilitación de interrupción en los canales inyectados

Habilitación de interrupción del watchdog

Habilitación de interrupción para el final de conversión (EOC)

Canal al que se le aplicará el watchdog

## ADC\_CR2 (Registro de Control 2)



## ADC\_SMPR1 (Registro de Tiempo de Muestreo 1)

|                  |                   |
|------------------|-------------------|
| 000: 1.5 ciclos  | 100: 41.5 ciclos  |
| 001: 7.5 ciclos  | 101: 55.5 ciclos  |
| 010: 13.5 ciclos | 110: 71.5 ciclos  |
| 011: 28.5 ciclos | 111: 239.5 ciclos |



## ADC\_SMPR2 (Registro de Tiempo de Muestreo 2)



## ADC\_JOFRx (Registro de Offset de dato de canal inyectado)



Define el offset a ser restado del dato crudo convertido cuando se convierte un canal inyectado. El resultado se puede leer en el registro ADC\_JDRx

## ADC\_HTR (Registro para el umbral alto del watchdog)



## ADC\_LTR (Registro para el umbral bajo del watchdog)



## ADC\_SQR1 (Registro de secuencia de los canales regulares 1)



## ADC\_SQR2 (Registro de secuencia de los canales regulares 2)



## ADC\_SQR3 (Registro de secuencia de los canales regulares 3)



## ADC\_JSQR (Registro de secuencia de los canales injectados)



## ADC\_JSQR (Registro de secuencia de los canales injectados)



Cuando  $JL=3$  (4 conversiones en la secuencia), el ADC convierte los canales en el orden:  $JSQ1[4:0] \rightarrow JSQ2[4:0] \rightarrow JSQ3[4:0] \rightarrow JSQ4[4:0]$

Cuando  $JL=2$  (3 conversiones en la secuencia), el ADC convierte los canales en el orden:  $JSQ2[4:0] \rightarrow JSQ3[4:0] \rightarrow JSQ4[4:0]$

Cuando  $JL=1$  (2 conversiones en la secuencia), el ADC convierte los canales en el orden:  $JSQ3[4:0] \rightarrow JSQ4[4:0]$

Cuando  $JL=0$  (1 conversión en la secuencia), el ADC convierte sólo el canal  $JSQ4[4:0]$

## ADC\_JDRx (Registro de datos de los canales injectados) ( $x = 1..4$ )



Contiene el resultado de la conversión del canal  
inyectado x

## ADC\_DR (Registro de datos de los canales regulares)

