Date: Mar. 20, 2023

# **RENESAS TECHNICAL UPDATE**

TOYOSU FORESIA, 3-2-24, Toyosu, Koto-ku, Tokyo 135-0061, Japan Renesas Electronics Corporation

| Product<br>Category   | MPU/MCU                                                                 |         | Document<br>No.         | TN-RA*-A0076A/E                     | Rev. | 1.00   |  |  |
|-----------------------|-------------------------------------------------------------------------|---------|-------------------------|-------------------------------------|------|--------|--|--|
| Title                 | The update on how to access RDR and SCI on the RA6T2 Group MCU Products |         | Information<br>Category | Technical Notification              |      |        |  |  |
| Applicable<br>Product | RA6T2 Group                                                             | Lot No. | Reference<br>Document   | RA6T2 Group Use<br>Hardware Rev.1.3 |      | iual : |  |  |

This document describes the update on how to access RDR and TDR of SCI in the RA6T2 Group User's Manual: Hardware, Rev.1.30.

#### Before correction

26.2.2 RDR: Receive Data Register

Base address:  $SCI_Bn = 0x4011_8000 + 0x0100 \times n (n = 0 \text{ to } 4, 9)$ 

Offset address: 0x00

| Bit position      | 31 | 30 | 29 | 28   | 27   | 26 | 25  | 24   | 23 | 22 | 21 | 20     | 19 | 18 | 17 | 16 |
|-------------------|----|----|----|------|------|----|-----|------|----|----|----|--------|----|----|----|----|
| Bit field         | -  | -  | -  | FER  | PER  | -  | -   | ORER | -  | -  | -  | -      | -  | -  | -  | -  |
| Value after reset | 0  | 0  | 0  | 0    | 0    | 0  | 0   | 0    | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0  |
|                   |    |    |    |      |      |    |     |      |    |    |    |        |    |    |    |    |
| Bit position      | 15 | 14 | 13 | 12   | 11   | 10 | 9   | 8    | 7  | 6  | 5  | 4      | 3  | 2  | 1  | 0  |
| Bit field         | -  | -  | -  | FFER | FPER | DR | MPB |      |    |    | R  | DAT[8: | 0] |    |    |    |
| Value after reset | 0  | 0  | 0  | 0    | 0    | 0  | 0   | 0    | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0  |

| Bit   | Symbol    | Function                                                                                                                                                                                                                                                   | R/W |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 8:0   | RDAT[8:0] | Serial receive data  RDAT is a 9-bit register for storing received data.  Received data is stored in [6:0] when 7-bit data is selected, in [7:0] when 8-bit data is selected, and in [8:0] when 9-bit data is selected. And 0 is stored in the unused bit. | R   |
| 9     | MPB       | Multi-processor flag 0: Data transmission cycles 1: ID transmission cycles                                                                                                                                                                                 | R   |
| 10    | DR        | Receive data ready flag<br>FRSR.DR can be read.                                                                                                                                                                                                            | R   |
| 11    | FPER      | FIFO parity error flag Valid only in Asynchronous mode 0: There is no parity error in the data read from the receive-FIFO 1: There is parity error in the data read from the receive-FIFO                                                                  | R   |
| 12    | FFER      | FIFO framing error flag Valid only in Asynchronous mode 0: There is no framing error in the data read from the receive-FIFO 1: There is framing error in the data read from the receive-FIFO                                                               | R   |
| 23:13 | -         | These bits are read as 0.                                                                                                                                                                                                                                  | R   |
| 24    | ORER      | Overrun Error flag CSR.ORER can be read.                                                                                                                                                                                                                   | R   |
| 26:25 | -         | These bits are read as 0.                                                                                                                                                                                                                                  | R   |
| 27    | PER       | Parity error flag CSR.PER can be read.                                                                                                                                                                                                                     | R   |
| 28    | FER       | Framing error flag CSR.FER can be read.                                                                                                                                                                                                                    | R   |
| 31:29 | -         | These bits are read as 0.                                                                                                                                                                                                                                  | R   |

In FIFO mode (CCR3.FM = 1), this register is 16-stage FIFO buffer configuration.

Date: Mar. 20, 2023

26.2.3 TDR: Transmit Data Register

Base address:  $SCI_Bn = 0x4011_8000 + 0x0100 \times n (n = 0 \text{ to } 4, 9)$ 

Offset address: 0x04

