ADC

Description

Analog to digital converter

The ADC peripheral is a 12-bit general purpose successive-approximation type (SAR) ADC, which can be used to sample analog-capable I/O pins or internal chip voltages at up to 200 kS/s with manual, GPIO, COMPA or periodical timer trigger. The ADC input signal is also positive input to the COMPB peripheral.

The input stage consists of a switched capacitor stage where the input voltage is sampled and then held before the conversion is done. The ADC can be operated in synchronous or asynchronous mode:

  • In synchronous mode the start trigger will start the sampling for a programmable amount of time before the conversion is performed in order to allow for high impedance sources to be properly sampled.
  • In asynchronous mode the ADC will sample continuously and then stop sampling once the start signal triggers in order to perform a conversion. This mode will allow jitter-free sampling, at expense of increased current consumption.

The input and reference voltages are scaled down internally by a factor 1408 / 4095 before being used in the ADC. It is possible to disable down-scaling of the ADC input, for increased resolution at the cost of reduced input range. Note that this changes the maximum input rating of the ADC input, and that higher voltages may damage the ADC.

The reference voltage can either be fixed (nominally 4.3 V for scaled-down input) or relative (nominally VDDS for scaled-down input).

The ADC values returned by adcReadFifo() are not compensated for offset and gain errors in the ADC. This compensation, using factory configuration data stored during chip production, can be done by using the AUX_ADC DriverLib module on the System CPU to:

  • Adjust ADC values sampled by the Sensor Controller (through the output data structure)
  • Unadjust ADC threshold values to be used in Sensor Controller task code (through the cfg data structure)

One or more instances of the Analog Pins resource must be used to enable sampling on analog-capable I/O pins.

Block Diagram

The block diagram shows signal routing for the ADC (with I/O pins for 7x7 RGZ package):

../_images/adc__0__light.png

ADC FIFO

The ADC FIFO can store between between 0 and 4 samples. Use the adcGetFifoStatus() procedure to get the current FIFO status:

  • BV_ADC_FIFO_EMPTY : The FIFO contains no samples
  • BV_ADC_FIFO_ALMOST_FULL : The FIFO contains exactly 3 samples
  • BV_ADC_FIFO_FULL : The FIFO contains exactly 4 samples
  • BV_ADC_FIFO_UNDERFLOW : FIFO underflow has occurred (the FIFO was read while empty)
  • BV_ADC_FIFO_OVERFLOW : FIFO overflow has occurred (a new sample was added while the FIFO was full)

If overflow or underflow occurs, the ADC FIFO will enter an error condition, where no more samples can be added to the FIFO. During the overflow condition, it is still possible to read the samples that are already in the FIFO. Use the adcFlushFifo() procedure to clear the error condition.

Examples

Sampling One Pin

// Select ADC input
adcSelectGpioInput(AUXIO_A_SENSOR_OUTPUT);

// Enable the ADC (fixed reference, 2.7 us sample time, manual trigger)
adcEnableSync(ADC_REF_FIXED, ADC_SAMPLE_TIME_2P7_US, ADC_TRIGGER_MANUAL);

// Sample the sensor and store the ADC value
adcGenManualTrigger();
adcReadFifo(output.adcValue);

// Disable the ADC
adcDisable();

Sampling Multiple Pins

// Enable the ADC (fixed reference, 2.7 us sample time, manual trigger)
adcEnableSync(ADC_REF_FIXED, ADC_SAMPLE_TIME_2P7_US, ADC_TRIGGER_MANUAL);

// For each pin (with one entry per pin in cfg.pAdcValue[] and output.pAdcValue[]) ...
for (U16 n = 0; n < SENSOR_OUTPUT_COUNT; n++) {

    // Select ADC input
    adcSelectGpioInput(cfg.pAuxioASensorOutput[n]);

    // Sample the pin and store the ADC value
    adcGenManualTrigger();
    adcReadFifo(output.pAdcValue[n]);
}

// Disable the ADC
adcDisable();

Procedures Overview

