34.7.1 Control A
Name: | CTRLA |
Offset: | 0x00 |
Reset: | 0x00000000 |
Property: | PAC Write-Protection, Enable-Protected Bits, Write-Synchronized Bits |
Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | |
DORD | CPOL | CMODE | FORM[3:0] | ||||||
Access | R/W | R/W | R/W | R/W | R/W | R/W | R/W | ||
Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
Bit | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | |
SAMPA[1:0] | RXPO[1:0] | TXPO[1:0] | |||||||
Access | R/W | R/W | R/W | R/W | R/W | R/W | |||
Reset | 0 | 0 | 0 | 0 | 0 | 0 |
Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |
SAMPR[2:0] | RXINV | TXINV | IBON | ||||||
Access | R/W | R/W | R/W | R/W | R/W | R/W | |||
Reset | 0 | 0 | 0 | 0 | 0 | 0 |
Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |
RUNSTDBY | MODE[2:0] | ENABLE | SWRST | ||||||
Access | R/W | R/W | R/W | R/W | R/W | R/W | |||
Reset | 0 | 0 | 0 | 0 | 0 | 0 |
Bit 30 – DORD Data Order
This bit selects the data order when a character is shifted out from the Data register.
Value | Description |
---|---|
0 | MSB is transmitted first. |
1 | LSB is transmitted first. |
Bit 29 – CPOL Clock Polarity
This bit selects the relationship between data output change and data input sampling in synchronous mode.
Value | TxD Change | RxD Sample |
---|---|---|
0x0 | Rising XCK edge | Falling XCK edge |
0x1 | Falling XCK edge | Rising XCK edge |
Bit 28 – CMODE Communication Mode
This bit selects asynchronous or synchronous communication.
Value | Description |
---|---|
0 | Asynchronous communication. |
1 | Synchronous communication. |
Bits 27:24 – FORM[3:0] Frame Format
These bits define the frame format.
Value | Description |
---|---|
0x0 | USART frame |
0x1 | USART frame with parity |
0x2 | LIN Host - Break and sync generation. See LIN Command (CTRLB.LINCMD). |
0x3 | Reserved |
0x4 | Auto-baud (LIN Client) - break detection and auto-baud. |
0x5 | Auto-baud - break detection and auto-baud with parity |
0x6 | Reserved |
0x7 | ISO 7816 |
0x8-0xF | Reserved |
Bits 23:22 – SAMPA[1:0] Sample Adjustment
These bits define the sample adjustment.
Value | 16x Over-sampling (CTRLA.SAMPR=0 or 1) | 8x Over-sampling (CTRLA.SAMPR=2 or 3) |
---|---|---|
0x0 | 7-8-9 | 3-4-5 |
0x1 | 9-10-11 | 4-5-6 |
0x2 | 11-12-13 | 5-6-7 |
0x3 | 13-14-15 | 6-7-8 |
Bits 21:20 – RXPO[1:0] Receive Data Pinout
These bits define the receive data (RxD) pin configuration.
Value | Name | Description |
---|---|---|
0x0 | PAD[0] | SERCOM PAD[0] is used for data reception |
0x1 | PAD[1] | SERCOM PAD[1] is used for data reception |
0x2 | PAD[2] | SERCOM PAD[2] is used for data reception |
0x3 | PAD[3] | SERCOM PAD[3] is used for data reception |
Bits 17:16 – TXPO[1:0] Transmit Data Pinout
These bits define the transmit data (TxD) and XCK pin configurations.
Value | TxD Pin Location | XCK Pin Location (When Applicable) | RTS/TE | CTS |
---|---|---|---|---|
0x0 | SERCOM PAD[0] | SERCOM PAD[1] | N/A | N/A |
0x1 | Reserved | |||
0x2 | SERCOM PAD[0] | N/A | SERCOM PAD[2] | SERCOM PAD[3] |
0x3 | SERCOM_PAD[0] | SERCOM_PAD[1] | SERCOM_PAD[2] | N/A |
Bits 15:13 – SAMPR[2:0] Sample Rate
These bits select the sample rate.
Value | Description |
---|---|
0x0 | 16x over-sampling using arithmetic baud rate generation. |
0x1 | 16x over-sampling using fractional baud rate generation. |
0x2 | 8x over-sampling using arithmetic baud rate generation. |
0x3 | 8x over-sampling using fractional baud rate generation. |
0x4 | 3x over-sampling using arithmetic baud rate generation. |
0x5-0x7 | Reserved |
Bit 10 – RXINV Receive Data Invert
This bit controls whether the receive data (RxD) is inverted or not.
- Start, parity and stop bit(s) are unchanged. When enabled, parity is calculated on the inverted data.
- This bit is enable-protected. This bit is not synchronized.
- This field is only valid when using ISO7816 T=0 mode (CTRLA.MODE=0x7).
Value | Description |
---|---|
0 | RxD is not inverted. |
1 | RxD is inverted. |
Bit 9 – TXINV Transmit Data Invert
This bit controls whether the transmit data (TxD) is inverted or not.
- Start, parity and stop bit(s) are unchanged. When enabled, parity is calculated on the inverted data.
- This bit is enable-protected. This bit is not synchronized.
- This field is only valid when using ISO7816 T=0 mode (CTRLA.MODE=0x7).
Value | Description |
---|---|
0 | TxD is not inverted. |
1 | TxD is inverted. |
Bit 8 – IBON Immediate Buffer Overflow Notification
This bit controls when the buffer overflow status bit (STATUS.BUFOVF) is asserted when a buffer overflow occurs.
Value | Description |
---|---|
0 | STATUS.BUFOVF is asserted when it occurs in the data stream. |
1 | STATUS.BUFOVF is asserted immediately upon buffer overflow. |
Bit 7 – RUNSTDBY Run In Standby
This bit defines the functionality in standby sleep mode.
Value | External Clock | Internal Clock |
---|---|---|
0x0 | External clock is disconnected when ongoing transfer is finished. All reception is dropped. | Generic clock is disabled when ongoing transfer is finished. The device will not wake up on Transfer Complete interrupt unless the appropriate ONDEMAND bits are set in the clocking chain. |
0x1 | Wake on Receive Complete interrupt. | Generic clock is enabled in all sleep modes. Any interrupt can wake up the device. |
Bits 4:2 – MODE[2:0] Operating Mode
These bits select the USART serial communication interface of the SERCOM.
Value | Description |
---|---|
0x0 | USART with external clock |
0x1 | USART with internal clock |
Bit 1 – ENABLE Enable
- This bit is write-synchronized: SYNCBUSY.ENABLE must be checked to ensure the CTRLA.ENABLE synchronization is complete.
- This bit is not enable-protected.
Value | Description |
---|---|
0 | The peripheral is disabled or being disabled. |
1 | The peripheral is enabled or being enabled. |
Bit 0 – SWRST Software Reset
Writing '0' to this bit has no effect.
Writing '1' to this bit resets all registers in the SERCOM, except DBGCTRL, to their initial state, and the SERCOM will be disabled.
Writing '1' to CTRLA.SWRST will always take precedence, meaning that all other writes in the same write-operation will be discarded. Any register write access during the ongoing reset will result in an APB error. Reading any register will return the reset value of the register.
- When the CTRLA.SWRST is written, the user must poll SYNCBUSY.SWRST bit to know when the reset operation is complete.
- During a SWRST, access to registers/bits without SWRST are disallowed until SYNCBUSY.SWRST is cleared by hardware.
- This bit is not enable protected.
Value | Description |
---|---|
0 | There is no reset operation ongoing. |
1 | The reset operation is ongoing. |