| Bit position      | 31 | 30 | 29 | 28        | 27 | 26 | 25   | 24          | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------------|----|----|----|-----------|----|----|------|-------------|----|----|----|----|----|----|----|----|
| Bit field         | -  | -  | -  | -         | -  | -  | -    | -           | -  | -  | -  | -  | -  | -  | -  | -  |
| Value after reset | 1  | 1  | 1  | 1         | 1  | 1  | 1    | 1           | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
|                   |    |    |    |           |    |    |      |             |    |    |    |    |    |    |    |    |
| Bit position      | 15 | 14 | 13 | 12        | 11 | 10 | 9    | 8           | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Bit field         | i  | -  | -  | TSYN<br>C | -  | -  | MPBT | T TDAT[8:0] |    |    |    |    |    |    |    |    |
| Value after reset | 1  | 1  | 1  | 1         | 1  | 1  | 1    | 1           | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

| Bit   | Symbol    | Function                                                                                                                                                                                                                                                                         | R/W |
|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 8:0   | TDAT[8:0] | Serial transmit data TDAT is a 9-bit register for setting transmit data. Transmit data is set in [6:0] when 7-bit data is selected, in [7:0] when 8-bit data is selected, and in [8:0] when 9-bit data is selected. When byte access, write TDR [15:8] and then write TDR [7:0]. | R/W |
| 9     | MPBT      | Multi-processor transfer bit flag Value of the multi-processor bit in the transmission frame. This bit is use in Asynchronous and Manchester mode. When writing to this bit when not used, write the initial value.  0: Data transmission cycles 1: ID transmission cycles       | R/W |
| 11:10 | -         | These bits are read as 1. The write value should be 1.                                                                                                                                                                                                                           | R/W |
| 12    | TSYNC     | Transmit SYNC data It is valid when MCR.SBSEL = 1 and MCR.SYNSEL = 1 in Manchester mode. When this bit is not used, write the initial value.  0: The Start Bit is transmitted as DATA SYNC.  1: The Start Bit is transmitted as COMMAND SYNC.                                    | R/W |
| 31:13 | -         | These bits are read as 1. The write value should be 1.                                                                                                                                                                                                                           | R/W |

In FIFO mode (CCR3.FM = 1), this register is 16-stage FIFO buffer configuration.

## 31.3.2 CRC Snoop Function

The CRC snoop function monitors reads from and writes to a specific register and performs CRC calculation on the monitored data automatically. Because the CRC snoop function recognizes writes to and reads from a specific register address as a trigger to automatically perform CRC calculation, there is no need to write data to the CRCDIR register. All I/O register specified in the section 31.2.5. CRCSAR: Snoop Address Register are subject to the CRC snoop. The CRC snoop is useful in monitoring writes to the SCIn.TDR (n = 0 to 4, 9) register, and reads from the SCIn.RDR (n = 0 to 4, 9) register. To use this function, write the lower address 14 bits of a specific register to bits CRCSA13 to CRCSA0 in the CRCSAR register, and set CRCSEN bit in the CRCCR1 register to 1. Then, set the CRCSWR bit in the CRCCR1 register to 1 to enable snooping on writes to the target register, or set the CRCSWR bit in the CRCCR1 register to 0 to enable snooping on reads from the target register. It is possible that access to a target I/O register may be executed before the CRCSWR bit write completed. In this case, the data is not stored in the CRCDIR register. To avoid this issue, before accessing I/O register, read back the CRCSWR bit that was written to confirm that the write completed.

When both the CRCSEN and CRCSWR bits are set to 1, and data is written to a target register in a bus master module such as the CPU, DMAC, and DTC, the CRC calculator stores the data in the CRCDIR register and performs CRC calculation. Similarly, when the CRCSEN bit is set to 1, CRCSWR bit to 0, and data is read from a target register in a bus master module such as the CPU, DMAC, and DTC, the CRC calculator stores the data in the CRCDIR register and performs CRC calculations.

When the CRC code is generated by using CRC-8, CRC-16, and CRC-CCITT generating polynomial, the target register is accessed in 1 byte (8 bits). Similarly, when the CRC code is generated by using CRC-32 and CRC-32C generating polynomial, the target register is accessed in words (32 bits).

When CPU is halted, CRC snoop operation is invalid.

When CRC is marked as secure by PSARC.PSARC1 bit, the CRC snoop function is available for secure access to the specified I/O registers. When CRC is marked as non-secure by PSARC.PSARC1 bit, the CRC snoop function is available for non-secure access to the specified I/O registers.

### Date: Mar. 20, 2023

# After correction

26.2.2 RDR/RDR\_BY : Receive Data Register Base address: SCI\_Bn =  $0x4011_8000 + 0x0100 \times n$  (n = 0 to 4, 9)