Name Brief description
adcDisable() Disables the ADC. More …
adcDisableInputScaling() Disables scaling of the ADC input. More …
adcEnableAsync() Enables the ADC for asynchronous operation, with continuous sampling between conversions. More …
adcEnableSync() Enables the ADC for synchronous operation, with a fixed sampling period before each conversion. More …
adcFlushFifo() Flushes the ADC FIFO. More …
adcGenManualTrigger() Generates a single manual ADC trigger. More …
adcGetFifoStatus() Returns flags indicating the status of the ADC FIFO. More …
adcPopFifo() Pops and returns the first sample from the FIFO. More …
adcReadFifo() Waits until there is at least one sample in the ADC FIFO, and then pops and returns the first sample from the FIFO. More …
adcSelectGpioInput() Selects a GPIO pin as input for the ADC. More …
adcSelectIntInput() Selects an internal voltage as input the ADC. More …

Constants

Name Description
ADC_INPUT_DCOUPL Selects DCOUPL as input, nominally 1.27 V
ADC_INPUT_VDDS Selects VDDS (supply voltage) as input, nominally VDDS
ADC_INPUT_VSS Selects VSS/GND (ground) as input, nominally 0.0 V
ADC_REF_FIXED Selects fixed reference, nominally 4.3 V
ADC_REF_VDDS_REL Selects relative reference, nominally VDDS
ADC_SAMPLE_TIME_10P6_US ADC sampling time: Sample the input for 10.6 us before converting
ADC_SAMPLE_TIME_10P9_MS ADC sampling time: Sample the input for 10.9 ms before converting
ADC_SAMPLE_TIME_170_US ADC sampling time: Sample the input for 170 us before converting
ADC_SAMPLE_TIME_1P37_MS ADC sampling time: Sample the input for 1.37 ms before converting
ADC_SAMPLE_TIME_21P3_US ADC sampling time: Sample the input for 21.3 us before converting
ADC_SAMPLE_TIME_2P73_MS ADC sampling time: Sample the input for 2.73 ms before converting
ADC_SAMPLE_TIME_2P7_US ADC sampling time: Sample the input for 2.7 us before converting
ADC_SAMPLE_TIME_341_US ADC sampling time: Sample the input for 341 us before converting
ADC_SAMPLE_TIME_42P6_US ADC sampling time: Sample the input for 42.6 us before converting
ADC_SAMPLE_TIME_5P3_US ADC sampling time: Sample the input for 5.3 us before converting
ADC_SAMPLE_TIME_5P46_MS ADC sampling time: Sample the input for 5.46 ms before converting
ADC_SAMPLE_TIME_682_US ADC sampling time: Sample the input for 682 us before converting
ADC_SAMPLE_TIME_85P3_US ADC sampling time: Sample the input for 85.3 us before converting
ADC_TRIGGER_AUXIO_HIGH_BASE ADC trigger: AUXIO (base + index) rising edge
ADC_TRIGGER_AUXIO_LOW_BASE ADC trigger: AUXIO (base + index) falling edge
ADC_TRIGGER_AUX_TIMER0 ADC trigger: Periodical, generated by the Timer 0 resource
ADC_TRIGGER_AUX_TIMER1 ADC trigger: Periodical, generated by the Timer 1 resource
ADC_TRIGGER_COMPA_HIGH ADC trigger: COMPA output rising edge
ADC_TRIGGER_COMPA_LOW ADC trigger: COMPA output falling edge
ADC_TRIGGER_MANUAL ADC trigger: Single, generated by calling adcGenManualTrigger()
BV_ADC_FIFO_ALMOST_FULL ADC FIFO flag: The FIFO is almost full (3 of 4 samples)
BV_ADC_FIFO_EMPTY ADC FIFO flag: The FIFO is empty
BV_ADC_FIFO_FULL ADC FIFO flag: The FIFO is full (4 of 4 samples)
BV_ADC_FIFO_OVERFLOW ADC FIFO flag: FIFO overflow has occurred
BV_ADC_FIFO_UNDERFLOW ADC FIFO flag: FIFO underflow has occurred

Global Variables

None.

Procedures

adcDisable

Prototype: adcDisable()

