43.6.1 Channel Context

Channel context refers to the unique set of control, status and data register configurations that define the operation of the ADC for a specific type of conversion. For example, if the ADC is configured for Burst Average mode, that configuration can be saved as a channel context. Up to four channel contexts can be configured for sequencing. Context information is stored in duplicated registers located in device memory and can only be accessed through the A/D Context Selection (ADCTX) Register or via Direct Memory Access (DMA).

Important: The ADCLK and ADACT registers are not included as part of a channel context.

The conversion clock rate selected by ADCLK and the auto-conversion trigger source selected by ADACT are used for all contexts. For example, if Context 1 enables the Timer1 overflow as the auto-conversion trigger source, the Timer1 overflow trigger will be used for all other contexts as well. If user software configures the auto-conversion trigger to use the Timer0 overflow as the trigger source for Context 2, Context 1 will be reconfigured in hardware to also use the Timer0 overflow as the trigger source.

The table below highlights the registers that are part of a context.

Table 43-4. ADC Context Registers
RegisterBit Pos.Bit 7Bit 6Bit 5Bit 4Bit 3Bit 2Bit 1Bit 0
ADCON0(1)7:0ONCONTCSENCSFMGO
ADCON17:0PPOLIPENGPOLDSEN
ADCON27:0PSISCRS[2:0]ACLRMD[2:0]
ADCON37:0 CALC[2:0]SOITMD[2:0]
ADSTAT7:0AOVUTHRLTHRMATHSTAT[2:0]
ADREF7:0NREFPREF[1:0]
ADPCH7:0PCH[5:0]
ADPRE7:0PRE[7:0]
15:8PRE[12:8]
ADACQ7:0ADACQ[7:0]
15:8ADACQ[12:8]
ADCAP7:0CAP[4:0]
ADRPT7:0RPT[7:0]
ADCNT7:0CNT[7:0]
ADFLTR7:0FLTR[7:0]
15:8FLTR[15:8]
ADRES7:0RES[7:0]
15:8RES[15:8]
ADPREV7:0PREV[7:0]
15:8PREV[15:8]
ADACC7:0ACC[7:0]
15:8ACC[15:8]
23:16ACC[17:16]
ADSTPT7:0STPT[7:0]
15:8STPT[15:8]
ADERR7:0ERR[7:0]
15:8ERR[15:8]
ADLTH7:0LTH[7:0]
15:8LTH[15:8]
ADUTH7:0UTH[7:0]
15:8UTH[15:8]
Note:
  1. The ADCON0 register is not included as part of a channel context with the exception of bit 6 (CONT).

The A/D Context Selection (ADCTX) register selects the context number that will be given read/write access. The A/D Context Display Select (CTXSW) bit is used to determine the read/write status of the A/D Channel Context Selection (CTX) bits, which are used to determine the channel context number.

When CTXSW is set (CTXSW = 1), the CTX bits display the context number the sequencer is currently scanning or the context number that was active when the sequencer stopped scanning due to a context threshold interrupt.

Important: When CTXSW is set, the CTX bits are read-only and may only be read while context sequencing is enabled (CSEN = 1).

When CTXSW is clear (CTXSW = 0), the CTX bits display the context number as selected by user software. Any context can be selected by writing the CTX bits with the desired context number.