Offset address: 0x00

| Bit position      | 31 | 30 | 29 | 28   | 27   | 26 | 25  | 24   | 23 | 22  | 21 | 20      | 19 | 18 | 17  | 16 |
|-------------------|----|----|----|------|------|----|-----|------|----|-----|----|---------|----|----|-----|----|
| Bit field         | -  | -  | -  | FER  | PER  | -  | -   | ORER | -  | -   | -  | -       | -  | -  | -   | -  |
| Value after reset | 0  | 0  | 0  | 0    | 0    | 0  | 0   | 0    | 0  | 0   | 0  | 0       | 0  | 0  | 0   | 0  |
| Bit position      | 15 | 14 | 13 | 12   | 11   | 10 | 9   | 8    | 7  | 6   | 5  | 4       | 3  | 2  | 1   | 0  |
| Dit position      | 13 | 14 | 13 | 12   |      | 10 |     |      |    | - 0 |    | 7       |    |    | - 1 |    |
| Bit field         | -  | -  | -  | FFER | FPER | DR | MPB |      |    |     | R  | DAT[8:0 | 0] |    |     |    |
| Value after reset | 0  | 0  | 0  | 0    | 0    | 0  | 0   | 0    | 0  | 0   | 0  | 0       | 0  | 0  | 0   | 0  |

| Bit   | Symbol    | Function                                                                                                                                                                                                                                                                                           | R/W |
|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 8:0   | RDAT[8:0] | Serial receive data RDAT is a 9-bit register for storing received data. Received data is stored in [6:0] when 7-bit data is selected, in [7:0] when 8-bit data is selected, and in [8:0] when 9-bit data is selected. And 0 is stored in the unused bit.  Use RDR_BY for byte access to RDR [7:0]. | R   |
| 9     | MPB       | Multi-processor flag 0: Data transmission cycles 1: ID transmission cycles                                                                                                                                                                                                                         | R   |
| 10    | DR        | Receive data ready flag FRSR.DR can be read.                                                                                                                                                                                                                                                       | R   |
| 11    | FPER      | FIFO parity error flag Valid only in Asynchronous mode 0: There is no parity error in the data read from the receive-FIFO 1: There is parity error in the data read from the receive-FIFO                                                                                                          | R   |
| 12    | FFER      | FIFO framing error flag Valid only in Asynchronous mode 0: There is no framing error in the data read from the receive-FIFO 1: There is framing error in the data read from the receive-FIFO                                                                                                       | R   |
| 23:13 | -         | These bits are read as 0.                                                                                                                                                                                                                                                                          | R   |
| 24    | ORER      | Overrun Error flag CSR.ORER can be read.                                                                                                                                                                                                                                                           | R   |
| 26:25 | -         | These bits are read as 0.                                                                                                                                                                                                                                                                          | R   |
| 27    | PER       | Parity error flag CSR.PER can be read.                                                                                                                                                                                                                                                             | R   |
| 28    | FER       | Framing error flag CSR.FER can be read.                                                                                                                                                                                                                                                            | R   |
| 31:29 | -         | These bits are read as 0.                                                                                                                                                                                                                                                                          | R   |

In FIFO mode (CCR3.FM = 1), this register is 16-stage FIFO buffer configuration.

When using FIFO mode, use RDR for 32-bit access.

26.2.3 TDR/TDRLL/TDRLH : Transmit Data Register Base address: SCI\_Bn =  $0x4011_8000 + 0x0100 \times n$  (n = 0 to 4, 9)

Offset address: 0x04 (TDR/TDRLL) 0x05 (TDRLH)

| Bit position      | 31 | 30 | 29 | 28          | 27 | 26 | 25          | 24 | 23 | 22 | 21 | 20     | 19 | 18 | 17 | 16 |   |
|-------------------|----|----|----|-------------|----|----|-------------|----|----|----|----|--------|----|----|----|----|---|
| · ·               |    |    |    | <del></del> | :  |    | <del></del> |    |    |    |    |        |    |    | ı  |    | 1 |
| Bit field         | -  | -  | -  | -           | -  | -  | -           | -  | -  | -  | -  | -      | -  | -  | -  | -  |   |
| Value after reset | 1  | 1  | 1  | 1           | 1  | 1  | 1           | 1  | 1  | 1  | 1  | 1      | 1  | 1  | 1  | 1  | 3 |
| Bit position      | 15 | 14 | 13 | 12          | 11 | 10 | 9           | 8  | 7  | 6  | 5  | 4      | 3  | 2  | 1  | 0  | _ |
| Bit field         | -  | -  | -  | TSYN<br>C   | -  | -  | МРВТ        |    |    |    | Т  | DAT[8: | 0] |    |    |    |   |
| Value after reset | 1  | 1  | 1  | 1           | 1  | 1  | 1           | 1  | 1  | 1  | 1  | 1      | 1  | 1  | 1  | 1  | • |