Disables the ADC.

adcDisableInputScaling

Prototype: adcDisableInputScaling()

Disables scaling of the ADC input. Scaling is enabled by default, and is always reenabled by adcDisable() .

This procedure must only be called while the ADC is disabled, before calling adcEnableSync() or adcEnableAsync() .

Note that different input maximum ratings apply when input scaling is disabled, and that violating these may damage the device.

adcEnableAsync

Prototype: adcEnableAsync(#refSource, #trigger)

Enables the ADC for asynchronous operation, with continuous sampling between conversions.

The ADC trigger starts the conversion. Note that the first conversion may be invalid if the initial sampling period is too short.

This procedure must only be called when the ADC is disabled. To change ADC configuration, call adcDisable() before re-enabling the ADC.

Parameter value(s)

  • #refSource : ADC reference source, either ADC_REF_FIXED or ADC_REF_VDDS_REL
  • #trigger : ADC trigger (ADC_TRIGGER_XYZ)

adcEnableSync

Prototype: adcEnableSync(#refSource, #sampleTime, #trigger)

Enables the ADC for synchronous operation, with a fixed sampling period before each conversion.

The ADC is idle between conversions, and the ADC trigger starts the sampling period before the conversion.

This procedure must only be called when the ADC is disabled. To change ADC configuration, call adcDisable() before re-enabling the ADC.

Parameter value(s)

  • #refSource : ADC reference source, either ADC_REF_FIXED or ADC_REF_VDDS_REL
  • #sampleTime : ADC sampling time before each conversion, ADC_SAMPLE_TIME_N_US or ADC_SAMPLE_TIME_N_MS
  • #trigger : ADC trigger (ADC_TRIGGER_XYZ)

adcFlushFifo

Prototype: adcFlushFifo()

Flushes the ADC FIFO. This empties the FIFO and clears the underflow/overflow flags.

Note: This procedure must only be called while the ADC is enabled.

adcGenManualTrigger

Prototype: adcGenManualTrigger()

Generates a single manual ADC trigger.

For synchronous mode, the trigger starts sampling followed by conversion.

For asynchronous mode, the trigger starts conversion.

adcGetFifoStatus

Prototype: adcGetFifoStatus(value)

Returns flags indicating the status of the ADC FIFO.

The flags indicate FIFO empty, full and almost full, and whether overflow/underflow has occurred.

Return value(s)

  • value : Currently active ADC status flags, that is zero or more BV_ADC_FIFO_XYZ constants OR’ed together

adcPopFifo

Prototype: adcPopFifo(value)

Pops and returns the first sample from the FIFO.

Note that this procedure causes ADC FIFO underflow if executed while the FIFO is empty.

Return value(s)

  • value : ADC value

adcReadFifo

Prototype: adcReadFifo(value)

Waits until there is at least one sample in the ADC FIFO, and then pops and returns the first sample from the FIFO.

Note that this procedure will deadlock under the following conditions:

  • ADC FIFO underflow has occurred
  • ADC FIFO overflow has occurred, and the FIFO has been read empty afterwards
  • The configured ADC trigger (for example an external signal) never occurs
  • During task debugging in Sensor Controller Studio, when using timer-based ADC trigger (AUX timers and RTC keep running while the Sensor Controller is halted)

Use instead a combination of adcGetFifoStatus() , adcPopFifo() and timeout, if such conditions are relevant for your application.

Return value(s)

  • value : ADC value

adcSelectGpioInput

Prototype: adcSelectGpioInput(auxio)

Selects a GPIO pin as input for the ADC.

Note that calling this procedure also selects the same input for COMPB.

Parameter value(s)

  • auxio : External input selection (index of AUX I/O pin)

adcSelectIntInput

Prototype: adcSelectIntInput(intInput)

Selects an internal voltage as input the ADC. This may be used for calibration and for measuring power supply voltage.

Note that calling this procedure also selects the same input for COMPB.

Parameter value(s)

  • intInput : Internal input selection: ADC_INPUT_VDDS, ADC_INPUT_DCOUPL or ADC_INPUT_VSS