| Bit   | Symbol    | Function                                                                                                                                                                                                                                                                                                                                                 | R/W |
|-------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 8:0   | TDAT[8:0] | Serial transmit data TDAT is a 9-bit register for setting transmit data. Transmit data is set in [6:0] when 7-bit data is selected, in [7:0] when 8-bit data is selected, and in [8:0] when 9-bit data is selected. When byte access, write TDR [15:8] and then write TDR [7:0].                                                                         | R/W |
| 9     | MPBT      | Use TDRLL for byte access to TDR [7:0], TDRLH for byte access to TDR [15:8].  Multi-processor transfer bit flag Value of the multi-processor bit in the transmission frame. This bit is use in Asynchronous and Manchester mode. When writing to this bit when not used, write the initial value.  0: Data transmission cycles 1: ID transmission cycles | R/W |
| 11:10 | -         | These bits are read as 1. The write value should be 1.                                                                                                                                                                                                                                                                                                   | R/W |

| Date: | ivia | r. ∠ | ٤υ, | 2023 | ·<br> |
|-------|------|------|-----|------|-------|
|       |      |      |     |      | . 1   |
|       |      | _    |     |      |       |

| 12    | TSYNC | Transmit SYNC data It is valid when MCR.SBSEL = 1 and MCR.SYNSEL = 1 in Manchester mode. When this bit is not used, write the initial value.  0: The Start Bit is transmitted as DATA SYNC.  1: The Start Bit is transmitted as COMMAND SYNC. | R/W |
|-------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| 31:13 | -     | These bits are read as 1. The write value should be 1.                                                                                                                                                                                        | R/W |

In FIFO mode (CCR3.FM = 1), this register is 16-stage FIFO buffer configuration. When using FIFO mode, use TDR for 32-bit access.

#### 31.3.2 CRC Snoop Function

The CRC snoop function monitors reads from and writes to a specific register and performs CRC calculation on the monitored data automatically. Because the CRC snoop function recognizes writes to and reads from a specific register address as a trigger to automatically perform CRC calculation, there is no need to write data to the CRCDIR register. All I/O register specified in the section 31.2.5. CRCSAR: Snoop Address Register are subject to the CRC snoop. The CRC snoop is useful in monitoring writes to the SCIn.TDR (n = 0 to 4, 9) register, and reads from the SCIn.RDR (n = 0 to 4, 9) register. To use this function, write the lower address 14 bits of a specific register to bits CRCSA13 to CRCSA0 in the CRCSAR register, and set CRCSEN bit in the CRCCR1 register to 1. Then, set the CRCSWR bit in the CRCCR1 register to 1 to enable snooping on writes to the target register, or set the CRCSWR bit in the CRCCR1 register to 0 to enable snooping on reads from the target register. It is possible that access to a target I/O register may be executed before the CRCSWR bit write completed. In this case, the data is not stored in the CRCDIR register. To avoid this issue, before accessing I/O register, read back the CRCSWR bit that was written to confirm that the write completed.

When both the CRCSEN and CRCSWR bits are set to 1, and data is written to a target register in a bus master module such as the CPU, DMAC, and DTC, the CRC calculator stores the data in the CRCDIR register and performs CRC calculation. Similarly, when the CRCSEN bit is set to 1, CRCSWR bit to 0, and data is read from a target register in a bus master module such as the CPU, DMAC, and DTC, the CRC calculator stores the data in the CRCDIR register and performs CRC calculations.

When the CRC code is generated by using CRC-8, CRC-16, and CRC-CCITT generating polynomial, the target register is accessed in 1 byte (8 bits). RDR\_BY and TDRLL should be used to access RDR and TDR.

Similarly, when the CRC code is generated by using CRC-32 and CRC-32C generating polynomial, the target register is accessed in words (32 bits). Note that for RDR and TDR, CRC codes are generated that contain data other than RDAT and TDAT.

When CPU is halted, CRC snoop operation is invalid.

When CRC is marked as secure by PSARC.PSARC1 bit, the CRC snoop function is available for secure access to the specified I/O registers. When CRC is marked as non-secure by PSARC.PSARC1 bit, the CRC snoop function is available for non-secure access to the specified I/O registers.

