

Advanced 8-bit Micro-controller with 171K Flash ROM and Single CAN controllers



## **CS8961**

Advanced 8-bit Micro-controller with 171K Flash ROM and Single CAN controllers

Ver. 0.91



## CATALOG

| CHAPTER 1            | GENERAL                                                              | 7             |
|----------------------|----------------------------------------------------------------------|---------------|
| 1. GENERA            | L DESCRIPTION                                                        | 7             |
| 2. FEATUR            | =5                                                                   |               |
| CHAPTER 2            | BLOCK DIAGRAM                                                        | 8             |
| CHAPTER 3            | PIN CONFIGURATION                                                    | 9             |
| 1. PACKAG            | E TYPE                                                               | 9             |
| 2. PIN CON           | FIGURATION                                                           | 10            |
| CHAPTER 4            | MEMORY ALLOCATION                                                    | 14            |
| 1. INTERNA           | AL SPECIAL FUNCTION REGISTERS (SFR)                                  | 14            |
| 2. INTERNA           | AL RAM                                                               |               |
| 4 CAN REC            | AL SPECIAL FUNCTION REGISTERS (AFR)                                  | 14            |
| 5. AUXILIA           | RY RAM (AUXRAM)                                                      |               |
| CHAPTER 5            | MEMORY MAP OF XFR (0X0F000X0FFF)                                     | 15            |
| 1. CHIP CO           | NFIGURATION                                                          | 16            |
| CHAPTER 6            | HIGH PERFORMANCE ONE CYCLE 8 BIT MICRO-CONTROLLER                    | 18            |
| 1. INTRODI           |                                                                      |               |
| 2. INTERNA           | AL DATA MEMORY & SFRS ALLOCATION                                     | 18            |
| SFR Men              | погу Мар                                                             |               |
| CHAPTER 7            | SPECIAL SFR DEFINITION                                               | 20            |
| 1. PROGRA            | MWAIT STATES REGISTER                                                | 20            |
| 1.1 Wa               | ait-states Cycle Register (default 0X00)                             |               |
| 1.2 WIS              | I Register Values                                                    |               |
| 2.1 LAT/LA           | ess Control Register                                                 |               |
| 2.2 Addre            | ess Control                                                          | 20            |
| 2.3 Stack            | Pointer Register                                                     | 21            |
| Extended             | Stack Pointer Register                                               |               |
| 3. DATAPC            | JINTER EXTENDED REGISTERS<br>Pointor Extended Pagistor               |               |
| 3.1 Data             | Pointer Extended 1 Register                                          | 21            |
| 3.3 MOV              | X @Ri Extended High Register                                         |               |
| 4. RESERV            | ED REGISTER                                                          | 22            |
| 5. DATA PC           |                                                                      |               |
| 5.1 Data             | Pointer Register DPTR (default 0X0000)                               |               |
| 5.2 Data<br>5.3 Data | Pointer T Register DPTRT (delauit 0x0000)<br>nointer Select Register |               |
| DPTR0. I             | DPTR 1 operation                                                     |               |
| 6. CLOCK C           | CONTROL REGISTER-STRETCH BITS                                        | 23            |
| 6.1 Clock            | Control Register                                                     | 23            |
| 6.2 Clock            | Control Period                                                       |               |
| 7.1 TIMED A          | UUESS REGISTERS                                                      |               |
|                      |                                                                      |               |
| CHAPTER 8            |                                                                      | 25            |
| 1. INTERRU           | JPT VECTOR                                                           |               |
| 1.1 INT<br>1.2 Int   | errupt Errable Register                                              | 25<br>26      |
| 1.3 Ex               | ternal Interrupt Enable Register                                     |               |
|                      |                                                                      | Page 2 of 133 |



| 1.4 External Interrupt Priority Register                               | 26       |
|------------------------------------------------------------------------|----------|
| 1.5 External Interrupt Flag Register                                   | 26       |
| 1.8 Timer 0,1 Configuration Register                                   | 27       |
| 1.9 Timer 2 Configuration Register                                     | 27       |
| 1.10 UART0 Configuration Register                                      | 27       |
| 1.11 UART1Configuration Register                                       | 27       |
| 1.12 External Interrupt Registers                                      | 27       |
| CHAPTER 9 POWER SAVING UNIT                                            | 30       |
|                                                                        | 30       |
| 1.1 Stop Bit Power Configuration Register                              |          |
| 2. Power Management Mode                                               |          |
| 2.1 Power Management Register                                          |          |
| 2.2 Status Register                                                    | 31       |
| 2.3 Power Management Related Bit                                       | 31       |
| 3. Low Power Mode                                                      | 32       |
| 4. PMM AND PERIPHERALS                                                 | 32       |
| 5. SWITCHBACK FEATURE                                                  | 33       |
| 6. SWITCHBACK FEATURE TIMING                                           | 33       |
| CHAPTER 10 TIMERS                                                      | 34       |
|                                                                        | 24       |
| 1. TIMER U AND TIMER 1                                                 |          |
| 1.1 Timer 0, Timer1 Modes                                              |          |
| 1.2 Timer 0, Timer 1 Configuration Register                            | 34<br>31 |
| 1.3 Timer 0, Timer 1 Control Register                                  |          |
| 2 TIMER () OPERATION                                                   |          |
| 2.1 Mode ()                                                            |          |
| 2.2 Mode 1                                                             |          |
| 2.3 Mode 2                                                             |          |
| 3. TIMER 1 OPERATION                                                   | 37       |
| 3.1 Mode 0                                                             | 37       |
| 3.2 Mode 1                                                             | 37       |
| 3.3 Mode 2                                                             | 38       |
| 4. TIMER 2 OPERATION                                                   | 38       |
| 4.1 Capture Mode                                                       | 38       |
| Timer 2 Configuration Register                                         |          |
| 4.2 Auto-Reload Mode (Up or Down Counter)                              | 40       |
| Timer2 12MOD Register                                                  | 40       |
| 4.3 Baud Rate Generator Mode                                           |          |
| CHAPTER 11 SERIAL PORTS (UARTS)                                        | 43       |
| 1. UART0                                                               | 43       |
| UART0 Buffer Register                                                  | 43       |
| UART0 Configuration Register                                           | 43       |
| UART0 Bits In Power Configuration Register                             | 44       |
| URAT0 Bits In Interrupt Enable Register                                | 44       |
| URAT0 Bits In Interrupt Priority Register                              | 44       |
| 1.1 MODE 0 , SYNCHRONOUS                                               | 45       |
| 1.2 MODE 1, 8-BIT UART, VARIABLE BAUD RATE, TIMER 1 OR 2 CLOCK SOURCES | 45       |
| 1.3 MODE 2, 9-BIT UART, FIXED BAUD RATE                                |          |
| 1.4 MODE 3, 9-BIT UART, VARIABLE BAUD RATE, TIMER 1 OR 2 CLOCK SOURCES |          |
| 2. UAKI1                                                               |          |
| UARII Butter Register                                                  |          |
| UARTI CONTIGURATION REGISTER                                           | 41       |
| UARTI DIIS IN POWER CONIIgURATION REGISTER                             |          |
| URATI DIS III III.eriupi Eriable Register                              | 48<br>40 |
| UTAT I DIS III III.ettupi Fliolity Register                            | 48       |



| 2.1 MODE 0, SYNCHRONOUS                                          | 48         |
|------------------------------------------------------------------|------------|
| 2.2 MODE 1, 8-BIT UART, VARIABLE BAUD RATE, TIMER 1 CLOCK SOURCE | 48         |
| 2.3 MODE 2, 9-BIT UART, FIXED BAUD RATE                          | 49         |
| 2.4 MODE 3, 9-BIT UART, VARIABLE BAUD RATE, TIMER 1 CLOCK SOURCE | 49         |
|                                                                  | 50         |
| CHAFTER 12 MDU - MULTIFLICATION AND DIVISION UNIT                |            |
| MDU Registers Location                                           | 50         |
| ARCON Registers                                                  | 50         |
| MDU Operations Timing                                            | 50         |
| 1. DIVISION AND MULTIPLICATION OPERATIONS                        | 51         |
| 1.1 WRITE SEQUENCE                                               | 51         |
| 1.2 READ SEQUENCE                                                | 51         |
| 2. NORMALIZE OPERATION                                           | 52         |
| 2.1 WRITE SEQUENCE                                               | 52         |
| 2.2 READ SEQUENCE                                                | 52         |
| 3. Shift Operation                                               | 52         |
| 3.1 WRITE SEQUENCE                                               |            |
| 3.2 READ SEQUENCE                                                |            |
| 4. MDU ERROR FLAG                                                |            |
| 5. MDU OVERFLOW FLAG                                             | 53         |
| CHAPTER 13 DI2CM - MASTER IIC BUS CONTROLLER                     | 54         |
|                                                                  | <b>F</b> 4 |
|                                                                  |            |
| 1.1 THE IZC-BUS CONCEPT                                          |            |
|                                                                  | 54         |
| 1.2 TRANSFERRING DATA                                            |            |
| 1.3 DIT TRANSFER                                                 |            |
| 1.4 DATA VALIDITT                                                |            |
| 1.6 RVTE EODMAT                                                  |            |
| 1.0 BTTE FORMAT                                                  |            |
| 1.8 CLOCK SVNCHRONIZATION                                        |            |
| 1.0 OLOOK STNOLIKONIZATION                                       |            |
| 1 10 DATA FORMAT WITH 7-BIT ADDRESS                              |            |
| 2 INTERNAL REGISTERS                                             |            |
| 2 1 I2CMTP - TIMER PERIOD REGISTER                               |            |
| 2.2 I2CMCR - CONTROL AND STATUS REGISTERS                        |            |
| 3. AVAILABLE COMMAND SEQUENCES                                   |            |
| 3.1 SINGLE SEND.                                                 |            |
| 3.2 SINGLE RECEIVE                                               | 64         |
| 3.3 BURST SEND                                                   |            |
| 3.4 BURST RECEIVE                                                | 67         |
| 3.5 BURST RECEIVE AFTER BURST SEND                               | 68         |
| 3.6 BURST SEND AFTER BURST RECEIVE                               | 69         |
|                                                                  | 70         |
| CHAPTER 14 SLAVE IIC                                             |            |
| 1. SLAVEB 0 IIC AND SLAVE B 1 IIC                                | 70         |
| 2. SLAVEB 0 IIC XFR                                              | 71         |
| 3. SLAVE B 1 IIC XFR                                             | 72         |
| CHAPTER 15 SPI                                                   | 74         |
|                                                                  |            |
| SPI Timing Illustration                                          | 76         |
| CHAPTER 16 ISP                                                   | 70         |
|                                                                  |            |
| 1. JTAG ISP                                                      | 79         |
| 2. UART ISP                                                      | 80         |
| CHAPTER 17 WATCHDOG TIMER                                        |            |
|                                                                  |            |



| 1. WATCHDOG TIMER RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2. SIMPLE TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3. SYSTEM MONITOR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4. WATCHDOG RELATED REGISTERS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4.1 WATCHDOG CONTROL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4.2 CLOCK CONTROL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| CHAPTER 18 RTC OPERATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 84                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 84                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | +0<br>8 <i>1</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3 SAMPI ING TIMEP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4 RTC REGISTER DEFINITIONS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| CHAPTER 19 PWM DAC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 02                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CHAPTER 20 LOW VOLTAGE DETECTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| CHAPTER 21 ECT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 93                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1. ECT2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3.1 Capture Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3.2 Auto-Reload Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2. ECT3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4.1 Capture Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4.2 Auto-Reload Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3. ECT5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6.1 Capture Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6.2 Auto-Reload Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CHAPTER 22 JTAG TAP CONTROLLER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| CHAPTER 22 JTAG TAP CONTROLLER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| CHAPTER 22 JTAG TAP CONTROLLER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION<br>2. REGISTERS DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | <b></b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <b>101</b><br>101<br>101<br>101<br>101                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | <b>101</b><br>101<br>101<br>101<br>101<br>102                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <b>101</b><br>101<br>101<br>101<br>101<br>102<br>104                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION<br>2. REGISTERS DESCRIPTION<br>2.1 Registers mapping<br>CAN0 Registers Mapping<br>2.2 Registers Function Description<br>Mode Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>101</b> 101 101 101 101 102 104 104                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>101</b> 101 101 101 101 102 104 104 105                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>101</b> 101 101 101 101 102 104 104 105 106                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register .<br>Command Register .<br>Status Register.<br>Interrupt Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <b>101</b> 101 101 101 101 102 104 104 105 106 108                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register .<br>Command Register .<br>Status Register .<br>Interrupt Register .<br>Interrupt Enable Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>101</b> 101 101 101 101 102 104 104 105 106 108 109                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register.<br>Command Register.<br>Status Register.<br>Interrupt Register.<br>Interrupt Register.<br>Bus Timing Register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <b>101</b> 101 101 101 101 102 104 104 105 106 108 109 110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2. 1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register.<br>Command Register.<br>Command Register.<br>Interrupt Register.<br>Interrupt Register.<br>Interrupt Enable Register.<br>Bus Timing Register.<br>Filter Enable Register.                                                                                                                                                                                                                                                                                                                                                                                                                                | <b>101</b> 101 101 101 101 102 104 104 105 106 108 109 110                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2. 1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register .<br>Command Register .<br>Status Register .<br>Interrupt Register .<br>Interrupt Register .<br>Interrupt Enable Register .<br>Bus Timing Register .<br>Filter Enable Register .<br>Arbitration Lost Capture Register .                                                                                                                                                                                                                                                                                                                                                                                  | <b>101</b> 101 101 101 101 102 104 104 104 105 106 108 109 110 111 114                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION<br>2. REGISTERS DESCRIPTION<br>2. 1 Registers mapping<br>CAN0 Registers Mapping<br>2.2 Registers Function Description<br>Mode Register<br>Command Register<br>Status Register<br>Interrupt Register<br>Interrupt Register<br>Interrupt Enable Register<br>Filter Enable Register<br>Arbitration Lost Capture Register<br>Error Code Capture Register                                                                                                                                                                                                                                                                                                                                                                                                 | <b>101</b> 101 101 101 101 102 104 104 104 105 106 108 109 110 111 114 114                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| CHAPTER 22 JTAG TAP CONTROLLER.<br>CHAPTER 23 CAN CONTROLLER.<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register .<br>Command Register .<br>Command Register .<br>Status Register .<br>Interrupt Register .<br>Interrupt Register .<br>Interrupt Enable Register .<br>Filter Enable Register .<br>Filter Enable Register .<br>Arbitration Lost Capture Register .<br>Error Code Capture Register .<br>Error Warning Limit Register                                                                                                                                                                                                                                                                                       | <b>101</b> 101 101 101 101 102 104 104 105 106 108 109 110 111 111 114 116 117                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CHAPTER 22 JTAG TAP CONTROLLER.<br>CHAPTER 23 CAN CONTROLLER.<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register<br>Command Register<br>Command Register<br>Status Register<br>Interrupt Register<br>Interrupt Enable Register<br>Bus Timing Register<br>Filter Enable Register<br>Filter Enable Register<br>Arbitration Lost Capture Register<br>Error Code Capture Register<br>Error Warning Limit Register<br>Receive Error Counter Register<br>Receive Error Counter Register                                                                                                                                                                                                                                        | <b>101</b> 101 101 101 101 102 104 104 104 105 106 108 109 110 111 114 114 116 117 118                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| CHAPTER 22 JTAG TAP CONTROLLER.<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers Mapping.<br>CANO Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register .<br>Command Register .<br>Command Register .<br>Interrupt Register .<br>Interrupt Register .<br>Interrupt Enable Register .<br>Bus Timing Register .<br>Filter Enable Register .<br>Fror Code Capture Register .<br>Error Warning Limit Register .<br>Receive Error Counter Register .<br>Transmit Error Counter Register                                                                           | <b>101</b> 101 101 101 101 101 102 104 104 104 105 106 108 109 110 111 114 114 116 117 118 118                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CHAPTER 22 JTAG TAP CONTROLLER.<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers Mapping.<br>CANO Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register .<br>Command Register .<br>Command Register .<br>Interrupt Register .<br>Interrupt Register .<br>Interrupt Enable Register .<br>Bus Timing Register .<br>Filter Enable Register .<br>Fror Code Capture Register .<br>Error Warning Limit Register .<br>Receive Error Counter Register .<br>Transmit Error Counter Register .<br>Received Frame Counter Register                                                                  | 101         101         101         101         101         101         101         101         101         101         102         104         105         106         108         109         110         111         114         115         116         117         118         118         118                                                                                                                                                                                                                                                                                                                                                           |
| CHAPTER 22 JTAG TAP CONTROLLER.<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION<br>2. REGISTERS DESCRIPTION<br>2.1 Registers Mapping<br>CANO Registers Mapping<br>2.2 Registers Function Description<br>Mode Register<br>Command Register<br>Status Register<br>Interrupt Register<br>Interrupt Register<br>Bus Timing Register<br>Filter Enable Register<br>Filter Enable Register<br>Arbitration Lost Capture Register<br>Error Code Capture Register<br>Error Warning Limit Register<br>Receive Error Counter Register<br>Transmit Error Counter Register<br>Received Frame Counter Register<br>Received Frame Information Register<br>Received Frame Information Register                                                                                                                                                       | 101         101         101         101         101         101         101         101         101         101         102         104         105         106         108         109         110         111         114         115         116         117         118         118         118         118         118         118                                                                                                                                                                                                                                                                                                                       |
| CHAPTER 22 JTAG TAP CONTROLLER.<br>CHAPTER 23 CAN CONTROLLER.<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CANO Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register.<br>Command Register.<br>Status Register.<br>Interrupt Register.<br>Interrupt Register.<br>Interrupt Enable Register.<br>Bus Timing Register.<br>Filter Enable Register.<br>Filter Enable Register.<br>Arbitration Lost Capture Register.<br>Error Code Capture Register.<br>Error Warning Limit Register.<br>Receive Error Counter Register.<br>Receive Error Counter Register.<br>Received Frame Counter Register.<br>Received Frame Information Register.<br>Transmit Buffer.                                                                                                                        | 101         101         101         101         101         101         101         101         101         102         104         105         106         108         109         110         111         114         115         116         117         118         118         118         118         119                                                                                                                                                                                                                                                                                                                                               |
| CHAPTER 22 JTAG TAP CONTROLLER.<br>CHAPTER 23 CAN CONTROLLER.<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2. 1 Registers Description.<br>2. 1 Registers Mapping.<br>CANO Registers Mapping.<br>2. 2 Registers Function Description.<br>Mode Register<br>Command Register<br>Status Register.<br>Interrupt Register.<br>Interrupt Register.<br>Interrupt Enable Register.<br>Bus Timing Register.<br>Filter Enable Register.<br>Filter Enable Register.<br>Filter Enable Register.<br>Filter Enable Register.<br>Firor Code Capture Register.<br>Error Code Capture Register.<br>Error Warning Limit Register.<br>Receive Error Counter Register.<br>Receive Frame Counter Register.<br>Received Frame Counter Register.<br>Received Frame Information Register.<br>Transmit Buffer.<br>Transmit Frame Information Register. | 101         101         101         101         101         101         101         101         101         102         104         105         106         108         109         110         111         114         115         116         117         118         118         118         119         120                                                                                                                                                                                                                                                                                                                                               |
| CHAPTER 22 JTAG TAP CONTROLLER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 101         101         101         101         101         101         101         101         102         104         105         106         108         109         110         111         114         115         106         108         109         110         111         114         115         116         117         118         118         118         118         119         120                                                                                                                                                                                                                                                           |
| CHAPTER 22 JTAG TAP CONTROLLER.<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CANO Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register .<br>Command Register .<br>Command Register .<br>Command Register .<br>Interrupt Register .<br>Interrupt Register .<br>Interrupt Enable Register .<br>Bus Timing Register .<br>Filter Enable Register .<br>Filter Enable Register .<br>Friter Enable Register .<br>Error Code Capture Register .<br>Error Warning Limit Register .<br>Receive Error Counter Register .<br>Received Frame Counter Register .<br>Received Frame Counter Register .<br>Transmit Error Transmit Enformation Register .<br>Transmit Buffer .<br>Transmit Frame Information Register .<br>Data field                           | 101         101         101         101         101         102         104         105         106         108         109         110         111         114         115         106         108         109         110         111         114         115         106         108         109         110         111         111         114         115         116         117         118         118         118         119         120         120         121                                                                                                                                                                                   |
| CHAPTER 22 JTAG TAP CONTROLLER.<br>CHAPTER 23 CAN CONTROLLER.<br>1. CAN CONTROLLER FUNCTION DESCRIPTION.<br>2. REGISTERS DESCRIPTION.<br>2.1 Registers mapping.<br>CAN0 Registers Mapping.<br>2.2 Registers Function Description.<br>Mode Register .<br>Command Register .<br>Command Register .<br>Interrupt Register .<br>Interrupt Enable Register .<br>Bus Timing Register .<br>Filter Enable Register .<br>Arbitration Lost Capture Register .<br>Error Code Capture Register .<br>Error Warning Limit Register .<br>Receive Error Counter Register .<br>Received Frame Counter Register .<br>Received Frame Information Register .<br>Transmit Buffer .<br>Transmit Frame Information Register .<br>Data field .<br>Filter Status Registers                                                                                                          | 101         101         101         101         101         102         104         105         106         108         109         110         111         114         115         106         108         109         110         111         114         115         106         108         109         110         111         114         115         116         117         118         118         118         119         120         121         122                                                                                                                                                                                               |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION<br>2. REGISTERS DESCRIPTION<br>2. 1 Registers Mapping<br>CANO Registers Mapping<br>CANO Registers Function Description<br>Mode Register<br>Command Register<br>Status Register<br>Interrupt Register<br>Interrupt Enable Register<br>Interrupt Enable Register<br>Filter Enable Register<br>Filter Enable Register<br>Arbitration Lost Capture Register<br>Error Code Capture Register<br>Error Warning Limit Register<br>Receive Error Counter Register<br>Receive Frame Counter Register<br>Transmit Error Counter Register<br>Received Frame Information Register<br>Transmit Buffer<br>Transmit Frame Information Register<br>Data field<br>Filter Status Registers<br>Dispatch Time Registers<br>Dispatch Time Registers                        | 101         101         101         101         101         102         104         105         106         108         109         110         111         114         115         106         108         109         110         111         114         115         106         107         108         109         110         111         111         111         111         111         111         111         111         111         111         111         111         111         111         111         111         112         113         114         115         116         117         118         118         119         120         1 |
| CHAPTER 22 JTAG TAP CONTROLLER<br>CHAPTER 23 CAN CONTROLLER<br>1. CAN CONTROLLER FUNCTION DESCRIPTION<br>2. REGISTERS DESCRIPTION<br>2. 1 Registers mapping<br>CAN0 Registers Mapping<br>2.2 Registers Function Description<br>Mode Register<br>Command Register<br>Command Register<br>Status Register<br>Interrupt Register<br>Interrupt Enable Register<br>Bus Timing Register<br>Filter Enable Register<br>Filter Enable Register<br>Filter Enable Register<br>Error Code Capture Register<br>Error Warning Limit Register<br>Receive Error Counter Register<br>Received Frame Information Register<br>Transmit Error Counter Register<br>Received Frame Information Register<br>Transmit Frame Information Register<br>Transmit Frame Information Register<br>Transmit Frame Information Register<br>Dispatch Time Registers<br>3. BASIC FUNCTION.    | 101         101         101         101         101         102         104         105         106         108         109         110         111         114         115         106         108         109         110         111         111         114         115         110         111         111         111         112         113         114         115         116         117         118         118         118         119         120         121         122         125         126                                                                                                                                               |



| 3.2 Proper setting of Operating mode and Silent mode | 126 |
|------------------------------------------------------|-----|
| 3.3 Proper setting of Baud Rate                      | 126 |
| 3.4 The setting of the acceptance filter             | 127 |
| 4. Advanced Function                                 | 131 |
| 4.1 Dispatch                                         | 131 |
| 5. CAN TEST                                          | 131 |
| 5.1 Self Loop Test                                   | 131 |
| CAN0 In Self Loop Test                               | 131 |
| CHAPTER 24 PACKAGE OUTLINE                           | 132 |
| 1. PACKAGE OUTLINE                                   | 132 |
| 64-pin LQFP                                          | 132 |



## Advanced 8-bit Micro-controller with 171K Flash ROM and Single CAN controllers

#### CHAPTER 1 GENERAL

#### **1. GENERAL DESCRIPTION**

The CS8961 micro-controller is a single-cycle 8051 CPU core embedded device. It includes a 171K-byte internal program Flash ROM, a 256-byte internal RAM, and a 4K-byte auxiliary RAM. It also includes some advanced peripherals such as 2-channels CAN ports, 9 channels of general PWM output ports as well as a Real Time Clock (RTC) module. The Boot-Code-Free ISP (In System Programming) feature allows users to update the programming codes easily via JTAG ports or a UART port. In addition, user can debug system at real time via JTAG interface.

#### 2. FEATURES

- Single Cycle 8051 CPU core, maximum operating clock up to 20 MHz
- Single + 5V (CS8961) power supply
- Embedded 171K-byte Flash ROM
- 4352-byte RAM
  - 256-byte Internal RAM
  - 4K-byte Auxiliary RAM
- 8 channels general PWM outputs
- 6 channel of 8-bit supporting Programmable PWM output frequency 2 channel of 8-bit supporting Programmable PWM output frequency (100 Hz ~ 100KHz) output frequency with 4-bits flexible time base period

- Maximum 39 I/O pins
- ECC generation with 1-bit correction
- Three 16-bit Counters/Timers
- One programmable buffered clock output ports to drive peripheral devices
- Built-in one Master and two Slave I<sup>2</sup>C ports
- Built-in SPI controller
- Hardware ISP (In-System-Programming), no Boot Code required
- Two Full-duplex UARTS
- Built-in one CAN controller according to CAN protocol version 2.0B.
- Multi interrupt sources
- Programmable Watch Dog Timer.
- Built-in Real Time Clock (RTC),
- Dual Data Pointer (DPTR)
- Flash-ROM program code protection
- JTAG interface Debug System.
- Industrial operating temperature range (-40°C ~ +85°C)
- 64-pin LQFP packages
- Green packages available



### CHAPTER 2 BLOCK DIAGRAM



Figure-1 Block Diagram



#### CHAPTER 3 PIN CONFIGURATION

#### **1. PACKAGE TYPE**



Figure-2 Package Type



#### 2. PIN CONFIGURATION

A "CMOS pin" can be used as Input or Output mode. To use these pins as output mode, S/W needs to set the corresponding output enable control bit to 1. Otherwise, the output enable control bit should clear to 0. In output mode, these pins can sink and drive at least 4mA current.

An "open drain pin" means it can sink at least 4mA current but no drive current to VDD. It can be used as input or output function and need an external pull up resistor.

An "8051 standard pin" is a pseudo open drain pin. It can sink at least 4mA current when output low level, and drive at least 4mA current for 160nS when output transit from low to high, then keep drive 100uA to maintain the pin at high level. It can be used as input or output function. It need an external pull up resistor when drive heavy load device.

The pins functionality is described in the following table. All pins are one directional. There are no three states outputs pins and internal signals.

| Namo     | Pin No. | Pin Type |         | Default      | Pin           | Eurotion Description                                     |  |
|----------|---------|----------|---------|--------------|---------------|----------------------------------------------------------|--|
| Name     | LQFP    | Туре     | Default | Function     | Configuration | Function Description                                     |  |
| P10/T2   | 1       | I/O      | I       | P10          | 5             | General purpose I/O / External Timer 2<br>Input;         |  |
| P11/ET2  | 2       | I/O      | I       | P11          | 5             | General purpose I/O / External Timer 2 trigger Input     |  |
| P12/RX1  | 3       | I/O      | I       | P12          | 5             | General purpose I/O / UART1 serial<br>receiver input     |  |
| P13/TX1  | 4       | I/O      | Ι       | P13          | 5             | General purpose I/O / UART1 serial<br>transmitter output |  |
| P14/INT2 | 5       | I/O      | I       | P14          | 5             | General purpose I/O / External interrupt 2               |  |
| RTC_VDD  | 6       | -        | -       | RTC_VDD      | -             | RTC Power Supply                                         |  |
| RTC_X1   | 7       | I        | I       | RTC_X1       | С             | RTC clock input                                          |  |
| RTC_X2   | 8       | 0        | 0       | RTC_X2       | С             | RTC clock output                                         |  |
| RTC_VSS  | 9       | -        | -       | RTC_VSS      | -             | RTC ground                                               |  |
| P15/INT3 | 10      | I/O      | I       | P15          | С             | General purpose I/O / External interrupt 3               |  |
| P16/INT4 | 11      | I/O      | I       | P16          | С             | General purpose I/O / External interrupt 4               |  |
| P17/INT5 | 12      | I/O      | I       | P17          | С             | General purpose I/O / External interrupt 5               |  |
| JTAG-RST | 13      | I        | I       | JTAG-<br>RST | D             | Reset JTAG module                                        |  |
| JTAG-IN  | 14      | I        | I       | JTAG-IN      | U             | JTAG input                                               |  |
| JTAG-SEL | 15      | I        | Ι       | JTAG-<br>SEL | U             | JTAG mode select                                         |  |
| JTAG-CLK | 16      | I        | I       | JTAG-<br>CLK | D             | JTAG clock input                                         |  |
| JTAG-OUT | 17      | 0        | 0       | JTAG-<br>OUT | U             | JTAG output                                              |  |
| P30/RX0  | 18      | I/O      | I       | P30          | 5             | General purpose I/O / UART0 serial<br>receiver input     |  |
| P31/TX0  | 19      | I/O      | Ι       | P31          | 5             | General purpose I/O / UART0 serial<br>transmitter output |  |
| P32/INT0 | 20      | I/O      | Ι       | P32          | 5             | General purpose I/O / External interrupt 0               |  |
| P33/INT1 | 21      | I/O      | I       | P33          | 5             | General purpose I/O / External interrupt 1               |  |
| P34/T0   | 22      | I/O      | I       | P34          | 5             | General purpose I/O / timer 0 input                      |  |

Page 10 of 133

| Namo           | Pin No. | Pin Type |         | Default  | Pin           | Eunction Description                                                         |  |  |
|----------------|---------|----------|---------|----------|---------------|------------------------------------------------------------------------------|--|--|
| Name           | LQFP    | Туре     | Default | Function | Configuration | Tunction Description                                                         |  |  |
| P35/T1         | 23      | I/O      | I       | P35      | 5             | General purpose I/O / timer 1 input                                          |  |  |
| X1             | 24      | I        | I       | X1       | С             | Oscillator input                                                             |  |  |
| X2             | 25      | 0        | 0       | X2       | С             | Oscillator output                                                            |  |  |
| VDD5           | 26      | -        | -       | VDD5     | -             | +5V Positive Power Supply                                                    |  |  |
| VSS5           | 27      | -        | -       | VSS5     | -             | Ground                                                                       |  |  |
| V25            | 28      | -        | -       | V25      | -             | +2.5V Positive Power Output                                                  |  |  |
| P44/SDA0       | 29      | I/O      | I       | P44      | OU            | General purpose I/O / Slave IIC 0 bus serial data line                       |  |  |
| P45/SCL0       | 30      | I/O      | I       | P45      | OU            | General purpose I/O / Slave IIC 0 bus clock line                             |  |  |
| P46/SDA1       | 31      | I/O      | I       | P46      | OU            | General purpose I/O / Slave IIC 1 bus serial data line                       |  |  |
| P47/SCL1       | 32      | I/O      | I       | P47      | OU            | General purpose I/O / Slave IIC 1 bus clock line                             |  |  |
| P56            | 33      | I/O      | I       | P56      | С             | General purpose I/O                                                          |  |  |
| P57            | 34      | I/O      | I       | P57      | С             | General purpose I/O                                                          |  |  |
| NC             | 35      | -        | -       | NC       | -             | NC                                                                           |  |  |
| NC             | 36      | -        | -       | NC       | -             | NC                                                                           |  |  |
| VSS            | 37      | -        | -       | VSS      | -             | Ground                                                                       |  |  |
| VSS            | 38      | -        | -       | VSS      | -             | Ground                                                                       |  |  |
| P60/PWM0       | 39      | I/O      | I       | P60      | OU            | General purpose I/O / 14-bit PWM DAC output                                  |  |  |
| P61/PWM2       | 40      | I/O      | I       | P61      | OU            | General purpose I/O / 8-bit PWM DAC output                                   |  |  |
| P62/PWM4       | 41      | I/O      | I       | P62      | OU            | General purpose I/O / 8-bit PWM DAC output                                   |  |  |
| P63/PWM6       | 42      | I/O      | I       | P63      | OU            | General purpose I/O / 8-bit PWM DAC output                                   |  |  |
| P66            | 43      | I/O      | I       | P66      | С             | General purpose I/O                                                          |  |  |
| V25            | 44      | -        | -       | V25      | -             | 2.5V external compensate capacitor                                           |  |  |
| P72/ET2T/SCS   | 45      | I/O      | I       | P72      | 5             | General purpose I/O / ECT2 Input / SPI chip select.                          |  |  |
| P73/ET2ET/MOSI | 46      | I/O      | I       | P73      | 5             | General purpose I/O / ECT2 trigger Input /SPI Master output and Slave input. |  |  |
| P74/ET3T/MISO  | 47      | I/O      | I       | P74      | 5             | General purpose I/O / ECT3 Input / SPI<br>Master input and Slave output.     |  |  |
| P75/ET3ET/MSCK | 48      | I/O      | Ι       | P75      | 5             | General purpose I/O / ECT3 trigger Input / SPI Master clock output.          |  |  |
| MD2            | 49      | I        | I       | MD2      | D             | Work mode select                                                             |  |  |
| MD1            | 50      | I        | Ι       | MD1      | D             | Work mode select                                                             |  |  |
| MD0            | 51      | I        | Ι       | MDO      | D             | Work mode select                                                             |  |  |
| RSTN           | 52      | I        | I       | RSTN     | U             | Active low reset.                                                            |  |  |
| P84/MDA        | 53      | I/O      | Ι       | P84      | OU            | General purpose I/O / Master IIC bus clock line                              |  |  |
| P85/MCL        | 54      | I/O      | I       | P85      | OU            | General purpose I/O / Master IIC bus serial data line.                       |  |  |
| VDD5           | 55      | -        | -       | VDD5     | -             | +5V Positive Power Supply                                                    |  |  |

Page 11 of 133



| Nomo        | Pin No. | Pin Type |         | Default  | Pin           | Function Decoription                        |
|-------------|---------|----------|---------|----------|---------------|---------------------------------------------|
| Name        | LQFP    | Туре     | Default | Function | Configuration | Function Description                        |
| VSS5        | 56      | -        | -       | VSS5     | -             | Ground                                      |
| P90/PWM1    | 57      | I/O      | I       | P90      | OU            | General purpose I/O / 14-bit PWM DAC output |
| P91/PWM3    | 58      | I/O      | I       | P91      | OU            | General purpose I/O / 8-bit PWM DAC output  |
| P92/PWM5    | 59      | I/O      | I       | P92      | OU            | General purpose I/O / 8-bit PWM DAC output  |
| P93/PWM7    | 60      | I/O      | I       | P93      | OU            | General purpose I/O / 8-bit PWM DAC output  |
| P96/ET5T    | 61      | I/O      | I       | P96      | 5             | General purpose I/O / ECT5 Input.           |
| P97/ET5ET   | 62      | I/O      | I       | P97      | 5             | General purpose I/O / ECT5 trigger Input.   |
| P40/CAN_RX0 | 63      | I/O      | I       | P40      | OU            | General purpose I/O / CAN0 serial input.    |
| P41/CAN_TX0 | 64      | I/O      | I       | P41      | OU            | General purpose I/O / CAN0 serial output.   |

#### Note: Pin Configuration description

C: Standard CMOS bi-directional pad.



- OU: Open Drain pad with an internal pull-up resistor.





8051 Standard Pin

- 5: Standard 8051.



- D: Input only pad with an internal pull-down resistor.



- U: Input only pad with an internal pull-up resistor.





#### CHAPTER 4 MEMORY ALLOCATION

#### 1. INTERNAL SPECIAL FUNCTION REGISTERS (SFR)

The SFR is a group of registers that are the same as standard 8051.

#### 2. INTERNAL RAM

There are total 256 bytes internal RAM in CS8961, the same as standard 8052.

#### 3. EXTERNAL SPECIAL FUNCTION REGISTERS (XFR)

The XFR is a group of registers allocated in the 8051 external RAM area F00h - FFFh. These registers are used for special functions. Programs can use "MOVX" instruction to access these registers.

#### 4. CAN REGISTERS

There are total 1024 bytes a CAN Registers allocated in the 8051 external RAM area 0X0B00 – 0X0EFF. Programs can use "MOVX" instruction to access the CAN Registers

#### 5. AUXILIARY RAM (AUXRAM)

There are total 4K auxiliary RAM allocated in the 8051 external RAM area 0X1000 – 0X1FFF. Programs can use "MOVX" instruction to access the AUXRAM.







#### CHAPTER 5 MEMORY MAP OF XFR (0X0F00---0X0FFF)

| Reg name | addr         | bit7    | bit6                     | bit5      | bit4          | bit3         | bit2     | bit1       | bit0          |  |
|----------|--------------|---------|--------------------------|-----------|---------------|--------------|----------|------------|---------------|--|
| IICSTUS0 | 0X0F01 (r)   | WadrB0  |                          | SIvRWB0   | SackIn0       | SLVS0        |          |            |               |  |
| INTFLG0  | 0X0F03 (r)   | TXBI0   | RCBI0                    | SIvBMI0   | STOPI0        | ReStal0      |          |            |               |  |
| INTFLG0  | 0X0F03 (w)   |         |                          | SIvBMI0   | STOPI0        | ReStal0      |          |            |               |  |
| INTEN0   | 0X0F04 (w)   | ETXBI0  | ERCBI0                   | ESIvBMI0  | ESTOPIC       | EreStal0     | 1        |            |               |  |
| RCBBUF0  | 0X0F08 (r)   |         |                          | S         | ave B 0 IIC   | receives b   | uffer    |            |               |  |
| TXBBUF0  | 0X0F08 (w)   |         |                          | SI        | ave B 0 IIC   | transmits b  | ouffer   |            |               |  |
| SLVBADR0 | 0X0F09 (w)   | ENSIvB0 |                          |           | Slav          | ve B 0 IIC a | ddress   |            |               |  |
| ISPSLV   | 0X0F0B(w)    |         |                          | ISP Slave | e address     |              |          |            |               |  |
| ISPEN    | 0X0F0C(w)    |         |                          | W         | rite 92h to e | enable ISP   | Mode     |            |               |  |
| ISPCMP1  | 0X0F0D(w)    |         |                          | I         | SP compa      | ed data 1 [  | 7:0]     |            |               |  |
| ISPCMP2  | 0X0F0E(w)    |         |                          | I         | SP compa      | ed data 2 [  | 7:0]     |            |               |  |
| ISPCMP3  | 0X0F0F(w)    |         |                          | I         | SP compa      | ed data 3 [  | 7:0]     |            |               |  |
| DA0L     | 0X0F20(r/w)  |         |                          | P         | ulse width    | of PWM DA    | VC 0     |            |               |  |
| DA1L     | 0X0F21(r/w)  |         |                          | P         | ulse width    | of PWM DA    | NC 1     |            |               |  |
| DA2      | 0X0F22(r/w)  |         | Pulse width of PWM DAC 2 |           |               |              |          |            |               |  |
| DA3      | 0X0F23(r/w)  |         | Pulse width of PWM DAC 3 |           |               |              |          |            |               |  |
| DA4      | 0X0F24(r/w)  |         | Pulse width of PWM DAC 4 |           |               |              |          |            |               |  |
| DA5      | 0X0F25(r/w)  |         | Pulse width of PWM DAC 5 |           |               |              |          |            |               |  |
| DA6      | 0X0F26(r/w)  |         | Pulse width of PWM DAC 6 |           |               |              |          |            |               |  |
| DA7      | 0X0F27(r/w)  |         | Pulse width of PWM DAC 7 |           |               |              |          |            |               |  |
| RESERVED | 0X0F28(r/w)  |         |                          |           | Reserved      | d (Don't use | e)       |            |               |  |
| RESERVED | 0X0F29(r/w)  |         |                          |           | Reserved      | d (Don't use | ·)       |            |               |  |
| RESERVED | 0X0F2A(r/w)  |         |                          |           | Reserved      | d (Don't use | .)       |            |               |  |
| PFC      | 0X0F2B(r/w)  | PFC13   | PFC12                    | PFC11     | PFC10         | PFC03        | PFC02    | PFC01      | PFC00         |  |
| PADMOD0  | 0X0F50(w)    | SPI_MOD |                          |           |               |              |          |            | Reserved      |  |
| PADMOD1  | 0X0F51(w)    | DA7E    | DA6E                     | DA5E      | DA4E          | DA3E         | DA2E     | DA1E       | DA0E          |  |
| PADMOD2  | 0X0F52 (r/w) | HIIC1E  | MIICEN                   | HIIC0E    | Reserved      | CAN0EN       | Rese     | erved (Kee | p <b>000)</b> |  |
| SEL      | 0X0F55(w)    |         | TRTC                     | WKOSC     | LPS           | Reserved     | Reserved |            |               |  |
| OPTION   | 0X0F56(w)    | PWMF    | DIV253                   |           | ENSCL1        | ENSCL0       |          |            |               |  |
| Reserved | 0X0F70       |         |                          |           | Reserved      | d (Don't use | )        |            |               |  |
| IICSTUS1 |              | WadrB1  |                          | SIVRW/R1  | Sackin1       | SI \/S1      |          |            |               |  |
|          |              | TXRI1   | RCBI1                    | SlyRMI1   | STOPI1        | ReStal1      |          |            |               |  |
| INTELG1  |              | 17,BH   | KODIT                    | SlyBMI1   | STOPI1        | ReStal1      |          |            |               |  |
| INTEN1   | 0X0F94(w)    | ETXBI1  | ERCBI1                   | ESIVBMI1  | ESTOP1        | Frstal1      |          |            |               |  |
| RCBBUF1  | 0X0F98(r)    |         |                          |           | laveB 1 IIC   | receives b   | uffer    |            |               |  |



| Reg name  | addr        | bit7    | bit6                          | bit5                   | bit4  | bit3   | bit2     | bit1    | bit0     |  |
|-----------|-------------|---------|-------------------------------|------------------------|-------|--------|----------|---------|----------|--|
| TXBBUF1   | 0X0F98(w)   |         | SlaveB 1 IIC transmits buffer |                        |       |        |          |         |          |  |
| SLVBADR1  | 0X0F99(w)   | EnslvB1 |                               | SlaveB 1 IIC address   |       |        |          |         |          |  |
| EXINTEN   | 0X0F9A(w)   | INT2EN  |                               |                        |       |        | INT5EN   | INT4EN  | INT3EN   |  |
| EXINTFLG  | 0X0F9B(r/W) | INT2FLG |                               |                        |       |        | INT5FLG  | INT4FLG | INT3FLG  |  |
| ECCINTEN  | 0X0F9C(r/W) | PUSEN   |                               |                        | PRGEN | D256EN | D4KEN    | CAN0EN  | Reserved |  |
| ECCINTGLG | 0X0F9D(r/W) |         |                               |                        | PRGF  | D256F  | D4KF     | CAN0F   | Reserved |  |
| POWER     | 0X0F9E(r/w) | EN      | FLAG                          |                        |       |        | PRSTEN   | CRSTEN  |          |  |
| PSCON     | 0X0F9F(r/w) | -       |                               | SWBSEL[2:0] CAHEN      |       |        |          |         |          |  |
| RTCCON    | 0X0FE0(w)   |         | RTC                           | RTC register address - |       |        |          |         |          |  |
| RTCDAT    | 0X0FE1(r/w) |         |                               |                        |       | RTC D  | ata[7:0] |         |          |  |

#### **1. CHIP CONFIGURATION**

The Chip Configuration registers define configuration of the chip and function of the pins.

#### PADMOD0 (r/w): (XFR 0X0F50) Pad mode control registers 0. (default 0X00)

|         | <u>, , ,</u> |       |       |       |       |       |       |          |
|---------|--------------|-------|-------|-------|-------|-------|-------|----------|
|         | Bit 7        | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0    |
| Name    | SPI_MOD      | -     | -     | -     | -     | -     | -     | Reserved |
| Default | 0            | -     | -     | -     | -     | -     | -     | 0        |

SPI\_MOD

= 1  $\rightarrow$  Pin "P7.2/ET2T/SCS" is SPI\_SCS;  $\rightarrow$  Pin "P7.4/ET3T/MISO" is SPI\_MISO; = 0  $\rightarrow$  Pin "P7.2/ET2T/SCS" is P7.2;  $\rightarrow$  Pin "P7.4/ET3T/MISO" is P7.4;

pin "P7.3/ET2ET/MOSI" is SPI\_MOSI. pin "P7.5/ET3ET/MSCK" is SPI\_MSCK. pin "P7.3/ET2ET/MOSI" is P7.3. pin "P7.5/ET3ET/MSCK" is P7.5.

#### PADMOD1 (r/w) : (XFR 0X0F51) Pad mode control registers 1. (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | DA7E  | DA6E  | DA5E  | DA4E  | DA3E  | DA2E  | DA1E  | DA0E  |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

| DA7E | = 1 | $\rightarrow$ Pin "P9.3/PWM7" is PWM7. |
|------|-----|----------------------------------------|
|      | = 0 | $\rightarrow$ Pin "P9.3/PWM7" is P9.3. |
| DA6E | = 1 | $\rightarrow$ Pin "P6.3/PWM6" is PWM6. |
|      | = 0 | $\rightarrow$ Pin "P6.3/PWM6" is P6.3. |
| DA5E | = 1 | $\rightarrow$ Pin "P9.2/PWM5" is PWM5. |
|      | = 0 | $\rightarrow$ Pin "P9.2/PWM5" is P9.2. |
| DA4E | = 1 | $\rightarrow$ Pin "P6.2/PWM4" is PWM4. |
|      | = 0 | $\rightarrow$ Pin "P6.2/PWM4" is P6.2. |
| DA3E | = 1 | $\rightarrow$ Pin "P9.1/PWM3" is PWM3. |
|      | = 0 | $\rightarrow$ Pin "P9.1/PWM3" is P9.1. |
| DA2E | = 1 | $\rightarrow$ Pin "P6.1/PWM2" is PWM2. |
|      | = 0 | $\rightarrow$ Pin "P6.1/PWM2" is P6.1. |
| DA1E | = 1 | $\rightarrow$ Pin "P9.0/PWM1" is PWM1. |
|      | = 0 | $\rightarrow$ Pin "P9.0/PWM1" is P9.0. |
| DA0E | = 1 | $\rightarrow$ Pin "P6.0/PWM0" is PWM0. |
|      | = 0 | $\rightarrow$ Pin "P6.0/PWM0" is P6.0. |

#### PADMOD2 (r/w) : (XFR 0X0F52) Pad mode control registers 2. (default 0X00)

|      | Bit 7  | Bit 6  | Bit 5  | Bit 4    | Bit 3  | Bit 2    | Bit 1    | Bit 0    |
|------|--------|--------|--------|----------|--------|----------|----------|----------|
| Name | HIIC1E | MIICEN | HIIC0E | Reserved | CAN0EN | Reserved | Reserved | Reserved |
|      |        |        |        |          |        |          | _        |          |



| Default | 0   | 0                       | 0             | 0          | 0  | 0                      | 0              | 0      |  |  |
|---------|-----|-------------------------|---------------|------------|----|------------------------|----------------|--------|--|--|
|         |     |                         |               |            |    |                        |                |        |  |  |
| HIIC1E  | = 1 | $\rightarrow$ Pin "SCL1 | /P4.7" is SC  | L1;        | pi | n "HSDA1/P             | 4.6" is SDA1   |        |  |  |
|         | = 0 | $\rightarrow$ Pin "SCL1 | /P4.7" is P4. | 7;         | pi | n "SDA1/P4.            | 6" is P4.6.    |        |  |  |
| MIICEN  | = 1 | $\rightarrow$ Pin "MCL/ | P8.5" is MCl  | _;         | pi | pin "MDA/P8.4" is MDA. |                |        |  |  |
|         | = 0 | $\rightarrow$ Pin "MCL/ | P8.5" is P8.5 | 5;         | pi | n "MDA/P8.4            | l" is P8.4.    |        |  |  |
| HIIC0E  | = 1 | $\rightarrow$ Pin "SCLC | /P4.5" is SC  | L0.        | P  | in "SDA0/P4            | .4" is SDA0.   |        |  |  |
|         | = 0 | $\rightarrow$ Pin "SCLC | /P4.5" is P4. | 5.         | Р  | in "SDA0/P4            | .4" is P4.4.   |        |  |  |
| CAN0EN  | = 1 | $\rightarrow$ Pin "CAN  | _RX0/P4.0" i  | s CAN_RX0; | pi | in "CAN_TXC            | /P4.1" is CA   | N_TX0. |  |  |
|         | = 0 | $\rightarrow$ Pin "CAN_ | _RX0/P4.0" i  | s P4.0;    | pi | in "CAN_TXC            | )/ P4.1" is P4 | .1.    |  |  |

#### **OPTION (r/w) : (XFR 0X0F56) chip option configuration (default 0X00)**

|         | Bit 7 | Bit 6  | Bit 5 | Bit 4  | Bit 3  | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|--------|-------|--------|--------|-------|-------|-------|
| Name    | PWMF  | DIV253 | -     | ENSCL1 | ENSCL0 | -     | -     | -     |
| Default | 0     | 0      | -     | 0      | 0      | -     | -     | -     |

| PWMF   | = 1             | ightarrow Selects system clock/512 as PWM clock frequency.                                                              |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------|
|        | = 0             | ightarrow Selects system clock/1024 as PWM clock frequency.                                                             |
| DIV253 | = 1             | $\rightarrow$ PWM pulse width is 253-step resolution.                                                                   |
|        | = 0             | $\rightarrow$ PWM pulse width is 256-step resolution.                                                                   |
| ENSCL1 | = 1             | $\rightarrow$ Enable SlaveB 1 IIC block to hold SCL pin low while CS8961 is unable to catch-up                          |
|        | with the        | external master's speed.                                                                                                |
| ENSCL0 | = 1<br>with the | $\rightarrow$ Enable SlaveB 0 IIC block to hold SCL pin low while CS8961 is unable to catch-up external master's speed. |

#### PSCON(w/r) : (XFR 0X0F9F) Power save mode control (default 0X00)

|         | , <u>,</u> | ,       |         |         | ,     |       |       |       |
|---------|------------|---------|---------|---------|-------|-------|-------|-------|
|         | Bit 7      | Bit 6   | Bit 5   | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | PUSEN      | SWBSEL2 | SWBSEL1 | SWBSEL0 | CAHEN | -     | -     | -     |
| Default | 0          | 0       | 0       | 0       | 0     | -     | -     | -     |

PUSEN

= 1  $\rightarrow$  Enable pulse mode.

= 0  $\rightarrow$  Disable pulse mode.

SWBSEL[2:0]

 $\rightarrow$  Determine the time period CPU switch back from stop mode after switch back condition.

| SWBSEL [2:0] | Delay time after switch back condition. |
|--------------|-----------------------------------------|
| 000          | 2,000 x system clock                    |
| 001          | 20,000 x system clock                   |
| 010          | 40,000 x system clock                   |
| 011          | 100,000 x system clock                  |
| 100          | 200,000 x system clock                  |
| 101          | 400,000 x system clock                  |
| 110          | 600,000 x system clock                  |
| 111          | 1,000,000 x system clock                |

CAHEN

= 1  $\rightarrow$  Enable internal 1 byte flash cache.

= 0  $\rightarrow$  Disable internal 1 byte flash cache.



#### CHAPTER 6 HIGH PERFORMANCE ONE CYCLE 8 BIT MICRO-CONTROLLER

#### 1. INTRODUCTION

CS8961 is an ultra high performance, speed optimized 8-bit embedded controller dedicated for operation with fast (typically on-chip) and slow (off-chip) memories. The chip has been designed with a special concern about performance to power consumption ratio. CS8959 is 100% binary-compatible with the industry standard 8051 8-bit micro-controller. The CS8961 is Hardware configure where internal data and program buses are separated. CS8961 has pipelined RISC architecture that is 6.7 times faster in typical applications compared to standard architecture. This performance can also be exploited to great advantage in low power applications where the core can be clocked more slowly than the original implementation for no performance penalty.

#### 2. INTERNAL DATA MEMORY & SFRS ALLOCATION

The picture below shows the Internal Memory and Special Function Registers (SFR) map.



#### Figure-5 SFR Map

The lower internal RAM consists of four register banks with eight registers each, a bit addressable segment with 128 bits (16 bytes) begins at 0X20, and a scratch pad area with 208 bytes. With the indirect addressing mode range 0X80 to 0X0FF highest 128 bytes of the internal memory is addressed. With the direct addressing mode range 0X80 to 0X0FF the SFR memory area is accessed.

# Analog Mixed Signal Division

#### SFR Memory Map

|           | 0/8    | 1/9      | 2/A      | 3/B      | 4/C      | 5/D      | 6/E      | 7/F     |       |
|-----------|--------|----------|----------|----------|----------|----------|----------|---------|-------|
| 0X0F8     | EXIP   | MD0      | MD1      | MD2      | MD3      | MD4      | MD5      | ARCON   | 0X0FF |
| 0X0F0     | В      |          |          |          | I2CMSA   | I2CMCR   | I2CMBUF  | I2CMTP  | 0X0F7 |
| 0XE8      | EXIE   |          | MXAX     |          | SPICR    | SPIMR    | SPIST    | SPIDATA | 0XEF  |
| 0XE0      | ACC    | T2CON5   | RLDL_5   | RLDH_5   | TH2_5    | TL2_5    |          |         | 0XE7  |
| 0XD8      | WDCON  | Reserved | Reserved | Reserved | Reserved | Reserved |          |         | 0XDF  |
| 0XD0      | PSW    | T2CON3   | RLDL_3   | RLDH_3   | TH2_3    | TL2_3    |          |         | 0XD7  |
| 0XC8      | T2CON  | T2MOD    | RCAP2L   | RCAP2H   | TL2      | TH2      |          |         | 0XCF  |
| 0XC0      | SCON1  | SBUF1    |          |          | PMR      | STATUS   | Reserved | TA      | 0XC7  |
| 0XB8      | IP     | T2CON2   | RLDL_2   | RLDH_2   | TH2_2    | TL2_2    |          |         | 0XBF  |
| 0XB0      | P3     | Reserved | Reserved | Reserved | Reserved | Reserved |          |         | 0XB7  |
| 0XA8      | IE     | Reserved | Reserved | Reserved | Reserved | Reserved |          |         | 0XAF  |
| 0XA0      | P2     | P4       | P5       | P6       | P7       | P8       | P9       |         | 0XA7  |
| 0X98      | SCON0  | SBUF0    | DPXR     | ESP      |          | ACON     |          | LVDT    | 0X9F  |
| 0X90      | P1     | EXIF     | WTST     | DPX      |          | DPX1     |          |         | 0X97  |
| 0X88      | TCON   | TMOD     | TL0      | TL1      | TH0      | TH1      | CKCON    |         | 0X8F  |
| 0X80      | P0     | SP       | DPL      | DPH      | DPL1     | DPH1     | DPS      | PCON    | 0X87  |
|           | 0/8    | 1/9      | 2/A      | 3/B      | 4/C      | 5/D      | 6/E      | 7/F     |       |
| Default v | /alue: |          |          |          |          |          |          |         |       |

|       | 0/8 | 1/9 | 2/A | 3/B | 4/C | 5/D | 6/E | 7/F |       |
|-------|-----|-----|-----|-----|-----|-----|-----|-----|-------|
| 0X0F8 | 00H | 0X0FF |
| 0X0F0 | 00H |     |     |     | 00H | 00H | 00H | FFH | 0X0F7 |
| 0XE8  | 00H |     | 00H |     | 20H | 00H | 00H | 00H | 0XEF  |
| 0XE0  | 00H | 00H | 00H | 00H | 00H | 00H |     |     | 0XE7  |
| 0XD8  | 00H | 00H | 00H | 00H | 00H | 00H |     |     | 0XDF  |
| 0XD0  | 00H | 00H | 00H | 00H | 00H | 00H |     |     | 0XD7  |
| 0XC8  | 00H | 00H | 00H | 00H | 00H | 00H |     |     | 0XCF  |
| 0XC0  | 00H | 00H |     |     | 00H | 00H | 00H | 00H | 0XC7  |
| 0XB8  | 00H | 00H | 00H | 00H | 00H | 00H |     |     | 0XBF  |
| 0XB0  | FFH | 00H | 00H | 00H | 00H | 00H |     |     | 0XB7  |
| 0XA8  | 00H | 00H | 00H | 00H | 00H | 00H |     |     | 0XAF  |
| 0XA0  | FFH |     | 0XA7  |
| 0X98  | 00H | 00H | 00H | 10H |     | 00H |     | 20H | 0X9F  |
| 0X90  | FFH | 00h | 00H | 00H |     | 00H |     |     | 0X97  |
| 0X88  | 00H | 00H | 00H | 00H | 00H | 00H | 03H |     | 0X8F  |
| 0X80  | FFH | 07H | 00H | 00H | 00H | 00H | 00H | 00H | 0X87  |
|       | 0/8 | 1/9 | 2/A | 3/B | 4/C | 5/D | 6/E | 7/F |       |



#### CHAPTER 7 SPECIAL SFR DEFINITION

#### **1. PROGRAM WAIT STATES REGISTER**

Wait States register holds the information about Program Memory access time. It allows the CS8959 core operation with fast (on-chip) and slow (off-chip) Program Memories.

#### 1.1 Wait-states Cycle Register (default 0X00)

#### WTST(w/r) : (SFR 0X92) Wait-states Cycle Register (default 0X00)

| <u> </u> |       | 1     | , ,   |       |        |        |        |        |
|----------|-------|-------|-------|-------|--------|--------|--------|--------|
|          | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
| Name     | -     | -     | -     | -     | WTST.3 | WTST.2 | WTST.1 | WTST.0 |
| Default  | -     | -     | -     | -     | 0      | 0      | 0      | 0      |

*Note:* These bits are considered during program fetches and MOVC instructions only. Minimal read cycle takes 1 clock period and maximal 16 clock periods

#### 1.2 WTST Register Values

| WTST value WTST[3:0] | Access time [clk] |
|----------------------|-------------------|
| 15                   | 16                |
| 14                   | 15                |
|                      |                   |
| 1                    | 2                 |
| 0                    | 1                 |

WTST[3:0] should be not less than 1 at this version

#### 2. FLAT/LARGE MODEL SWITCHING

Switching between LARGE and FLAT modes is performed by appropriate writes into ACON(0X9D) register. This register is timed access register, prevents from accidental change of working mode.

#### 2.1 Address Control Register

#### ACON(w/r) : (SFR 0X9D) Address Control Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | -     | -     | -     | -     | -     | SA    | AM1   | AM0   |
| Default | -     | -     | -     | -     | -     | 0     | 0     | 0     |

SA ----- Extend Stack Address Mode indicator. This bit is read only:

0 ----- All instructions utilize the 8-bit 8051 stack pointer SP(0X81) resides in internal data memory.

1 ----- All instructions utilize the 16-bit stack pointer formed by ESP:SP register (0X9B:OX81). Stack resides in external data memory.

AM[1:0] ----- Address Mode Control bits. These bits establish the addressing mode for the micro controller. They can only be modified by the Timed access register procedure.

#### 2.2 Address Control

| AM[1:0] Addressing Mode |                                        |  |  |  |  |  |
|-------------------------|----------------------------------------|--|--|--|--|--|
| 00                      | 16-bit Addressing Mode-LARGE           |  |  |  |  |  |
| 1X                      | 24-bit contiguous Addressing Mode-FLAT |  |  |  |  |  |

| Unimplemented | bit. Read as 0 or 1. |
|---------------|----------------------|
|---------------|----------------------|



To switch between modes the following instructions should be performed:

- MOV TA ,#0XAA
- MOV TA,#0X55
- MOV ACON ,#0X02;Switch to FLAT mode

Or

- MOV TA ,#0XAA
- MOV TA ,#0X55
- MOV ACON,#0X00;Switch to LARGE Mode

#### 2.3 Stack Pointer Register

#### SP(w/r) : (SFR 0X81) Stack Pointer Register (default 0X03)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | SP.7  | SP.6  | SP.5  | SP.4  | SP.3  | SP.2  | SP.1  | SP.0  |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     |

SP(0X81) register holds the low order 8-bit address used for addressing the Stack Memory. When processor is in LARGE or FLAT mode. After reset SP has 0X07 value.

#### Extended Stack Pointer Register

#### ESP(w/r) : (SFR 0X9B) Extended Stack Pointer Register (default 0X10)

| - ( - ) |       |       |       |       |       |       |       |       |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | ESP.7 | ESP.6 | ESP.5 | ESP.4 | ESP.3 | ESP.2 | ESP.1 | ESP.0 |
| Default | 0     | 0     | 0     | 1     | 0     | 0     | 0     | 0     |

ESP(0X9B) register holds the eight high order address bits used for addressing the Stack Memory when processor is in FLAT mode. After reset ESP has 0X00 value.

#### **3. DATA POINTER EXTENDED REGISTERS**

Data Pointer Extended register DPX, DPX1, MXAX, and DPXR hold the most significant part of memory Address during access to data located above 64 kB in LARGE and FLAT mode. After reset DPX, DPX1, MXAX, DPXR have 0X00 value.

#### 3.1 Data Pointer Extended Register

#### DPX(w/r) : (SFR 0X93) Data Pointer Extended Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | DPX.7 | DPX.6 | DPX.5 | DPX.4 | DPX.3 | DPX.2 | DPX.1 | DPX.0 |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 3.2 Data Pointer Extended 1 Register

#### DPX1(w/r) : (SFR 0X95) Data Pointer Extended 1 Register (default 0X00)

|         |        |        |        | J      |        | -1     |        |        |
|---------|--------|--------|--------|--------|--------|--------|--------|--------|
|         | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
| Name    | DPX1.7 | DPX1.6 | DPX1.5 | DPX1.4 | DPX1.3 | DPX1.2 | DPX1.1 | DPX1.0 |
| Default | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

#### 3.3 MOVX @Ri Extended High Register

#### MXAX(w/r) : (SFR 0XEA) MOVX @Ri Extended High Register (default 0X00)

|         | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|---------|--------|--------|--------|--------|--------|--------|--------|--------|
| Name    | MXAX.7 | MXAX.6 | MXAX.5 | MXAX.4 | MXAX.3 | MXAX.2 | MXAX.1 | MXAX.0 |
| Default | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

#### 3.4 MOVX @Ri Extended Middle Register

#### DPXR(w/r) : (SFR 0X9A) MOVX @Ri Extended Middle Register (default 0X00)

|         | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|---------|--------|--------|--------|--------|--------|--------|--------|--------|
| Name    | DPXR.7 | DPXR.6 | DPXR.5 | DPXR.4 | DPXR.3 | DPXR.2 | DPXR.1 | DPXR.0 |
| Default | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |



During MOVX instruction using DPTR/DPTR1 registers, the most significant part of address XRAMADDR[23:16] is always equal to DPX(0X93)/DPX1(0X95) contents. During MOVX instruction using R0 or R1 registers, the most significant part of address XRAMADDR[23:16] is always equal to MXAX(0XEA) contents and XRAMADDR[15:8] is always equal to DPXR(0X9A) contents, which is different from traditional 8051 MCU. These rules apply for FLAT and LARGE modes.

#### 4. RESERVED REGISTER

User should not write any value to this register (0XC6).

#### 5. DATA POINTER REGISTER

Dual data pointer registers are implemented to speed up data block copying. DPTR and DPTR1 are located at four SFR addresses. Active DPTR register is selected by SEL bit (0X86.0). If SEL bit is equal to 0 then DPTR(0X83:0X82) is selected otherwise DPTR1 (0X85:0X84).

#### 5.1 Data Pointer Register DPTR (default 0X0000)

#### DPH(w/r) : (SFR 0X83)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | DPH.7 | DPH.6 | DPH.5 | DPH.4 | DPH.3 | DPH.2 | DPH.1 | DPH.0 |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### DPL(w/r) : (SFR 0X82)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | DPL.7 | DPL.6 | DPL.5 | DPL.4 | DPL.3 | DPL.2 | DPL.1 | DPL.0 |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### 5.2 Data Pointer 1 Register DPTR1 (default 0X0000)

#### DPH1(w/r) : (SFR 0X85)

|         | 101110100 | /      |        |        |        |        |        |        |
|---------|-----------|--------|--------|--------|--------|--------|--------|--------|
|         | Bit 7     | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
| Name    | DPH1.7    | DPH1.6 | DPH1.5 | DPH1.4 | DPH1.3 | DPH1.2 | DPH1.1 | DPH1.0 |
| Default | 0         | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

#### DPL1(w/r) : (SFR 0X84)

|         | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|---------|--------|--------|--------|--------|--------|--------|--------|--------|
| Name    | DPL1.7 | DPL1.6 | DPL1.5 | DPL1.4 | DPL1.3 | DPL1.2 | DPL1.1 | DPL1.0 |
| Default | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

#### 5.3 Data pointer Select Register

#### DPS(w/r) : (SFR 0X86) Data pointer Select Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | ID1   | ID0   | TSL   | -     | -     | -     | -     | SEL   |
| Default | 0     | 0     | 0     | -     | -     | -     | -     | 0     |

ID[1:0] - Increment/decrement function select. See table below.

TSL - Toggle select enable. When set, this bit allows the following DPTR related instructions to toggle the SEL bit following execution of the instruction:

- INC DPTR
- MOV DPTR, #data16/#data24
- MOVC A, @A+DPTR
- MOVX @DPTR, A
- MOVX A, @DPTR
- When TSL=0, DPTR related instructions will not affect the state of the SEL bit.
- - Unimplemented bit. Read as 0 or 1

#### DPTR0, DPTR 1 operation



| ID1 | ID0 | SEL=0    | SEL=1      |
|-----|-----|----------|------------|
| 0   | 0   | INC DPTR | INC DPTR 1 |
| 0   | 1   | DEC DPTR | INC DPTR 1 |
| 1   | 0   | INC DPTR | DEC DPTR 1 |
| 1   | 1   | DEC DPTR | DEC DPTR 1 |

Selected data pointer register is used in the following instructions:

- MOVX @DPTR,A
- MOVX A, @DPTR
- MOVC A, @A+DPTR
- JMP @A+DPTR
- INC DPTR
- MOV DPTR, #data16/#data24

#### 6. CLOCK CONTROL REGISTER-STRETCH BITS

Clock control register CKCON(0X8E) contains MD[2:0] bits (STRETCH bits) hold the information about XRAMRD and XRAMWR pulses width.

#### 6.1 Clock Control Register

#### CKCON(w/r) : (SFR 0X8E) Clock Control Register (default 0X03)

|         | / . ( | - (   |       |       |       |       |       |       |  |  |  |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|--|--|--|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
| Name    | WD1   | WD0   | T2M   | T1M   | TOM   | MD2   | MD1   | MD0   |  |  |  |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     |  |  |  |

XRAMRD and XRAMWR signals are activated during MOVX instruction. The purpose of STRETCH bits is adjusting of communication speed with I/O devices such as slow RAM etc. After reset STRETCH bits have 0X03 value. It means that slow devices should work properly. If needed user can change stretch value, to speed up/slow down software execution. Stretch value can be changed any time during program execution (e.g. between MOVX to different speed devices).

#### 6.2 Clock Control Period

| MD[2:0] | Pulse width[clk] |  |  |  |
|---------|------------------|--|--|--|
| 7       | 8                |  |  |  |
| 6       | 7                |  |  |  |
|         |                  |  |  |  |
| 1       | 2                |  |  |  |
| 0       | 1                |  |  |  |

#### 7. TIMED ACCESS REGISTERS

Timed access registers have built in mechanism preventing them from accidental Writes. To do a correct write to such registers the following sequence has to be applied:

- MOV TA , #0XAA
- MOV TA , #0X55
- ;Any direct addressing instruction writing timed access register.

The time elapsed between first, second, and third operation does not matter (any number of Program Wait Sates is allowed). The only correct sequence is required. Any third instruction causes Protection mechanism to be turned on. This means that time protected register is opened for write only for single instruction. Reading from such register is never protected. Time access registers are listed in table below.



#### 7.1 Timed Access Registers

| Register name | Description              | Default |  |
|---------------|--------------------------|---------|--|
| ACON(0X9D)    | Address control register | 0X00    |  |
| WDCON(0XD8)   | Watchdog configuration   | 0X00    |  |



#### CHAPTER 8 INTERRUPT SYSTEM

CS8961 has implemented two levels interrupt priority control. Each external interrupt can be in high or low level priority group by setting or clearing a bit in the IP(0XB8), and EIP(0XF8) registers. External interrupt pins are activated at low level or by a falling edge Interrupt requests are sampled each system clock at the rising edge of CLK.

#### 1. INTERRUPT VECTOR

| Interrupt Flag | Function | Active level/edge | Flag resets | Vector | Natural priority |
|----------------|----------|-------------------|-------------|--------|------------------|
| IE0            | PIN INT0 | Low/Falling       | Hardware    | 0X03   | 1                |
| TF0            | Timer 0  | -                 | Hardware    | 0X0B   | 2                |
| IE1            | PIN INT1 | Low/Falling       | Hardware    | 0X13   | 3                |
| TF1            | Timer 1  | -                 | Hardware    | 0X1B   | 4                |
| TI0&RI0        | UART0    | -                 | Software    | 0X23   | 5                |
| TF2            | Timer2   | -                 | Software    | 0X2B   | 6                |
| TI1&RI1        | UART1    | -                 | Software    | 0X33   | 7                |
| I2CMF          | MI2C     | -                 | Software    | 0X3B   | 8                |
| AFIF           | AFI      | Low               | Hardware    | 0X43   | 9                |
| CAN0I          | CANOI    | Low               | Hardware    | 0X4B   | 10               |
| WDIF           | Watchdog | -                 | Software    | 0X5B   | 12               |
| SPI INT        | SPI INT  | Falling           | Software    | 0X63   | 13               |
| CANBUSI        | CANBUSI  | Falling           | Software    | 0X73   | 15               |

-----AFI: affixation function interrupt

All interrupts related registers are listed in this chapter. Each interrupt vector can be individually enabled or disabled by setting or clearing the corresponding bit in the IE(0XA8), T2CON(0XC8), or EXIE(0XE8). The IE contains global disable bit called EA.

#### 1.1 Interrupt Enable Register IE(w/r) : (SFR 0XA8) Interrupt Enable Register (default 0X00)

| <u>.=(,.) . (e</u> |       |       | ie negiete. | (     |       |       |       |       |
|--------------------|-------|-------|-------------|-------|-------|-------|-------|-------|
|                    | Bit 7 | Bit 6 | Bit 5       | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name               | EA    | ES1   | ET2         | ES0   | ET1   | EX1   | ET0   | EX0   |
| Default            | 0     | 0     | 0           | 0     | 0     | 0     | 0     | 0     |

EA - Enable global interrupts

EX0 - Enable INT0 interrupts

ET0 - Enable Timer 0 interrupts

EX1 - Enable INT1 interrupts

ET1 - Enable Timer 1 interrupts

ES0 - Enable UART0 interrupts

ET2 - Enable Timer 2 interrupts

ES1 - Enable UART1 interrupts

Each interrupt source can be individually programmed to one of the two priority levels by setting or clearing a bit in the IP(0XB8) or EXIP(0XF8) registers.



Default

0

Bit 0 PX0

0

## 1.2 Interrupt Priority Register

| r(wit) . (SFR UNBO) interrupt Friority Register (default UNUU) |       |       |       |       |       |       |       |  |  |  |
|----------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|--|--|--|
|                                                                | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 |  |  |  |
| Name                                                           | -     | PS1   | PT2   | PS0   | PT1   | PX1   | PT0   |  |  |  |

0

PX0 - INT0 priority level control (at 1-high level)

PT0 - Timer 0 priority level control (at 1-high level)

0

PX1 - INT1 priority level control (at 1-high level)

PT1 - Timer 1 priority level control (at 1-high level)

PS0 - UART0 priority level control (at 1-high level)

PT2 - Timer 2 priority level control (at 1-high level)

PS1 - UART1 priority level control (at 1-high level)

- - Unimplemented bit. Read as 0 or 1.

The DI2CM, external interrupts AFI, CAN0I interrupt, CANBUSI interrupt, and Watchdog interrupt control bits are located in EXIE(0XE8), EXIP(0XF8), EXIF(0X91) and WDCON(0XD8) registers.

0

0

0

#### 1.3 External Interrupt Enable Register

#### EXIE(w/r) : (SFR 0XE8) External Interrupt Enable Register (default 0X00)

|         | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|---------|-------|---------|-------|-------|-------|-------|-------|
| Name    | ECANBUS | -     | ESPIINT | EWDI  | -     | ECAN0 | EAFI  | EI2CM |
| Default | 0       | -     | 0       | 0     | -     | 0     | 0     | 0     |

EI2CM - Enable Master I<sup>2</sup>C (DI2CM) interrupt.

EAFI - Enable Affixation Functions Interrupts. Affixation Functions Interrupts include slave I<sup>2</sup>C interrupt, ECT interrupts, external interrupt 2, external interrupt 3, external interrupt 4, external interrupt 5, RTC interrupt, power warning interrupt, and HC\_ER interrupts. HC\_ER interrupts include 256 bytes ram error interrupt, program flash error interrupt, 4k AUXRAM error interrupt, and CAN0 ram error interrupt. If use one of these interrupts must enable this bit first.

ECAN0 - Enable CAN0 interrupt.

EWDI - Enable Watchdog interrupt.

ESPINIT - Enable SPI interrupt.

ECANBUS - Enable CANBUSI interrupt.

#### 1.4 External Interrupt Priority Register

#### EXIP(w/r) : (SFR 0XF8) External Interrupt Priority Register (default 0X00)

| <u> </u> | 1 /     |       |         |       | •     |       |       |       |
|----------|---------|-------|---------|-------|-------|-------|-------|-------|
|          | Bit 7   | Bit 6 | Bit 5   | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name     | PCANBUS | -     | PSPIINT | PWDI  | -     | PCAN0 | PAFI  | PI2CM |
| Default  | 0       | -     | 0       | 0     | -     | 0     | 0     | 0     |

PI2CM - Master I<sup>2</sup>C (DI2CM) priority level control (at 1-high level) PAFI - AFI priority level control (at 1-high level) PCAN0 - CAN0 priority level control (at 1-high level) PWDI - Watchdog priority level control (at 1-high level) PSPIINT - SPI priority level control (at 1-high level) PCANBUS - CANBUSI priority level control (at 1-high level)

#### 1.5 External Interrupt Flag Register

EXIF(w/r) : (SFR 0X91) External Interrupt Flag Register (default 0X00)

|         | Bit 7   | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0  |
|---------|---------|-------|-------|-------|-------|-------|-------|--------|
| Name    | CANBUSI | -     | SPIIF | -     | -     | CANOI | AFIF  | I2CMIF |
| Default | 0       | -     | 0     | -     | -     | 0     | 0     | 0      |

I2CMIF - Master I<sup>2</sup>C (DI2CM) interrupt flag. Must be cleared by software

AFIF - AFI interrupt flag. Cleared by hardware when processor branches to interrupt routine CAN0I - CAN0 interrupt flag. Cleared by hardware when processor branches to interrupt routine SPIIF - SPI interrupt flag. Must be cleared by software



CANBUSI - CANBUSI interrupt flag. Must be cleared by software - Unimplemented bit. Read as 0 or 1.

The watchdog interrupt is located in WDCON(0XD8). The external interrupts INT0-INT1, and Timer 0, 1, 2 interrupt control bits are located in TCON(0X88), T2CON(0XC8), IE(0XA8) and IP(0XB8) registers.

#### 1.8 Timer 0,1 Configuration Register

#### TCON(w/r) : (SFR 0X88) Timer 0,1 Configuration Register (default 0X00)

|         |       |       |       |       |       | - /   |       |       |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | TF1   | TR1   | TF0   | TR0   | IE1   | IT1   | IE0   | IT0   |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

IT0 - INT0 level (at 0)/ edge (at 1) sensitivity

IT1 - INT1 level (at 0)/ edge (at 1) sensitivity

IE0 - INT0 interrupt flag. Cleared by hardware when processor branches to interrupt routine

IE1 - INT1 interrupt flag. Cleared by hardware when processor branches to interrupt routine

TF0 - Timer 0 interrupt (overflow) flag. Cleared by hardware when processor branches to interrupt routine

TF1 - Timer 1 interrupt (overflow) flag. Cleared by hardware when processor branches to interrupt routine

#### 1.9 Timer 2 Configuration Register

T2CON(w/r) : (SFR 0XC8) Timer 2 Configuration Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | TF2   | EXF2  | RCLK  | TCLK  | EXEN2 | TR2   | CT2   | CPRL2 |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

TF2 - Timer 2 interrupt (overflow) flag. Must be cleared by software. The flag will not be set when either RCLK or TCLK is set.

EXF2 - Falling edge indicator on T2EX pin when EXEN2=1. Must be cleared by software.

EXEN2 - Enable T2EX pin functionality.

1 - allows capture or reload as a result of T2EX pin falling edge

0 - ignore T2EX events

#### 1.10 UART0 Configuration Register

#### SCON0 (w/r) : (SFR 0X98) UART0 Configuration Register (default 0X00)

|         | <u>/                                    </u> |       |       |       |       |       |       |       |
|---------|----------------------------------------------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7                                        | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | SM00                                         | SM01  | SM02  | REN0  | TB08  | RB08  | TI0   | RI0   |
| Default | 0                                            | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

RI0 - UART0 receiver interrupt flag. Must be cleared by software

TI0 - UART0 transmitter interrupt flag. Must be cleared by software

#### 1.11 UART1Configuration Register

SCON1 (w/r) : (SFR 0XC0) UART0 Configuration Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | SM10  | SM11  | SM12  | REN1  | TB18  | RB18  | TI1   | RI1   |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

RI1 - UART1 receiver interrupt flag. Must be cleared by software

TI1 - UART1 transmitter interrupt flag. Must be cleared by software

#### **1.12 External Interrupt Registers**

#### EXINTEN(w/r) : (XFR 0X0F9A) External interrupt enable (default 0X00)

|         | Bit 7    | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2    | Bit 1    | Bit 0    |
|---------|----------|-------|-------|-------|-------|----------|----------|----------|
| Name    | EXINT2EN | -     | -     | -     | -     | EXINT5EN | EXINT4EN | EXINT3EN |
| Default | 0        | -     | -     | -     | -     | 0        | 0        | 0        |

INT2EN = 1  $\rightarrow$  Enable external interrupt 2 from P1.4.



| INT5EN | = 1 | $\rightarrow$ Enable external interrupt 5 from P1.7. |
|--------|-----|------------------------------------------------------|
| INT4EN | = 1 | $\rightarrow$ Enable external interrupt 4 from P1.6. |
| INT3EN | = 1 | $\rightarrow$ Enable external interrupt 3 from P1.5. |

#### EXINTFLG (w/r) : (XFR 0X0F9B) External Interrupt Flag (default 0X00)

|         | Bit 7   | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2   | Bit 1   | Bit 0   |
|---------|---------|-------|-------|-------|-------|---------|---------|---------|
| Name    | INT2FLG | -     | -     | -     | -     | INT5FLG | INT4FLG | INT3FLG |
| Default | 0       | -     | -     | -     | -     | 0       | 0       | 0       |

INT2FLG  $\rightarrow$  INT2 interrupt flag. Must be cleared by software

 $\rightarrow$  INT5 interrupt flag. Must be cleared by software INT5FLG INT4FLG  $\rightarrow$  INT4 interrupt flag. Must be cleared by software

 $\rightarrow$  INT3 interrupt flag. Must be cleared by software **INT3FLG** 

#### ECCINTEN(w/r) : (XFR 0X0F9C) Error Correction Code interrupt enable. (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3  | Bit 2 | Bit 1  | Bit 0     |
|---------|-------|-------|-------|-------|--------|-------|--------|-----------|
| Name    | -     | -     | -     | PRGEN | D256EN | D4KEN | CAN0EN | Reserved* |
| Default | -     | -     | -     | 0     | 0      | 0     | 0      | 0         |

| PRGEN        | = 1        | $\rightarrow$ Enable program RAM error interrupt.            |
|--------------|------------|--------------------------------------------------------------|
| D256EN       | = 1        | $\rightarrow$ Enable 256 bytes internal RAM error interrupt. |
| D4KEN        | = 1        | $\rightarrow$ Enable 4k AUXRAM error interrupt.              |
| CAN0EN       | = 1        | $\rightarrow$ Enable CAN0 RAM error interrupt.               |
| *Reserved bi | t in ECCIN | NTEN bit-0 must always be clear to zero.                     |

#### ECCINTFLG(w/r): (XFR 0X0F9D) Error Correction Code interrupt flag. (default 0X00)

|         |       | ,     |       |       |       |       |       |       |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | -     | -     | -     | PRGF  | D256F | D4KF  | CAN0F | -     |
| Default | -     | -     | -     | 0     | 0     | 0     | 0     | -     |
|         |       |       |       |       |       |       |       |       |

PRGF  $\rightarrow$  The program RAM error interrupt flag. Must be cleared by software. D256F  $\rightarrow$  The 256 bytes internal RAM error interrupt flag. Must be cleared by software.

 $\rightarrow$  4k AUXRAM ram error interrupt flag. Must be cleared by software.

D4KEF  $\rightarrow$  CAN0 RAM error interrupt flag. Must be cleared by software. CAN0F

In CS8961, those external interrupt, INT2-INT5, and all RAM error interrupts are shared with AFIF that interrupt vector is 0X43.

The figurate below is all interrupts diagram of CS8961.







#### CHAPTER 9 POWER SAVING UNIT

Although the CS8961 is a high-speed micro-controller designed for maximum performance, it also provides power saving unit with two advanced power conservation modes. These modes are Power Management Mode, Lower power mode and Stop. CS8961 interconnection with clock generator is shown in figure below.



Figure-6 Power Saving Unit Interconnection

The Clock Control block chapter shows example implementation of this module.

#### 1. Stop Mode

Stop mode is the lowest power state that the micro-controller can enter. This is achieved by cutting-off frequency provided to CLK pin, resulting in a fully static condition. No processing is possible, timers are stopped, and no serial communication is possible. Processor operation will be postponed on the instruction that sets the STOP bit. Stop mode can be exited in two ways:

1.) A non-clocked interrupt such as the external interrupts INT0-INT5 can be used. Clocked interrupts such as the watchdog timer, internal timers, and serial ports don't operate in Stop mode. Processor operation will resume with the fetching of the interrupt vector associated with the interrupt that caused the exit from Stop mode. When the interrupt service routine will complete, RETI returns the program to the instruction immediately following the one that invoked the Stop mode.

2.) RSTN pin causes the exit from Stop mode. Processor operation will resume execution at address 0X000000.

#### 1.1 Stop Bit Power Configuration Register

PCON(w/r) : (SFR 0X87) Stop Bit Power Configuration Register (default 0X00)

|         |       | /     |       |       |       |       |       |       |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | SMOD0 | SMOD1 | -     | -     | -     | -     | STOP  | -     |
| Default | 0     | 0     | -     | -     | -     | -     | 0     | -     |

STOP - STOP mode bit

=1  $\rightarrow$  Enter STOP mode.

- Unimplemented bit. Read as 0 or 1



STOP bit indicates true state of core. It means that clock signal must be disconnected from input CLK pin source immediately. After exit from STOP mode it is automatically cleared by hardware, so software always read it as logic zero.

#### 2. Power Management Mode

The Power Management Mode (PMM) feature allows software to dynamically match operating frequency and current consumption with the need for processing power. Instead of the full CLK clock speed provided to CS8961 core, power management mode tells external clock generator unit to divide by 256 CLK frequency to conserve power.

The switchback feature allows the micro-controller to almost instantaneously return to full speed mode upon acknowledgment of an external interrupt or a falling edge on a serial port receiver pin. Additionally, micro-controller operating in PMM would normally be unable to sample an incoming serial transmission to properly receive it. The switchback feature allows micro-controller to return to full speed operation in time to receive incoming serial port data and process interrupts with no loss in performance.

#### 2.1 Power Management Register

|              | -          | -           |                 |                |
|--------------|------------|-------------|-----------------|----------------|
| PMR(w/r) : ( | (SFR 0XC4) | Power Manag | gement Register | (default 0X00) |

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | CD1   | CD0   | SWB   | -     | -     | -     | -     | -     |
| Default | 0     | 0     | 0     | -     | -     | -     | -     | -     |

 $CD[1:0] = 11 \rightarrow$  Enable Power Management Mode (PMM) and clock speed divided by 256

- = 01  $\rightarrow$  Disable Power Management Mode (PMM) and return full-speed mode
- SWB Switchback enable
  - $\rightarrow$  Enable interrupts and serial port causes switchback.
  - = 0  $\rightarrow$  Interrupts and serial port don't affect clock CD[1:0]
- Unimplemented bit. Read as 0 or 1.

The CS8959 incorporate a STATUS(0XC5) register to prevent the device from accidentally reducing the clock rate during the servicing of an external interrupt or serial port activity.

#### 2.2 Status Register

= 1

#### STATUS(r) : (SFR 0XC5) Status Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | -     | HIP   | LIP   | -     | SPTA1 | SPRA1 | SPTA0 | SPRA0 |
| Default | -     | 0     | 0     | -     | 0     | 0     | 0     | 0     |

HIP - High Priority (HP) interrupt status LIP - Low Priority (LP) interrupt status SPTA1 - UART1 transmitter activity status SPRA1 - UART1 receiver activity status SPTA0 - UART0 transmitter activity status SPRA0 - UART0 receiver activity status - Unimplemented bit. Read as 0 or 1.

This register can be interrogated to determine if a high priority, or low priority interrupt is in progress, or if serial port activity is occurring. Based on this information the software can delay or reject a planned change in the clock divider rate. Table below shows Power Management related registers and bits.

#### 2.3 Power Management Related Bit

| Bit name | Location | Function                                                                                                                   | Read/Write access |
|----------|----------|----------------------------------------------------------------------------------------------------------------------------|-------------------|
| CD[1:0]  | PMR.7-6  | Clock Divider control<br>CD[1:0]<br>0 1 full speed (default after reset)<br>1 1 divided by 256 (PMM)<br>- 0 not applicable | Unrestricted      |



| Bit name | Location | Function                                                                                                                                 | Read/Write access |
|----------|----------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| SWB      | PMR.5    | Switchback enable<br>0- interrupts and serial port don't affect clock CD[1:0]<br>1- enabled interrupts and serial port causes switchback | Unrestricted      |
| HIP      | STATUS.6 | High Priority (HP) interrupt status<br>0- no HP interrupt<br>1- HP interrupt progressing                                                 | Read only         |
| LIP      | STATUS.5 | Low Priority (LP) interrupt status<br>0- no LP interrupt<br>1- LP interrupt progressing                                                  | Read only         |
| SPTA1    | STATUS.3 | UART1 transmitter activity status<br>0- UART1 transmitter inactive<br>1- UART1 transmitter active                                        | Read only         |
| SPRA1    | STATUS.2 | UART1 receiver activity status<br>0- UART1 receiver inactive<br>1- UART1 receiver active                                                 | Read only         |
| SPTA0    | STATUS.1 | UART0 transmitter activity status<br>0- UART0 transmitter inactive<br>1- UART0 transmitter active                                        | Read only         |
| SPRA0    | STATUS.0 | UART0 receiver activity status<br>0- UART0 receiver inactive<br>1- UART0 receiver active                                                 | Read only         |

#### 3. Low Power Mode

When RTC is used, CS8961 will add a more Low Power Mode. Via

MOV DPTR, #0F55h MOV A, #xx01xxxxb MOVX @DPTR, A

System will run at a lower frequency from RTC OSCPAD (RTC\_X1). System CLK will be down to 1/2 RTC OSC frequency, and the system OSC will stop. When user wants to run back to full speed, following things will be done:

MOV DPTR, #0F55h MOV A, #xx11xxxxb MOVX @DPTR, A NOP (NOP number =0,1....) MOV DPTR, #0F55h MOV A, #xx10Xxxxb MOVX @DPTR, A NOP (NOP number =1, 2...)

/\* Wakeup OSCPAD \*/

/\* return to full speed \*/

#### SEL (r/w) : (XFR 0X0F55) RTC select (default 0X20)

|              | Bit 7                                                                                                              | Bit 6                                                                       | Bit 5                                                | Bit 4                                        | Bit 3                                    | Bit 2             | Bit 1 | Bit 0 | l |
|--------------|--------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------------|------------------------------------------|-------------------|-------|-------|---|
| Name         | -                                                                                                                  | TRTC                                                                        | WKOSC                                                | LPS                                          | -                                        | -                 | -     | -     |   |
| Default      | -                                                                                                                  | 0                                                                           | 1                                                    | 0                                            | -                                        | -                 | -     | -     |   |
| TRTC         | = 1 $\rightarrow$ RTC clock source from internal clock generator<br>= 0 $\rightarrow$ RTC clock source from RTC X1 |                                                                             |                                                      |                                              |                                          |                   |       |       |   |
| WKOSC<br>LPS | Write 1 t<br>Low pow<br>= 0<br>= 1                                                                                 | to wake up the ver mode set $\rightarrow$ The syste $\rightarrow$ The syste | e external cl<br>ect<br>m clock sour<br>m clock sour | ock X1 from<br>ce is from ex<br>ce is from R | Low power r<br>ternal clock<br>ГC_X1 / 2 | node.<br>input X1 |       |       |   |

#### 4. PMM And Peripherals

The Power Management Mode (PMM) reduces power consumption by externally dividing the clock signal provided to the micro-controller, causing it to operate at a reduced speed. When PMM is invoked, the frequency of system clock should be divided by 256. Note that all internal functions, on-board timers (including serial port baud rate generation), watchdog timer, and software timing loops will also run at the reduced speed.



PMM is entered and exited by setting the Clock Rate Divider bits (PMR.7-6). In addition, use of the switchback feature is possible to affect a return from PMM to the full speed mode. This allows both hardware and software to cause an exit from PMM. It is the responsibility of the software to test for UART activity before attempting to change speed, as a modification of the clock divider bits during a UART operation will corrupt the data. In general, it is not possible to generate standard baud rates while in PMM, and the user is advised to avoid PMM or use the switchback feature if UART operation is desired.

#### 5. Switchback Feature

The switchback feature solves one of the most vexing dilemmas faced by power conscious systems. Many applications are unable to use Stop mode because they require constant computation. The switchback feature allows a system to operate at a relatively slow speed, and burst to a faster mode when required by an external event.

Enable this feature by setting the SWB bit (PMR.5), a qualified interrupt (interrupt which has occurred and been acknowledged) or serial port reception or transmission cause the micro-controller to return to full speed mode. An interrupt must be enabled and also not blocked by a higher priority interrupt. After the event is completed, software can manually return the micro-controller to PMM. The following sources can trigger switchback:

- 1. AFI interrupts if enabled.
- 2. Any external interrupt 0/1/2/3/4/5 if enabled.
- 3. UART0/UART1serial start bit detected.
- 4. UART0/UART1 transmit buffer loaded.
- 5. Watchdog timer reset.
- 6. External reset by PAD RSTN.

In the case of a UART-initiated switchback, the switchback is not generated by the associated interrupt. This is because a device operating in PMM will not be able to correctly receive a byte of data to generate an interrupt. Instead, a switchback is generated by a UART reception on the falling edge associated with the start bit, if the associated receiver enable bit (SCON0.4 or SCON1.4) is set. For UART transmissions, a switchback is generated when the UART buffer is loaded. This ensures the micro-controller will be operating in full speed mode when the data is being transmitted, and eliminates the need for a write to the CD[1:0] bits to exit PMM before transmitting. The switchback feature is unaffected by the state of the serial port interrupt flags.

#### 6. Switchback Feature Timing

The timing of the switchback is dependent on the source. Interrupt–initiated switchbacks will occur at the start of the first cycle following the event initiating the switchback. If the current instruction in progress is a write to the IE, IP, EXIE, or EXIP registers, interrupt processing will be delayed until the completion of the following instruction. UART-initiated switchbacks occur at the start of the instruction following the MOV that loads SBUF0 or SBUF1. UART-initiated switchbacks occur during the cycle in which the falling edge was detected. There are a few points that must be considered when using a serial port reception to generate a switchback. Under normal circumstances, noise on the line or an aborted transmission would cause the serial port to timeout and the data to be ignored. This presents a problem if the switchback is used, however, because a switchback functions are used in a noisy environment, the user is advised to periodically check if the device has accidentally exited PMM.

A similar problem can occur if multiprocessor communication protocols are used in conjunction with PMM. The problem is that an invalid address that should be ignored by a particular processor will still generate a switchback. As a result it is not recommended to use a multiprocessor communication scheme in conjunction with PMM. If the system power considerations will allow for an occasional erroneous switchback, a polling scheme can be used to place the device back into PMM.



#### CHAPTER 10 TIMERS

The CS8961 contains three 16-bit timer/counters, Timer 0, Timer 1 and Timer 2. In the "timer mode", Timer 0,1 registers are incremented every 12 or 4 CLK periods when appropriate timer is enabled. In the "timer mode", Timer 2 registers are incremented every 12 or 2 CLK periods (depends on working mode) when it is enabled. In the "counter mode" the timer registers are incremented every falling transition on theirs corresponding input pins: T0, T1 or T2. The input pins are sampled every CLK period.

#### 1. Timer 0 And Timer 1

Timer 0 and Timer 1 are fully compatible with the standard 8051 timers. Each timer consist of two 8-bit registers TH0(0X8C), TL0(0X8A), TH1(0X8D), TL1(0X8B).Timers 0,1 work in the same four modes. The modes are described below.

#### 1.1 Timer 0, Timer1 Modes

| M1 | MO | Mode | Function Description                                                                                                                                                      |
|----|----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0  | 0  | 0    | THx operates as 8-bit timer/counter with a divide by 32 prescaler server by lower 5-bit of TLx.                                                                           |
| 0  | 1  | 1    | 16-bit timer/counter. THx and TLx are cascaded                                                                                                                            |
| 1  | 0  | 2    | TLx operates as 8-bit timer/counter with 8-bit auto-reload by THx                                                                                                         |
| 1  | 1  | 3    | TL0 is configured as 8-bit timer/counter controlled by the standard Timer 0 bits. TH0 is an 8-bit timer controlled by the Timer 1 controls bits. Timer 1 holds its count. |

#### 1.2 Timer 0, Timer1 Control Mode Register

#### TMOD (r/w) : (SFR 0X89) Timer 0, Timer1 Control Mode Register (default 0X00)

|         | Bit 7               | Bit 6 | Bit 5 | Bit 4 | Bit 3               | Bit 2 | Bit 1 | Bit 0 |
|---------|---------------------|-------|-------|-------|---------------------|-------|-------|-------|
|         | Timer1 Control Bits |       |       |       | Timer0 Control Bits |       |       |       |
| Name    | GATE                | СТ    | M1    | MO    | GATE                | СТ    | M1    | MO    |
| Default | 0                   | 0     | 0     | 0     | 0                   | 0     | 0     | 0     |

#### GATE - Gating control

CT

- 1 --- Timer x enable while GATEx pin is high and TRx control bit is set.
- 0 --- Timer x enable while TRx control bit is set.
- Counter or timer select bit
  - 1 ---Counter mode
  - 0 --- Timer mode.
- M1,0 Mode select bits

#### 1.3 Timer 0, Timer 1 Configuration Register

#### TCON (r/w) : (SFR 0X88) Timer 0,Timer1 Configuration Register (default 0X00)

|         | - (   | <b>,</b> |       |       |       |       |       |       |
|---------|-------|----------|-------|-------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | TF1   | TR1      | TF0   | TR0   | IE1   | IT1   | IE0   | IT0   |
| Default | 0     | 0        | 0     | 0     | 0     | 0     | 0     | 0     |

TR0 - Timer 0 run control bit

TR1 - Timer 1 run control bit.

Note : External input GATE0(P3.2), GATE1(P3.3) pins can be programmed to function as a gate to facilitate pulse width measurements.

#### 1.4 Clock Control Register

#### CKCON(r/w) : (SFR 0X8E) Clock Control Register (default 0X03) Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 WD1 WD0 T2M T1M MD2 Name TOM MD1 Default 0 0 0 0 0 0 1

T2M - Timer 2 clock modulus control bit.

1 : Timer2 clock = OSC clock / 4

Bit 0

MD0

1



- 0 : Timer2 clock = OSC clock / 12
- T1M Timer 1 clock modulus control bit.
  - 1 : Timer1 clock = OSC clock / 4
  - 0 : Timer1 clock = OSC clock / 12
- TOM Timer 0 clock modulus control bit.
  - 1 : Timer0 clock = OSC clock / 4 0 : Timer0 clock = OSC clock / 12

#### 2. Timer 0 Operation

#### 2.1 Mode 0

In this mode, the Timer0 register is configured as a 13-bit register. As the count rolls over from all 1s to all 0s, Timer0 interrupt flag TF0 is set. The counted input is enabled to the Timer0 when TCON.4=1 and either TMOD.3=0 or GATE0=1. The 13-bit register consists of all 8 bits of TH0 and the lower 5 bits of TL0. The upper 3 bits of TL0 are indeterminate and should be ignored.



Figure-7 Timer0 Mode 0

#### 2.2 Mode 1

Mode 1 is the same as Mode0, except that the timer register is running with all 16 bits.







#### 2.3 Mode 2

Mode 2 configures the timer register as an 8-bit counter(TL0) with automatic reload. Overflow from TL0 not only sets TF0, but also reloads TL0 with the contents of TH0, which is loaded by software. The reload leaves TH0 unchanged.





#### 2.4 Mode 3

Timer0 in Mode 3 establishes TL0 and TH0 as two separate counters. TL0 uses the Timer0 control bits. TH0 is locked into a timer function and uses the TR1 and TF1 flags from Timer1 and controls Timer1 interrupt. Mode 3 provided for applications requiring an extra 8-bit timer/counter. When Timer0 is in Mode 3, Timer1 can be turned on/off by switching it into its own Mode 3, or can still be used by the serial channel as a baud rate generator, or in any application where interrupt from Timer 1 is not required.






## 3. Timer 1 Operation

## 3.1 Mode 0

In this mode, the Timer1 register is configured as a 13-bit register. As the count rolls over from all 1s to all 0s, Timer1 interrupt flag TF1 is set. The counted input is enabled to the Timer1 when TCON.6=1 and either TMOD.7=0 or GATE1=1. The 13-bit register consists of all 8 bits of TH1 and the lower 5 bits of TL1. The upper 3 bits of TL1 are indeterminate and should be ignored.



Figure-11 Timer1 Mode 0

## 3.2 Mode 1

Mode 1 is the same as Mode0, except that the timer register is running with all 16 bits.



Figure-12 Timer1 Mode1



## 3.3 Mode 2

Mode 2 configures the timer register as an 8-bit counter (TL1) with automatic reload. Overflow from TL1 not only sets TF1, but also reloads TL1 with the contents of TH1, which is loaded by software. The reload leaves TH1 unchanged.



Figure-13 Timer1 Mode1

Mode 3 Timer1 will be held counting. The effect is the same as setting TR1=0.

## 4. Timer 2 Operation

Timer 2 is a 16-bit Timer/Counter, which can operate as either an event timer or an event counter, as selected by C/T2 in the special function register T2CON (0XC8). Timer 2 has three operating modes: Capture, Auto-reload (up or down counting), and Baud Rate Generator, which are selected by bits in the T2CON.

| RCLK+TCLK | CP/RL2 | TR2 | MODE                |  |  |
|-----------|--------|-----|---------------------|--|--|
| 0         | 0      | 1   | 16-bit Auto-reload  |  |  |
| 0         | 1      | 1   | 16-bit Capture      |  |  |
| 1         | Х      | 1   | Baud rate generator |  |  |
| Х         | Х      | 0   | (off)               |  |  |

## 4.1 Capture Mode

In the capture mode there are two options, which are selected by bit EXEN2 in T2CON. If EXEN2=0, then timer 2 is a 16-bit timer or counter (as selected by C/T2 in T2CON) which, upon overflowing sets bit TF2, the timer 2 overflow bit. This bit can be used to generate an interrupt (by enabling the Timer 2 interrupt bit in the IE register). If EXEN2= 1, Timer 2 operates as described above, but with the added feature that a 1- to -0 transition at external input T2EX causes the current value in the Timer 2 registers, TL2 and TH2, to be captured into registers RCAP2L and RCAP2H, respectively. In addition, the transition at T2EX causes bit EXF2 in T2CON to be set, and EXF2 like TF2 can generate an interrupt (which vectors to the same location as Timer 2 overflow interrupt.

The Timer 2 interrupt service routine can interrogate TF2 and EXF2 to determine which event caused the interrupt). The capture mode is illustrated in Figure-14 (There is no reload value for TL2 and TH2 in this mode. Even when a capture event occurs from T2EX, the counter keeps on counting T2EX pin transitions or osc/12 pulses.).

#### Timer 2 Configuration Register T2CON (r/w) : (SFR 0XC8) Timer 2 Configuration Register (default 0X00)

| 120011 (1/1 | ) . (01 11 0/10 | $\mathcal{O}_{\mathcal{O}}$ inner $\mathcal{L}$ v | sonngarado | in negister ( |       | <b>,</b> |       |        |
|-------------|-----------------|---------------------------------------------------|------------|---------------|-------|----------|-------|--------|
|             | Bit 7           | Bit 6                                             | Bit 5      | Bit 4         | Bit 3 | Bit 2    | Bit 1 | Bit 0  |
| Name        | TF2             | EXF2                                              | RCLK       | TCLK          | EXEN2 | TR2      | C/T2  | CP/RL2 |
| Default     | 0               | 0                                                 | 0          | 0             | 0     | 0        | 0     | 0      |

TF2 - Timer 2 interrupt (overflow) flag. Must be cleared by software.

The flag will not be set when either RCLK or TCLK is set.

- EXF2 Falling edge indicator on T2EX pin when EXEN2=1. Must be cleared by software.
- RCLK Receive clock enable
  - 1 UART0 receiver is clocked by Timer 2 overflow pulses
  - 0 UART0 receiver is clocked by Timer 1 overflow pulses
- TCLK Transmit clock enable.
  - 1 UART0 transmitter is clocked by Timer 2 overflow pulses
  - 0 UART0 transmitter is clocked by Timer 1 overflow pulses
- EXEN2 Enable T2EX pin functionality.
  - 1 allows capture or reload as a result of T2EX pin falling edge
  - 0 ignore T2EX events
- TR2 Start/stop Timer 2
  - 1 start
  - 0 stop
- C/T2 Timer/counter select
  - 1 external event counter. Clock source is T2 pin
  - 0 timer Internally clocked
- CP/RL2 Capture/reload select
  - 1 T2EX pin falling edge causes capture to occur when EXEN2=1
  - 0 automatic reload occurs: on Timer 2 overflow or falling edge of T2EX pin when EXEN2=1. When RCLK or TCLK is set this bit is ignored and automatic reload on Timer 2 overflow is forced.



Figure-14 Timer 2 Capture Mode



## 4.2 Auto-Reload Mode (Up or Down Counter)

In the 16-bit auto-reload mode, Timer 2 can be configured (as either a timer or counter (C/T2 in T2CON)) then programmed to count up or down. The counting direction is determined by bit DCEN (Down Counter Enable) which is located in the T2MOD register (0XC9). When reset is applied the DCEN=0 which means Timer 2 will default to counting up. If DCEN bit is set, Timer 2 can count up or down depending on the value of the T2EX pin.

## Timer2 T2MOD Register

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | -     | -     | -     | -     | -     | -     | -     | DCEN  |
| Default | -     | -     | -     | -     | -     | -     | -     | 0     |

Timer 2 which will count up automatically when DCEN=0. In this mode there are two options selected by bit EXEN2 in T2CON register. If EXEN2=0, then Timer 2 counts up to 0FFFFH and sets the TF2 (Overflow Flag) bit upon overflow. This causes the Timer 2 registers to be reloaded with the 16-bit value in RCAP2L and RCAP2H. The values in RCAP2L and RCAP2H are preset by software means. If EXEN2=1, then a 16-bit reload can be triggered either by an overflow or by a 1-to-0 transition at input T2EX. This transition also sets the EXF2 bit. The Timer 2 interrupt, if enabled, can be generated when either TF2 or EXF2 are 1.







DCEN=1 which enables Timer 2 to count up or down. This mode allows pin T2EX to control the direction of count. When a logic 1 is applied at pin T2EX Timer 2 will count up. Timer 2 will overflow at 0FFFFH and set the TF2 flag, which can then generate an interrupt, if the interrupt is enabled. This timer overflow also causes the 16–bit value in RCAP2L and RCAP2H to be reloaded into the timer registers TL2 and TH2.

When a logic 0 is applied at pin T2EX this causes Timer 2 to count down. The timer will underflow when TL2 and TH2 become equal to the value stored in RCAP2L and RCAP2H. Timer 2 underflow sets the TF2 flag and causes 0FFFFH to be reloaded into the timer registers TL2 and TH2.

The external flag EXF2 toggles when Timer 2 underflows or overflows. This EXF2 bit can be used as a 17th bit of resolution if needed. The EXF2 flag does not generate an interrupt in this mode of operation.



Figure-16 Timer 2 Auto-Reloaded Mode (DCEN =1)



#### 4.3 Baud Rate Generator Mode

Bits TCLK and/or RCLK in T2CON allow the serial port transmit and receive baud rates to be derived from either Timer 1 or Timer 2. When TCLK= 0, Timer 1 is used as the serial port (UART0) transmit baud rate generator. When TCLK= 1, Timer 2 is used as the serial port (UART0) transmit baud rate generator. RCLK has the same effect for the serial port receive baud rate. With these two bits, the serial port can have different receive and transmit baud rates – one generated by Timer 1, the other by Timer 2.



Figure-17 Timer 2 As A Baud Rate Generator Mode

The Timer 2 as a baud rate generator mode is valid only if RCLK and/or TCLK = 1 in T2CON register. Note that a rollover in TH2 does not set TF2, and will not generate an interrupt. Thus, the Timer 2 interrupt does not have to be disabled when Timer 2 is in the baud rate generator mode. Also if the EXEN2 (T2 external enable flag) is set, a 1-to-0 transition in T2EX (Timer/counter 2 trigger input) will set EXF2 (T2 external flag) but will not cause a reload from (RCAP2H, RCAP2L) to (TH2,TL2). Therefore when Timer 2 is in use as a baud rate generator, T2EX can be used as an additional external interrupt, if needed. When Timer 2 is in the baud rate generator mode, one should not try to read or write TH2 and TL2.

As a baud rate generator, Timer 2 is incremented every state time (osc/2) or asynchronously from pin T2; under these conditions, a read or write of TH2 or TL2 may not be accurate. The RCAP2 registers may be read, but should not be written to, because a write might overlap a reload and cause write and/or reload errors. The timer should be turned off (clear TR2) before accessing the Timer 2 or RCAP2 registers.



# CHAPTER 11 SERIAL PORTS (UARTS)

Both serial ports are full duplex, meaning it can transmit and receive concurrently. They are receive doublebuffered, meaning they can commence reception of a second byte before a previously received byte has been read from the receive register. Writing to SBUFx loads the transmit register, and reading SBUFx reads a physically separate receive register. The serial ports can operate in 4 modes: one synchronous and three asynchronous modes.

Mode 2 and 3 have a special provision for multiprocessor communications. This feature is enabled by setting SMx2 bit in SCONx register. The master processor first sends out an address byte which identifies the target slave. An address byte differs from a data byte in that the 9th bit is 1 in an address byte and 0 in a data byte. With SMx2 = 1, no slave will be interrupted by a data byte. An address byte, will interrupt all slaves. The addressed slave will clear its SMx2 bit and prepare to receive the data bytes that will be came. The slaves that weren't being addressed leave their SMx2 set and ignoring the incoming data.

## <u>1. UART0</u>

The UART0 has the same functionality as a standard 8052 UART. The UART0 related registers are: SBUF0(0X99), SCON0(0X98), PCON(0X87), IE(0XA8) and IP(0XB8). The UART0 data buffer (SBUF0) consists of two separate registers: transmit and receive registers. A data writes into the SBUF0 sets this data in UART0 output register and starts a transmission. A data reads from SBUF0, reads data from the UART0 receive register.

#### UART0 Buffer Register

#### SBUF0 (r/w) : (SFR 0X99) UART0 Buffer Register (default 0X00)

|         |       | /     |       |       | 1     |       |       |       |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | SB0.7 | SB0.6 | SB0.5 | SB0.4 | SB0.3 | SB0.2 | SB0.1 | SB0.0 |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### UART0 Configuration Register

#### SCON0 (r/w) : (SFR 0X98) UART0 Configuration Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | SM00  | SM01  | SM02  | REN0  | TB08  | RB08  | TIO   | RI0   |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

SM02 - Enables a multiprocessor communication feature

SM01 - Sets baud rate

SM00 - Sets baud rate

REN0 - If set, enables serial reception. Cleared by software to disable reception.

TB08 - The 9th transmitted data bit in Modes 2 and 3. Set or cleared by the CPU, depending on the function it performs (parity check, multiprocessor communication etc.)

RB08 - In Modes 2 and 3 it is the 9th data bit received. In Mode 1, if SM12 is 0,RB08 is the stop bit. In Mode 0 this bit is not used.

TI0 - Transmit interrupt flag, set by hardware after completion of a serial transfer. Must be cleared by software. RI0 - Receive interrupt flag, set by hardware after completion of a serial reception. Must be cleared by software

The UART0 modes are presented in table below.

| SM00 | SM01 | Mode | Description    | Baud Rate          |
|------|------|------|----------------|--------------------|
| 0    | 0    | 0    | Shift register | fosc/12            |
| 0    | 1    | 1    | 8-bit UART     | variable           |
| 1    | 0    | 2    | 9-bit UART     | fosc/32 or fosc/64 |
| 1    | 1    | 3    | 9-bit UART     | variable           |



## The UART0 baud rates are presented in the table below.

| Mode      | Baud Rate                                                                                                    |
|-----------|--------------------------------------------------------------------------------------------------------------|
| Mode 0    | F <sub>CLK</sub> /12                                                                                         |
| Mode 1, 3 | Timer 1 or Timer 2 overflow rate                                                                             |
| Mode 2    | $\begin{array}{ll} \text{SMOD0} = 0 & f_{\text{CLK}}/64 \\ \text{SMOD0} = 1 & f_{\text{CLK}}/32 \end{array}$ |

The SMOD0 bit is located in PCON register.

#### UART0 Bits In Power Configuration Register

#### PCON0 (r/w) : (SFR 0X98) UART0 Bits In Power Configuration Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | SMOD0 | SMOD1 | -     | -     | -     | -     | STOP  | -     |
| Default | 0     | 0     | -     | -     | -     | -     | 0     | -     |

#### SMOD0 - UART0 double baud rate bit

- Unimplemented bit. Read as 0 or 1.

#### URAT0 Bits In Interrupt Enable Register

#### IE (r/w) : (SFR 0XA8) URATO Bits In Interrupt Enable Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | ,<br>Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|------------|-------|-------|
| Name    | EA    | ES1   | ET2-  | ES0   | ET1   | EX1        | ET0   | EX0   |
| Default | 0     | 0     | 0     | 0     | 0     | 0          | 0     | 0     |

#### ES0 - RI0&TI0 interrupt enable flag

1 – Enable UART0 RI0 & TIO interrupt.

0 – Disable UART0 RI0 & TI0 interrupt.

## URAT0 Bits In Interrupt Priority Register

### IP (r/w) : (SFR 0XB8) URATO Bits In Interrupt Priority Register (default 0X00)

|         |       |       | meenaper | lienty negle | lei (aeiaait | 0/100/ |       |       |
|---------|-------|-------|----------|--------------|--------------|--------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5    | Bit 4        | Bit 3        | Bit 2  | Bit 1 | Bit 0 |
| Name    | -     | PS1   | PT2      | PS0          | PT1          | PX     | ET0   | EX0   |
| Default | -     | 0     | 0        | 0            | 0            | 0      | 0     | 0     |

#### PS0 - RI0&TI0 interrupt priority flag

1 – Set to high priority

0 - Set to low priority

- Unimplemented bit. Read as 0 or 1.



## 1.1 MODE 0, SYNCHRONOUS

Pin P30/RX0 serves as bi-direction pad. P31/TX0 output is a shift clock. The baud rate is fixed at 1/12 of the CLK clock frequency. Eight bits are transmitted with LSB first. Reception is initialized by setting the flags in SCON0 as follows: RI0=0 and REN0=1.

|            | 0ns 200ns 400ns 600ns 800ns 1.0us 1.2us 1.4us 1.6us 1.8us 2.0us 2.2u |
|------------|----------------------------------------------------------------------|
| clk        |                                                                      |
| clk/12     |                                                                      |
| SBUF_write |                                                                      |
| send       |                                                                      |
| SBUF_shift |                                                                      |
| rxd        | D0 / D1 / D2 / D3 / D4 / D5 / D6 / D7 /                              |
| txd        |                                                                      |
| ti         |                                                                      |

## Figure-18 UART0 Transmission Mode 0 Timing Diagram

#### 1.2 MODE 1, 8-BIT UART, VARIABLE BAUD RATE, TIMER 1 OR 2 CLOCK SOURCES

Pin P30/RX0 serves as input, and P31/TX0 serves as serial output. 10 bits are transmitted: a start bit (always 0), 8 data bits (LSB first), and a stop bit (always 1). On receive, a start bit synchronizes the transmission, 8 data bits are available by reading SBUF0, and stop bit sets the flag RB08 in the SFR SCON0. The baud rate is variable and depends from Timer 1 or Timer 2 mode. To enable Timer 2 clocking set the TCLK, RCLK bits located in T2CON (0XC8) register.



Figure-19 UART0 Transmission Mode 1 Timing Diagram



## 1.3 MODE 2, 9-BIT UART, FIXED BAUD RATE

This mode is similar to Mode 1 with two differences. The baud rate is fixed at 1/32 or 1/64 of system clock frequency, and 11 bits are transmitted or received: a start bit (0), 8 data bits (LSB first), a programmable 9th bit, and a stop bit (1). The 9th bit can be used to control the parity of the UART interface: at transmission, bit TB08 in SCON0 is output as the 9th bit, and at receive, the 9th bit affects RB08 in SCON0.

|            | Ons 500ns 1.0us 1.5us 2.0us 2.5us 3.0us 3.5us 4.0us 4.5us 5.0us 5.5us 6.0us 6.5us 7.0us |
|------------|-----------------------------------------------------------------------------------------|
| tx_clk     |                                                                                         |
| SBUF_write |                                                                                         |
| send       |                                                                                         |
| SBUF_shift |                                                                                         |
| rxd        |                                                                                         |
| txd        | START / D0 / D1 / D2 / D3 / D4 / D5 / D6 / D7 / TBB / STOP                              |
| ti         |                                                                                         |

Figure-20 UART0 Transmission Mode 2 Timing Diagram

#### 1.4 MODE 3, 9-BIT UART, VARIABLE BAUD RATE, TIMER 1 OR 2 CLOCK SOURCES

The only difference between Mode 2 and Mode 3 is that the baud rate is a variable in Mode 3. When REN0=1 data receiving is enabled. The baud rate is variable and depends from Timer 1 or Timer 2 mode. To enable Timer 2 clocking set the TCLK, RCLK bits located in T2CON (0XC8) register.



Figure-21 UART0 Transmission Mode 2 Timing Diagram



## <u>2. UART1</u>

The UART1 has the same functionality as a standard 8052 UART. The UART1 related registers are: SBUF1(0XC1), SCON1(0XC0), PCON(0X87), IE(0XA8) and IP(0XB8). The UART1 data buffer (SBUF1) consists of two separate registers: transmit and receive registers. Data write into the SBUF1 sets this data in UART1 output register and starts a transmission. Data read from SBUF1, reads data from the UART1 receive register.

#### UART1 Buffer Register

### SBUF1 (r/w) : (SFR 0XC1) UART1 Buffer Register (default 0X00)

| • = • · · (·· · · | /     | · / • · · · · · = |       |       |       |       |       |       |
|-------------------|-------|-------------------|-------|-------|-------|-------|-------|-------|
|                   | Bit 7 | Bit 6             | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name              | SB1.7 | SB1.6             | SB1.5 | SB1.4 | SB1.3 | SB1.2 | SB1.1 | SB1.0 |
| Default           | 0     | 0                 | 0     | 0     | 0     | 0     | 0     | 0     |

#### UART1 Configuration Register

#### SCON1 (r/w) : (SFR 0XC0) UART1 Configuration Register (default 0X00)

|         | <i>i i i</i> |       |       |       |       |       |       |       |
|---------|--------------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7        | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | SM10         | SM11  | SM12  | REN1  | TB18  | RB18  | TI1   | RI1   |
| Default | 0            | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

SM12 - Enables a multiprocessor communication feature

SM11 - Sets baud rate

SM10 - Sets baud rate

REN1 - If set, enables serial reception. Cleared by software to disable reception.

TB18 - The 9th transmitted data bit in Modes 2 and 3. Set or cleared by the CPU, depending on the function it performs (parity check, multiprocessor communication etc.)

RB18 - In Modes 2 and 3 it is the 9th data bit received. In Mode 1, if SM12 is 0,RB18 is the stop bit. In Mode 0 this bit is not used.

TI1 - Transmit interrupt flag, set by hardware after completion of a serial transfer. Must be cleared by software.

RI1 - Receive interrupt flag, set by hardware after completion of a serial reception. Must be cleared by software

#### The UART1 modes are presented in table below.

| SM10 | SM11 | Mode | Description    | Baud Rate            |
|------|------|------|----------------|----------------------|
| 0    | 0    | 0    | Shift register | F <sub>CLK</sub> /12 |
| 0    | 1    | 1    | 8-bit UART     | variable             |
| 1    | 0    | 2    | 9-bit UART     | Fclк/32 or Fclк/64   |
| 1    | 1    | 3    | 9-bit UART     | variable             |

#### The UART1 baud rates are presented in the table below.

| Mode      | Baud Rate                                                 |
|-----------|-----------------------------------------------------------|
| Mode 0    | F <sub>CLK</sub> /12                                      |
| Mode 1, 3 | Timer 1 overflow rate                                     |
| Mode 2    | $SMOD = 0 \qquad F_{CLK}/64$ $SMOD = 1 \qquad F_{CLK}/32$ |

The SMOD1 bit is located in PCON register.

#### UART1 Bits In Power Configuration Register

## PCON (r/w) : (SFR 0X87) UART1 Bits In Power Configuration Register (default 0X00)

| Name SMOD0 SMOD1 | STOP | - |
|------------------|------|---|
| Default 0 0      | 0    | - |

#### SMOD1 - UART1 double baud rate bit

- Unimplemented bit. Read as 0 or 1.

#### URAT1 Bits In Interrupt Enable Register

#### IE (r/w) : (SFR 0XA8) URAT1 Bits In Interrupt Enable Register (default 0X00)

| <u> </u> |       |       |       |       |       |       |       |       |
|----------|-------|-------|-------|-------|-------|-------|-------|-------|
|          | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name     | EA    | ES1   | ET2-  | ES0   | ET1   | EX1   | ET0   | EX0   |
| Default  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### ES1 - RI1&TI1 interrupt enable flag

1 – Enable UART1 RI1 & TI1 interrupt.

0 – Disable UART1 RI1& TI1 interrupt.

#### URAT1 Bits In Interrupt Priority Register

IP (r/w) : (SFR 0XB8) URAT1 Bits In Interrupt Priority Register (default 0X00)

|         |       |       |       | · · · · · · · · · · · · · · · · · · · |       |       |       |       |
|---------|-------|-------|-------|---------------------------------------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4                                 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | -     | PS1   | PT2   | PS0                                   | PT1   | PX    | ET0   | EX0   |
| Default | -     | 0     | 0     | 0                                     | 0     | 0     | 0     | 0     |

PS1 - RI1&TI1 interrupt priority flag

1 – Set to high priority

0 - Set to low priority

- Unimplemented bit. Read as 0 or 1

#### 2.1 MODE 0, SYNCHRONOUS

Pin P12/RX1 serves as bi-direction pad. P13/TX1 output is a shift clock. The baud rate is fixed at 1/12 of the system clock frequency. Eight bits are transmitted with LSB first. Reception is initialized by setting the flags in SCON1 as follows: RI1=0 and REN1=1.

|            | 0ns 200ns | 400ns 6 | 00ns 800r | is 1.0us | 1.2us      | 1.4us | 1.6us | 1.8us 2.0us | 2.2us |
|------------|-----------|---------|-----------|----------|------------|-------|-------|-------------|-------|
| clk        |           |         |           |          |            |       |       |             |       |
| clk/12     | ΛΛ        |         |           |          |            |       | /     |             |       |
| SBUF_write |           |         |           |          |            |       |       |             |       |
| send       | <i>_</i>  |         |           |          |            |       |       |             |       |
| SBUF_shift |           |         |           |          |            |       |       |             |       |
| rxd        |           | D0      | D1 ( D    | 02 X D3  | <u>) (</u> | D4 X  | D5    | D6 X D7     | ·/    |
| txd        |           |         |           |          |            |       |       |             |       |
| ti         |           |         |           |          |            |       |       |             |       |

Figure-22 UART1 Transmission Mode 0 Timing Diagram

#### 2.2 MODE 1, 8-BIT UART, VARIABLE BAUD RATE, TIMER 1 CLOCK SOURCE

Pin P12/RX1 serves as input, and P13/TX1 serves as serial output. 10 bits are transmitted: a start bit (always 0), 8 data bits (LSB first), and a stop bit (always 1). On receive, a start bit synchronizes the transmission, 8 data bits are available by reading SBUF1, and stop bit sets the flag RB18 in the SFR SCON1. The baud rate is variable and depends from Timer 1 only.



|            | 0us               | 10us  |           | 20us | ;             | 30u | s<br>IIII | 40u | IS  | 50u | s<br>IIII | 60u: | s<br>IIII | 70u: | s<br>IIII | 80u: | s<br>IIII | 90u | s   | 100us |
|------------|-------------------|-------|-----------|------|---------------|-----|-----------|-----|-----|-----|-----------|------|-----------|------|-----------|------|-----------|-----|-----|-------|
| tx_clk     | $\square \Lambda$ |       | Λ_        |      | $\Lambda_{-}$ |     | $\Lambda$ |     | _/_ |     | $\Lambda$ |      | _/_       |      | _/_       |      | $\Lambda$ |     | _/_ |       |
| SBUF_write |                   |       |           |      |               |     |           |     |     |     |           |      |           |      |           |      |           |     |     |       |
| send       |                   |       |           |      |               |     |           |     |     |     |           |      |           |      |           |      |           |     |     |       |
| SBUF_shift |                   |       | Λ         |      |               |     | $\Lambda$ |     |     |     | $ \_  $   |      | $\Lambda$ |      | $\Lambda$ |      | $\Lambda$ |     |     |       |
| rxd        |                   |       |           |      |               |     |           |     |     |     |           |      |           |      |           |      |           |     |     |       |
| txd        |                   | START | $\square$ | D0   |               | D1  | X         | D2  |     | D3  |           | D4   |           | D5   |           | D6   |           | D7  |     | STOP  |
| ti         |                   |       |           |      |               |     |           |     |     |     |           |      |           |      |           |      |           |     |     |       |



## 2.3 MODE 2, 9-BIT UART, FIXED BAUD RATE

This mode is similar to Mode 1 with two differences. The baud rate is fixed at 1/32 or 1/64 of system clock frequency, and 11 bits are transmitted or received: a start bit (0), 8 data bits (LSB first), a programmable 9th bit, and a stop bit (1). The 9th bit can be used to control the parity of the UART interface: at transmission, bit TB18 in SCON1 is output as the 9th bit, and at receive, the 9th bit affects RB18 in SCON1.

|            | 0ns 500n | is 1.0us | 1.5us 2 | .0us 2.5us | 3.0us | 3.5us | 4.0us | 4.5us ( | 5.0us (      | 5.5us | 6.0us 6 | .5us 7.0 | us   |
|------------|----------|----------|---------|------------|-------|-------|-------|---------|--------------|-------|---------|----------|------|
| tx_clk     | Λ        |          |         |            |       |       | ſ     | \       | Λ            | _/_   |         | /        | ^    |
| SBUF_write |          |          |         |            |       |       |       |         |              |       |         |          |      |
| send       |          |          |         |            |       |       |       |         |              |       |         |          |      |
| SBUF_shift |          | /        |         |            |       | /     |       | \       | Λ            | _/_   |         |          |      |
| rxd        |          |          |         |            |       |       |       |         |              |       |         |          |      |
| txd        |          | START /  | D0      | D1 X       | D2    | D3    | D4    | D5      | <u> (</u> D6 | ;(    | D7 (    | ТВВ      | STOP |
| ti         |          |          |         |            |       |       |       |         |              |       |         |          |      |

Figure-24 UART1 Transmission Mode 2 Timing Diagram

## 2.4 MODE 3, 9-BIT UART, VARIABLE BAUD RATE, TIMER 1 CLOCK SOURCE

The only difference between Mode 2 and Mode 3 is that the baud rate is a variable in Mode 3. When REN1=1 data receiving is enabled. The baud rate is variable and depends from Timer 1 only.



Figure-25 UART1 Transmission Mode 3 Timing Diagram



# CHAPTER 12 MDU – MULTIPLICATION AND DIVISION UNIT

This arithmetic unit (called MDU) provides fast 32-bit division, 16-bit multiplication and shift and normalize features. All operations are unsigned integer operations. The MDU is handled by seven registers MD0 to MD5, contain the operands and the result and one control register called ARCON.

## MDU Registers Location

| SFR Name | Address                   | Description          |  |  |  |
|----------|---------------------------|----------------------|--|--|--|
| MD0      | 0X0F9                     | MDU data register 0  |  |  |  |
| MD1      | 0X0FA MDU data register 1 |                      |  |  |  |
| MD2      | 0X0FB                     | MDU data register 2  |  |  |  |
| MD3      | 0X0FC                     | MDU data register 3  |  |  |  |
| MD4      | 0X0FD                     | MDU data register 4  |  |  |  |
| MD5      | 0X0FE                     | MDU data register 5  |  |  |  |
| ARCON    | 0X0FF                     | MDU control register |  |  |  |

#### ARCON Registers

#### ARCON (r/w) : (SFR 0XFF) ARCON Registers (default 0X00)

|         |       |       |       |       | -7    |       |       |       |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | MDEF  | MDOV  | SLR   | SC.4  | SC.3  | SC.2  | SC.1  | SC.0  |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

MDEF - Error flag. Indicates an improperly performed operation. Set by hardware when an operation is restarted by a write access to MDx before the first operation has been completed. MDEF is automatically cleared after being read.

MDOV - Overflow flag. Controlled by hardware only. Set if division by zero or multiplication result is greater than 0X0000FFFFh

- SLR Shift direction bit 1 - shift right
  - 0 shift left
- SC[4:0] Shift counter bits. When preset with 00000B, normalizing is selected. After operation SC[4:0] contain the number of normalizing shifts performed. When set with a value differ than 0, shift operation is started. The number of shifts performed is determined by the count written to SC[4:0]

Table below describes the four general operations the MDU is able to perform:

## MDU Operations Timing

| Operation            | Result | Reminder | Execution time [CLK] |
|----------------------|--------|----------|----------------------|
| 32b/16b              | 32b    | 16b      | 17                   |
| 16b/16b              | 16b    | 16b      | 9                    |
| 16bx16b              | 32b    | -        | 10                   |
| 32b normalize        | -      | -        | 3-20                 |
| 32b shift left/right | -      | -        | 3-18                 |



MDU operation is consisted of three phases:

- 1. Loading MDx registers in an appropriate order dependent on operation.
- 2. Executing operation.
- 3. Result reading from MDx registers.

MDU Read/Write Sequences

| Operation   | Shift/ | Norm | 32b/32b |          |      | 16b/16b |          |      | 16bx16b |               |      |
|-------------|--------|------|---------|----------|------|---------|----------|------|---------|---------------|------|
| First write | MD0    | Low  | MD0     | Dividend | Low  | MD0     | Dividend | Low  | MD0     | Multiplicand  | Low  |
|             | MD1    |      | MD1     | Dividend |      | MD1     | Dividend | High | MD4     | Multiplicator | Low  |
|             | MD2    |      | MD2     | Dividend |      |         |          |      |         |               |      |
|             | MD3    | High | MD3     | Dividend | High |         |          |      |         |               |      |
|             |        |      | MD4     | Divisor  | Low  | MD4     | Divisor  | Low  | MD1     | Multiplicand  | High |
| Last write  | ARCO   | N    | MD5     | Divisor  | High | MD5     | Divisor  | High | MD5     | Multiplicator | High |
| First read  | MD0    | Low  | MD0     | Quotient | Low  | MD0     | Quotient | Low  | MD0     |               | Low  |
|             | MD1    |      | MD1     | Quotient |      | MD1     | Quotient | High | MD1     |               |      |
|             | MD2    |      | MD2     | Quotient |      |         |          |      | MD2     | Product       |      |
|             | MD3    | High | MD3     | Quotient | High |         |          |      | MD3     |               | High |
|             |        |      | MD4     | Reminder | Low  | MD4     | Reminder | Low  |         |               |      |
| Last read   |        |      | MD5     | Reminder | High | MD5     | Reminder | High |         |               |      |

## 1. Division And Multiplication Operations

Below are described sequential operations performed to execute division and multiplication operations on required data arguments.

#### **1.1 WRITE SEQUENCE**

The first and the last write operations in phase one are fixed for every calculation of the MDU. All write operations in-between determine the type of MDU calculation. A write to MD0 is the first transfer to be done in any case. This write resets the MDU and triggers the error flag mechanism. The next two or three write operations select the calculation type. The last write-to-MD5 finally starts selected MUL/DIV operation.

#### 1.2 READ SEQUENCE

Any read-out of the MDx registers should begin with MD0. The last read from MD5 (division) or MD3 (multiplication) determines the end of a whole calculation and releases the error flag mechanism. There is no restriction on the time within which a calculation must be completed. Any new write access to MD0 starts a new calculation, no matter whether the read-out of the former result has been completed or not.



## 2. Normalize Operation

Normalizing is done on an integer variable stored in MD0 to MD3. "To normalize" means, that all reading zeroes of an integer variable in registers MD0 to MD3 are removed by shift left operations. The whole operation is completed when the MSB of number contains a logic 1.

To select a normalize operation, the five bit field ARCON.0 to ARCON.4 must be cleared. That means, a writeto-ARCON instruction with the value XXX0 0000B starts the operation. After normalizing, bits ARCON.0 to ARCON.4 contain the number of shift left operations which were done. This number may further on be used as an exponent.

Register ARCON controls an up to 32-bit wide normalize and shift operation in registers MD0 to MD3. It also contains the overflow flag and the error flag.

#### 2.1 WRITE SEQUENCE

A write-to-MD0 is the first transfer to be done for normalize and shift. This write resets the MDU and triggers the error flag mechanism. To start a shift or normalize operation the last write must access register ARCON.

#### 2.2 READ SEQUENCE

The order in which the first three registers MD0 to MD2 are read is not critical. The last read from MD3 determines the end of a whole shift or normalize procedure and releases the error flag mechanism.

Note: Any write access to ARCON triggers a shift or normalize operation and therefore changes the contents of registers MD0 to MD3.

Completion of operation, can also be controlled by the error flag mechanism. The error flag is set if one of the relevant registers (MD0 through MD3) is accessed before the previously commenced operation has been completed. For proper operation of the error flag mechanism, it is necessary to take care that the right write or read sequence to or from registers MD0 to MD3 is maintained.

#### 3. Shift Operation

By a write-to-ARCON instruction - a shift left/right operation can be started. In this case register bit SLR (ARCON.5) has to contain the shift direction, and ARCON.0 to ARCON.4 the shift count (which must not be 0). During shift, zeroes come into the left or right end of the registers MD0 or MD3, respectively.

Register ARCON controls an up to 32-bit wide normalize and shift operation in registers MD0 to MD3. It also contains the overflow flag and the error flag.

#### 3.1 WRITE SEQUENCE

A write-to-MD0 is the first transfer to be done for normalize and shift. This write resets the MDU and triggers the error flag mechanism. To start a shift or normalize operation the last write must access register ARCON.

#### 3.2 READ SEQUENCE

The order in which the first three registers MD0 to MD2 are read is not critical. The last read from MD3 determines the end of a whole shift or normalize procedure and releases the error flag mechanism.

Note: Any write access to ARCON triggers a shift or normalize operation and therefore changes the contents of registers MD0 to MD3!

Completion of operation, can also be controlled by the error flag mechanism. The error flag is set if one of the relevant registers (MD0 through MD3) is accessed before the previously commenced operation has been completed. For proper operation of the error flag mechanism, it is necessary to take care that the right write or read sequence to or from registers MD0 to MD3 is maintained.



## 4. MDU Error Flag

The error fag indicates an improperly performed operation. The error mechanism flag is automatically enabled during MD0 write and disabled during result reading from MD3 (multiplication) or MD5 (division) register. The flag is set if:

- current calculation has been interrupted or restarted
- mechanism is enabled and read operation is performed
- The flag is cleared if: operation is successfully completed and read access is performed

## 5. MDU Overflow Flag

The flag is set if:

- division by zero occurred
- multiplication result is greater than 0X0000FFFF
- normalize operation has been performed on normalized number (MD3(7)=1)

This flag is read only.



# CHAPTER 13 DI2CM - MASTER IIC BUS CONTROLLER

## 1. The I2C-Bus Short Specification

### **1.1 THE I2C-BUS CONCEPT**

The I2C-bus supports any IC fabrication process (NMOS, CMOS, bipolar). Two wires, serial data (SDA) and serial clock (SCL), carry information between the devices connected to the bus. Each devices is recognized by a unique address – whether it's a micro-controller, LCD driver, memory or keyboard interface – and can operate as either a transmitter or receiver, depending on the function of the device. Obviously an LCD driver is only a receiver, whereas a memory can both receive and transmit data. In addition to transmitters and receivers, devices can also be considered as masters or slaves when performing data transfers (see Figure below).



#### Figure-26

A master is the device which initiates a data transfer on the bus and generates the SCL clock signals. The I2Cbus is a multi-master bus. This means that more than one device capable of controlling the bus can be connected to it. As masters are usually micro-controllers or microprocessors.

#### Definition Of I2c-Bus Terminology

| Term            | Description                                                                                                                                              |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transmitter     | The device which sends the data to the bus                                                                                                               |
| Receiver        | The device which receives the data from the bus                                                                                                          |
| Master          | The device which initiates a transfer, generates clock signals and terminates a transfer                                                                 |
| Slave           | The device addressed by a mater                                                                                                                          |
| Multi-master    | More than one mater can attempt to control the bus at the same time without corrupting the message                                                       |
| Arbitration     | Procedure to ensure that, if more than one master simultaneously tries to control the bus, only one is allowed to do so and the message is not corrupted |
| Synchronisation | Procedure to synchronise the clock signals of two or more devices                                                                                        |



## 1.2 TRANSFERRING DATA

Both SDA and SCL are bi-directional lines, connected to a positive supply voltage via a pull-up resistor (see figure below). When the bus is free, both lines are HIGH. The output stages of devices connected to the bus must have an open drain or open-collector in order to perform the wired-AND function. Data on the I2C-bus can be transferred at a rate up to 100 kbit/s in the Standard mode, up to 400 kbit/s in the Fast mode.



Figure-27 Connection Master And Slave Devices To I2c-Bus

## 1.3 BIT TRANSFER

Due to the variety of different technology devices (CMOS, NMOS, bipolar) which can be connected to the I2Cbus, the levels of the logical '0' (LOW) and '1' (HIGH) are not fixed and depend on the associated level of VDD. One clock pulse is generated for each data bit transferred.



## **1.4 DATA VALIDITY**

The data on the SDA line must be stable during the HIGH period of the clock. The HIGH or LOW state of the data line can only change when the clock signal on the SCL line is LOW (see figure below).





## **1.5 START AND STOP CONDITIONS**

Within the procedure of the I2C-bus, unique situations arise which are defined as START and STOP conditions (see figure below). A HIGH to LOW transition on the SDA line while SCL is HIGH is one such unique case. This situation indicates a START condition. A LOW to HIGH transition on the SDA line while SCL is HIGH defines a STOP condition. START and STOP conditions are always generated by the Master. The bus is considered to be busy after the START condition. The bus is considered to be free again a certain time after the STOP condition.



Figure-29 START And STOP Conditions

## 1.6 BYTE FORMAT

Every byte put on the SDA line must be 8-bits long. The number of bytes that can be transmitted per transfer is unrestricted. Each byte has to be followed by an acknowledge bit. Data is transferred with the most significant bit (MSB) first. If a receiver can't receive another complete byte of data until it has performed some other function, for example servicing an internal interrupt, it can hold the clock line SCL LOW to force the transmitter into a wait state. Data transfer than continues when the receiver is ready for another byte of data and releases clock line SCL.

## **1.7 ACKNOWLEDGE**

Data transfer with acknowledge is obligatory. The acknowledge-related clock pulse is generated by the master. The transmitter releases the SDA line (HIGH) during the acknowledge clock pulse. The receiver must pull down the SDA line during the acknowledge clock pulse so that it remains stable LOW during the HIGH period of this clock pulse. Of course, set-up and hold times must also be taken into account.

When a slave-receiver doesn't acknowledge the slave address (for example, it's unable to receive because it's performing some real-time function), the data line must be left HIGH by the slave. The master can then generate a STOP condition to abort the transfer. If a master-receiver is involved in a transfer, it must signal the end of data to the slave-transmitter by not generating acknowledge on the last byte that was clocked out of the slave. The slave-transmitter must release the data line to allow the master to generate a STOP or repeated START condition.



## **1.8 CLOCK SYNCHRONIZATION**

All masters generate their own clock on the SCL line to transfer messages on the I2C-bus. Data is only valid during the HIGH period of the clock. A defined clock is therefore needed for the bit-by-bit arbitration procedure to take place. Clock synchronization is performed using the wired-AND connection of I2C interfaces to the SCL line. A synchronized SCL clock is generated with its LOW period determined by the device with the longest clock LOW period, and its HIGH period determined by the one with the shortest clock HIGH period.

#### **1.9 ARBITRATION**

A master may start a transfer only if the bus is free. Two or more masters may generate a START condition within the minimum hold time of the START condition which results in a defined START condition to the bus. Arbitration takes place on the SDA line, while the SCL line is at the HIGH level, in such a way that the master which transmits a HIGH level, while another master is transmitting a LOW level will switch off its DATA output stage because the level on the bus doesn't correspond to its own level.

Arbitration can continue for many bits. Its first stage is comparison of the address bits. If the masters are each trying to address the same device, arbitration continues with comparison of the data-bits. Because address and data information on the I2C-bus is determined by the winning master, no information is lost during the arbitration process. A master that loses the arbitration can generate clock pulses until the end of the byte in which it loses the arbitration.

As an Hs-mode master has a unique 8-bit master code, it will always finish the arbitration during the first byte.

#### **1.10 DATA FORMAT WITH 7-BIT ADDRESS**

Data transfers follow the format shown in figure below. After the START condition, a slave address is sent. This address is 7 bits long followed by an eighth bit which is a data direction bit (R/S) - a 'zero' indicates a transmission (SEND), a 'one' indicates a request for data (RECEIVE). A data transfer is always terminated by a STOP condition generated by the master. However, if a master still wishes to communicate on the bus, it can generate a repeated START condition and address another slave without first generating a STOP condition. Various combinations of receive/send formats are then possible within such a transfer.



Figure-30 A Complete Data Transfer With 7-Bit Address

The first seven bits of the first byte make up the slave address. The eighth bit determines the direction of the message. A 'zero' in the R/S position of the first byte means that the master will write (send) information to a selected slave. A 'one' in this position means that the master will receive information from the slave.



Figure-31 The First Byte After The START Condition



## 2. Internal Registers

There are six registers used to interface to the host: the Control, Status, Slave Address, Transmitted Data, Received Data and Timer Period Register.

#### **DI2CM Register For Writing**

| Register | Address | Function                  |
|----------|---------|---------------------------|
| I2CMSA   | 0X0F4   | Slave address             |
| I2CMCR   | 0X0F5   | Control                   |
| I2CMBUF  | 0X0F6   | Transmitter data register |
| I2CMTP   | 0X0F7   | Timer period              |

#### DI2CM Register For Reading

| Register | Address | Function               |
|----------|---------|------------------------|
| I2CMSA   | 0X0F4   | Slave address          |
| I2CMCR   | 0X0F5   | Status                 |
| I2CMBUF  | 0X0F6   | Receiver data register |
| I2CMTP   | 0X0F7   | Timer period           |

#### 2.1 I2CMTP - TIMER PERIOD REGISTER

#### DI2CM Timer Period Register

I2CTP (r/w) : (SFR 0XF7) DI2CM Timer Period Register (default 0X00)

|         |       | /     |       |       |       |       |       |       |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | CTP.7 | CTP.6 | CTP.5 | CTP.4 | CTP.3 | CTP.2 | CTP.1 | CTP.0 |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

To generate wide range of SCL frequencies the core have build-in 8-bit timer.

SCL\_PERIOD = 8\* (1+TIMER\_PRD) \* CLK\_PRD

for example:

- CLK\_PRD = 50ns (system clock freuqncy = 20 MHz);
- TIMER\_PRD = 24; (The value contains in DI2CM Timer Period Register) SCL\_PERIOD = 8\* (1+24)\* 50ns = 8\*25\*50ns = 10000ns =10us SCL\_FREQUENCY = 1/10us = 100kHz

## 2.2 I2CMCR - CONTROL AND STATUS REGISTERS

The Control Register consists of three bits: the RUN bit, the START bit, and the STOP bit. The START bit will cause the generation of the START, or REPEATED START protocol. The Stop bit determines if the cycle will stop at the end of the data cycle, or continue on to a burst. To generate a single read cycle, the Slave Address register is written with the desired address, the R/S bit is set to '1', and Control Register is written with ACK=0, STOP=1, START=1, RUN=1 (binary xxxx0111 x mean 0 or 1) to perform the operation and stop. When the operation is completed (or aborted due an error) the interrupt pin becomes active and the data may be read from Received Data Register. The ACK bit must be set normally to logic 1. This cause the I2C bus controller to send an acknowledge automatically after each byte.

The bit must be reset when the I2C bus controller is operated in master/receiver mode and requires no further data to be sent from slave transmitter.



## DI2CM Control Register

## I2CMCR (w) : (SFR 0XF5) DI2CM Control Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | -     | -     | -     | HS    | ACK   | STOP  | START | RUN   |
| Default | -     | -     | -     | 0     | 0     | 0     | 0     | 0     |

#### Control Bits Combinations Permitted In IDLE State

| HS | R/S | ACK | STOP | START | RUN | OPERATION                                                                                                 |
|----|-----|-----|------|-------|-----|-----------------------------------------------------------------------------------------------------------|
| 0  | 0   | -   | 0    | 1     | 1   | START condition followed by SEND (Master remains in Transmitter mode)                                     |
| 0  | 0   | -   | 1    | 1     | 1   | START condition followed by SEND and STOP condition                                                       |
| 0  | 1   | 0   | 0    | 1     | 1   | START condition followed by RECEIVE operation with negative Acknowledge (Master remains in Receiver mode) |
| 0  | 1   | 0   | 1    | 1     | 1   | START condition followed by RECEIVE and STOP condition                                                    |
| 0  | 1   | 1   | 0    | 1     | 1   | START condition followed by RECEIVE (Master remains in Receiver mode)                                     |
| 0  | 1   | 1   | 1    | 1     | 1   | Forbidden sequence                                                                                        |

--- All other control bits combinations not mentioned in table above are NOP's.

#### Control Bits Combinations Permitted In Master Transmitter Mode

| HS | R/S | ACK | STOP | START | RUN | OPERATION                                                                                                                 |
|----|-----|-----|------|-------|-----|---------------------------------------------------------------------------------------------------------------------------|
| 0  | -   | -   | 0    | 0     | 1   | SEND operation (Master remains in Transmitter mode)                                                                       |
| 0  | -   | -   | 1    | 0     | 0   | STOP condition                                                                                                            |
| 0  | -   | -   | 1    | 0     | 1   | SEND followed by STOP condition                                                                                           |
| 0  | 0   | -   | 0    | 1     | 1   | Repeated START condition followed by SEND (Master remains in Transmitter mode)                                            |
| 0  | 0   | -   | 1    | 1     | 1   | Repeated START condition followed by SEND and STOP condition                                                              |
| 0  | 1   | 0   | 0    | 1     | 1   | Repeated START condition followed by RECEIVE operation with <i>negative Acknowledge (Master remains in Receiver mode)</i> |
| 0  | 1   | 0   | 1    | 1     | 1   | Repeated START condition followed by SEND and STOP condition                                                              |
| 0  | 1   | 1   | 0    | 1     | 1   | Repeated START condition followed by RECEIVE (Master remains in Receiver mode)                                            |
| 0  | 1   | 1   | 1    | 1     | 1   | Forbidden sequence                                                                                                        |

--- All other control bits combinations not mentioned in table above are NOP's.

## Control Bits Combinations Permitted In Master Receiver Mode

| HS | R/S | ACK | STOP | START | RUN | OPERATION                                                                            |
|----|-----|-----|------|-------|-----|--------------------------------------------------------------------------------------|
| 0  | -   | 0   | 0    | 0     | 1   | RECEIVE operation with <i>negative Acknowledge (Master remains in Receiver mode)</i> |
| 0  | -   | -   | 1    | 0     | 0   | STOP condition**                                                                     |
| 0  | -   | 0   | 1    | 0     | 1   | RECEIVE followed by STOP condition                                                   |
| 0  | -   | 1   | 0    | 0     | 1   | RECEIVE operation (Master remains in Receiver mode)                                  |
| 0  | -   | 1   | 1    | 0     | 1   | Forbidden sequence                                                                   |



| 0 | 1 | 0 | 0 | 1 | 1 | Repeated START condition followed by RECEIVE operation with <i>negative Acknowledge (Master remains in Receiver mode)</i> |
|---|---|---|---|---|---|---------------------------------------------------------------------------------------------------------------------------|
| 0 | 1 | 0 | 1 | 1 | 1 | Repeated START condition followed by RECEIVE and STOP condition                                                           |
| 0 | 1 | 1 | 0 | 1 | 1 | Repeated START condition followed by RECEIVE (Master remains in Receiver mode)                                            |
| 0 | 0 | - | 0 | 1 | 1 | Repeated START condition followed by SEND (Master remains in Receiver mode)                                               |
| 0 | 0 | - | 1 | 1 | 1 | Repeated START condition followed by SEND and STOP condition                                                              |

--- All other control bits combinations not mentioned in table above are NOP's. in Master Receiver mode STOP condition should be generated only after Data negative Acknowledge executed by Master or Address negative Acknowledge executed by Slave.

The Status Register consists of six bits: the BUSY bit, the ERROR bit, the ADDR\_ACK bit, the DATA\_ACK bit, the ARB\_LOST bit, and the IDLE bit.

DI2CM Status Register I2CMCR (r) : (SFR 0XF5) DI2CM Status Register (default 0X00)

|         | Bit 7 | Bit 6    | Bit 5 | Bit 4    | Bit 3    | Bit 2    | Bit 1 | Bit 0 |
|---------|-------|----------|-------|----------|----------|----------|-------|-------|
| Name    | -     | BUS_BUSY | IDLE  | ARB_LOST | DATA_ACK | ADDR_ACK | ERROR | BUSY  |
| Default | -     | 0        | 0     | 0        | 0        | 0        | 0     | 0     |

BUS\_BUSY – this bit indicates that the Bus is Busy, and access is not possible. This bit is set/reset by START and STOP conditions;

IDLE - this bit indicates that I2C Bus controller is in the IDLE state:

ARB\_LOST - this bit indicates that due the last operation I2C Bus controller lost the arbitration;

DATA\_ACK - this bit indicates that due the last operation transmitted data wasn't acknowledged;

ADDR\_ACK - this bit indicates that due the last operation slave address wasn't acknowledged;

- ERROR this bit indicates that due the last operation an error occurred: slave address wasn't acknowledged, transmitted data wasn't acknowledged, or I2C Bus controller lost the arbitration;
- BUSY this bit indicates that I2C Bus controller receiving, or transmitting data on the bus, and other bits of Status register are no valid;

## **I2CMSA -** SLAVE ADDRESS REGISTER

The Slave Address Register consists of eight bits: seven address bits (A6-A0), and Receive/not Send bit R/S. The R/S bit determines if the next operation will be a Receive (high), or Send (low).

#### DI2CM Slave Address Register

I2CMSA (r/w) : (SFR 0XF4) DI2CM Slave Address Register (default 0X00)

|         | .)    | , = = = • • |       | 50 e g. e . e . |       | -/    |       |       |
|---------|-------|-------------|-------|-----------------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6       | Bit 5 | Bit 4           | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | A.6   | A.5         | A.4   | A.3             | A.2   | A.1   | A.0   | R/S   |
| Default | 0     | 0           | 0     | 0               | 0     | 0     | 0     | 0     |

#### **DI2CMBUF -** RECEIVER AND TRANSMITTER REGISTERS

The Transmitter Data Register consists of eight data bits which will be sent on the bus due the next Send, or Burst Send operation. The first send bit is the D.7 (MSB).

DI2CM Transmitter Data Register

#### I2CMBUF (w) : (SFR 0XF6) DI2CM Transmitter Data Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | D.7   | D.6   | D.5   | D.4   | D.3   | D.2   | D.1   | D.0   |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |



The Receiver Data Register consists of eight data bits which have been received on the bus due the last Receive, or Burst Receive operation.

### DI2CM Receiver Data Register

#### I2CMBUF (r) : (SFR 0XF6) DI2CM Receiver Data Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | D.7   | D.6   | D.5   | D.4   | D.3   | D.2   | D.1   | D.0   |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |



## 3. Available Command Sequences

The command flowcharts presented in this chapter are concerned to NORMAL and FAST transmission speeds. In HIGH speed mode a special MASTER CODE is required before processing into particular operation. It is described in Operations in High-speed mode subchapter.

## 3.1 SINGLE SEND



Figure-32 Single SEND Flowchart





Figure-33 Single SEND Waveform



Figure-33a Single SEND Waveform - REGISTERS WRITING



## Figure-33b Single SEND Waveform - STATUS REGISTER READING



## **3.2 SINGLE RECEIVE**











## 3.3 BURST SEND







# CS8961 PRELIMINARY



## Figure-37 Sending n=3 Bytes Waveform



## 3.4 BURST RECEIVE









Figure-39 Receiving m=3 Bytes Waveform

## 3.5 BURST RECEIVE AFTER BURST SEND











#### 3.6 BURST SEND AFTER BURST RECEIVE



#### Figure-42 Receiving m Bytes Followed By Repeated Start And Sending n Bytes Flowchart



## Figure-43 Receiving 3 Bytes Followed By Repeated Start And Sending 3 Bytes Waveform



# **CHAPTER 14 SLAVE IIC**

## 1. SlaveB 0 IIC And Slave B 1 IIC

The SlaveB 0 IIC block is connected to SDA0 and SCL0 (The SlaveB 1 IIC block is connected to SDA1 and SCL1) pins only. This block cans receive/transmit data using IIC protocols. S/W may write the SLVBADR register to determine the slave addresses.

In receive mode, the block first detects IIC slave address matching the condition then issues a SlvBMI0(SlvBMI1) interrupt. The data from SDA0(SDA1) is shifted into shift register then written to RCBBUF0(RCBBUF1) register when a data byte is received. The first byte loaded is word address (slave address is dropped). This block also generates a RCBI0(RCBI1) (receives buffer full interrupt) every time when the RCBBUF0(RCBBUF1) is loaded. If S/W is not able to read out the RCBBUF0(RCBBUF1) in time, the next byte in shift register is not written to RCBBUF0(RCBBUF1) and the slave block returns NACK to the master. This feature guarantees the data integrity of communication. The WadrB0(WadrB1) flag can tell S/W whether the data in RCBBUF0(RCBBUF1) is a word address or not.

In transmit mode, the block first detects IIC slave address matching the condition, then issues a SIvBMI0(SIvBMI1) interrupt. In the meantime, the data pre-stored in the TXBBUF0(TXBBUF1) is loaded into shift register, resulting in TXBBUF0(TXBBUF1) emptying and generates a TXBI0(TXBI1) (transmit buffer empty interrupt). S/W should write the TXBBUF0(TXBBUF1) a new byte for the next transfer before shift register empties. A failure of this process causes data corrupt. The TXBI0(TXBI1) occurs every time when shift register reads out the data from TXBBUF0(TXBBUF1).

The SlvBMI0(SlvBMI0) is cleared by writing "0" to corresponding bit in INTFLG0(INTFLG1) register. The RCBI0(RCBI1) is cleared by reading out RCBBUF0(RCBBUF1). The TXBI0(TXBI1) is cleared by writing TXBBUF0(TXBBUF1).

| IICSTUS0 | F01h (r) | WadrB0   |                                | SlvRWB0  | SackIn0        | SLVS0         |    |  |  |  |
|----------|----------|----------|--------------------------------|----------|----------------|---------------|----|--|--|--|
| INTFLG0  | F03h (r) | TXBI0    | RCBI0                          | SlvBMI0  | STOPI0         | ReStal0       |    |  |  |  |
| INTFLG0  | F03h (w) |          |                                | SIvBMI0  | STOPI0         | ReStal0       |    |  |  |  |
| INTEN0   | F04h (w) | ETXBI0   | ERCBI0                         | ESIvBMI0 | ESTOPI0        | EreStal0      |    |  |  |  |
| RCBBUF0  | F08h (r) |          |                                | Slav     | ve B 0 IIC red | ceives buffer |    |  |  |  |
| TXBBUF0  | F08h (w) |          | Slave B 0 IIC transmits buffer |          |                |               |    |  |  |  |
| SLVBADR0 | F09h (w) | ENSIvB 0 | Slave B 0 IIC address          |          |                |               |    |  |  |  |
| IICSTUS1 | F91h(w)  | WadrB1   |                                | SlvRWB1  | Sackin1        | SLVS1         |    |  |  |  |
| INTFLG1  | F93h(r)  | TXBI1    | RCBI1                          | SlvBMI1  | STOPI1         | ReStal1       |    |  |  |  |
| INTFLG1  | F93h(w)  |          |                                | SlvBMI1  | STOPI1         | ReStal1       |    |  |  |  |
| INTEN1   | F94h(w)  | ETXBI21  | ERCBI1                         | ESIvBMI1 | ESTOPI1        | Erstal1       |    |  |  |  |
| RCBBUF1  | F98h(r)  |          | SlaveB 1 IIC receives buffer   |          |                |               |    |  |  |  |
| TXBBUF1  | F98h(w)  |          | SlaveB 1 IIC transimits buffer |          |                |               |    |  |  |  |
| SLVBADR1 | F99h(w)  | ENSIvB1  |                                |          | Slavel         | B1 IIC addres | SS |  |  |  |

Slave B Register List

#### **OPTION** (r/w) : (XFR 0X0F56) Chip Option Configuration (default 0X00)

|                                                                                                                                             | Bit 7 | Bit 6  | Bit 5 | Bit 4  | Bit 3  | Bit 2 | Bit 1 | Bit 0 |  |
|---------------------------------------------------------------------------------------------------------------------------------------------|-------|--------|-------|--------|--------|-------|-------|-------|--|
| Name                                                                                                                                        | PWMF  | DIV253 | -     | ENSCL1 | ENSCL0 | -     | -     | -     |  |
| Default                                                                                                                                     | 0     | 0      | -     | 0      | 0      | -     | -     | -     |  |
| ENSCL1 = 1 $\rightarrow$ Enable SlaveB 1 IIC block to hold SCL pin low while CS8959 is unable to catch-up with the external master's speed. |       |        |       |        |        |       |       |       |  |
| ENSCL0 = 1 $\rightarrow$ Enable SlaveB 0 IIC block to hold SCL pin low while CS8959 is unable to catch-up with the external master's speed. |       |        |       |        |        |       |       |       |  |

## 2. SlaveB 0 IIC XFR

#### IICSTUS0 (r) : (XFR 0X0F01) IIC0 Status Registers (default 0X00)

|         | Bit 7  | Bit 6 | Bit 5   | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|--------|-------|---------|---------|-------|-------|-------|-------|
| Name    | WadrB0 | -     | SIvRWB0 | SackIn0 | SLVS0 | -     | -     | -     |
| Default | 0      | -     | 0       | 0       | 0     | -     | -     | -     |

| WadrB0  | =1       | $\rightarrow$ The data in RCBBUF0 is word address.                                               |
|---------|----------|--------------------------------------------------------------------------------------------------|
| SIVRVDU | =1<br>=0 | $\rightarrow$ Current transfer is slave transmit $\rightarrow$ Current transfer is slave receive |
| SackIn0 | =1       | $\rightarrow$ The external IIC host respond NACK.                                                |
| SLVS0   | =1       | $\rightarrow$ The slave block has detected a START, cleared when STOP detected.                  |

#### INTFLG0 (r/w) : (XFR 0X0F03) IIC0 Interrupt Flag Registers (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5   | Bit 4  | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|---------|--------|---------|-------|-------|-------|
| Name    | TXBI0 | RCBI0 | SIvBMI0 | STOPI0 | ReStal0 | -     | -     | -     |
| Default | 0     | 0     | 0       | 0      | 0       | -     | -     | -     |

An interrupt event will set its individual flag. While the corresponding interrupt enable bit is set, the AFI source will be driven by a zero level. Software MUST clear this register while serving the interrupt routine.

## **INTFLG0** (w) : Interrupt flag.

| SIvBMI0 | =1 | $\rightarrow$ No action.           |
|---------|----|------------------------------------|
|         | =0 | $\rightarrow$ Clears SlvBMI0 flag. |
| STOPI0  | =1 | $\rightarrow$ No action.           |
|         | =0 | $\rightarrow$ Clears STOPI0 flag.  |
| ReStal0 | =1 | $\rightarrow$ No action.           |
|         | =0 | $\rightarrow$ Clears ReStal0 flag. |

## **INTFLG0** (r) : Interrupt flag.

| TXBI0    | =1 | $\rightarrow$ Indicates the TXBBUF0 need a new data byte, cleared by writing TXBBUF0. |
|----------|----|---------------------------------------------------------------------------------------|
| RCBI0    | =1 | ightarrow Indicates the RCBBUF0 has received a new data byte, cleared by reading      |
| RCBBUF0. |    |                                                                                       |
| SIvBMI0  | =1 | $\rightarrow$ Indicates the slave IIC address B match condition.                      |
| STOPI0   | =1 | ightarrow Indicates the slave IIC has detected a STOP condition for SCL0/SDA0 pins.   |
| ReStal0  | =1 | → Indicates the slave IIC has detected a repeat START condition for SCL0/SDA0 pins    |
|          |    |                                                                                       |

## INTEN0 (w) : (XFR 0X0F04) IIC0 Interrupt Enable Registers (default 0X00)

|         | Bit 7  | Bit 6  | Bit 5    | Bit 4   | Bit 3    | Bit 2 | Bit 1 | Bit 0 |
|---------|--------|--------|----------|---------|----------|-------|-------|-------|
| Name    | ETXBI0 | ERCBI0 | ESIvBMI0 | ESTOPI0 | EreStal0 | -     | -     | -     |
| Default | 0      | 0      | 0        | 0       | 0        | -     | -     | -     |

| ETXBI0   | = 1 | $\rightarrow$ Enables TXBBUF0 interrupt.                 |
|----------|-----|----------------------------------------------------------|
| ERCBI0   | = 1 | $\rightarrow$ Enables RCBBUF0 interrupt.                 |
| ESIvBMI0 | = 1 | $\rightarrow$ Enables slave address B 0 match interrupt. |
| ESTOPI0  | = 1 | $\rightarrow$ Enables IIC bus STOP interrupt.            |
| EreStal0 | = 1 | $\rightarrow$ Enables IIC bus repeat START interrupt.    |

## RCBBUF0 (r) : (XFR 0X0F08) IIC0 Receive Data Buffer (default 0X00)

|         | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| Name    | IIC0RX7 | IIC0RX6 | IIC0RX5 | IIC0RX4 | IIC0RX3 | IIC0RX2 | IIC0RX1 | IIC0RX0 |
| Default | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Slave IIC block B 0 receives data buffer.

## TXBBUF0 (w) : (XFR 0X0F08) IIC0 Transmit Data Buffer (default 0X00)



|         | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| Name    | IIC0TX7 | IIC0TX6 | IIC0TX5 | IIC0TX4 | IIC0TX3 | IIC0TX2 | IIC0TX1 | IIC0TX0 |
| Default | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Slave IIC block B 0 transmits data buffer.

#### SLVBADR0 (w) : (XFR 0X0F09) IIC0 Enable and Address Register (default 0X00)

|         | Bit 7    | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|---------|----------|--------|--------|--------|--------|--------|--------|--------|
| Name    | ENSIvB 0 | IIC0A6 | IIC0A5 | IIC0A4 | IIC0A3 | IIC0A2 | IIC0A1 | IIC0A0 |
| Default | 0        | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

EnsivB0 =1  $\rightarrow$  Enables slave IIC block B 0.

 $= 0 \rightarrow \text{Disables slave IIC block B 0.}$ 

IIC0A6-0  $\rightarrow$  Slave IIC address B 0 to which the slave block should respond.

## 3. Slave B 1 IIC XFR

#### IICSTUS1 (r) : (XFR 0X0F91) IIC1 Status Registers (default 0X00)

|         | Bit 7  | Bit 6 | Bit 5   | Bit 4   | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|--------|-------|---------|---------|-------|-------|-------|-------|
| Name    | WadrB1 | -     | SlvRWB1 | SackIn1 | SLVS1 | -     | -     | -     |
| Default | 0      | -     | 0       | 0       | 0     | -     | -     | -     |

| WadrB1  | =1 | $\rightarrow$ The data in RCBBUF0 is word address.                              |
|---------|----|---------------------------------------------------------------------------------|
| SlvRWB1 | =1 | $\rightarrow$ Current transfer is slave transmit                                |
|         | =0 | $\rightarrow$ Current transfer is slave receive                                 |
| SackIn1 | =1 | $\rightarrow$ The external IIC host respond NACK.                               |
| SLVS1   | =1 | $\rightarrow$ The slave block has detected a START, cleared when STOP detected. |

#### INTFLG1 (r/w) : (XFR 0X0F93) IIC1 Interrupt Flag Registers (default 0X00)

|         |       |       |         | <u>g g.e.e.</u> | (       | ,     |       |       |
|---------|-------|-------|---------|-----------------|---------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5   | Bit 4           | Bit 3   | Bit 2 | Bit 1 | Bit 0 |
| Name    | TXBI1 | RCBI1 | SIvBMI1 | STOPI1          | ReStal1 | -     | -     | -     |
| Default | 0     | 0     | 0       | 0               | 0       | -     | -     | -     |

An interrupt event will set its individual flag. While the corresponding interrupt enable bit is set, the AFI source will be driven by a zero level. Software MUST clear this register while serving the interrupt routine.

| INTFLG1 (w) : Interrupt flag. |    |                                    |  |  |  |  |  |  |
|-------------------------------|----|------------------------------------|--|--|--|--|--|--|
| SIvBMI1                       | =1 | $\rightarrow$ No action.           |  |  |  |  |  |  |
|                               | =0 | $\rightarrow$ Clears SlvBMI1 flag. |  |  |  |  |  |  |
| STOPI1                        | =1 | $\rightarrow$ No action.           |  |  |  |  |  |  |
|                               | =0 | $\rightarrow$ Clears STOPI1 flag.  |  |  |  |  |  |  |
| ReStal1                       | =1 | $\rightarrow$ No action.           |  |  |  |  |  |  |
|                               | =0 | $\rightarrow$ Clears ReStal1 flag. |  |  |  |  |  |  |

#### INTFLG1 (r) : Interrupt flag.

|          |    | et nag.                                                                                         |
|----------|----|-------------------------------------------------------------------------------------------------|
| TXBI1    | =1 | $\rightarrow$ Indicates the TXBBUF1 need a new data byte, cleared by writing TXBBUF1.           |
| RCBI1    | =1 | ightarrow Indicates the RCBBUF1 has received a new data byte, cleared by reading                |
| RCBBUF1. |    |                                                                                                 |
| SIvBMI1  | =1 | $\rightarrow$ Indicates the slave IIC address B match condition.                                |
| STOPI1   | =1 | $\rightarrow$ Indicates the slave IIC has detected a STOP condition for SCL1/SDA1 pins.         |
| ReStal1  | =1 | $\rightarrow$ Indicates the slave IIC has detected a repeat START condition for SCL1/SDA1 pins. |
|          |    |                                                                                                 |

#### INTEN1 (w) : (XFR 0X0F94) IIC1 Interrupt Enable Registers (default 0X00)

|      | Bit 7  | Bit 6  | Bit 5    | Bit 4   | Bit 3    | Bit 2 | Bit 1 | Bit 0 |
|------|--------|--------|----------|---------|----------|-------|-------|-------|
| Name | ETXBI1 | ERCBI1 | ESIvBMI1 | ESTOPI1 | EreStal1 | -     | -     | -     |


| Default | 0 | 0 | 0 | 0 | 0 | - | - | - |
|---------|---|---|---|---|---|---|---|---|
|         |   |   |   |   |   |   |   |   |

| ETXBI1   | = 1 | $\rightarrow$ Enables TXBBUF1 interrupt.                 |
|----------|-----|----------------------------------------------------------|
| ERCBI1   | = 1 | $\rightarrow$ Enables RCBBUF1 interrupt.                 |
| ESIvBMI1 | = 1 | $\rightarrow$ Enables slave address B 1 match interrupt. |
| ESTOPI1  | = 1 | $\rightarrow$ Enables IIC bus STOP interrupt.            |
| EreStal1 | = 1 | $\rightarrow$ Enables IIC bus repeat START interrupt.    |

## RCBBUF1 (r) : (XFR 0X0F98) IIC1 Receive Data Buffer (default 0X00)

|         | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| Name    | IIC1RX7 | IIC1RX6 | IIC1RX5 | IIC1RX4 | IIC1RX3 | IIC1RX2 | IIC1RX1 | IIC1RX0 |
| Default | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Slave IIC block B 1 receives data buffer.

## TXBBUF1 (w) : (XFR 0X0F98) IIC1 Transmit Data Buffer (default 0X00)

|         | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| Name    | IIC1TX7 | IIC1TX6 | IIC1TX5 | IIC1TX4 | IIC1TX3 | IIC1TX2 | IIC1TX1 | IIC1TX0 |
| Default | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

Slave IIC block B 1 transmits data buffer.

## SLVBADR1 (w) : (XFR 0X0F99) IIC1 Enable and Address Register (default 0X00)

|         | Bit 7    | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|---------|----------|--------|--------|--------|--------|--------|--------|--------|
| Name    | ENSIvB 1 | IIC1A6 | IIC1A5 | IIC1A4 | IIC1A3 | IIC1A2 | IIC1A1 | IIC1A0 |
| Default | 0        | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

EnslvB1  $\rightarrow$  Enables slave IIC block B 1. =1

 $\rightarrow$  Disables slave IIC block B 1. =0

IIC1A6-0

 $\rightarrow$  Slave IIC address B 1 to which the slave block should respond.



## CHAPTER 15 SPI

The Serial Peripheral Interface (SPI) is an enhanced synchronous serial hardware which is compatible with Motorola's SPI specifications. There are extra 4 entries read FIFO and 4 entries write FIFO available inter the on-chip SPI circuit. CS8961 SPI control pins shared with P7.2, P7.3, P7.4, and P7.5. Its registers defined are as following.

## PADMOD0 (r/w): (XFR 0X0F50) Pad mode control registers 0. (default 0X00)

|         | <u>()</u> |       |       |       |       |       |       |       |
|---------|-----------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7     | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | SPI_MOD   | -     | -     | -     | -     | -     | -     | DA8E  |
| Default | 0         | -     | -     | -     | -     | -     | -     | 0     |

| SPI_MOD | = 1 | $\rightarrow$ Pin "P7.2/ET2T/SCS" is SPI_SCS;   |
|---------|-----|-------------------------------------------------|
|         |     | $\rightarrow$ Pin "P7.4/ET3T/MISO" is SPI_MISO; |
|         | = 0 | $\rightarrow$ Pin "P7.2/ET2T/SCS" is P7.2;      |
|         |     | $\rightarrow$ Pin "P7.4/ET3T/MISO" is P7.4;     |
| DA8E    | = 1 | $\rightarrow$ Pin "P6.4/PWM8" is PWM8.          |
|         | = 0 | $\rightarrow$ Pin "P6.4/PWM8" is P6.4.          |

pin "P7.3/ET2ET/MOSI" is SPI\_MOSI. pin "P7.5/ET3ET/MSCK" is SPI\_MSCK. pin "P7.3/ET2ET/MOSI" is P7.3. pin "P7.5/ET3ET/MSCK" is P7.5.

## SPICR (r/w): (SFR 0XEC) SPI Configuration Register. (default 0X20)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | SPIE  | SPIEN | MSTR  | CPOL  | CPHA  | SCKE  | -     | -     |
| Default | 0     | 0     | 1     | 0     | 0     | 0     | -     | -     |

| SPIE  |     | $\rightarrow$ SPI Interrupt Enable                                  |
|-------|-----|---------------------------------------------------------------------|
|       | = 1 | $\rightarrow$ Enable SPI Interrupt.                                 |
|       | = 0 | $\rightarrow$ Disable SPI Interrupt.                                |
| SPIEN |     | $\rightarrow$ SPI Enable                                            |
|       | = 1 | $\rightarrow$ Enable SPI function and interface                     |
|       | = 0 | $\rightarrow$ Disable SPI function and interface                    |
| MSTR  |     | $\rightarrow$ SPI operation mode select.                            |
|       | = 1 | $\rightarrow$ SPI operates in Master Mode.                          |
|       | = 0 | $\rightarrow$ SPI operates in Slave Mode.                           |
| CPOL  |     | $\rightarrow$ SPI Clock Polarity Control Bit                        |
|       | = 1 | $\rightarrow$ Allow SCK at 1 during SPI is stopped.                 |
|       | = 0 | $\rightarrow$ Allow SCK at 0 during SPI is stopped.                 |
| CPHA  |     | $\rightarrow$ SPI Clock Phase Select Bit                            |
|       | = 1 | $\rightarrow$ If CPOL = 1, Data transmitted on falling edge of SCK. |
|       |     | If CPOL = 0, Data transmitted on rising edge of SCK.                |
|       | = 0 | $\rightarrow$ If CPOL = 1, Data transmitted on rising edge of SCK.  |
|       |     | If CPOL = 0, Data transmitted on falling edge of SCK.               |
| SCKE  |     | $\rightarrow$ SPI Data Input Sample Phase                           |
|       | = 1 | $\rightarrow$ Use rising edge of SCK to sample the input data       |
|       | = 0 | $\rightarrow$ Use falling edge of SCK to sample the input data      |

## SPIMR (r/w): (SFR 0XED) SPI Mode Control Register. (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2    | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|----------|-------|-------|
| Name    | ICNT  | [1:0] | FCLR  | -     |       | SPR[2:0] |       | DIR   |
| Default | (     | )     | 0     | -     |       | 000      |       | 0     |

| ICNT[1:0] |      | ightarrow Interrupt threshold of transmit and receive byte count        |
|-----------|------|-------------------------------------------------------------------------|
|           | = 00 | $\rightarrow$ Interrupt is generated after 1 byte is sent or received   |
|           | = 01 | $\rightarrow$ Interrupt is generated after 2 bytes are sent or received |
|           | = 10 | $\rightarrow$ Interrupt is generated after 3 bytes are sent or received |
|           | = 11 | $\rightarrow$ Interrupt is generated after 4 bytes are sent or received |
| FCLR      |      | $\rightarrow$ FIFO Clear Bit                                            |



|          | = 1   | $\rightarrow$ Clear transmit and receive FIFO    |
|----------|-------|--------------------------------------------------|
|          | = 0   | $\rightarrow$ No action                          |
| SPR[2:0] |       | $\rightarrow$ SPI Clock (SCK) Rate Setting       |
|          | = 000 | $\rightarrow$ SCK = SYSCLK / 6                   |
|          | = 001 | $\rightarrow$ SCK = SYSCLK / 8                   |
|          | = 010 | $\rightarrow$ SCK = SYSCLK / 16                  |
|          | = 011 | $\rightarrow$ SCK = SYSCLK / 32                  |
|          | = 100 | $\rightarrow$ SCK = SYSCLK / 64                  |
|          | = 101 | $\rightarrow$ SCK = SYSCLK / 128                 |
|          | = 110 | $\rightarrow$ SCK = SYSCLK / 256                 |
|          | = 111 | $\rightarrow$ SCK = SYSCLK / 512                 |
| DIR      |       | $\rightarrow$ SPI Transfer Direction             |
|          | = 1   | $\rightarrow$ Transfer data in MSB first format. |
|          | = 0   | $\rightarrow$ Transfer data in LSB first format. |

## SPIST (r/w): (SFR 0XEE) SPI Status Register. (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | SSPIF | POVR  | TOVR  | TUDR  | RFULL | REMPT | TFULL | REMPT |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

|     | $\rightarrow$ SPI Interrupt Flag. Set by hardware to indicate that the data transfer has been completed. Clear by written 0 to this bit or disable SPI.                                         |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | $\rightarrow$ Receive FIFO overrun error flag. Receiving another data in receive FIFO full state, ROVR will be set and generate an interrupt. Clear by written 0 to this bit or disable SPI.    |
|     | $\rightarrow$ Transfers FIFO overrun error flag. Writing another data in transfer FIFO full state, TOVR will be set and generate an interrupt. Clear by written 0 to this bit or disable SPI.   |
|     | $\rightarrow$ Transmit under-run error flag. Transmitting another data in transfer FIFO empty state, TUDR will be set and generate an interrupt. Clear by written 0 to this bit or disable SPI. |
|     | → Receive FIFO Full Status                                                                                                                                                                      |
| = 1 | $\rightarrow$ Receive FIFO is full. Read only.                                                                                                                                                  |
| = 0 | $\rightarrow$ Receive FIFO is not full. Read only.                                                                                                                                              |
|     | ightarrow Receive FIFO Empty Status                                                                                                                                                             |
| = 1 | $\rightarrow$ Receive FIFO is empty. Read only.                                                                                                                                                 |
| = 0 | $\rightarrow$ Receive FIFO is not empty. Read only.                                                                                                                                             |
|     | $\rightarrow$ Transfer FIFO Full Status                                                                                                                                                         |
| = 1 | $\rightarrow$ Transfer FIFO is full. Read only.                                                                                                                                                 |
| = 0 | $\rightarrow$ Transfer FIFO is not full. Read only.                                                                                                                                             |
|     | $\rightarrow$ Transfer FIFO Empty Status                                                                                                                                                        |
| = 1 | $\rightarrow$ Transfer FIFO is empty. Read only.                                                                                                                                                |
| = 0 | $\rightarrow$ Transfer FIFO is not empty. Read only.                                                                                                                                            |
|     | = 1<br>= 0<br>= 1<br>= 0<br>= 1<br>= 0<br>= 1<br>= 0                                                                                                                                            |

## SPIDATA (r/w): (SFR 0XEF) SPI Data Register. (default 0X00)

|         | Bit 7             | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------------------|-------|-------|-------|-------|-------|-------|-------|
| Name    | SPI Data Register |       |       |       |       |       |       |       |
| Default |                   |       |       | 0X    | 00    |       |       |       |

SPIDATA

 $\rightarrow$  When writing, SPIDATA is for SPI transmit data.

 $\rightarrow$  When reading, SPIDATA is for SPI receive data.

# Analog Mixed Signal Division

# SPI Timing Illustration Error!

|                      | SPI MODE TIMING, MASTER MODE                         |
|----------------------|------------------------------------------------------|
| SPEN                 |                                                      |
| SCK (CPOL=0, CPHA=0) |                                                      |
| SDO                  | it7 / bit6 / bit5 / bit4 / bit3 / bit2 / bit1 / bit0 |
| SDI (SCKE=1) bit7    | bit0                                                 |
| SDI (SCKE=0)bit7     |                                                      |
| SSPIF                |                                                      |
|                      | SPI MODE TIMING, MASTER MODE                         |
| SPEN                 |                                                      |
| SCK (CPOL=0, CPHA=1) |                                                      |
| SDO                  | 7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                 |
| SDI (SCKE=1) bit7    |                                                      |
| SDI (SCKE=0)bit7     |                                                      |
| SSPIF                |                                                      |
|                      | SPI MODE TIMING, MASTER MODE                         |
| SPEN                 |                                                      |
| SCK (CPOL=1, CPHA=0) |                                                      |
| SDO bit              | 7 bit6 bit5 bit4 bit3 bit2 bit1 bit0                 |
| SDI (SCKE=0)         |                                                      |
| SDI (SCKE=1)         |                                                      |
| SSPIF                |                                                      |



## CS8961 PRELIMINARY

SPI MODE TIMING (SLAVE MODE)

| SPEN                                                            |
|-----------------------------------------------------------------|
| SCS                                                             |
|                                                                 |
| SCK(CPOL=0, CPHA=0)                                             |
| SDO bit7 / bit6 / bit5 / bit4 / bit3 / bit2 / bit1 / bit0 / X / |
| SDI (SCKE=1) bit7 bit0                                          |
| SDI (SCKE=0)                                                    |
| SSPIF                                                           |
| SPI MODE TIMING (SLAVE MODE)                                    |
| SPEN                                                            |
| SCS                                                             |
|                                                                 |
| SCK (CPOL=1, CPHA=0)                                            |
| SDO bit7 / bit6 / bit5 / bit4 / bit3 / bit2 / bit1 / bit0 /     |
|                                                                 |
| bit7 bit0                                                       |
| SDI (SCKE=0)<br>bit7<br>bit7<br>bit7<br>bit0<br>bit0            |



SPI MODE TIMING (SLAVE MODE)





## CHAPTER 16 ISP

The Flash memory can be programmed by a specific writer (the user may need to import a .hex file) in serial mode via JTAG or UART while the system is working. The CRC check is feasible during ISP for error detection.

After Power on / Reset, the CS8961 is running the original program code; when ISP is enabling, the flash interface is switched to ISP host, and meanwhile the 8051 stops fetching new program data. To prevent unexpected MCU behavior, it is suggested S/W keeps the MCU in an idle status when entering ISP mode; moreover, the Watchdog Timer Reset function must be disabled.

ISP mode can be activated by software or hardware, described as the following:

1), S/W ISP – write ISPEN register to enter into ISP mode. (91h:JTAG ISP / 92h:UART ISP)

2), H/W ISP – a serial password (the same for JTAG ISP and UART ISP) is defined to avoid mistaken operation. CS8961 switches to ISP mode only when the valid "ISP Slave Address and Compared Data" are received from the JTAG or UART port. The default values\* for the sequence are "0X94 0XAC 0XCA 0X53" in hexadecimal form.

| Reg name | XFR Addr  | Bit7 | Bit6                                           | Bit5 | Bit4 | Bit3 | Bit2 | Bit1 | Bit0 |
|----------|-----------|------|------------------------------------------------|------|------|------|------|------|------|
| ISPSLV   | 0X0F0B(w) |      | ISP Slave Address -                            |      |      |      |      |      | -    |
| ISPEN    | 0X0F0C(w) |      | Write 0X91 / 0X92 to enable JTAG/UART ISP Mode |      |      |      |      |      |      |
| ISPCMP1  | 0X0F0D(w) |      | ISP compared data 1                            |      |      |      |      |      |      |
| ISPCMP2  | 0X0F0E(w) |      | ISP compared data 2                            |      |      |      |      |      |      |
| ISPCMP3  | 0X0F0F(w) |      | ISP compared data 3                            |      |      |      |      |      |      |

ISP Registers (Write-Only)

ISPSLV: to define the ISP block address for identification. The valid ISP address consists of the six highest bits, and the two lowest bits are used for command indictor. The default value is 0X94.

ISPEN: S/W ISP Enable register. Write 0X91 to enable JTAG ISP mode / 0X92 to enable UART ISP mode. Default value = 0X00.

ISPCMP1: ISP compared data 1. The default value is 0XAC, and 0X00 is an invalid value. ISPCMP2: ISP compared data 2. The default value is 0XCA, and 0X00 is an invalid value. ISPCMP3: ISP compared data 3. The default value is 0X53, and 0X00 is an invalid value.

\*It is recommended not to modify the sequence unless the specific writer is compatible with changeable "ISP address" or "compared data".

## 1. JTAG ISP

The ISP function is implemented in one chain of the JTAG TAP (Test Access Port) controller. With specific writer software, the user can easily download his program to the MCU via the JTAG port. For more information about the JTAG TAP controller, please refer to Chapter 23 – JTAG TAP controller.



## 2. UART ISP

In CS8961, UART0 is allocated for UART ISP; if the UART ISP function is desired, P3.0(RX0) and P3.1(TX0) must be reserved for the UART host while activating UART ISP mode.

The baud rate of UART ISP is self-synchronized\* to the host (4800, 9600 or 19200 bps is recommended), depending on the operating frequency. Refer to the table below.

Recommended baud rate under different operating frequencies

| Baud Rate (bps)           |      |      |       |
|---------------------------|------|------|-------|
| Operating Frequency (MHz) | 4800 | 9600 | 19200 |
| 3.5795                    | 0    | Х    | Х     |
| 4.000                     | 0    | Х    | Х     |
| 6.000                     | 0    | Х    | Х     |
| 8.000                     | 0    | 0    | Х     |
| 11.059                    | 0    | 0    | Х     |
| 12.000                    | 0    | 0    | Х     |
| 12.096                    | 0    | 0    | Х     |
| 14.318                    | 0    | 0    | 0     |
| 16.000                    | 0    | 0    | 0     |
| 20.000                    | 0    | 0    | 0     |
| 22.118                    | 0    | 0    | 0     |
| 24.576                    | 0    | 0    | 0     |
| 25.000                    | 0    | 0    | 0     |

X : Not support in the UART writer

O: Baud rate is workable in the UART writer

\*Since the baud rate of UART ISP, independent of the UART0 settings, will be synchronized to "the first data byte 0X55" detected on P3.0; once the synchronization is established the value could not be changed until next "CPU Reset", hence earlier data transferred over P3.0 could probably cause baud rate mismatch for UART ISP (fail to enter ISP mode).

Considering only UART data rate and hardware accessing time, the following table shows estimated time for ISP operations. Accessing time will be proportional to the system period, but UART baud rate is still the dominant factor. In real applications it will take longer due to information processing delay.

| Estimated time for ISP operations (System Frequency = 20MHz) |             |             |            |  |  |  |  |  |
|--------------------------------------------------------------|-------------|-------------|------------|--|--|--|--|--|
| UART Baud Rate                                               | 4800 bps    | 9600 bps    | 19200 bps  |  |  |  |  |  |
| Read 1 byte                                                  | 18.8 ms     | 9.4 ms      | 4.7 ms     |  |  |  |  |  |
| Read 1 page (1024 bytes)                                     | 2168.4 ms   | 1093.4 ms   | 555.9 ms   |  |  |  |  |  |
| Read whole flash (171k bytes)                                | 368002.0 ms | 185576.9 ms | 94364.4 ms |  |  |  |  |  |
| Program 1 word (2 bytes)                                     | 20.9 ms     | 10.5 ms     | 5.3 ms     |  |  |  |  |  |
| Program 1 page(1024 bytes)                                   | 2182.8 ms   | 1107.8 ms   | 570.3 ms   |  |  |  |  |  |
| Program whole flash (171k bytes)                             | 370453.0 ms | 188028.3 ms | 96815.8 ms |  |  |  |  |  |
| Read CRC code (1 time)                                       | 14.6 ms     | 7.3 ms      | 3.7 ms     |  |  |  |  |  |
| Erase whole flash                                            | 357.0 ms    | 346.6 ms    | 341.4 ms   |  |  |  |  |  |

Page 80 of 133



## CHAPTER 17 WATCHDOG TIMER

The Watchdog Timer is a user programmable clock counter that can serve as:

- \_\_\_a time-base generator
- \_\_\_ an event timer,
- \_\_\_ or a system supervisor.

As can be seen in the figure below, the timer is driven by the main system clock that is supplied to a series of dividers. The divider output is selectable, and determines interval between timeouts. When the timeout is reached, an interrupt flag will be set, and if enabled, a reset will occur. The interrupt flag will cause an interrupt to occur if its individual enable bit is set and the global interrupt enable is set. The reset and interrupt are completely discrete functions that may be acknowledged or ignored, together or separately for various applications.



Figure-45 Watchdog Timer Structure

## 1. Watchdog Timer Reset

The Watchdog Timer Reset function works as follows. After initializing the correct timeout interval, software first restarts the Watchdog using RWT and then enables the reset mode by setting the Enable Watchdog Timer Reset (WDCON.1) bit. At any time prior to reaching its user selected terminal value, software can set the Reset Watchdog Timer (WDCON.0) bit. If RWT is set before the timeout is reached, the timer will start over. If the timeout is reached without RWT being set, the Watchdog will reset the CPU. Hardware will automatically clear RWT after software sets it. When the reset occurs, the Watchdog Timer Reset Flag (WDCON.2) will automatically be set to indicate the cause of the reset, however software must clear this bit manually.

## 2. Simple Timer

The Watchdog Timer is a free running timer. When used as a simple timer with both the reset (EWT=0) and interrupt functions disabled (EWDI=0), the timer will continue to set the Watchdog Interrupt flag each time the timer completes the selected timer interval as programmed by WD[1:0]. Restarting the timer using the RWT bit, allows software to use the timer in a polled timeout mode. The WDIF bit is cleared by software or any reset. The Watchdog Interrupt is also available for applications that don't need a true Watchdog Reset but simply a very long timer. The interrupt is enabled using the Enable Watchdog Timer Interrupt (EIE.4) bit. When the timeout occurs, the Watchdog Timer will set the WDIF bit (WDCON.3), and an interrupt will occur if the global interrupt enable (EA) is set. Note that WDIF is set 512 clocks before a potential Watchdog Reset. The Watchdog Interrupt Flag indicates the source of the interrupt, and must be cleared by software. Proper use of the Watchdog Interrupt with the Watchdog Reset allows interrupt software to survey the system for errant conditions.



## 3. System Monitor

When using the Watchdog Timer as a system monitor, the Watchdog Reset function should be used. If the Interrupt function was used, the purpose of the watchdog would be defeated. For example, assume the system is executing errant code prior to the Watchdog Interrupt. The interrupt would temporarily force the system back into control by vectoring the CPU to the interrupt service routine. Restarting the Watchdog and exiting by an RETI or RET, would return the processor to the lost position prior to the interrupt. By using the Watchdog Reset function, the processor is restarted from the beginning of the program, and therefore placed into a known state.

## 4. Watchdog Related Registers

The watchdog timer has several SFR bits that contribute to its operation. It can be enabled to function as either a reset source, interrupt source, software polled timer or any combination of the three. Both the reset and interrupt have status flags. The watchdog also has a bit that restarts the timer. A summary table showing the bit locations is below. A description follows.

| Bit name | Register | Bit position | Description                     |
|----------|----------|--------------|---------------------------------|
| EWDI     | EIE      | EIE.4        | Enable Watchdog Timer Interrupt |
| WD[1:0]  | CKCON    | CKCON.7-6    | Watchdog Interval               |
| RWT      |          | WDCON.0      | Reset Watchdog Timer            |
| EWT      | MDCON    | WDCON.1      | Enable Watchdog Timer Reset     |
| WTRF     | WECON    | WDCON.2      | Watchdog Timer Reset flag       |
| WDIF     |          | WDCON.3      | Watchdog Interrupt flag         |

## 4.1 WATCHDOG CONTROL

Watchdog control bits are described below. Please note that access (write) to this register has to be performed using Timed access registers procedure.

## Watchdog Control Register

|         |       |       | <u> </u> | <u> </u> | /     |       |       |       |
|---------|-------|-------|----------|----------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5    | Bit 4    | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | -     | -     | -        | -        | WDIF  | WTRF  | EWT   | RWT   |
| Default | -     | -     | -        | -        | 0     | 0     | 0     | 0     |

- WDIF Watchdog Interrupt Flag. WDIF in conjunction with the Enable Watchdog Interrupt bit (EWDI:EXIE.4), and EWT, indicates if a watchdog timer event has occurred and what action should be taken. This bit must be cleared by software before exiting the interrupt service routine, or another interrupt is generated. Setting WDIF in software will generate a watchdog interrupt if enabled.
- WTRF Watchdog Timer Reset Flag. When set by hardware, indicates that a watchdog timer reset has occurred. Set by software don't generate a watchdog timer reset. It is cleared by RSTN pin, but otherwise must be cleared by software. The watchdog timer has no effect on this bit, If EWT bit is cleared.
- EWT Enable Watchdog Timer Reset. The reset of micro-controller by watchdog timer is controlled by this bit. This bit has no effect on the ability of the watchdog timer to generate a watchdog interrupt.
  - 0 watchdog timer timeout doesn't reset micro-controller
  - 1 watchdog timer timeout resets micro-controller
- RWT Reset Watchdog Timer. Setting RWT resets the watchdog timer count. Timed Access procedure must be used to set this bit before the watchdog timer expires, or a watchdog timer reset and/or interrupt will be generated if enabled.
- - Unimplemented bit. Read as 0 or 1.



Table below summarizes Watchdog Control bits and taken operation concerned to theirs values.

## Watchdog Bits And Actions

| EWT | EWDI | WDIF | Result                                                                                                                                                |
|-----|------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| х   | х    | 0    | No watchdog event.                                                                                                                                    |
| 0   | 0    | 1    | Watchdog time-out has expired. No interrupt has been generated.                                                                                       |
| 0   | 1    | 1    | Watchdog interrupt has occurred.                                                                                                                      |
| 1   | 0    | 1    | Watchdog time-out has expired. No interrupt has been generated. Watchdog timer reset will occur in 512 clock periods (CLK pin) if RWT is not strobed. |
| 1   | 1    | 1    | Watchdog interrupt has occurred. Watchdog timer reset will occur in 512 clock periods (CLK pin) if RWT is not set using Timed Access procedure.       |

## **4.2 CLOCK CONTROL**

The Watchdog timeout selection is made using bits WD[1:0] as shown in the figure.

Clock Control Register ----Watchdog Bits

## CKCON(w/r) : (SFR 0X8E) Clock Control Register (default 0X03)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | WD1   | WD0   | T2M   | T1M   | TOM   | MD2   | MD1   | MD0   |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 1     | 1     |

Clock control register CKCON(0X8E) contains WD[1:0] bits select Watchdog timer timeout period. The Watchdog is clocked directly from CLK pin, and PMM mode directly affects its timeout period. It is increased 256 times when CS8959 is in PMM mode. This allows the watchdog period to remain synchronized with device operation.

The Watchdog has four timeout selections based on the input CLK clock frequency as shown in the figure. The selections are a pre-selected number of clocks. Therefore, the actual timeout interval is dependent on the CLK frequency.

Watchdog Intervals

| WD[1:0] | Watchdog Interval | Number of clocks |
|---------|-------------------|------------------|
| 00      | 2 <sup>17</sup>   | 131072           |
| 01      | 2 <sup>20</sup>   | 1048576          |
| 10      | 2 <sup>23</sup>   | 8388608          |
| 11      | 2 <sup>26</sup>   | 67108864         |

Note that the time period shown above is for the interrupt events. The RESET, when enabled, will occur 512 clocks later regardless of whether the interrupt is used. Therefore the actual Watchdog timeout period is the number shown above plus 512 clocks (always CLK pin).



## **CHAPTER 18 RTC OPERATION**

## 1. REAL-TIME CLOCK

The CS8961 has built-in simple real-time clock to keep track of time stamp of seconds, minutes and hours. It operates on the low-frequency 32.768KHz reference clock crystal. No day information will be kept. If this feature is needed, the firmware engineer needs to write firmware to keep track of the day changes and use XRAM to store the date information. No alarm, watchdog timer or minute stopwatch hardware is implemented at this moment.

The programmer needs to set at least one of the interrupt enable bits in order for the RTC function to work properly. The interrupt will happen at interrupt 2.



Figure-45 RTC Configuration

## 2. RTC Registers Configure

## RTC Control Register (RTCCON)

## RTCCON(w/r) : (XFR 0X0FE0) RTC Control Register (default 0X00)

|         | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0  |  |  |  |
|---------|--------|--------|--------|--------|--------|--------|-------|--------|--|--|--|
| Name    | RTC_A4 | RTC_A3 | RTC_A2 | RTC_A1 | RTC_A0 | RTC_WR | -     | RTC_EN |  |  |  |
| Default | 0      | 0      | 0      | 0      | 0      | 0      | -     | 0      |  |  |  |

RTC\_A4-0 - The RTC register address to operate. RTC\_WR - RTC\_WR signal

1: Write 1 to set the RTC\_WR signal to high. The firmware needs to put the data at RTCDAT register and write this bit to high for at least 200ns to ensure correct writing.

0: Write 0 to clear the RTC\_WR signal to 0. Make it inactive.

RTC\_EN - RTC enable

1: Write 1 to enable the RTC output. (connect to RTC OE)

0: Write 0 to disable the RTC output and set all output to 0.

## RTC Data Register (RTCDAT)

## RTCDAT(w/r) : (XFR 0X0FE1) RTC Data Register (default 0X00)

|         | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|---------|--------|--------|--------|--------|--------|--------|--------|--------|
| Name    | RTC_D7 | RTC_D6 | RTC_D5 | RTC_D4 | RTC_D3 | RTC_D2 | RTC_D1 | RTC_D0 |
| Default | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

When write, this byte stores the byte to be written. When read, this byte presents the data coming from RTC.

*Example: If you want to configure RTC Minute Register (Address :5H) to 0X45 and enable RTC output, you can use the following instructions:* 

MOV DPTR, #0FE0H; MOV A, #2DH; MOVX @DPTR, A;



MOV DPTR, #0FE1H; MOV A, #45H; MOVX @DPTR, A ;

## 3. Sampling Timer

The sampling timer is designed to support application software. You can choose a frequency from SAMx bits of the RTCIEN1 register. The sampling timer will generate an interrupt based on that frequency. You can use this timer for digitizer sampling, keyboard de-bouncing, or communication polling in your application. The sampling timer only operates if the RTC is enabled. The predefined frequency is shown below.

#### Frequency Choose SAMS

| SAM7 | 512Hz |
|------|-------|
| SAM6 | 256Hz |
| SAM5 | 128Hz |
| SAM4 | 64Hz  |
| SAM3 | 32Hz  |
| SAM2 | 16Hz  |
| SAM1 | 8Hz   |
| SAM0 | 4Hz   |

## 4. RTC Register Definitions

Note that for each writing activity, the firmware needs to set RTCCON[2] to 1 and clear it to 0 to generate a write clock pulse. Setting RTCCON[1] to 1 will enable the RTC module to output specified address data. Otherwise the data read in RTCDAT will be 0.

To avoid accidentally writing data to these registers during system power on/off, a safe-guard scheme is added. All the RTC registers except RTCIEN1, RTCIEN2, RTCSTS1 and RTCSTS2, are protected with this approach. Before writing data into these protected registers, the firmware had to follow a special sequence in order to enable writing these spare registers.

- 1. Write 1 to bit 7 of RTCIEN2,
- 2. Write 0 to bit 7 of RTCSTS2,
- 3. Write 0 to bit 7 RTCIEN2,
- 4. Write 1 to bit 7 of RTCSTS2.

After enabling the permission, the firmware can write to any other RTC registers, in any order, with no restriction. And the firmware needs to write 8'h10100000 to RTCSTS2 to turn off writing spare registers immediately.

There will be 16 spare 8-bit registers residing in the RTC module. It's fine to read all the RTC spare registers at any time.

## RTCIEN1(w/r) : (RTC\_A4-0 : 0X00) RTC Interrupt Enable 1 Register (default 0X00)

| •       | Bit 7   | Bit 6   | Bit 5   | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| Name    | SAM7_IE | SAM6_IE | SAM5_IE | SAM4_IE | SAM3_IE | SAM2_IE | SAM1_IE | SAM0_IE |
| Default | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

| SAM7_IE | =1 | $\rightarrow$ Enables SAM7 interrupt  |
|---------|----|---------------------------------------|
|         | =0 | $\rightarrow$ Disables SAM7 interrupt |
| SAM6_IE | =1 | $\rightarrow$ Enables SAM6 interrupt  |
|         | =0 | → Disables SAM6 interrupt             |
| SAM5_IE | =1 | ightarrow Enables SAM5 interrupt      |



|         | =0 | $\rightarrow$ Disables SAM5 interrupt |
|---------|----|---------------------------------------|
| SAM4_IE | =1 | ightarrow Enables SAM4 interrupt      |
|         | =0 | $\rightarrow$ Disables SAM4 interrupt |
| SAM3_IE | =1 | ightarrow Enables SAM3 interrupt      |
|         | =0 | $\rightarrow$ Disables SAM3 interrupt |
| SAM2_IE | =1 | ightarrow Enables SAM2 interrupt      |
|         | =0 | $\rightarrow$ Disables SAM2 interrupt |
| SAM1_IE | =1 | ightarrow Enables SAM1 interrupt      |
|         | =0 | $\rightarrow$ Disables SAM1 interrupt |
| SAM0_IE | =1 | ightarrow Enables SAM0 interrupt      |
|         | _0 | Dischlos SAMO interrunt               |

## =0 $\rightarrow$ Disables SAM0 interrupt

## RTCIEN2(w/r) : (RTC\_A4-0 : 0X01) RTC Interrupt Enable 2 Register (default 0X00)

|         | / .    | ,     |       | -      | <u> </u> | ,       |        |        |
|---------|--------|-------|-------|--------|----------|---------|--------|--------|
|         | Bit 7  | Bit 6 | Bit 5 | Bit 4  | Bit 3    | Bit 2   | Bit 1  | Bit 0  |
| Name    | Unlock | -     | -     | ALM_IE | Day_IE   | Hour_IE | Min_IE | Sec_IE |
| Default | 0      | -     | -     | 0      | 0        | 0       | 0      | 0      |

| Unlock  | : Reserved to unlock spare area written permission                                |
|---------|-----------------------------------------------------------------------------------|
| ALM_IE  | =1 $\rightarrow$ Enables this alarm interrupt                                     |
|         | $\rightarrow$ Disables this alarm interrupt                                       |
| Day_IE  | : A day interrupt flag is raised for every 24-hour clock increment (at midnight). |
|         | =1 $\rightarrow$ Enables the day interrupt.                                       |
|         | $\rightarrow$ Disables the day interrupt.                                         |
| Hour_IE | : A hour interrupt flag is raised every hour.                                     |
|         | =1 $\rightarrow$ Enables the hour interrupt.                                      |
|         | $\rightarrow$ Disables the hour interrupt.                                        |
| Min_IE  | : A minute interrupt flag is raised every minute.                                 |
|         | =1 $\rightarrow$ Enables the minute interrupt.                                    |
|         | $\rightarrow$ Disables the minute interrupt.                                      |
| Sec_IE  | : A second interrupt flag is raised every second.                                 |
|         | =1 $\rightarrow$ Enables the second interrupt.                                    |
|         | $\rightarrow$ Disables the second interrupt.                                      |

## RTCSTS1(w/r) : (RTC\_A4-0 : 0X02) RTC Interrupt Status 1 Register (default 0X00)

|         |         |                                          |                |                | <u> </u> | 1       |         |         |  |  |  |
|---------|---------|------------------------------------------|----------------|----------------|----------|---------|---------|---------|--|--|--|
|         | Bit 7   | Bit 6                                    | Bit 5          | Bit 4          | Bit 3    | Bit 2   | Bit 1   | Bit 0   |  |  |  |
| Name    | SAM7_IF | SAM6_IF                                  | SAM5_IF        | SAM4_IF        | SAM3_IF  | SAM2_IF | SAM1_IF | SAM0_IF |  |  |  |
| Default | 0       | 0                                        | 0              | 0              | 0        | 0       | 0       | 0       |  |  |  |
|         |         |                                          |                |                |          |         |         |         |  |  |  |
| SAM7_IF | =1      | $\rightarrow$ SAM7 inte                  | errupt occurre | ed; Write 1 to | o clear. |         |         |         |  |  |  |
|         | =0      | $\rightarrow$ No SAM7                    | interrupt occ  | urred          |          |         |         |         |  |  |  |
| SAM6_IF | =1      | $\rightarrow$ SAM6 inte                  | errupt occurre | ed; Write 1 to | o clear. |         |         |         |  |  |  |
|         | =0      | $\rightarrow$ No SAM6                    | interrupt occ  | urred          |          |         |         |         |  |  |  |
| SAM5_IF | =1      | $\rightarrow$ SAM5 inte                  | errupt occurre | ed; Write 1 to | clear.   |         |         |         |  |  |  |
|         | =0      | $\rightarrow$ No SAM5                    | interrupt occ  | urred          |          |         |         |         |  |  |  |
| SAM4_IF | =1      | $\rightarrow$ SAM4 inte                  | errupt occurre | ed; Write 1 to | clear.   |         |         |         |  |  |  |
|         | =0      | $\rightarrow$ No SAM4                    | interrupt occ  | urred          |          |         |         |         |  |  |  |
| SAM3_IF | =1      | $\rightarrow$ SAM3 inte                  | errupt occurre | ed; Write 1 to | clear.   |         |         |         |  |  |  |
|         | =0      | $\rightarrow$ No SAM3 interrupt occurred |                |                |          |         |         |         |  |  |  |
| SAM2_IF | =1      | $\rightarrow$ SAM2 inte                  | errupt occurre | ed; Write 1 to | clear.   |         |         |         |  |  |  |
|         | =0      | $\rightarrow$ No SAM2 interrupt occurred |                |                |          |         |         |         |  |  |  |
| SAM1_IF | =1      | $\rightarrow$ SAM1 inte                  | errupt occurre | ed; Write 1 to | o clear. |         |         |         |  |  |  |
|         | =0      | $\rightarrow$ No SAM1                    | interrupt occ  | urred          |          |         |         |         |  |  |  |
| SAM0_IF | =1      | $\rightarrow$ SAM0 inte                  | errupt occurre | ed; Write 1 to | o clear. |         |         |         |  |  |  |
|         | =0      | $\rightarrow$ No SAM0                    | interrupt occ  | urred          |          |         |         |         |  |  |  |
|         |         |                                          | •              |                |          |         |         |         |  |  |  |

## RTCSTS2(w/r) : (RTC\_A4-0 : 0X03) RTC Interrupt Status 2 Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4  | Bit 3  | Bit 2   | Bit 1  | Bit 0  |
|---------|-------|-------|-------|--------|--------|---------|--------|--------|
| Name    | -     | -     | -     | ALM_IF | Day_IF | Hour_IF | Min_IF | Sec_IF |
| Default | -     | -     | -     | 0      | 0      | 0       | 0      | 0      |

| ALM_IF  | =1 | $\rightarrow$ Alarm interrupt occurred. Write 1 to clear.  |
|---------|----|------------------------------------------------------------|
|         | =0 | $\rightarrow$ No alarm interrupt.                          |
| Day_IE  | =1 | $\rightarrow$ Day interrupt occurred. Write 1 to clear.    |
|         | =0 | $\rightarrow$ No Day interrupt.                            |
| Hour_IE | =1 | $\rightarrow$ Hour interrupt occurred. Write 1 to clear.   |
|         | =0 | $\rightarrow$ No Hour interrupt.                           |
| Min_IE  | =1 | $\rightarrow$ Minute interrupt occurred. Write 1 to clear. |
|         | =0 | $\rightarrow$ No Minute interrupt.                         |
| Sec_IE  | =1 | $\rightarrow$ Second interrupt occurred. Write 1 to clear. |
|         | =0 | $\rightarrow$ No Second interrupt.                         |

## RTCSEC(w/r) : (RTC\_A4-0 : 0X04) RTC Second Register (default 0X00)

|         | / (    |         |          |          |          |          |          |          |
|---------|--------|---------|----------|----------|----------|----------|----------|----------|
|         | Bit 7  | Bit 6   | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
| Name    | ADJ_EN | RUN_ADJ | ADJ_VAL5 | ADJ_VAL4 | ADJ_VAL3 | ADJ_VAL2 | ADJ_VAL1 | ADJ_VAL0 |
| Default | -      | -       | -        | 0        | 0        | 0        | 0        | 0        |

| ADJ_EN     | =1 | ightarrow Enable automatic time adjustment.                                      |
|------------|----|----------------------------------------------------------------------------------|
|            | =0 | ightarrow Disable automatic time adjustment.                                     |
| RUN_ADJ    | =1 | ightarrow RTC clock runs too fast, need to count more.                           |
|            | =0 | $\rightarrow$ RTC clock runs too slow, need to count less.                       |
| ADJ_VAL5-0 |    | $\rightarrow$ Write the automatic clock adjustment values (need in VBAT domain). |
|            |    | $\rightarrow$ Read second counter value.                                         |

## RTCMIN(w/r) : (RTC\_A4-0 : 0X05) RTC Minute Register (default 0X00)

| , ,     | Bit 7   | Bit 6 | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
|---------|---------|-------|----------|----------|----------|----------|----------|----------|
| Name    | CLR_CNT | -     | MIN_CNT5 | MIN_CNT4 | MIN_CNT3 | MIN_CNT2 | MIN_CNT1 | MIN_CNT0 |
| Default | 0       | -     | 0        | 0        | 0        | 0        | 0        | 0        |

MIN\_CNT5-0  $\rightarrow$  User can program the minute counter by writing a value.

## RTCHOUR(w/r) : (RTC\_A4-0 : 0X06) RTC Hour Register (default 0X00)

|         | / \   |       |       |         |         |         |         |         |
|---------|-------|-------|-------|---------|---------|---------|---------|---------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4   | Bit 3   | Bit 2   | Bit 1   | Bit 0   |
| Name    | AM_PM | -     | -     | HR_CNT4 | HR_CNT3 | HR_CNT2 | HR_CNT1 | HR_CNT0 |
| Default | 0     | -     | -     | 0       | 0       | 0       | 0       | 0       |
|         |       |       |       |         |         |         |         |         |

| AM_PM     | =1 | $\rightarrow$ Write 1 to enable 12 Hour AM/PM format.                                     |
|-----------|----|-------------------------------------------------------------------------------------------|
|           | =0 | $\rightarrow$ Write 0 to enable 24 Hour format.                                           |
| HR_CNT4   | =1 | $\rightarrow$ If AM_PM = 1, it means PM now. If AM_PM = 0, it is the MSB of hour counter. |
|           | =0 | $\rightarrow$ If AM_PM = 1, it means AM now. If AM_PM = 0, it is the MSB of hour counter. |
| HR_CNT3-0 |    | $\rightarrow$ If AM_PM = 1, HR_CNT3-0 indicate the hour value 0 to 11.                    |
|           |    | $\rightarrow$ If AM_PM = 0, HR_CNT4-0 indicate the hour value 0 to 23.                    |

## RTCDAYL(w/r) : (RTC\_A4-0 : 0X07) RTC Day Counter Low Byte Register (default 0X00)

|         | Bit 7 | Bit 6                                                                           | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |  |
|---------|-------|---------------------------------------------------------------------------------|-------|-------|-------|-------|-------|-------|--|--|--|--|
| Name    | D     | Day counter starting from Jan. 1, year 2000, this is the low byte "RTCDAY[7:0]" |       |       |       |       |       |       |  |  |  |  |
| Default |       | 0X00                                                                            |       |       |       |       |       |       |  |  |  |  |

## RTCDAYH(w/r) : (RTC\_A4-0 : 0X08) RTC Day Counter High Byte Register (default 0X00)

|         | Bit 7 | Bit 6                                                                             | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |  |
|---------|-------|-----------------------------------------------------------------------------------|-------|-------|-------|-------|-------|-------|--|--|--|
| Name    | Da    | Day counter starting from Jan. 1, year 2000, this is the high byte "RTCDAY[15:8]" |       |       |       |       |       |       |  |  |  |
| Default |       |                                                                                   |       | 0X    | 00    |       |       |       |  |  |  |

## ALMSEC(w/r) : (RTC\_A4-0 : 0X09) RTC Alarm Second Register (default 0X00)

|         | <u> </u> |          | <u>_</u> |          |          |          |          |          |
|---------|----------|----------|----------|----------|----------|----------|----------|----------|
|         | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
| Name    | Reserved | Reserved | ALM_SEC5 | ALM_SEC4 | ALM_SEC3 | ALM_SEC2 | ALM_SEC1 | ALM_SEC0 |
| Default | -        | -        | 0        | 0        | 0        | 0        | 0        | 0        |

ALM\_SEC5-0  $\rightarrow$  Expected alarm "second" setting.

## ALMMIN(w/r) : (RTC\_A4-0 : 0X0A) RTC Alarm Minute Register (default 0X00)

|         | Bit 7    | Bit 6    | Bit 5    | Bit 4    | Bit 3    | Bit 2    | Bit 1    | Bit 0    |
|---------|----------|----------|----------|----------|----------|----------|----------|----------|
| Name    | Reserved | Reserved | ALM_MIN5 | ALM_MIN4 | ALM_MIN3 | ALM_MIN2 | ALM_MIN1 | ALM_MIN0 |
| Default | -        | -        | 0        | 0        | 0        | 0        | 0        | 0        |

ALM\_MIN5-0  $\rightarrow$  Expected alarm "minute" setting.

## ALMHOUR(w/r) : (RTC\_A4-0 : 0X0B) RTC Alarm Hour Register (default 0X00)

|         | Bit 7    | Bit 6    | Bit 5    | Bit 4     | Bit 3     | Bit 2     | Bit 1     | Bit 0     |
|---------|----------|----------|----------|-----------|-----------|-----------|-----------|-----------|
| Name    | Reserved | Reserved | Reserved | ALM_HOUR4 | ALM_HOUR3 | ALM_HOUR2 | ALM_HOUR1 | ALM_HOUR0 |
| Default | -        | -        | -        | 0         | 0         | 0         | 0         | 0         |

ALM\_HOUR4-0  $\rightarrow$  Expected alarm "hour" settings, in 24-hour representation.

## ALMDAYL(w/r) : (RTC\_A4-0 : 0X0C) RTC Alarm Day Low Byte Register (default 0X00)

|         | Bit 7    | Bit 6         | Bit 5         | Bit 4        | Bit 3         | Bit 2         | Bit 1          | Bit 0      |
|---------|----------|---------------|---------------|--------------|---------------|---------------|----------------|------------|
| Name    | Expected | alarm "day" s | settings. Day | counter star | ting from Jan | . 1, year 200 | 0, this is the | high byte. |
| Default |          |               |               | 0X           | 00            |               |                |            |

ALMDAYL  $\rightarrow$  Expected alarm "day" settings. Day counter starting from Jan. 1, year 2000, this is the low byte.

## ALMDAYH(w/r) : (RTC\_A4-0 : 0X0D) RTC Alarm Day High Byte Register (default 0X00)

|         | Bit 7 | Bit 6         | Bit 5         | Bit 4       | Bit 3         | Bit 2        | Bit 1           | Bit 0  |
|---------|-------|---------------|---------------|-------------|---------------|--------------|-----------------|--------|
| Name    | Exped | cted alarm "d | ay" settings. | Day counter | starting from | n year 2000, | this is the low | v byte |
| Default |       |               |               | 0X          | 00            |              |                 |        |

ALMDAYH  $\rightarrow$  Expected alarm "day" settings. Day counter starting from Jan. 1, year 2000, this is the high byte.

Note that the actual day, month, and year shall be calculated by firmware. The hardware only provides the day counter after Jan. 1, 2000.

## Address 10 – 1FH: RTC Spare Register 0 - 15 (RTCSP1 – RTCSP15)

These spare registers are in RTC power domain. The data could be kept as long as VBAT is available



## CHAPTER 19 PWM DAC

Each output pulse width of PWM DAC converter is controlled by an 8-bit register in XFR. The frequency of PWM clock is fosc/256 or fosc/128, selected by PWMF. And the total duty cycle step of these DAC outputs is 253 or 256, selected by DIV253. If DIV253=1, writing FDH/FEH/FFH to DAC register generates stable high output. If DIV253=0, the output pulses low at least once even if the DAC register's content is FFH. Writing 00H to DAC register generates stable low output.

| DAC Registers |             |                                         |                          |       |              |           |       |       |       |  |
|---------------|-------------|-----------------------------------------|--------------------------|-------|--------------|-----------|-------|-------|-------|--|
| DA0L          | 0X0F20(r/w) |                                         |                          | Р     | ulse width o | f PWM DAC | 0     |       |       |  |
| DA1L          | 0X0F21(r/w) |                                         |                          | Р     | ulse width o | f PWM DAC | 1     |       |       |  |
| DA2           | 0X0F22(r/w) |                                         |                          | Р     | ulse width o | f PWM DAC | 2     |       |       |  |
| DA3           | 0X0F23(r/w) |                                         |                          | Р     | ulse width o | f PWM DAC | 3     |       |       |  |
| DA4           | 0X0F24(r/w) |                                         | Pulse width of PWM DAC 4 |       |              |           |       |       |       |  |
| DA5           | 0X0F25(r/w) | Pulse width of PWM DAC 5                |                          |       |              |           |       |       |       |  |
| DA6           | 0X0F26(r/w) |                                         | Pulse width of PWM DAC 6 |       |              |           |       |       |       |  |
| DA7           | 0X0F27(r/w) |                                         |                          | Р     | ulse width o | f PWM DAC | 7     |       |       |  |
| PFC           | 0X0F2B(r/w) | PFC13                                   | PFC12                    | PFC11 | PFC10        | PFC03     | PFC02 | PFC01 | PFC00 |  |
| PADMOD        | 0X0F51(w)   | DA7E DA6E DA5E DA4E DA3E DA2E DA1E DA0E |                          |       |              |           |       |       |       |  |
| OPTION        | 0X0F56(r/w) | PWMIF                                   | DIV253                   | -     | ENSCL1       | ENSCL0    | -     | -     | -     |  |

## **OPTION** (r/w) : (XFR 0X0F56) Chip Option Configuration (default 0X00)

|         | Bit 7 | Bit 6                                                           | Bit 5          | Bit 4         | Bit 3  | Bit 2 | Bit 1 | Bit 0 |  |  |
|---------|-------|-----------------------------------------------------------------|----------------|---------------|--------|-------|-------|-------|--|--|
| Name    | PWMF  | DIV253                                                          | -              | ENSCL1        | ENSCL0 | -     | -     | -     |  |  |
| Default | 0     | 0                                                               | -              | 0             | 0      | -     | -     | -     |  |  |
| PWMF    | = 1   | $\rightarrow$ Selects system clock/512 as PWM clock frequency.  |                |               |        |       |       |       |  |  |
|         | = 0   | $\rightarrow$ Selects system clock/1024 as PWM clock frequency. |                |               |        |       |       |       |  |  |
| DIV253  | = 1   | $\rightarrow$ PWM pulse width is 253-step resolution.           |                |               |        |       |       |       |  |  |
|         | = 0   | $\rightarrow$ PWM puls                                          | se width is 25 | 6-step resolu | ution. |       |       |       |  |  |

## DA0L (r/w) : (XFR 0X0F20) DA0 Pulse Width Register (default 0X80)

|         |       | ,        |       | <u> </u> |       |       |       |       |  |  |
|---------|-------|----------|-------|----------|-------|-------|-------|-------|--|--|
|         | Bit 7 | Bit 6    | Bit 5 | Bit 4    | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
| Name    |       | DA0[7:0] |       |          |       |       |       |       |  |  |
| Default |       |          |       | 0X       | 80    |       |       |       |  |  |

DA0[7:0]  $\rightarrow$  The output pulse width control for PWM DAC0.

## DA1L (r/w) : (XFR 0X0F21) DA1 Low Pulse Width Register (default 0X80)

| <u> </u> |       |          |       |       |       | -     |       |       |  |
|----------|-------|----------|-------|-------|-------|-------|-------|-------|--|
|          | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
| Name     |       | DA1[7:0] |       |       |       |       |       |       |  |
| Default  |       |          |       | 0X    | 80    |       |       |       |  |

DA1[7:0]  $\rightarrow$  The output pulse width control for PWM DAC1.

## DA2 (r/w) : (XFR 0X0F22) DA2 Pulse Width Register (default 0X80)

|         | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|---------|-------|----------|-------|-------|-------|-------|-------|-------|--|
| Name    |       | DA2[7:0] |       |       |       |       |       |       |  |
| Default | 0X80  |          |       |       |       |       |       |       |  |

DA2[7:0]

 $\rightarrow$  The output pulse width control for PWM DAC2.



## DA3 (r/w) : (XFR 0X0F23) DA3 Pulse Width Register (default 0X80)

| - ( - ) |       |          |       |       |       |       |       |       |  |
|---------|-------|----------|-------|-------|-------|-------|-------|-------|--|
|         | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
| Name    |       | DA3[7:0] |       |       |       |       |       |       |  |
| Default |       | 0X80     |       |       |       |       |       |       |  |

DA3[7:0]  $\rightarrow$  The output pulse width control for PWM DAC3.

## DA4 (r/w) : (XFR 0X0F24) DA4 Pulse Width Register (default 0X80)

|         | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|---------|-------|----------|-------|-------|-------|-------|-------|-------|--|
| Name    |       | DA4[7:0] |       |       |       |       |       |       |  |
| Default |       | 0X80     |       |       |       |       |       |       |  |

DA4[7:0]  $\rightarrow$  The output pulse width control for PWM DAC4.

## DA5 (r/w) : (XFR 0X0F25) DA5 Pulse Width Register (default 0X80)

|         | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|---------|-------|----------|-------|-------|-------|-------|-------|-------|--|
| Name    |       | DA5[7:0] |       |       |       |       |       |       |  |
| Default |       | 0X80     |       |       |       |       |       |       |  |

DA5[7:0]  $\rightarrow$  The output pulse width control for PWM DAC5.

## DA6 (r/w) : (XFR 0X0F26) DA6 Pulse Width Register (default 0X80)

|         | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
|---------|-------|----------|-------|-------|-------|-------|-------|-------|--|--|
| Name    |       | DA6[7:0] |       |       |       |       |       |       |  |  |
| Default |       | 0X80     |       |       |       |       |       |       |  |  |

DA6[7:0]  $\rightarrow$  The output pulse width control for PWM DAC6.

## DA7 (r/w) : (XFR 0X0F27) DA7 Pulse Width Register (default 0X80)

|         | Bit 7 | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |
|---------|-------|----------|-------|-------|-------|-------|-------|-------|--|
| Name    |       | DA7[7:0] |       |       |       |       |       |       |  |
| Default |       | 0X80     |       |       |       |       |       |       |  |

DA7[7:0]  $\rightarrow$  The output pulse width control for PWM DAC7.

## PFC (r/w) : (XFR 0X0F2B) Pre-frequency Scale Register (default 0X00)

|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
| Name    | PFC13 | PFC12 | PFC11 | PFC10 | PFC03 | PFC02 | PFC01 | PFC00 |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

PFC  $\rightarrow$  Output period control for DA0, DA1.

DA1 period = system clock period X 2<sup>(PFC13, PFC12, PFC11, PFC10)</sup>. The minimum value for DA1 period is system clock period x 2

DA0 period = system clock period X 2<sup>(PFC03, PFC01, PFC01, PFC00)</sup>. The minimum value for DA0 period is system clock period x 2

All of PWM DAC converters are centered with value 0X80 after power on.

## PADMOD1 (r/w) : (XFR 0X0F51) Pad mode control registers 1. (default 0X00)

|         |       |       |       | U     |       |       |       |       |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|
|         | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| Name    | DA7E  | DA6E  | DA5E  | DA4E  | DA3E  | DA2E  | DA1E  | DA0E  |
| Default | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|         |       |       |       |       |       |       |       |       |

| DA7E | = 1 | $\rightarrow$ Pin "P9.3/PWM7" is PWM7. Select DA7 output |
|------|-----|----------------------------------------------------------|
|      | = 0 | $\rightarrow$ Pin "P9.3/PWM7" is P9.3.                   |
| DA6E | = 1 | $\rightarrow$ Pin "P6.3/PWM6" is PWM6. Select DA6 output |
|      | = 0 | $\rightarrow$ Pin "P6.3/PWM6" is P6.3.                   |

| DA5E | = 1 | $\rightarrow$ Pin "P9.2/PWM5 | " is PWM5. Select DA5 output |
|------|-----|------------------------------|------------------------------|
|      |     |                              |                              |



|      | = 0 | $\rightarrow$ Pin "P9.2/PWM5" is P9.2.                   |
|------|-----|----------------------------------------------------------|
| DA4E | = 1 | $\rightarrow$ Pin "P6.2/PWM4" is PWM4. Select DA4 output |
|      | = 0 | $\rightarrow$ Pin "P6.2/PWM4" is P6.2.                   |
| DA3E | = 1 | $\rightarrow$ Pin "P9.1/PWM3" is PWM3. Select DA3 output |
|      | = 0 | $\rightarrow$ Pin "P9.1/PWM3" is P9.1.                   |
| DA2E | = 1 | $\rightarrow$ Pin "P6.1/PWM2" is PWM2. Select DA2 output |
|      | = 0 | $\rightarrow$ Pin "P6.1/PWM2" is P6.1.                   |
| DA1E | = 1 | $\rightarrow$ Pin "P9.0/PWM1" is PWM1. Select DA1 output |
|      | = 0 | $\rightarrow$ Pin "P9.0/PWM1" is P9.0.                   |
| DA0E | = 1 | $\rightarrow$ Pin "P6.0/PWM0" is PWM0. Select DA0 output |
|      | = 0 | $\rightarrow$ Pin "P6.0/PWM0" is P6.0.                   |



## CHAPTER 20 LOW VOLTAGE DETECTION

The Low Voltage Detection Circuit (LVDT) detects the condition of VDD5 supply and V25 supply. When enabled, it detect VDD5 < VTH condition, and can be configured to generate an interrupt (LVDT\_INT) or a system reset (LVDT\_RST). Because the existence of on-chip regulator the system and user program should have ample time to responds to the interrupt. The larger the decoupling capacitance on V25, the longer this time can be extended. To ensure a reliable MCU operation and prevent loss of data, user program should terminate all critical process and wait for power supply to get back to normal or as power supply continue to deteriorate and finally reset the system.

The block diagram of Low Voltage Detection Circuit is shown in the following figure.



The default state of the LVDT circuit for V25 is enabled and the LVDT circuit for VDD5 is disabled. The user program needs to enable the preferred configuration and set the appropriate detection threshold level. The following XFR registers are used for this purpose.

## POWER(w/r) : (XFR 0X0F9E) Power management (default 0X02)

|         | Bit 7    | Bit 6    | Bit 5 | Bit 4 | Bit 3 | Bit 2  | Bit 1  | Bit 0 |
|---------|----------|----------|-------|-------|-------|--------|--------|-------|
| Name    | Reserved | Reserved | -     | -     | -     | PRSTEN | CRSTEN | -     |
| Default | 0        | 0        | -     | -     | -     | 0      | 1      | -     |

| PRSTEN | = 1 | $\rightarrow$ Enable LVDT for power supply VDD5 (5v).  |
|--------|-----|--------------------------------------------------------|
|        | = 0 | $\rightarrow$ Disable LVDT for power supply VDD5 (5v). |
| CRSTEN | = 1 | $\rightarrow$ Enable LVDT for core power V25 (2.5v).   |
|        | = 0 | $\rightarrow$ Disable LVDT for core power V25 (2.5v).  |

## LVDTCTL(w/r) : (SFR 0X9F) LVDT Control Register (default 0X20)

|            | Bit 7      | Bit 6                                              | Bit 5                                                                                                                                                                                                                             | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |  |  |
|------------|------------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------|-------|-------|-------|--|--|
| Name       | LVDT_IF    | LVDT_IE                                            | LVDTHD[5:0]                                                                                                                                                                                                                       |       |       |       |       |       |  |  |
| Default    | 0          | 0                                                  |                                                                                                                                                                                                                                   | 0X20  |       |       |       |       |  |  |
| LVDT_IF    |            | $\rightarrow$ This bit is generate an when VDD5    | This bit is set when VDD5 lower than the threshold level and the LVDT circuit will nerate an interrupt (LVDT_INT) to inform system if LVDT_IE is set. Writing a zero en VDD5 higher than the threshold level will clear this bit. |       |       |       |       |       |  |  |
| LVDT_IE    | = 1<br>= 0 | $\rightarrow$ Enable LV<br>$\rightarrow$ Disable L | DT interrupt                                                                                                                                                                                                                      | t     |       |       |       |       |  |  |
| LVDTHD[5:0 | ]          | → The thresh<br>minimum (ap<br>its maximum         | hold level for VDD5. LVDTHD = $0X3F$ will set the detection threshold at its proximately 2.6V), and LVDTHD = $0X00$ will set the detection threshold at (approximately 4.9V).                                                     |       |       |       |       |       |  |  |



## **CHAPTER 21 ECT**

The CS8961 ECT (Enhanced Capture Timer) module has the features of the Time2. But ECT module does not be a baud rate generator. CS8961 has 3 ECTs for various frequencies detection.

## 1. ECT2

ECT2 is a 16-bit Timer/Counter, which can operate as either an event timer or an event counter, as selected by C/ECT2T\* in the special function register T2CON2 (0XB9). ECT2 has two operating modes: Capture, Autoreload, which are selected by bits in the T2CON2.

ECT2 Configuration Register

|           | Bit 7      | Bit 6                                                                     | Bit 5                                                                    | Bit 4           | Bit 3          | Bit 2         | Bit 1      | Bit 0     |  |  |  |
|-----------|------------|---------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------|----------------|---------------|------------|-----------|--|--|--|
| Name      | E2_TF2     | E2_EXF2                                                                   | E2_TF2EN                                                                 | E2_EXF2EN       | E2_EXEN2       | E2_TR2        | C/ECT2T    | E2_CP/RL2 |  |  |  |
| Default   | 0          | 0                                                                         | 0                                                                        | 0               | 0              | 0             | 0          | 0         |  |  |  |
|           |            |                                                                           |                                                                          |                 |                |               |            |           |  |  |  |
| E2_TF2    | :          | ECT2 interro                                                              | ECT2 interrupt (overflow) flag. Must be cleared by software.             |                 |                |               |            |           |  |  |  |
| E2_EXF2   | :          | Falling edge                                                              | Falling edge indicator on ECT2ET pin when E2_EXEN2=1. Must be cleared by |                 |                |               |            |           |  |  |  |
| software. |            |                                                                           |                                                                          |                 |                |               |            |           |  |  |  |
| E2_TF2EN  | :          | Overflow in                                                               | terrupt enab                                                             | ole.            |                |               |            |           |  |  |  |
|           | =1         | $\rightarrow$ Enable overflow interrupt                                   |                                                                          |                 |                |               |            |           |  |  |  |
|           | =0         | $\rightarrow$ Disable c                                                   | overflow inter                                                           | rupt            |                |               |            |           |  |  |  |
| E2_EXF2EN | <b>I</b> : | Falling edge                                                              | e interrupt e                                                            | nable           |                |               |            |           |  |  |  |
|           | =1         | $\rightarrow$ Enable falling edge interrupt                               |                                                                          |                 |                |               |            |           |  |  |  |
|           | =0         | $\rightarrow$ Disable f                                                   | alling edge ir                                                           | nterrupt        |                |               |            |           |  |  |  |
| E2_EXEN2  | :          | Enable ECT                                                                | 2ET pin fund                                                             | ctionality.     |                |               |            |           |  |  |  |
|           | =1         | ightarrow Allows capture or reload as a result of ECT2ET pin falling edge |                                                                          |                 |                |               |            |           |  |  |  |
|           | =0         | $\rightarrow$ Ignore ECT2ET events                                        |                                                                          |                 |                |               |            |           |  |  |  |
| E2_TR2    | :          | Start/stop E                                                              | CT2                                                                      |                 |                |               |            |           |  |  |  |
|           | =1         | $\rightarrow$ Start                                                       |                                                                          |                 |                |               |            |           |  |  |  |
|           | =0         | $\rightarrow$ Stop                                                        |                                                                          |                 |                |               |            |           |  |  |  |
| C/ECT2T   | :          | Timer/count                                                               | er select                                                                |                 |                |               |            |           |  |  |  |
|           | =1         | $\rightarrow$ External                                                    | event counte                                                             | er. Clock sourc | e is ECT2T p   | bin           |            |           |  |  |  |
|           | =0         | $\rightarrow$ Timer Int                                                   | ernally clock                                                            | ed              |                |               |            |           |  |  |  |
| E2_CP/RL2 | :          | Capture/relo                                                              | oad select                                                               |                 |                |               |            |           |  |  |  |
|           | =1         | $\rightarrow$ ECT2ET                                                      | pin falling ec                                                           | dge causes ca   | pture to occu  | r when E2_E   | EXEN2=1    |           |  |  |  |
|           | =0         | $\rightarrow$ Automati<br>E2_EXEN2=                                       | c reload occi<br>=1.                                                     | urs: on ECT1 o  | overflow or fa | lling edge of | FECT2ET pi | n when    |  |  |  |

## T2CON2 (r/w) : (SFR 0XB9) ECT2 Configuration Register (default 0X00)

## 3.1 Capture Mode

In the capture mode there are two options that are selected by bit E2\_EXEN2 in T2CON2. If E2\_EXEN2=0, then ECT2 is a 16-bit timer or counter (as selected by C/ECT2T in T2CON2) which, upon overflowing sets bit E2\_TF2, the ECT2 overflow bit. This bit can be used to generate an interrupt (by enabling the ECT2 interrupt bit in the EXINTEN register). If E2\_EXEN2= 1, ECT2 operates as described above, but with the added feature that a 1- to -0 transition at external input ECT2ET causes the current value in the ECT2 registers, TL2 2(0XBC) and TH2 2(0XBD), to be captured into registers RLDL 2(0XBA) and RLDH 2(0XBB), respectively. In addition, the transition at ECT2ET causes bit E2\_EXF2 in T2CON2 to be set, and E2\_EXF2 like E2\_TF2 can generate an interrupt (which vectors to the same location as ECT2 overflow interrupt.

The ECT2 interrupt service routine can interrogate E2\_TF2 and E2\_EXF2 to determine which event caused the interrupt). The capture mode is illustrated in Figure (There is no reload value for TL2 2 and TH2 2 in this mode. Even when a capture event occurs from ECT2ET, the counter keeps on counting ECT2ET pin transitions or osc/12 pulses.)





Figure-49 ECT2 Capture Mode

## 3.2 Auto-Reload Mode

In the 16-bit auto-reload mode, ECT2 can be configured (as either a timer or counter (C/ECT2T in T2CON2)). ECT2 will count up automatically. In this mode there are two options selected by bit E2\_EXEN2 in T2CON2 register. If E2\_EXEN2=0, then ECT2 counts up to 0XFFFF and sets the E2\_TF2 (Overflow Flag) bit upon overflow. This causes the ECT2 registers to be reloaded with the 16-bit value in RLDL\_2 and RLDH\_2. The values in RLDL\_2 and RLDH\_2 are preset by software means. If E2\_EXEN2=1, then a 16-bit reload can be triggered either by an overflow or by a 1-to-0 transition at input ECT2ET. This transition also sets the E2\_EXF2 bit. The ECT2 interrupt, if enabled, can be generated when either E2\_TF2 or E2\_EXF2 are 1.







## 2. ECT3

ECT3 is a 16-bit Timer/Counter, which can operate as either an event timer or an event counter, as selected by C/ECT3T\* in the special function register T2CON3 (0XD1). ECT3 has two operating modes: Capture, Autoreload, which are selected by bits in the T2CON3.

|           | Bit 7  | Bit 6                                                                         | Bit 5                                                                    | Bit 4           | Bit 3          | Bit 2         | Bit 1       | Bit 0     |  |  |  |  |
|-----------|--------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------|----------------|---------------|-------------|-----------|--|--|--|--|
| Name      | E3_TF2 | E3_EXF2                                                                       | E3_TF2EN                                                                 | E3_EXF2EN       | E3_EXEN2       | E3_TR2        | C/ECT3T     | E3_CP/RL2 |  |  |  |  |
| Default   | 0      | 0                                                                             | 0                                                                        | 0               | 0              | 0             | 0           | 0         |  |  |  |  |
|           |        |                                                                               |                                                                          |                 |                |               |             |           |  |  |  |  |
| E3_TF2    | :      | ECT3 interrupt (overflow) flag. Must be cleared by software.                  |                                                                          |                 |                |               |             |           |  |  |  |  |
| E3_EXF2   | :      | Falling edge                                                                  | Falling edge indicator on ECT3ET pin when E3_EXEN2=1. Must be cleared by |                 |                |               |             |           |  |  |  |  |
| software. |        |                                                                               |                                                                          |                 |                |               |             |           |  |  |  |  |
| E3_TF2EN  | :      | Overflow in                                                                   | terrupt enab                                                             | ole.            |                |               |             |           |  |  |  |  |
|           | =1     | $\rightarrow$ Enable overflow interrupt                                       |                                                                          |                 |                |               |             |           |  |  |  |  |
|           | =0     | $\rightarrow$ Disable c                                                       | overflow inter                                                           | rupt            |                |               |             |           |  |  |  |  |
| E3_EXF2EN | N :    | Falling edg                                                                   | e interrupt e                                                            | nable           |                |               |             |           |  |  |  |  |
|           | =1     | $\rightarrow$ Enable falling edge interrupt                                   |                                                                          |                 |                |               |             |           |  |  |  |  |
|           | =0     | ightarrow Disable falling edge interrupt                                      |                                                                          |                 |                |               |             |           |  |  |  |  |
| E3_EXEN2  | :      | Enable ECT                                                                    | 3ET pin fund                                                             | ctionality.     |                |               |             |           |  |  |  |  |
|           | =1     | $\rightarrow$ Allows capture or reload as a result of ECT3ET pin falling edge |                                                                          |                 |                |               |             |           |  |  |  |  |
|           | =0     | $\rightarrow$ Ignore ECT3ET events                                            |                                                                          |                 |                |               |             |           |  |  |  |  |
| E3_TR2    | :      | Start/stop E                                                                  | CT3                                                                      |                 |                |               |             |           |  |  |  |  |
|           | =1     | $\rightarrow$ Start                                                           |                                                                          |                 |                |               |             |           |  |  |  |  |
|           | =0     | $\rightarrow$ Stop                                                            |                                                                          |                 |                |               |             |           |  |  |  |  |
| C/ECT3T   | :      | Timer/count                                                                   | er select                                                                |                 |                |               |             |           |  |  |  |  |
|           | =1     | $\rightarrow$ External                                                        | event counte                                                             | er. Clock sourc | e is ECT3T p   | bin           |             |           |  |  |  |  |
|           | =0     | $\rightarrow$ Timer Int                                                       | ernally clock                                                            | ed              |                |               |             |           |  |  |  |  |
| E3_CP/RL2 | :      | Capture/relo                                                                  | bad select                                                               |                 |                |               |             |           |  |  |  |  |
|           | =1     | $\rightarrow$ ECT3ET                                                          | pin falling ec                                                           | lge causes ca   | oture to occu  | r when E3_I   | EXEN2=1     |           |  |  |  |  |
|           | =0     | → Automati<br>E3_EXEN2=                                                       | c reload occi<br>=1.                                                     | urs: on ECT3 o  | overflow or fa | lling edge of | f ECT3ET pi | n when    |  |  |  |  |

## T2CON3 (r/w) : (SFR 0XD1) ECT3 Configuration Register (default 0X00)

## 4.1 Capture Mode

In the capture mode there are two options that are selected by bit E3\_EXEN2 in T2CON3. If E3\_EXEN2=0, then ECT3 is a 16-bit timer or counter (as selected by C/ECT3T in T2CON3) which, upon overflowing sets bit E3\_TF2, the ECT3 overflow bit. This bit can be used to generate an interrupt (by enabling the ECT3 interrupt bit in the EXINTEN register). If E3\_EXEN2= 1, ECT3 operates as described above, but with the added feature that a 1- to -0 transition at external input ECT3ET causes the current value in the ECT3 registers, TL2\_3(0XD4) and TH2\_3(0XD5), to be captured into registers RLDL\_3(0XD2) and RLDH\_3(0XD3), respectively. In addition, the transition at ECT3ET causes bit E3\_EXF2 in T2CON3 to be set, and E3\_EXF2 like E3\_TF2 can generate an interrupt (which vectors to the same location as ECT3 overflow interrupt.

The ECT3 interrupt service routine can interrogate E3\_TF2 and E3\_EXF2 to determine which event caused the interrupt). The capture mode is illustrated in Figure (There is no reload value for TL2\_3 and TH2\_3 in this mode. Even when a capture event occurs from ECT3ET, the counter keeps on counting ECT3ET pin transitions or osc/12 pulses.)







## 4.2 Auto-Reload Mode

In the 16-bit auto-reload mode, ECT3 can be configured (as either a timer or counter (C/ECT3T in T2CON3)). ECT3 will count up automatically. In this mode there are two options selected by bit E3\_EXEN2 in T2CON3 register. If E3\_EXEN2=0, then ECT3 counts up to 0XFFFF and sets the E3\_TF2 (Overflow Flag) bit upon overflow. This causes the ECT3 registers to be reloaded with the 16-bit value in RLDL\_3 and RLDH\_3. The values in RLDL\_3 and RLDH\_3 are preset by software means. If E3\_EXEN2=1, then a 16-bit reload can be triggered either by an overflow or by a 1-to-0 transition at input ECT3ET. This transition also sets the E3\_EXF2 bit. The ECT3 interrupt, if enabled, can be generated when either E3\_TF2 or E3\_EXF2 are 1.







## <u>3. ECT5</u>

ECT5 is a 16-bit Timer/Counter, which can operate as either an event timer or an event counter, as selected by C/ECT5T\* in the special function register T2CON5 (0XE1). ECT5 has two operating modes: Capture, Autoreload, which are selected by bits in the T2CON5.

|           | Bit 7  | Bit 6                                                                         | E                                                                        | Bit 5     |        | Bit 4     | Bit 3          | Bit 2          | Bit 1       | Bit 0     |  |  |
|-----------|--------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------|--------|-----------|----------------|----------------|-------------|-----------|--|--|
| Name      | E5_TF2 | E5_EXF2                                                                       | E5_                                                                      | TF2EN     | E5_    | EXF2EN    | E5_EXEN2       | E5_TR2         | C/ECT5T     | E5_CP/RL2 |  |  |
| Default   | 0      | 0                                                                             |                                                                          | 0         |        | 0         | 0              | 0              | 0           | 0         |  |  |
|           |        |                                                                               |                                                                          |           |        |           |                |                |             |           |  |  |
| E5_TF2    | :      | ECT5 interr                                                                   | CT5 interrupt (overflow) flag. Must be cleared by software.              |           |        |           |                |                |             |           |  |  |
| E5_EXF2   | :      | Falling edge                                                                  | Falling edge indicator on ECT5ET pin when E5_EXEN2=1. Must be cleared by |           |        |           |                |                |             |           |  |  |
| software. |        |                                                                               |                                                                          |           |        |           |                |                |             |           |  |  |
| E5_TF2EN  | :      | Overflow in                                                                   | terru                                                                    | pt enab   | ole.   |           |                |                |             |           |  |  |
|           | =1     | $\rightarrow$ Enable overflow interrupt                                       |                                                                          |           |        |           |                |                |             |           |  |  |
|           | =0     | $\rightarrow$ Disable c                                                       | verfl                                                                    | ow inter  | rupt   |           |                |                |             |           |  |  |
| E5_EXF2EN | N :    | Falling edg                                                                   | e inte                                                                   | errupt e  | nabl   | е         |                |                |             |           |  |  |
|           | =1     | ightarrow Enable falling edge interrupt                                       |                                                                          |           |        |           |                |                |             |           |  |  |
|           | =0     | $\rightarrow$ Disable f                                                       | alling                                                                   | edge i    | nterru | ipt       |                |                |             |           |  |  |
| E5_EXEN2  | :      | Enable ECT                                                                    | 5ET                                                                      | pin fund  | ctiona | ality.    |                |                |             |           |  |  |
|           | =1     | $\rightarrow$ Allows capture or reload as a result of ECT5ET pin falling edge |                                                                          |           |        |           |                |                |             |           |  |  |
|           | =0     | $\rightarrow$ Ignore ECT5ET events                                            |                                                                          |           |        |           |                |                |             |           |  |  |
| E5_TR2    | :      | Start/stop E                                                                  | CT5                                                                      |           |        |           |                |                |             |           |  |  |
|           | =1     | $\rightarrow$ Start                                                           |                                                                          |           |        |           |                |                |             |           |  |  |
|           | =0     | $\rightarrow$ Stop                                                            |                                                                          |           |        |           |                |                |             |           |  |  |
| C/ECT5T   | :      | Timer/count                                                                   | er se                                                                    | lect      |        |           |                |                |             |           |  |  |
|           | =1     | $\rightarrow$ External                                                        | even                                                                     | t counte  | er. Cl | ock sourc | e is ECT5T     | pin            |             |           |  |  |
|           | =0     | $\rightarrow$ Timer Int                                                       | ernal                                                                    | ly clock  | ed     |           |                |                |             |           |  |  |
| E5_CP/RL2 | :      | Capture/relo                                                                  | ad s                                                                     | elect     |        |           |                |                |             |           |  |  |
|           | =1     | $\rightarrow$ ECT5ET                                                          | pin fa                                                                   | alling ed | dge c  | auses cap | pture to occu  | ir when E5_I   | EXEN2=1     |           |  |  |
|           | =0     | $\rightarrow$ Automati                                                        | c relo                                                                   | ad occ    | urs: c | n ECT5 c  | overflow or fa | alling edge of | f ECT5ET pi | n when    |  |  |
|           |        | E5_EXEN2                                                                      | =1.                                                                      |           |        |           |                | 0 0            |             |           |  |  |
|           |        |                                                                               |                                                                          |           |        |           |                |                |             |           |  |  |

## T2CON5 (r/w) : (SFR 0XE1) ECT5 Configuration Register (default 0X00)

## 6.1 Capture Mode

In the capture mode there are two options that are selected by bit E5\_EXEN2 in T2CON5. If E5\_EXEN2=0, then ECT5 is a 16-bit timer or counter (as selected by C/ECT5T in T2CON5) which, upon overflowing sets bit E5\_TF2, the ECT5 overflow bit. This bit can be used to generate an interrupt (by enabling the ECT5 interrupt bit in the EXINTEN register). If E5\_EXEN2= 1, ECT5 operates as described above, but with the added feature that a 1- to -0 transition at external input ECT5ET causes the current value in the ECT5 registers, TL2\_5(0XE4) and TH2\_5(0XE5), to be captured into registers RLDL\_5(0XE2) and RLDH\_5(0XE3), respectively. In addition, the transition at ECT5ET causes bit E5\_EXF2 in T2CON5 to be set, and E5\_EXF2 like E5\_TF2 can generate an interrupt (which vectors to the same location as ECT5 overflow interrupt.

The ECT5 interrupt service routine can interrogate E5\_TF2 and E5\_EXF2 to determine which event caused the interrupt). The capture mode is illustrated in Figure (There is no reload value for TL2\_5 and TH2\_5 in this mode. Even when a capture event occurs from ECT5ET, the counter keeps on counting ECT5ET pin transitions or osc/12 pulses.).







## 6.2 Auto-Reload Mode

In the 16-bit auto-reload mode, ECT5 can be configured (as either a timer or counter (C/ECT5T in T2CON5)). ECT5 will count up automatically. In this mode there are two options selected by bit E5\_EXEN2 in T2CON5 register. If E5\_EXEN2=0, then ECT5 counts up to 0XFFFF and sets the E5\_TF2 (Overflow Flag) bit upon overflow. This causes the ECT5 registers to be reloaded with the 16-bit value in RLDL\_5 and RLDH\_5. The values in RLDL\_5 and RLDH\_5 are preset by software means. If E5\_EXEN2=1, then a 16-bit reload can be triggered either by an overflow or by a 1-to-0 transition at input ECT5ET. This transition also sets the E5\_EXF2 bit. The ECT5 interrupt, if enabled, can be generated when either E5\_TF2 or E5\_EXF2 are 1.







## CHAPTER 22 JTAG TAP CONTROLLER

CS8961 provides the JTAG interface with the TAP controller compliant to IEEE 1149.1, with which the following functions are implemented.

- Boundary Scan: The value of the IO pins could be read or written via the JTAG boundary-scan chain, as the MCU remains in its functional mode.
- Debug: With the software debug tool, user could run or stop the MCU, set breakpoint, read or write the register, and go or step his program.
- MBIST: The JTAG TAP controller allows user access to the MBIST (Memory built-in self test) scan chain to test the SRAM memory.
- ISP: The user could easily download his program to the MCU via the JTAG interface with the software ISP tool.



If you need any tool of above, you can ask ISSI for help.



## JTAG interface signals

| Pin Name | Abbreviation | Signal          | Description                                                                                                       |
|----------|--------------|-----------------|-------------------------------------------------------------------------------------------------------------------|
| JTAG_CLK | ТСК          | Test Clock      | A Test clock input that synchronizes the test logic.                                                              |
| JTAG_SEL | TMS          | Test Mode State | A pulled-up input that is sampled at the rising edge of TCK to determine the next state.                          |
| JTAG_IN  | TDI          | Test Data In    | A pulled-up Test Data input that is sampled at the rising edge of TCK.                                            |
| JTAG_OUT | TDO          | Test Data Out   | Represents the Test Data shifted out of the device and is valid on the falling edge of TCK.                       |
| JTAG_RST | TRST         | Test Reset      | An optional pin* which, when available, can reset (asynchronous, active high) the TAP controller's state machine. |

\*If JTAG\_RST pin is not presented on the host device, the TAP controller could also be reset by pulling TMS for 5 TCK cycles, which avoids resetting the whole chip.



## CHAPTER 23 CAN CONTROLLER

The Controller Area Network (CAN) is a serial, asynchronous, multi-master communication protocol for connecting electronic control modules, sensors and actuators in automotive and industrial applications.

The controller is designed according to CAN protocol version 2.0B.

Attractive features are implemented for a wide range of applications, supporting system optimization, diagnosis and maintenance.

## 1. CAN Controller Function Description

In CS8961, the CAN controller has the main function as follows:

- Operating mode
- Silent mode
- Listen-Only mode
- Bus Auto-Recovery
- Self test mode
- Self-Reception
- Programmable Baud-Rate
- 32 filers
- Dispatch
- Forward
- Error Detection
- Loop test
- Back-up pins

## 2. Registers Description

## 2.1 Registers mapping

The CAN0 is the peripherals of the MCU. CAN0 occupies space from 0X0B00 to 0X0CFF in XFR (Auxiliary Function Register). The address reserved is for future use. Reading and writing operation to those addresses has no effect.

Note that some registers are accessible in operating mode and some registers are accessible in Silent mode. The sign "——" stands for inaccessible in writing operation.



## CAN0 Registers Mapping

|                     | Operati                              | ng Mode                      | Silent Mode                          |                                    |  |
|---------------------|--------------------------------------|------------------------------|--------------------------------------|------------------------------------|--|
| ADDR                | read                                 | write                        | read                                 | write                              |  |
| 0B00H               | Mode Register<br>(Note 1)            | Mode Register<br>(Note 1)    | Mode Register<br>(Note 1)            | Mode Register<br>(Note 1)          |  |
| 0B01H               | 00H<br>(Note 2)                      | Command Register<br>(Note 2) | 00H<br>(Note 2)                      |                                    |  |
| 0B02H               | Status Register                      |                              | Status Register                      |                                    |  |
| 0B03H               | Interrupt Register<br>(Note 3)       |                              | 00H<br>(Note 3)                      |                                    |  |
| 0B04H               | Interrupt Enable<br>Register         | Interrupt Enable<br>Register | Interrupt Enable<br>Register         | Interrupt Enable<br>Register       |  |
| 0B05H<br> <br>0B08H | Reserved                             | Reserved                     | Reserved                             | Reserved                           |  |
| 0B09H               | Bus Timing<br>Register 0             |                              | Bus Timing<br>Register 0             | Bus Timing<br>Register 0           |  |
| 0B0AH               | Bus Timing<br>Register 1             |                              | Bus Timing<br>Register 1             | Bus Timing<br>Register 1           |  |
| 0B0BH               | Reserved                             | Reserved                     | Reserved                             | Reserved                           |  |
| 0B0CH               | Filer Enable<br>Register 3           |                              | Filer Enable<br>Register 3           | Filer Enable<br>Register 3         |  |
| 0B0DH               | Filer Enable<br>Register 2           |                              | Filer Enable<br>Register 2           | Filer Enable<br>Register 2         |  |
| 0B0EH               | Filer Enable<br>Register 1           |                              | Filer Enable<br>Register 1           | Filer Enable<br>Register 1         |  |
| 0B0FH               | Filer Enable<br>Register 0           |                              | Filer Enable<br>Register 0           | Filer Enable<br>Register 0         |  |
| 0B10H               | Arbitration Lost<br>Capture Register |                              | Arbitration Lost<br>Capture Register |                                    |  |
| 0B11H               | Error Code<br>Capture Register       |                              | Error Code<br>Capture Register       |                                    |  |
| 0B12H               | Error Warning Limit<br>Register      |                              | Error Warning<br>Limit Register      | Error Warning<br>Limit Register    |  |
| 0B13H               | Receive Error<br>Counter Register    |                              | Receive Error<br>Counter Register    | Receive Error<br>Counter Register  |  |
| 0B14H               | Transmit Error<br>Counter Register   |                              | Transmit Error<br>Counter Register   | Transmit Error<br>Counter Register |  |
| 0B15H               | Receive Frame<br>Counter Register    |                              | 00H(Note 4)                          | 00H                                |  |
| 0B16H               | Filter Number<br>Register            |                              | Filter Number<br>Register            |                                    |  |
| 0B17H               | Receive Frame                        | Transmit Frame               | Receive Frame                        |                                    |  |
| 0B18H               | Receive ID<br>Register 3             | Transmit ID<br>Register 3    | Receive ID<br>Register 3             |                                    |  |
| 0B19H               | Receive ID<br>Register 2             | Transmit ID<br>Register 2    | Receive ID<br>Register 2             |                                    |  |
| 0B1AH               | Receive ID<br>Register 1             | Transmit ID<br>Register 1    | Receive ID<br>Register 1             |                                    |  |
| 0B1BH               | Receive ID<br>Register 0             | Transmit ID<br>Register 0    | Receive ID<br>Register 0             |                                    |  |
| 0B1CH               | Receive DATA                         | Transmit DATA                | Receive DATA                         |                                    |  |
| 0B1DH               | Receive DATA<br>Register 2           | Transmit DATA<br>Register 2  | Receive DATA<br>Register 2           |                                    |  |



| ADDR                | Operati                     | ng Mode                     | Silent Mode                        |                             |  |
|---------------------|-----------------------------|-----------------------------|------------------------------------|-----------------------------|--|
|                     | read                        | write                       | read                               | write                       |  |
| 0B1EH               | Receive DATA<br>Register 3  | Transmit DATA<br>Register 3 | Receive DATA<br>Register 3         |                             |  |
| 0B1FH               | Receive DATA<br>Register 4  | Transmit DATA<br>Register 4 | Receive DATA<br>Register 4         |                             |  |
| 0B20H               | Receive DATA<br>Register 5  | Transmit DATA<br>Register 5 | Receive DATA<br>Register 5         |                             |  |
| 0B21H               | Receive DATA<br>Register 6  | Transmit DATA<br>Register 6 | Receive DATA<br>Register 6         |                             |  |
| 0B22H               | Receive DATA<br>Register 7  | Transmit DATA<br>Register 7 | Receive DATA<br>Register 7         |                             |  |
| 0B23H               | Receive DATA<br>Register 8  | Transmit DATA<br>Register 8 | Receive DATA<br>Register 8         |                             |  |
| 0B24H               | Filter Status<br>Register 3 |                             | Dispatch Time<br>Register 3(Note5) | Dispatch Time<br>Register 3 |  |
| 0B25H               | Filter Status<br>Register 2 |                             | Dispatch Time<br>Register 2        | Dispatch Time<br>Register 2 |  |
| 0B26H               | Filter Status<br>Register 1 |                             | Dispatch Time<br>Register 1        | Dispatch Time<br>Register 1 |  |
| 0B27H               | Filter Status<br>Register 0 |                             | Dispatch Time<br>Register 0        | Dispatch Time<br>Register 0 |  |
| 0B28H<br> <br>0C28H | Receive FIFO                | Receive FIFO                | Filter Registers                   | Filter Registers            |  |
| 0B29H<br> <br>0C90H | Reserved                    | Reserved                    | Reserved                           | Reserved                    |  |
| 0C91H               | Loop Test Enable            | Loop Test Enable            | Loop Test Enable                   | Loop Test Enable            |  |
| 0C92H               | Loop Test                   | Loop Test                   | Loop Test                          | Loop Test                   |  |
| 0C93H<br> <br>0CFFH | Reserved                    |                             |                                    |                             |  |

Notes:

- 1. Bits from Mode[1] to Mode[3] can be read and written in Silent mode and are read only in Operating mode.
- 2. Command Register can only be written in Operating mode. Reading the register in Operating mode will get 0. In Silent mode, the register is cleared.
- 3. This is a read only register. In Silent mode, the register is cleared.
- 4. This is a read only register. In Silent mode, the register is cleared.
- 5. In Silent mode, the upper 4 bits of the Dispatch Time 3 register are safe bits. If you want to configure the Dispatch Time registers, you must write 6h into the upper 4 bits first, or writing operation to the dispatch time registers is invalid.



## 2.2 Registers Function Description

Mode Register (MOD) XER ADDR.

## Mode Register

| BIT       | SYMBOL         | NAME              | Reset Value | VALUE  | FUNCTION                        |
|-----------|----------------|-------------------|-------------|--------|---------------------------------|
| MOD.7     |                | Reserved          | 0           |        | Reserved                        |
| MOD.6     |                | Reserved          | 0           |        | Reserved                        |
| MOD.5     |                | Reserved          | 0           |        | Reserved                        |
| MOD.4     |                | Reserved          | 0           |        | Reserved                        |
| MOD.3 BAR |                | Bus Auto Recovery | 0           | 1      | Bus Auto Recovery Mode (Note 1) |
|           | DAK            |                   |             | 0      | Normal                          |
| MOD.2 STM | OTM.           | Colf Toot Mode    | 0           | 1      | Self Test Mode (Note 2)         |
|           | Sell Test Mode | 0                 | 0           | Normal |                                 |
| MOD.1 LOM |                | Listen Only Mode  | 0           | 1      | Listen Only Mode (Note 3)       |
|           | LOM            |                   |             | 0      | Normal                          |
| MOD.0     | SM             | Silent Mode       | 1           | 1      | Silent Mode (Note 4)            |
|           |                |                   |             | 0      | Operating Mode                  |

## Notes :

- 1. The bit can be read and written in Silent mode and is read-only in Operating mode. When this bit is set, CAN controller will work in Bus Auto Recovery mode. When bus is off and CAN controller works in this mode, the controller will wait 128 occurrences of bus-free signal (11 consecutive 'recessive' bits) and then the bus is turned on again, the value of the Receive Error counter register and Transmit error counter register is 0 and 128 correspondingly. When the bus is off and the CAN controller is not in Bus Auto Recovery mode, the controller enter into Silent mode and the value of the Receive Error counter register and Transmit error counter register and Transmit error counter register is 0 and 128 correspondingly. In this condition, MCU can write a value less then 255 into the Transmit Error Counter register to make the bus on. CAN controller will stay in Silent mode until the CPU clears the Silent mode bit.
- 2. The bit can be read and written in Silent mode and is read only in Operating mode. When this bit is set, CAN controller will work in Self Test Mode. In this mode, a full node test is possible without any other active node on the bus using the self reception request command; The CAN controller will perform a successful transmission, even if there is no acknowledge received. But when transmitting successfully, the transmit error counter will count down by 1 if its value is not zero.
- 3. The bit can be read and written in Silent mode and is read-only in Operating mode. When this bit is set, CAN controller will work in Listen Only mode. In this mode, the CAN controller would give no acknowledge to the CAN-bus, even if a message is received successfully. In this mode, the error counters are stopped at the current value and message transmission is not possible. But when detecting bus error, node will transmit error flag. All other functions can be used like in Operating mode.
- 4. When this bit is set, CAN controller will work in Silent mode. After hardware reset, the CAN controller works in Silent mode. In Silent mode, normal transmitting and receiving is impossible. After CAN controller quit Silent mode, a bus-free signal (11 recessive bits) have to be detected for bus idle.



## Command Register

| BIT       | SYMBOL                    | NAME                    | Reset Value | VALUE                           | FUNCTION                                                            |
|-----------|---------------------------|-------------------------|-------------|---------------------------------|---------------------------------------------------------------------|
| CMD.7     |                           | Reserved                | 0           | 0                               | Reserved                                                            |
| CMD.6     |                           | Reserved                | 0           | 0                               | Reserved (Note 1)                                                   |
| CMD 5 OFR | OFR                       | Overload Frame          | 0           | 1                               | Request transmitting overload frame (Note 2)                        |
|           | -                         | Request                 |             | 0                               | No action                                                           |
| CMD.4 SRR | SRR                       | Self Receive<br>Request | 0           | 1                               | A message shall be transmitted and received simultaneously (Note 3) |
|           | _                         |                         |             | 0                               | No action                                                           |
| CMD.3 CDO | 000                       | Clear Data Overrun      | 0           | 1                               | Clear data overrun status bit (Note 4)                              |
|           | CDO                       |                         |             | 0                               | No action                                                           |
| CMD.2 RRB | Release Receive<br>Buffer | 0                       | 1           | Release receive buffer (Note 5) |                                                                     |
|           |                           |                         | 0           | No action                       |                                                                     |
| CMD.1     | AT                        | Abort Transmitting      | 0           | 1                               | Abort transmitting (Note 6)                                         |
|           |                           |                         |             | 0                               | No action                                                           |
|           | тр                        | Tropomit Poquest        | 0           | 1                               | Transmit request (Note 7)                                           |
|           | IK                        | Transmit Request        | 0           | 0                               | No action                                                           |

## Notes:

1. This is reserved bit and must always be kept in zero.

- 2. When the bit is set, the start of an Overload frame is only allowed to be started at the first bit time of an expected INTERMISSION.
- 3. Upon self reception request a message is transmitted and simultaneously received if the acceptance filter is set to the corresponding identifier. A receive and a transmit interrupt will indicate correct self reception (see also Self Test Mode in MODE register).
- 4. This command bit is used to clear the data overrun condition indicated by the data overrun status bit.
- 5. After reading the contents of the receive buffer, the CPU can release this memory space in the RXFIFO by setting the Release Receive Buffer bit to logic 1. This may result in another message becoming immediately available within the receive buffer. If there is no other message available, the receive interrupt bit is reset.
- 6. The abort transmission bit is used when the CPU requires the suspension of the previously requested transmission, e.g. to transmit a more urgent message before. A transmission already in progress is not stopped. In order to see if the original message has been either transmitted successfully or aborted, the transmission complete status bit should be checked. This should be done after the transmit buffer status bit has been set to logic 1 or a transmit interrupt has been generated.
- 7. We can transmit a message in the transmit buffer by setting this bit to logic 1. If the transmission request was set to logic 1 in the previous command, it should be cancelled by setting the transmission request bit to logic 0. The requested transmission may be cancelled by setting the abort transmission bit to logic 1.



## Status Register

| Status Register (STR) XFR ADDR: 0B02H |        |                                       |             |       |                                                                                                                                           |
|---------------------------------------|--------|---------------------------------------|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------|
| BIT                                   | SYMBOL | NAME                                  | Reset Value | VALUE | FUNCTION                                                                                                                                  |
|                                       | BS     | Bus Status<br>(Note 1)                | 0           | 1     | Bus-off: the CAN controller is not involved in bus activities.                                                                            |
| 517.7                                 | 60     |                                       | 0           | 0     | Bus-on: the CAN controller is involved in bus activities.                                                                                 |
|                                       | ES     | Error Status<br>(Note 2)              | 0           | 1     | Error: at least one of the error counters has<br>reached or exceeded the CPU warning limit<br>defined by the Error Warning Limit Register |
|                                       |        |                                       |             | 0     | Ok: both error counters are below the warning limit.                                                                                      |
| STA.5                                 | TS     | Transmit Status<br>(Note 3)           | 0           | 1     | Transmit: the CAN controller is transmitting a message                                                                                    |
|                                       |        |                                       |             | 0     | Idle                                                                                                                                      |
|                                       | RS     | Receive Status<br>(Note 3)            | 0           | 1     | Receive: the CAN controller is receiving a message.                                                                                       |
|                                       |        |                                       |             | 0     | Idle                                                                                                                                      |
| STA.3 TO                              | TCS    | Transmit Complete<br>Status (Note 4)  | 1           | 1     | Complete: last requested transmission has been successfully completely                                                                    |
|                                       | 100    |                                       |             | 0     | Incomplete: previously requested<br>transmission is not yet completed                                                                     |
|                                       |        |                                       |             | 1     | Released: the CPU may write a message into the transmit buffer                                                                            |
| STA.2                                 | TBS    | Transmit Buffer<br>Status (Note 5)    | 1           | 0     | Locked: the CPU cannot access the transmit buffer ; a message is either waiting for transmission or in the progress of being transmitted. |
| STA.1                                 | DOS    | Data Overrun<br>Status (Note 6)       | 0           | 1     | Overrun: a message was lost because<br>there was not enough space for that<br>message in the RXFIFO                                       |
|                                       |        |                                       |             | 0     | Full: one or more complete messages are available in the RXFIFO                                                                           |
| STA.0                                 | RBS    | RBS Receive Buffer<br>Status (Note 7) | 0           | 1     | Full: one or more complete message are available in the RXFIFO                                                                            |
|                                       |        |                                       | -           | 0     | Empty: no message is available                                                                                                            |



Notes:

- 1. When the transmit error counter exceeds the limit of 255, the bus status bit is set to logic 1 CAN controller will wait the minimum protocol-defined time (128 occurrences of the bus-free signal) for bus on again or when controller not in Bus Auto Recovery, CPU can write a value less than 255 into the transmit error counter to make the bus on. Then the bus status bit is cleared (bus-on), the error status bit is set to logic 0 (ok), an error warning interrupt is generated, if enabled.
- 2. Errors detected during reception or transmission will affect the error counters according to the CAN 2.0B protocol specification. The error status bit is set when at least one of the error counters has reached or exceeded the CPU warning limit (EWLR). An error warning interrupt is generated, if enabled. The default value of EWLR after hardware reset is 96.
- 3. If both the receive status and the transmit status bits are logic 0 (idle) the CAN-bus is idle. If at least one bit is set, the controller is waiting to become idle again.
- 4. The transmission complete status bit is set to logic 0 (incomplete) whenever the transmission request bit or the self reception request bit is set to logic 1. The transmission complete status bit will remain at logic 0 until a message is transmitted successfully.
- 5. 5. If the CPU tries to write to the transmit buffer when the transmit buffer status bit is logic 0 (locked), the written byte will not be accepted and will be lost without this being indicated.
- 6. 6. When a message that is to be received has passed the acceptance filter successfully, the CAN controller needs space in the RXFIFO to store the message information and for each data byte, which has been received. If there is not enough space to store the message, that message is dropped and the data overrun condition is indicated to the CPU at the moment this message becomes invalid. If this message is not completed successfully (e.g. due to an error), no overrun condition is indicated.
- 7. 7. After reading all messages within the RXFIFO and releasing their memory space with the command release receive buffer this bit is cleared.



## Interrupt Register

Interrupt Register (IR) XFR ADDR: 0B03H

| BIT     | SYMBOL   | NAME                                   | Reset Value | VALUE | FUNCTION                                                                                                                                                                                                                                                                                                                    |
|---------|----------|----------------------------------------|-------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IR.7    | BEI      | Bus Error Interrupt<br>(Note 1)        | 0           | 1     | Set: this bit is set when the CAN controller<br>detects an error on the CAN-bus and the<br>BEIE bit is set within the interrupt enable<br>register                                                                                                                                                                          |
|         |          |                                        |             | 0     | Reset                                                                                                                                                                                                                                                                                                                       |
| IR.6    | ALI      | Arbitration Lost<br>Interrupt (Note 1) | 0           | 1     | Set: this bit is set when the CAN controller<br>lost the arbitration and become a receiver<br>and the ALIE bit is set to logic 1 within<br>the Interrupt<br>Enable register.                                                                                                                                                |
|         |          |                                        |             | 0     | Reset                                                                                                                                                                                                                                                                                                                       |
| IR.5    | IR.5 EPI | Error Passive<br>Interrupt (Note 1)    | 0           | 1     | Set: this bit is set whenever the CAN controller has reached the error passive status (at least one error counter exceeds the protocol-defined level of 127) or if the CAN controller is in the error passive status and enters the error active status again and the EPIE bit is set within the interrupt enable register. |
|         |          |                                        |             | 0     | Reset                                                                                                                                                                                                                                                                                                                       |
| IR.4    | Reserved | Reserved                               | 0           | 0     | Reserved                                                                                                                                                                                                                                                                                                                    |
| IR.3    | DOI      | Data Overrun<br>Interrupt (Note 1)     | 0           | 1     | Set: this bit is set on a '0-to-1' transition of<br>the data overrun status bit and the DOIE bit<br>is set within the interrupt enable register                                                                                                                                                                             |
|         |          |                                        |             | 0     | Reset                                                                                                                                                                                                                                                                                                                       |
| IR.2 EI | EI       | Error Warning<br>Interrupt (Note 1)    | 0           | 1     | Set: this bit is set on every change (set and<br>clear) of either the error status or bus<br>status bits and the EIE bit is set within the<br>interrupt enable register                                                                                                                                                     |
|         |          |                                        |             | 0     | Reset                                                                                                                                                                                                                                                                                                                       |
| IR.1    | TI       | Transmit Interrupt<br>(Note 1)         | 0           | 1     | Set: this bit is set whenever the transmit<br>buffer status changes from '0-to-1'<br>(released) and the TIE bit is set within the<br>interrupt enable register.                                                                                                                                                             |
|         |          |                                        |             | 0     | Reset                                                                                                                                                                                                                                                                                                                       |
| IR.0    | RI       | RI Receive Interrupt<br>(Note 1,2)     | 0           | 1     | Set: this bit is set while the receive FIFO is<br>not empty and the RIE bit is set within the<br>interrupt enable register.                                                                                                                                                                                                 |
|         |          |                                        |             | 0     | Reset                                                                                                                                                                                                                                                                                                                       |

Notes:

- 1. The interrupt register allows the identification of an interrupt source. When one or more bits of this register are set to logic 1, a CAN interrupt will be indicated to the CPU. After this register is read by the CPU all bits are cleared except for the Receive Interrupt bit. The interrupt register appears to the CPU as a read only memory.
- 2. The behavior of this bit is equivalent to that of the receive buffer status bit if the corresponding interrupt enable bit (RIE) is set. So the receive interrupt bit is not cleared upon a read access to the interrupt register. Giving the command 'Release Receive Buffer' will clear RI temporarily. If there is another message available within the FIFO after the release command, RI is set again. Otherwise RI remains cleared.


#### Interrupt Enable Register

| Interrupt F | Register Inte | errupt Enable Regist                         | er (IER)    | XFR ADDR : | : 0B04H                                                                                                                                                                                                            |
|-------------|---------------|----------------------------------------------|-------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BIT         | SYMBOL        | NAME                                         | Reset Value | VALUE      | FUNCTION                                                                                                                                                                                                           |
| IER.7       | BEIE          | Bus Error Interrupt                          | 0           | 1          | Enabled: if a bus error has been detected,<br>the CAN controller requests the respective<br>interrupt.                                                                                                             |
|             |               |                                              |             | 0          | Disabled                                                                                                                                                                                                           |
| IER.6       | ALIE          | Arbitration Lost<br>Interrupt Enable         | 0           | 1          | Enabled: if the CAN controller has lost arbitration, the respective interrupt is requested.                                                                                                                        |
|             |               | (Note 1)                                     |             | 0          | Disabled                                                                                                                                                                                                           |
| IER.5       | EPIE          | Error Passive<br>Interrupt Enable            | 0           | 1          | Enabled: if the error status of the CAN controller changes from error active to error passive or vice versa, the respective interrupt is requested.                                                                |
|             |               |                                              |             | 0          | Disabled                                                                                                                                                                                                           |
| IER.4       | Reserved      | Reserved                                     | 0           | 0          | Reserved                                                                                                                                                                                                           |
| IER.3       | DOIE          | Data Overrun<br>Interrupt Enable<br>(Note 1) | 0           | 1          | Enabled: if the data overrun status bit is set (see status register), the CAN controller requests the respective interrupt.                                                                                        |
|             |               |                                              |             | 0          | Disabled                                                                                                                                                                                                           |
| IER.2       | EIE           | Error Warning<br>Interrupt Enable            | 0           | 1          | Enabled: if the error or bus status changes, the CAN controller requests the respective interrupt.                                                                                                                 |
|             |               | (Note 1)                                     |             | 0          | Disabled                                                                                                                                                                                                           |
| IER.1       | TIE           | Transmit Interrupt<br>Enable (Note 1)        | 0           | 1          | Enabled: when a message has been<br>successfully transmitted or the transmit<br>buffer is accessible again (e. g after an<br>abort transmission command), the CAN<br>controller requests the respective interrupt. |
|             |               |                                              |             | 0          | Disabled                                                                                                                                                                                                           |
| IER.0       | RIE           | Receive Interrupt                            | 0           | 1          | Enabled: when the receive buffer status is 'full', the CAN controller requests the respective interrupt.                                                                                                           |
|             |               | Enable (Note 1)                              |             | 0          | Disabled                                                                                                                                                                                                           |

Notes:

1. The interrupt enable register allows indicating different types of interrupt source. The register appears to the CPU as a read/write memory.



#### **Bus Timing Register**

#### BTR0 (r/w) : (XFR 0X0B09) Bus Timing Register 0 (default 0X00)

| BIT7     | BIT6     | BIT5     | BIT4     | BIT3     | BIT2     | BIT1     | BIT0     |
|----------|----------|----------|----------|----------|----------|----------|----------|
| SJW.1    | SJW.0    | BRP.5    | BRP.4    | BRP.3    | BRP.2    | BRP.1    | BRP.0    |
| (Note 1) | (Note 1) | (Note 2) |

Notes:

1. To compensate for phase shifts between clock oscillators of different bus controllers, any bus controller must re-synchronize on any relevant signal edge of the current transmission. The synchronization jump width defines the maximum number of clock cycles a bit period may be shortened or lengthened by one re-synchronization:

 $t_{siw} = 2 \times SJW.1 + SJW.0 + 1$ 

2. The period of the CAN system clock  $t_{SCL}$  is programmable and determines the individual bit timing. The CAN system clock is calculated using the following equation:

$$t_{scl} = 2 \times t_{clk} \times (32 \times BRP.5 + 16 \times BRP.4 + 8 \times BRP.3 + 4 \times BRP.2 + 2 \times BRP.1 + BRP.0 + 1)$$
 Where

 $t_{\scriptscriptstyle clk}$  = time period of the XTAL frequency =  $f_{\scriptscriptstyle XTAL}$ 

#### BTR1 (r/w) : (XFR 0X0B0A) Bus Timing Register 1 (default 0X67)

| BIT7     | BIT6     | BIT5     | BIT4     | BIT3     | BIT2     | BIT1     | BIT0     |
|----------|----------|----------|----------|----------|----------|----------|----------|
| SAM      | TSEG2.2  | TSEG2.1  | TSEG2.0  | TSEG1.3  | TSEG1.2  | TSEG1.1  | TSEG1.0  |
| (Note 1) | (Note 2) |

Notes:

- 1. When SAM bit is logic 1, the bus is triple-sampled: the bus is sampled three times, recommended for low/medium speed bus (class A and class B) where it is beneficial for filtering spikes on the bus line. When SAM bit is logic 0, the bus is single-sampled: the bus is sampled once, recommended for high speed buses (SAE class C).
- 2. TSEG1 and TSEG2 determine the number of clock cycles per bit period and the location of the sample point, where:

 $t_{SYNCSEG} = 1 \times t_{scl}$ 

 $t_{SEG1} = t_{scl} \times (8 \times TSEG1.3 + 4 \times TSEG1.2 + 2 \times TSEG1.1 + TSEG1.0 + 1)$ 

$$t_{\text{resc}} = t_{\text{resc}} \times (4 \times TSEG2.2 + 2 \times TSEG2.1 + TSEG2.0 + 1)$$





#### Filter Enable Register

#### Filter Enable Register 3 (FTE3) XFR ADDR: 0B0BH (Note 1)

| BIT    | SYMBOL                 | NAME              | Reset Value      | VALUE            | FUNCTION           |   |                    |
|--------|------------------------|-------------------|------------------|------------------|--------------------|---|--------------------|
|        | ETE21                  | Filter 21 openio  | 1                | 1                | Filter 31 enabled  |   |                    |
| FIE3.7 | FIESI                  | Filler 51 enable  | I                | 0                | Filter 31 disabled |   |                    |
| ETE2 6 | ETE20                  | Filter 20 opeble  | 1                | 1                | Filter 30 enabled  |   |                    |
| FIE3.0 | FIE30                  | Filler 50 enable  | I                | 0                | Filter 30 disabled |   |                    |
|        | ETE 20                 | Filter 20 epoble  | 1                | 1                | Filter 29 enabled  |   |                    |
| FIE3.5 | FIE29                  | Filler 29 enable  | I                | 0                | Filter 29 disabled |   |                    |
|        |                        | Filter 00 av abla |                  | 1                | Filter 28 enabled  |   |                    |
| F1E3.4 | FIE20                  | Filler 26 enable  | I                | 0                | Filter 28 disabled |   |                    |
|        | CTE 07                 | Filter 27 epoble  | 1                | 1                | Filter 27 enabled  |   |                    |
| FIE3.5 | FIEZ/                  | Filler 27 enable  | I                | 0                | Filter 27 disabled |   |                    |
|        | FTF26                  | Filter 26 epoble  | 1                | 1                | Filter 26 enabled  |   |                    |
| FIE3.2 | FIE20                  | Filter 26 enable  | Filter 26 enable | Filler 26 enable | 1                  | 0 | Filter 26 disabled |
|        | FTFOF                  | Filter 25 enchie  | 4                | 1                | Filter 25 enabled  |   |                    |
| FIE3.1 | FIE20                  | Filler 25 enable  | I                | 0                | Filter 25 disabled |   |                    |
|        | ETE 24                 | Filter 24 epokla  | 1                | 1                | Filter 24 enabled  |   |                    |
| FIE3.0 | FTE24 Filter 24 enable | Filler 24 enable  | 1                | 0                | Filter 24 disabled |   |                    |

Note:

1. This register is write able only in Silent mode. In Operating mode, the register is write-only.

#### Filter Enable Register 2 (FTE2) XFR ADDR: 0B0CH (Note 1)

| BIT    | SYMBOL                | NAME             | Reset Value | VALUE | FUNCTION           |
|--------|-----------------------|------------------|-------------|-------|--------------------|
|        | ETE 22                | Filtor 22 opable | 1           | 1     | Filter 23 enabled  |
|        | FIE23                 | Filler 23 enable | Ι           | 0     | Filter 23 disabled |
| ETE2 6 | ETEOD                 | Filter 22 openio | 1           | 1     | Filter 22 enabled  |
| FIE2.0 | FIEZZ                 | Filler 22 enable | Ι           | 0     | Filter 22 disabled |
| ETE2 5 |                       | Filter 21 openio | 1           | 1     | Filter 21 enabled  |
| FIE2.5 | FIEZI                 | Filler 21 enable |             | 0     | Filter 21 disabled |
| ETEQ 4 | ETE 20                | Filter 20 openio | 1           | 1     | Filter 20 enabled  |
| F1C2.4 | FIEZU                 | Fliter 20 enable | I           | 0     | Filter 20 disabled |
| ETEO 2 | ETE10                 | Filter 10 openio | 1           | 1     | Filter 19 enabled  |
| F122.3 | IE2.3 FIE19 Filter 19 | Filler 19 enable | I           | 0     | Filter 19 disabled |



| BIT    | SYMBOL | NAME             | Reset Value | VALUE | FUNCTION           |
|--------|--------|------------------|-------------|-------|--------------------|
| ETE2 2 | ETE10  | Filtor 18 opable | 1           | 1     | Filter 18 enabled  |
| FIEZ.Z | FIEIO  | Filler to enable | I           | 0     | Filter 18 disabled |
|        |        | Filter 17 epoble |             | 1     | Filter 17 enabled  |
| FIEZ.I | FIEI/  | Filler 17 enable | I           | 0     | Filter 17 disabled |
|        |        | Filter 16 enchle |             | 1     | Filter 16 enabled  |
| FIE2.0 | FIEIO  | Filler to enable |             | 0     | Filter 16 disabled |

Note:

1. This register is write able only in Silent mode. In Operating mode, the register is write-only.

| BIT    | SYMBOL                     | NAME                  | Reset Value            | VALUE              | FUNCTION           |                    |                   |
|--------|----------------------------|-----------------------|------------------------|--------------------|--------------------|--------------------|-------------------|
|        | ETE15                      | Filter 15 enable      | 1                      | 1                  | Filter 15 enabled  |                    |                   |
| 1161.7 | TIEIS                      |                       | I                      | 0                  | Filter 15 disabled |                    |                   |
| ETE1 6 |                            | Filtor 14 opphio      | 1                      | 1                  | Filter 14 enabled  |                    |                   |
| FIEI.0 | F1E14                      | Filler 14 enable      | Ι                      | 0                  | Filter 14 disabled |                    |                   |
|        | ETE12                      | Filter 12 opoblo      | 1                      | 1                  | Filter 13 enabled  |                    |                   |
| FIEI.3 | FIEIS                      | Filter 13 enable      | FIE13 Filter 13 enable | I                  | 0                  | Filter 13 disabled |                   |
|        | ETE12                      | TE12 Filter 12 enable | 1                      | 1                  | Filter 12 enabled  |                    |                   |
| F1C1.4 | FIEIZ                      |                       | I                      | 0                  | Filter 12 disabled |                    |                   |
|        |                            | Filter 11 opoblo      | 1                      | 1                  | Filter 11 enabled  |                    |                   |
| FIEI.3 | FIEII                      |                       | Ι                      | 0                  | Filter 11 disabled |                    |                   |
|        |                            |                       |                        | Filter 10 enable   | 1                  | 1                  | Filter 10 enabled |
| FIEI.2 | FIEIU                      | Filler TO enable      | 1                      | 0                  | Filter 10 disabled |                    |                   |
|        |                            | Filter 00 epoble      |                        | 1                  | Filter 09 enabled  |                    |                   |
| rıcı.1 | FIES                       |                       | I                      | 0                  | Filter 09 disabled |                    |                   |
| ETE1 0 | ETEO                       | Filter 08 apph/s      |                        | 1                  | Filter 08 enabled  |                    |                   |
|        | E1.0 FTE8 Filter 08 enable | I                     | 0                      | Filter 08 disabled |                    |                    |                   |

Filter Enable Register 1 (FTE1) XFR ADDR: 0B0DH (Note 1)

Note:

1. This register is write able only in Silent mode. In Operating mode, the register is write-only.

| BIT    | SYMBOL | NAME                  | Reset Value | VALUE | FUNCTION           |
|--------|--------|-----------------------|-------------|-------|--------------------|
|        | ETE7   | FTE7 Filter 07 enable | 1 -         | 1     | Filter 07 enabled  |
| FIEU.7 |        |                       |             | 0     | Filter 07 disabled |
| FTE0.6 | FTE6   | Filter 06 enable      | 1           | 1     | Filter 06 enabled  |

#### Filter Enable Register 0 (FTE0) XFR ADDR: 0B0EH (Note 1)



|        |                         |                  |       | 0                  | Filter 06 disabled |
|--------|-------------------------|------------------|-------|--------------------|--------------------|
|        | ETE5                    | Filter 05 apple  | 1     | 1                  | Filter 05 enabled  |
| FIE0.5 | FIES                    | Filler 05 enable | I     | 0                  | Filter 05 disabled |
| ETEO 4 | ETEA                    | Filter 04 opphie | 1     | 1                  | Filter 04 enabled  |
| F1E0.4 | F1 <b>E</b> 4           | Filler 04 enable | I     | 0                  | Filter 04 disabled |
| ETEO 2 | ETE2                    | Filter 03 enable | ble 1 | 1                  | Filter 03 enabled  |
| FIEU.3 | FIES                    |                  |       | 0                  | Filter 03 disabled |
| ETEO 2 | ETEO                    | Filter 02 openio | 1     | 1                  | Filter 02 enabled  |
| FIEU.2 | FIEZ                    | Filler 02 enable | I     | 0                  | Filter 02 disabled |
| ETEO 1 | CTC1                    | Filter 01 openio | 1     | 1                  | Filter 01 enabled  |
| FIEU.I | FIEI                    | Filter 01 enable | I     | 0                  | Filter 01 disabled |
| ETEO O | ETEO                    | Filter 00 opphie | 1     | 1                  | Filter 00 enabled  |
| F120.0 | D FIE0 Filter 00 enable | I                | 0     | Filter 00 disabled |                    |

Note:

1. This register is write able only in Silent mode. In Operating mode, the register is write-only



#### Arbitration Lost Capture Register

| BIT                     | SYMBOL                     | NAME                                         | VALUE        | FUNCTION                                        |  |  |  |
|-------------------------|----------------------------|----------------------------------------------|--------------|-------------------------------------------------|--|--|--|
| ALC.7~ALC.5             | -                          | Reserved                                     |              |                                                 |  |  |  |
| ALC.4                   | BITNO4                     | Bit number 4                                 |              |                                                 |  |  |  |
| ALC.3                   | BITNO3                     | Bit number 3                                 | For value ar | nd function see "Function of bits 4 to 0 of the |  |  |  |
| ALC.2                   | BITNO2                     | Bit number 2                                 | Arb          | itration Lost Capture register" Table           |  |  |  |
| ALC.1                   | BITNO1                     | Bit number 1                                 |              |                                                 |  |  |  |
| ALC.0                   | BITNO0                     | Bit number 0                                 |              |                                                 |  |  |  |
| ALC.2<br>ALC.1<br>ALC.0 | BITNO2<br>BITNO1<br>BITNO0 | Bit number 2<br>Bit number 1<br>Bit number 0 | Arb          | itration Lost Capture register" Table           |  |  |  |

Arbitration Lost Capture Register (ALC) XFR ADDR: 0B10H

This register contains information about the bit position of losing arbitration. The Arbitration Lost Capture register appears to the CPU as a read only memory. Reserved bits are read as logic 0.

On arbitration lost, the corresponding arbitration lost interrupt is forced, if enabled. At the same time, the current bit position of the bit stream processor is captured into the Arbitration Lost Capture register. The content within this register is fixed until the users software has read out its contents once. The capture mechanism is then activated again.

The corresponding interrupt flag located in the interrupt register is cleared during the read access to the interrupt register. A new arbitration lost interrupt is not possible until the arbitration lost capture register is read out once.









#### Function of bits 4 to 0 of the Arbitration Lost Capture register

|       |       | Bits  |       |       | Decimal | Eurotion                             |
|-------|-------|-------|-------|-------|---------|--------------------------------------|
| ALC.4 | ALC.3 | ALC.2 | ALC.1 | ALC.0 | Value   | Function                             |
| 0     | 0     | 0     | 0     | 0     | 0       | Arbitration lost in bit ID28         |
| 0     | 0     | 0     | 0     | 1     | 1       | Arbitration lost in bit ID27         |
| 0     | 0     | 0     | 1     | 0     | 2       | Arbitration lost in bit ID26         |
| 0     | 0     | 0     | 1     | 1     | 3       | Arbitration lost in bit ID25         |
| 0     | 0     | 1     | 0     | 0     | 4       | Arbitration lost in bit ID24         |
| 0     | 0     | 1     | 0     | 1     | 5       | Arbitration lost in bit ID23         |
| 0     | 0     | 1     | 1     | 0     | 6       | Arbitration lost in bit ID22         |
| 0     | 0     | 1     | 1     | 1     | 7       | Arbitration lost in bit ID21         |
| 0     | 1     | 0     | 0     | 0     | 8       | Arbitration lost in bit ID20         |
| 0     | 1     | 0     | 0     | 1     | 9       | Arbitration lost in bit ID19         |
| 0     | 1     | 0     | 1     | 0     | 10      | Arbitration lost in bit ID18         |
| 0     | 1     | 0     | 1     | 1     | 11      | Arbitration lost in bit SRTR(Note 1) |
| 0     | 1     | 1     | 0     | 0     | 12      | Arbitration lost in bit IDE          |
| 0     | 1     | 1     | 0     | 1     | 13      | Arbitration lost in bit ID17(Note 2) |
| 0     | 1     | 1     | 1     | 0     | 14      | Arbitration lost in bit ID16(Note 2) |
| 0     | 1     | 1     | 1     | 1     | 15      | Arbitration lost in bit ID15(Note 2) |
| 1     | 0     | 0     | 0     | 0     | 16      | Arbitration lost in bit ID14(Note 2) |
| 1     | 0     | 0     | 0     | 1     | 17      | Arbitration lost in bit ID13(Note 2) |
| 1     | 0     | 0     | 1     | 0     | 18      | Arbitration lost in bit ID12(Note 2) |
| 1     | 0     | 0     | 1     | 1     | 19      | Arbitration lost in bit ID11(Note 2) |
| 1     | 0     | 1     | 0     | 0     | 20      | Arbitration lost in bit ID10(Note 2) |
| 1     | 0     | 1     | 0     | 1     | 21      | Arbitration lost in bit ID9(Note 2)  |
| 1     | 0     | 1     | 1     | 0     | 22      | Arbitration lost in bit ID8(Note 2)  |
| 1     | 0     | 1     | 1     | 1     | 23      | Arbitration lost in bit ID7(Note 2)  |
| 1     | 1     | 0     | 0     | 0     | 24      | Arbitration lost in bit ID6(Note 2)  |
| 1     | 1     | 0     | 0     | 1     | 25      | Arbitration lost in bit ID5(Note 2)  |
| 1     | 1     | 0     | 1     | 0     | 26      | Arbitration lost in bit ID4(Note 2)  |
| 1     | 1     | 0     | 1     | 1     | 27      | Arbitration lost in bit ID3(Note 2)  |
| 1     | 1     | 1     | 0     | 0     | 28      | Arbitration lost in bit ID2(Note 2)  |
| 1     | 1     | 1     | 0     | 1     | 29      | Arbitration lost in bit ID1(Note 2)  |
| 1     | 1     | 1     | 1     | 0     | 30      | Arbitration lost in bit ID0(Note 2)  |
| 1     | 1     | 1     | 1     | 1     | 31      | Arbitration lost in bit RTR(Note 2)  |

Notes:

1. Bit RTR for standard frame messages.

2. Extended frame messages only.



#### Error Code Capture Register

| BIT   | SYMBOL | NAME         | VALUE | FUNCTION                               |
|-------|--------|--------------|-------|----------------------------------------|
| ECC.7 | ERRC1  | Error code 1 | -     | Note 2                                 |
| ECC.6 | ERRC0  | Error code 0 | -     | Note 2                                 |
| ECC F | פוס    | Direction    | 1     | Rx: error occurred during reception    |
| ECC.5 | DIK    | Direction    | 0     | Tx: error occurred during transmission |
| ECC.4 | SEG4   | Segment 4    | -     |                                        |
| ECC.3 | SEG3   | Segment 3    | -     |                                        |
| ECC.2 | SEG2   | Segment 2    | -     | Note 3                                 |
| ECC.1 | SEG1   | Segment 1    | -     |                                        |
| ECC.0 | SEG0   | Segment 0    | -     |                                        |

Notes:

- 1. If a bus error occurs, the corresponding bus error interrupt is always forced if enabled. At the same time, the current position of the bit stream processor is captured into the Error Code Capture register. The content within this register is fixed until the users software has read out its content once. The capture mechanism is then activated again. The corresponding interrupt flag located in the interrupt register is cleared during the read access to the interrupt register. A new bus error interrupt is not possible until the capture register is read out once.
- 2. For bit interpretation of bits ECC.7 and ECC.6 see table below.
- 3. For bit interpretation of bits ECC.4 to ECC.0 see table below.

#### Bit interpretation of bits ECC.7 and ECC.6

| ECC.7 | ECC.6 | FUNCTION            |
|-------|-------|---------------------|
| 0     | 0     | Bit error           |
| 0     | 1     | Form error          |
| 1     | 0     | Stuff error         |
| 1     | 1     | Other type of error |

#### Bit interpretation of bits ECC.4 to ECC.0

| ECC.4 | ECC.3 | ECC.2 | ECC.1 | ECC.0 | Function       |
|-------|-------|-------|-------|-------|----------------|
| 0     | 0     | 0     | 1     | 1     | Start of frame |
| 0     | 0     | 0     | 1     | 0     | ID28 to ID21   |
| 0     | 0     | 1     | 1     | 0     | ID20 toID18    |
| 0     | 0     | 1     | 0     | 0     | Bit SRTR       |
| 0     | 0     | 1     | 0     | 1     | Bit IDE        |
| 0     | 0     | 1     | 1     | 1     | ID17 to ID13   |
| 0     | 1     | 1     | 1     | 1     | ID12 to ID5    |
| 0     | 1     | 1     | 1     | 0     | ID4 to ID0     |

#### Page 117 of 133

# CS8961 PRELIMINARY

| ECC.4 | ECC.3 | ECC.2 | ECC.1 | ECC.0 | Function                       |
|-------|-------|-------|-------|-------|--------------------------------|
| 0     | 1     | 1     | 0     | 0     | Bit RTR                        |
| 0     | 1     | 1     | 0     | 1     | Reserved bit 1                 |
| 0     | 1     | 0     | 0     | 1     | Reserved bit 0                 |
| 0     | 1     | 0     | 1     | 1     | Data length code               |
| 0     | 1     | 0     | 1     | 0     | Data field                     |
| 0     | 1     | 0     | 0     | 0     | CRC sequence                   |
| 1     | 1     | 0     | 0     | 0     | CRC delimiter                  |
| 1     | 1     | 0     | 0     | 1     | Acknowledge slot               |
| 1     | 1     | 0     | 1     | 1     | Acknowledge delimiter          |
| 1     | 1     | 0     | 1     | 0     | End of frame                   |
| 1     | 0     | 0     | 1     | 0     | Intermission                   |
| 1     | 0     | 0     | 0     | 1     | Active error flag              |
| 1     | 0     | 1     | 1     | 0     | Passive error flag             |
| 1     | 0     | 0     | 1     | 1     | Tolerate dominant bits(Note 1) |
| 1     | 0     | 1     | 1     | 1     | Error delimiter                |
| 1     | 1     | 1     | 0     | 0     | Overload flag                  |

Note:

1. Any node tolerates up to 7 consecutive 'dominant' bits after send Active Error Flag, Passive Error Flag or Overload Flag.

#### Error Warning Limit Register

#### Error Warning Limit Register (EWLR) XFR ADDR: 0B12H (default 0X60) (Note 1)

| BIT7   | BIT6   | BIT5   | BIT4   | BIT3   | BIT2   | BIT1   | BIT0   |
|--------|--------|--------|--------|--------|--------|--------|--------|
| EWLR.7 | EWLR.6 | EWLR.5 | EWLR.4 | EWLR.3 | EWLR.2 | EWLR.1 | EWLR.0 |

Note:

1. The Error Warning Limit register can be defined within this register, the default value (after hardware reset) is 96 (Decimal). In Silent mode, this register appears to the CPU as a read/write memory. In Operating mode it is read only. The content change of the EWLR is only possible, if the Silent mode was entered previously. An error status change (see status register) and an error warning interrupt forced by the new register content will not occur until the Silent mode is quit again.





#### Receive Error Counter Register

| Receive Error Counter Register (RXERR) |         |         | XFR A   | DDR: 0B13H (N | Note 1) |         |         |
|----------------------------------------|---------|---------|---------|---------------|---------|---------|---------|
| BIT7                                   | BIT6    | BIT5    | BIT4    | BIT3          | BIT2    | BIT1    | BIT0    |
| RXERR.7                                | RXERR.6 | RXERR.5 | RXERR.4 | RXERR.3       | RXERR.2 | RXERR.1 | RXERR.0 |

Note:

1. The Receive Error Counter register reflects the current value of the receive error counter. After hardware reset, this register is initialized to logic 0. In operating mode this register appears to the CPU as a read only memory. A write access to this register is possible only in Silent mode. If a bus-off event occurs, the receive error counter is initialized to logic 0. The time bus-off is valid, writing to this register has no effect. Note that a CPU-forced content change of the receive error counter is only possible, if the Silent mode was entered previously. An error status change (see status register), an error warning or an error passive interrupt forced by the new register content will not occur, until the Silent mode is cancelled again.

#### Transmit Error Counter Register

#### Transmit Error Counter Register (TXERR) XFR ADDR: 0B14H (Note 1)

| BIT7    | BIT6    | BIT5    | BIT4    | BIT3    | BIT2    | BIT1    | BIT0    |
|---------|---------|---------|---------|---------|---------|---------|---------|
| TXERR.7 | TXERR.6 | TXERR.5 | TXERR.4 | TXERR.3 | TXERR.2 | TXERR.1 | TXERR.0 |

Note:

 The Transmit Error Counter register reflects the current value of the transmit error counter. In operating mode this register appears to the CPU as a read only memory. A write access to this register is possible only in Silent mode. After hardware reset, this register is initialized to logic 0. If a bus-off event occurs, the transmit error counter is initialized to 128.

#### Received Frame Counter Register

#### Received Frame Counter Register (RFCR) XFR ADDR: 0B15H (Note 1)

| BIT7   | BIT6   | BIT5   | BIT4   | BIT3   | BIT2   | BIT1   | BIT0   |
|--------|--------|--------|--------|--------|--------|--------|--------|
| RFCR.7 | RFCR.6 | RFCR.5 | RFCR.4 | RFCR.3 | RFCR.2 | RFCR.1 | RFCR.0 |

Note:

1. When CAN controller enters into Silent mode, the register is cleared. In Operating mode, the register is read only. Value of the register will be added by 1 if a frame is received successfully. The register will counted down when 'Release Receive Buffer 'command bit is set logic 1.

#### Received Frame Information Register

#### Received Frame Information Register (RIFR) XFR ADDR: 0B16H (Note 1)

| BIT7 | BIT6 BIT       |   | BIT4                           | BIT3 | BIT2 | BIT1 | BIT0 |  |
|------|----------------|---|--------------------------------|------|------|------|------|--|
| 0    | RIFR.6 (Note2) | 0 | Receive Filter Number (Note 3) |      |      |      |      |  |

Note:

1. This register is read only.

- 2. RIFR.6 is a reserved bit and shall be zero when read this bit.
- 3. RIFR[4:0] indicates the Receive Filter Number that the received data passed through.



#### Transmit Buffer

CAN Address

The global layout of the transmit buffer is shown in Figure below. One has to distinguish between the Standard Frame Format (SFF) and the Extended Frame Format (EFF) configuration. The transmit buffer allows the definition of one transmit message with up to eight data bytes.

CAN Addr

| B17h | TX Frame Information |
|------|----------------------|
| B18h | TX Identifier 4      |
| B19h | TX Identifier 3      |
| B1Ah | TX Identifier 2      |
| B1Bh | TX Identifier 1      |
| B1Ch | TX Data 1            |
| B1Dh | TX Data 2            |
| B1Eh | TX Data 3            |
| B1Fh | TX Data 4            |
| B20h | TX Data 5            |
| B21h | TX Data 6            |
| B22h | TX Data 7            |
| B23h | TX Data 8            |

Standard Format Frame

Extended Format Frame

| ess | B17h | TX Frame Information |
|-----|------|----------------------|
|     | B18h | TX Identifier 4      |
|     | B19h | TX Identifier 3      |
|     | B1Ah | TX Identifier 2      |
|     | B1Bh | TX Identifier 1      |
|     | B1Ch | TX Data 1            |
|     | B1Dh | TX Data 2            |
|     | B1Eh | TX Data 3            |
|     | B1Fh | TX Data 4            |
|     | B20h | TX Data 5            |
|     | B21h | TX Data 6            |
|     | B22h | TX Data 7            |
|     | B23h | TX Data 8            |
|     |      |                      |

#### Figure-58 Transmit Buffer Layout For Standard And Extended Frame Format Configurations

The transmit buffer layout is subdivided into descriptor and data fields where the first byte of the descriptor field is the frame information byte (frame information). It describes the frame format (SFF or EFF), remote or data frame and the data length. Four identifier bytes for both SFF and EFF messages follow. But only the lower 11 bits in the four identifier bytes are valid for SFF and the upper 21 bits are invalid. For EFF, the lower 29 bits in the four identifier bytes are valid and the upper 3 bits are invalid. The data field contains up to eight data bytes.

The transmit buffer has a length of 13 bytes. Note that a direct access to the transmit buffer RAM is possible using the XFR address from 0X0B17 to 0X0B23.Register mapping 0X0B17 to 0X0B23 should be programmed in operation mode. This RAM area is reserved for the transmit buffer.



#### Transmit Frame Information Register

| Transmit Frame Information Register |  |
|-------------------------------------|--|
| Transmit Trame information register |  |

| BIT     | SYMBOL   | NAME                          | VALUE  | FUNCTION              |  |  |
|---------|----------|-------------------------------|--------|-----------------------|--|--|
|         | FF       | Fromo format                  | 1      | Extended format frame |  |  |
|         | FF       | Frame Ionnat                  | 0      | Standard format frame |  |  |
|         | ртр      | Pomoto framo tronomit request | 1      | Remote frame          |  |  |
|         | RIR      |                               | 0      | Data frame            |  |  |
| TXFIR.5 | Reserved | Reserved                      | 0      | Reserved              |  |  |
| TXFIR.4 | Reserved | Reserved                      | 0      | Reserved              |  |  |
| TXFIR.3 | DLC.3    | Data length code 3            |        |                       |  |  |
| XFIR.2  | DLC.2    | Data length code 2            | Note 1 |                       |  |  |
| TXFIR.1 | DLC.1    | Data length code 1            |        |                       |  |  |
| TXFIR.0 | DLC.0    | Data length code 0            |        |                       |  |  |

Notes:

1. The number of bytes in the data field of a message is coded by the data length code. At the start of a remote frame transmission the data length code is not considered due to the RTR bit being logic 1 (remote). This forces the number of transmitted/received data bytes to be 0. Nevertheless, the data length code must be specified correctly to avoid bus errors, if two CAN controllers start a remote frame transmission with the same identifier simultaneously. The range of the data byte count is 0 to 8 bytes and is coded as follows: DataByteCount=8×DLC.3+4×DLC.2+2×DLC.1+DLC.0

For reasons of compatibility, no data length code >8 should be used. If a value >8 is selected, 8 bytes are transmitted in the data frame with the Data Length Code specified in DLC.

#### Identifier Register

In standard Frame Format (SFF) the identifier consists of 11 bits (ID.28 to ID.18) and in Extended Frame Format (EFF) messages the identifier consists of 29 bits (ID.28 to ID.0). ID.28 is the most significant bit, which is transmitted first on the bus during the arbitration process. The identifier acts as the message's name, used in a receiver for acceptance filtering, and also determines the bus access priority during the arbitration process. The smaller the binary value of the identifier is, the higher the priority is. This is due to the larger number of leading dominant bits during arbitration.

Standard Format Frame Identifier

| TX Identifier | Register 3    | XFR ADD       | DR:0B18H      |               |               |               |               |
|---------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|
| BIT7          | BIT6          | BIT5          | BIT4          | BIT3          | BIT2          | BIT1          | BIT0          |
| X<br>(Note 1) |

#### TX Identifier Register 2 XFR ADDR: 0B19H

| BIT7     | BIT6     | BIT5     | BIT4     | BIT3     | BIT2     | BIT1     | BIT0     |
|----------|----------|----------|----------|----------|----------|----------|----------|
| X        | X        | X        | X        | X        | X        | X        | X        |
| (Note 1) |



| TX Identifier | Register 1    | XFR ADDR: 0B1AH |               |               |                   |                   |                   |
|---------------|---------------|-----------------|---------------|---------------|-------------------|-------------------|-------------------|
| BIT7          | BIT6          | BIT5            | BIT4          | BIT3          | BIT2              | BIT1              | BIT0              |
| X<br>(Note 1) | X<br>(Note 1) | X<br>(Note 1)   | X<br>(Note 1) | X<br>(Note 1) | ID.28<br>(Note 2) | ID.27<br>(Note 2) | ID.26<br>(Note 2) |

#### TX Identifier Register 0 XFR ADDR: 0B1BH

| BIT7     | BIT6     | BIT5     | BIT4     | BIT3     | BIT2     | BIT1     | BIT0     |
|----------|----------|----------|----------|----------|----------|----------|----------|
| ID.25    | ID.24    | ID.23    | ID.22    | ID.21    | ID.20    | ID.19    | ID.18    |
| (Note 1) |

Note:

1. ID.X means identifier bit X

Extended Format Frame Identifier

#### TX Identifier Register XFR ADDR: 0B18H

| BIT7     | BIT6     | BIT5     | BIT4     | BIT3     | BIT2     | BIT1     | BIT0     |
|----------|----------|----------|----------|----------|----------|----------|----------|
| X        | X        | X        | ID.28    | ID.27    | ID.26    | ID.25    | ID.24    |
| (Note 1) | (Note 1) | (Note 1) | (Note 2) |

Notes:

1. Don't care

2. ID.X means identifier bit X

# TX Identifier Register 2 XFR ADDR: 0B19H BIT7 BIT6 BIT5 BIT4 BIT3

| BIT7     | BIT6     | BIT5     | BIT4     | BIT3     | BIT2     | BIT1     | BITO     |
|----------|----------|----------|----------|----------|----------|----------|----------|
| ID.23    | ID.22    | ID.21    | ID.20    | ID.19    | ID.18    | ID.17    | ID.16    |
| (Note 1) |

#### TX Identifier Register 1

#### XFR ADDR: 0B1AH

| BIT7     | BIT6     | BIT5     | BIT4     | BIT3     | BIT2     | BIT1     | BIT0     |
|----------|----------|----------|----------|----------|----------|----------|----------|
| ID.15    | ID.14    | ID.13    | ID.12    | ID.11    | ID.10    | ID.9     | ID.8     |
| (Note 1) |

#### Note:

1. ID.X means identifier bit X

#### TX Identifier Register 0 XFR ADDR: 0B1BH

| BIT7     | BIT6     | BIT5     | BIT4     | BIT3     | BIT2     | BIT1     | BIT0     |
|----------|----------|----------|----------|----------|----------|----------|----------|
| ID.7     | ID.6     | ID.5     | ID.4     | ID.3     | ID.2     | ID.1     | ID.0     |
| (Note 1) |

#### Note:

1. ID.X means identifier bit X

#### Data field

Data field registers is mapping to XFR address 0B1CH to 0B23H.

The number of transferred data bytes is defined by the data length code. The first bit transmitted is the most significant bit of data byte 1 at XFR address 0B1CH.



#### Filter Status Registers

#### Filter Status Register 3(FSR3) XFR ADDR: 0B24H (Note 1)

| BIT          | SYMBOL       | NAME                         | Reset Value | VALUE | FUNCTION                 |
|--------------|--------------|------------------------------|-------------|-------|--------------------------|
|              | ESD21        | Filter 31                    | 0           | 1     | Filter 31 is matched     |
| F3R3.7       | FORDI        | matching status              | 0           | 0     | Filter 31 is not matched |
| ESD2 6       | ESD20        | Filter 30<br>matching status | 0           | 1     | Filter 30 is matched     |
| FSR3.0       | FOROU        |                              |             | 0     | Filter 30 is not matched |
|              | ESP20        | Filter 29                    | 0           | 1     | Filter 29 is matched     |
| F3K3.5       | 5.5 F3R29    | matching status              | 0           | 0     | Filter 29 is not matched |
|              | FSR3.4 FSR28 | Filter 28<br>matching status | 0           | 1     | Filter 28 is matched     |
| F3K3.4       |              |                              |             | 0     | Filter 28 is not matched |
| ESD2 2       | ESD 27       | Filter 27<br>matching status | 0 -         | 1     | Filter 27 is matched     |
| F3K3.3       | FORZI        |                              |             | 0     | Filter 27 is not matched |
| ESD2 2       | ESDOG        | Filter 26                    | 0           | 1     | Filter 26 is matched     |
| FSR3.2       | F3K20        | matching status              | 0           | 0     | Filter 26 is not matched |
|              | FSD25        | Filter 25                    | 0           | 1     | Filter 25 is matched     |
| F3R3.1 F3R25 | F3R23        | matching status              | 0           | 0     | Filter 25 is not matched |
| ESP2 0       | ESD24        | Filter 24                    | 0           | 1     | Filter 24 is matched     |
| r3K3.U       | FOR24        | matching status              | U           | 0     | Filter 24 is not matched |

Note:

1. This is a read-only register in Operating mode. Reading or writing operation in Silent mode is for Dispatch time 3 register. When a frame message can pass through a filter, the respective filter matching status bit is set to logic 1.

Filter Status Register 2(FSR2) XFR ADDR: 0B25H (Note 1)

| BIT      | SYMBOL  | NAME                         | Reset Value | VALUE | FUNCTION                 |
|----------|---------|------------------------------|-------------|-------|--------------------------|
|          | ESD00   | Filter 23                    | 0           | 1     | Filter 23 is matched     |
| FORZ.7   | F3R23   | matching status              | 0           | 0     | Filter 23 is not matched |
|          | ESDOO   | Filter 22<br>matching status | 0           | 1     | Filter 22 is matched     |
| FSR2.0   |         |                              | 0           | 0     | Filter 22 is not matched |
|          |         | Filter 21<br>matching status | 0 -         | 1     | Filter 21 is matched     |
| F3R2.3   | FORZI   |                              |             | 0     | Filter 21 is not matched |
|          | ESD20   | Filter 20                    | 0           | 1     | Filter 20 is matched     |
| FSRZ.4   | F3K2U   | matching status              | 0           | 0     | Filter 20 is not matched |
| E6D0 0   | ESP10   | Filter 19<br>matching status | 0 -         | 1     | Filter 19 is matched     |
| 1 51(2.5 | 1 31(19 |                              |             | 0     | Filter 19 is not matched |



# CS8961 PRELIMINARY

| BIT          | SYMBOL                  | NAME                         | Reset Value | VALUE                    | FUNCTION                 |
|--------------|-------------------------|------------------------------|-------------|--------------------------|--------------------------|
| ESP2 2       | ESP2 2 ESP18            | Filter 18                    | 0           | 1                        | Filter 18 is matched     |
| FORZ.Z FORTO | matching status         | U                            | 0           | Filter 18 is not matched |                          |
| FSR2.1 FSR17 | <b>F</b> \$ <b>D</b> 17 | Filter 17<br>matching status | 0           | 1                        | Filter 17 is matched     |
|              | FORT                    |                              |             | 0                        | Filter 17 is not matched |
| FSR2.0 FSF   | 50040                   | Filter 16<br>matching status | 0           | 1                        | Filter 16 is matched     |
|              | FSR16                   |                              |             | 0                        | Filter 16 is not matched |

Note:

1. This is a read-only register in operating mode. Reading or writing operation is for Dispatch time 2 register. When a frame message can pass through a filter, the respective filter matching status bit is set to logic 1.

| BIT      | SYMBOL     | NAME                            | Reset Value | VALUE | FUNCTION                 |
|----------|------------|---------------------------------|-------------|-------|--------------------------|
| F0D4 7   | 50046      | Filter 15                       | 0           | 1     | Filter 15 is matched     |
| F3R1.7   | FORID      | matching status                 | 0           | 0     | Filter 15 is not matched |
| ESD1 6   | ESD14      | Filter 14                       | 0           | 1     | Filter 14 is matched     |
| FSR1.0   | F3K14      | matching status                 |             | 0     | Filter 14 is not matched |
|          | ESD12      | Filter 13                       | 0           | 1     | Filter 13 is matched     |
| FSK1.5   |            | matching status                 | 0           | 0     | Filter 13 is not matched |
|          | R1.4 FSR12 | 12 Filter 12<br>matching status | 0           | 1     | Filter 12 is matched     |
| F3K1.4   |            |                                 |             | 0     | Filter 12 is not matched |
|          | ESD11      | Filter 11<br>matching status    | 0 -         | 1     | Filter 11 is matched     |
| FORT.5   | FORT       |                                 |             | 0     | Filter 11 is not matched |
| ESP1 2   | ESP10      | Filter 10                       | 0           | 1     | Filter 10 is matched     |
| 1 01(1.2 | 1 SIXTO    | matching status                 | 0           | 0     | Filter 10 is not matched |
|          | ESDO       | Filter 9                        | 0           | 1     | Filter 9 is matched      |
| F3K1.1   | FOR9       | matching status                 | U           | 0     | Filter 9 is not matched  |
| ESP1 0   | FSD8       | Filter 8<br>matching status     | 0           | 1     | Filter 8 is matched      |
| FOR LU   | FUNU       |                                 | U           | 0     | Filter 8 is not matched  |

Note:

1. This is a read-only register in operating mode. Reading or writing operation is for Dispatch time 1 register. When a frame message can pass through a filter, the respective filter matching status bit is set to logic 1.



| BIT           | SYMBOL     |                             | Reset Value | VALUE | FUNCTION                |
|---------------|------------|-----------------------------|-------------|-------|-------------------------|
|               |            |                             |             |       |                         |
| FSR0.7        | FSR7       | Filter 7                    | 0           | 1     | Filter 7 is matched     |
|               |            | matching status             |             | 0     | Filter 7 is not matched |
| ESP2 6        | ESPA       | Filter 6                    | 0           | 1     | Filter 6 is matched     |
| F3N2.0        | FSRU       | matching status             | 0           | 0     | Filter 6 is not matched |
| ESPO 5        | ESDE       | Filter 5                    | 0           | 1     | Filter 5 is matched     |
| F3K0.5        | FORD       | matching status             | U           | 0     | Filter 5 is not matched |
| ESPO 4        | SR0.4 FSR4 | Filter 4<br>matching status | 0           | 1     | Filter 4 is matched     |
| F3K0.4        |            |                             |             | 0     | Filter 4 is not matched |
| ESD0 2        | ESD2       | Filter 3<br>matching status | 0           | 1     | Filter 3 is matched     |
| FSRU.3        | FORD       |                             |             | 0     | Filter 3 is not matched |
| ESPO 2        | ESDO       | Filter 2                    |             | 1     | Filter 2 is matched     |
| FSRU.2        | F3R2       | matching status             | 0           | 0     | Filter 2 is not matched |
| <b>FSD0 1</b> |            | Filter 1                    | 0           | 1     | Filter 1 is matched     |
| FORU.1        | FORI       | matching status             | U           | 0     | Filter 1 is not matched |
| ESB0.0        | ESDO       | Filter 0                    | 0           | 1     | Filter 0 is matched     |
| FORU.U        | FORU       | matching status             | U           | 0     | Filter 0 is not matched |

Note:

1. This is a read-only register in operating mode. Reading or writing operation is for Dispatch time 0 register. When a frame message can pass through a filter, the respective filter matching status bit is set to logic 1.



#### **Dispatch Time Registers**

Dispatch Time registers contains 4 dispatch enable bits and 28 Dispatch Time bits. When the 28 dispatch time bits are all set to logic 0, the dispatch function is disabled.

| Dispatch Time 3 Register ( | (DTR3) X | FR ADDR: 0B24H ( | Note 1) |  |
|----------------------------|----------|------------------|---------|--|
|                            |          |                  |         |  |

| DTR3.7   | DTR3.6   | DTR3.5   | DTR3.4   | DTR3.3   | DTR3.2   | DTR3.1   | DTR3.0   |
|----------|----------|----------|----------|----------|----------|----------|----------|
| WP3      | WP2      | WP1      | WP0      | DTR27    | DTR26    | DTR25    | DTR24    |
| (Note 2) | (Note 2) | (Note 2) | (Note 2) | (Note 3) | (Note 3) | (Note 3) | (Note 3) |

Note:

- 1. After hardware reset, the value of the register is 0.
- 2. The four bits are write-protect bits and can be written only in Silent mode. Only when {WP3, WP2, WP1, WP0} is 0X6, MCU can write DTR2, DTR1 and DTR0. Or the value written to the three registers is invalid.
- 3. The upper 4 dispatch time bits. The four bits can be written only in Silent mode.

| Dispatch Time 2 Register (DTR2) XFR A | DDR: 0B25H (Note 1) |
|---------------------------------------|---------------------|
|---------------------------------------|---------------------|

| DTR2.7 | DTR2.6 | DTR2.5 | DTR2.4 | DTR2.3 | DTR2.2 | DTR2.1 | DTR2.0 |
|--------|--------|--------|--------|--------|--------|--------|--------|
| DTR23  | DTR22  | DTR21  | DTR20  | DTR19  | DTR18  | DTR17  | DTR16  |

Note:

1. The dispatch time 2 register can be written only in Silent mode and the value of write-protect bits is 0X6. After hardware reset, the value of the register is 0.

| DTR1.7 | DTR1.6 | DTR1.5 | DTR1.4 | DTR1.3 | DTR1.2 | DTR1.1 | DTR1.0 |
|--------|--------|--------|--------|--------|--------|--------|--------|
| DTR15  | DTR14  | DTR13  | DTR12  | DTR11  | DTR10  | DTR9   | DTR8   |

Note:

1. The dispatch time 1 register can be written only in Silent mode and the value of write-protect bits is 0X6. After hardware reset, the value of the register is 0.

Dispatch Time 0 Register (DTR0) XFR ADDR: 0B27H (Note 1)

| DTR0.7 | DTR0.6 | DTR0.5 | DTR0.4 | DTR0.3 | DTR0.2 | DTR0.1 | DTR0.0 |
|--------|--------|--------|--------|--------|--------|--------|--------|
| DTR7   | DTR6   | DTR5   | DTR4   | DTR3   | DTR2   | DTR1   | DTR0   |

Note:

1. The dispatch time 0 register can be written only in Silent mode and the value of write-protect bits is 0X6. After hardware reset, the value of the register is 0.

The least significant bit equal to 200uS If dispatch period is 50 mS, adjust DTR0 (0XB27) to be 250 Then 250 \* 200 uS=50,000 uS = 50 ms The dispatch time will be 50ms

These four registers 0XB24 to 0XB27 only can program in silent mode.



#### **3. Basic Function**

#### 3.1 Pin Configuration

| CAN Pins | s Configur        | guration Register XFR ADDR: 0F52H |       |                                                                                             |       |                           |       |
|----------|-------------------|-----------------------------------|-------|---------------------------------------------------------------------------------------------|-------|---------------------------|-------|
| BIT 7    | BIT 6             | BIT 5                             | BIT 4 | BIT 3                                                                                       | BIT 2 | BIT 1                     | BIT 0 |
|          | Rese<br>(Must kee | erved<br>p in 0000)               |       | 1 :<br>PIN#75 = CAN0_RX<br>PIN#76 = CAN0_TX<br>0:<br>PIN#75 = GPIO P40<br>PIN#76 = GPIO P41 | (Mu   | Reserved<br>Ist keep in ( | 000)  |

#### 3.2 Proper setting of Operating mode and Silent mode

Some registers are writable only in Silent mode such as Bus Timing registers, so we must write these registers in the Silent mode and the CAN controller must guit Silent mode when these registers are configured properly to make the controller work (see also the "Mode Register " in chapter "Register Description").

#### 3.3 Proper setting of Baud Rate

Two registers BTR0 and BTR1 determine the baud rate in the CAN-bus. For detailed information about the two registers, please refer to section "Bus Timing Register" in the chapter "Register Description". The following example explains how to calculate the baud rate:

Supposed: the oscillator frequency is 16MHZ, value of the BTR0 and BTR1 is 01h and 14h, and so we can get the baud rate 500kbps as the following way:

$$BRP = 32 \times BRP.5 + 16 \times BRP.4 + 8 \times BRP.3 + 4 \times BRP.2 + 2 \times BRP.1 + BRP.0 + 1 = 1$$
  

$$t_{scl} = 2 \times t_{clk} \times (BRP + 1) = \frac{2 \times 2}{16 \times 10^{6}} = 0.25 \times 10^{-6}s$$
  

$$t_{SYNCSEG} = 1 \times t_{scl} = 0.25 \times 10^{-6}s$$
  

$$t_{SEG1} = t_{scl} \times (8 \times TSEG1.3 + 4 \times TSEG1.2 + 2 \times TSEG1.1 + TSEG1.0 + 1) = 5 \times t_{scl} = 1.25 \times 10^{-6}s$$
  

$$t_{SEG2} = t_{scl} \times (4 \times TSEG2.2 + 2 \times TSEG2.1 + TSEG2.0 + 1) = 2 \times t_{scl} = 0.5 \times 10^{-6}s$$
  

$$BT = t_{SYNCSEG} + t_{SEG1} + t_{SEG2} = 2 \times 10^{-6}s$$
  
BT stands for the time that a single bit lasts.  
So the baud rate in the CAN-bus is  $\frac{1}{BT} = \frac{1}{2 \times 10^{-6}} = 500 \times 10^{-6}bps$ 

 $2 \times 10^{-6}$ 

BT



#### 3.4 The setting of the acceptance filter

With the help of the acceptance filter, the CAN controller can receive proper frames from CAN-bus only when the identifier bits of the received frames are equal to the predefined ones within the acceptance filter registers.

The acceptance filter is defined by the Acceptance Code Registers (ACR) and the Mask Code Registers (MCR). The bit patterns of frames to be received are defined within the Acceptance Code registers. The corresponding mask code registers allow define certain bit positions to be 'don't care'. After hardware reset, all the Acceptance Code registers and Mask Code registers are cleared.

In CS8961, the CAN controller has 32 groups of acceptance filter. We must enable at least one group of filter previously. Each group of filter has 32 Acceptance Code bits and 32 Mask Code bits and occupies 8 bytes address space. They are mapping to the XFR address space as the Figures below. Acceptance code 3 register is the highest byte in the Acceptance Code; the Acceptance code 2 register is the lowest byte in the Acceptance Code Register and Mask Code and Mask Code 0 register is the lowest byte in the XFR address space. We take Filter 0 in CAN0 as an example: the address of the Acceptance Code 3 is 0X0B28 and the Mask Code 3 is 0X0B29. The address of the Acceptance Code 2 is 0X0B2A and the Mask Code 2 is 0XB2B and so on. When received message is standard format frame, the lower 11 bits of the Acceptance Code and the Mask Code are valid. When received message is extended format frame, the lower 29 bits of the Acceptance Code and the Mask Code are valid.



Figure-59 CAN0 Acceptance Filters





Extended frame: if an extended format frame is received, the complete identifier including the RTR bit is used for acceptance filtering. For a successful reception of a message, all single bit comparisons have to signal acceptance. It should be noted that the 3 most significant bits of ACR3 and MCR3 are not used. In order to be compatible with future products these bit should be 'don't care' by setting MCR3.7, MCR3.6 and MCR3.5 to logic 1.





#### Figure-61 Filter 0 in CAN0 Is Receiving Standard Frame Messages

Standard frame: if a standard format frame message is received, the completely identifier are used for acceptance filtering. For a successful reception of a frame, all single bit comparisons have to signal acceptance. Note that ACR3, MCR3, ACR2, MCR2 and the 5 most significant bits of ACR1 and MCR1 are not used. In order to be compatible with future products, these unused bits in Mask Code registers should be programmed to be 'don't care' by setting these bits to logic 1.



#### 3.5 The setting of Interrupt

In CAN0 controller, there are seven interrupt sources can be responded by MCU when respective interrupt is enabled. The other interrupt is CANBUSI, which can respond when CAN0 controller enters into bus off.

| CAN0I and CANBUSI |                   |             |        |  |  |  |  |
|-------------------|-------------------|-------------|--------|--|--|--|--|
| Interrupt Flag    | Active level/edge | Flag resets | vector |  |  |  |  |
| CAN0I             | Low               | Hardware    | 0X4B   |  |  |  |  |
| CANBUSI           | Falling           | Software    | 0X73   |  |  |  |  |

For detailed information about the CAN0I and CANBUSI, please refer to the 'Interrupt System'.

#### 3.6 Transmitting a frame

You must write transmit buffer to send a frame to CAN-bus, then set the transmit request bit to logic 1. The controller will wait for the bus idle and sends the frame to the bus.

For example, CAN0 will send a standard format frame to CAN-bus. Frame identifier is 0X001, the data have a length of 8 and the data are 11h, 22h, 33h, 44h, 55h, 66h, 77h and 88h..The program written in keil c is as follows:

Write\_reg(0X0B17,0X08); //write the frame information register, FF=0 , RTR=0 , DLC=8 Write reg(0X0B18,0X00); //write the TX ID3 Register Write\_reg(0X0B19,0X00); // write the TX ID2 Register Write\_reg0X0B1A,0X00); // write the TX ID1 Register Write reg(0X0B1B,0X01); // write the TX ID0 Register Write\_reg(0X0B1C,0X11); //write the TX data 1 Register Write\_reg(0X0B1C,0X22); // write the TX data 2 Register Write\_reg0X0B1C,0X33); // write the TX data 3 Register Write\_reg(0X0B1C,0X44); // write the TX data 4 Register Write\_reg(0X0B1C,0X55); // write the TX data 5 Register Write reg(0X0B1C,0X66); // write the TX data 6 Register Write\_reg(0X0B1C,0X77); // write the TX data 7 Register Write\_reg(0X0B1C,0X88); // write the TX data 8 Register Write\_reg(0X0B01,0X01); //write the transmit request bit Note that the prototype of the function Write reg is : Void Write reg(unsigned int address, unsigned char value);

#### 3.7 Receiving a frame

When CAN controller receives a frame successfully and the receive interrupt is enabled, the receive interrupt bit will be set logic 1. MCU is informed by the receive interrupt and reads the data in the receive buffer out, then releases the receive buffer. Please pay special attention here that the data must be read before releasing receive buffer, because the value in the receive buffer has changed after releasing receive buffer.



#### 4. Advanced Function

The CAN controller in CS8961 also has some distinct functions as follows:

#### 4.1 Dispatch

The CAN controller can transmit data periodically to CAN-bus to report its status. To realize this function, we must configure the dispatch time registers properly. The 28 dispatch time bits control the period that the controller transmits data to CAN-bus and the dispatch period is calculate as follows:

Provided the bit period is  $t_{b} = \frac{1}{BaudRate}$  and the value of the 28 dispatch time bits is "A", then the dispatch

time is  $100 \times A \times t_b$  second. In other words, the CAN controller transmits a message in the TX buffer to the

CAN-bus every  $100 \times A \times t_b$  second. When dispatch time bits are all set to logic 0, the dispatch function is disabled. When bus error in a dispatch frame, it can transmit an error frame and can't transmit the failed frame again.

#### 5. CAN Test

We provide a Self-Loop Test Mode, which support online test and the transceiver needn't participate in.

#### 5.1 Self Loop Test

#### CAN0 In Self Loop Test

The following figure illustrates the internal connection when CAN0 is in Self-Loop Test Mode. Self-Loop Test usually goes on in Self Test mode (see Mode register) with Self Receive command to test the controller whether it works. When going on Self-Loop testing, the controller can't receive data from CAN-bus.



Figure-62 CAN0 In Self Loop Test



## CHAPTER 24 PACKAGE OUTLINE

## 1. Package Outline

## 64-pin LQFP





| Sumbol | Dimensions in Millimeters |          |      |  |  |  |
|--------|---------------------------|----------|------|--|--|--|
| Symbol | MIN                       | NOM      | MAX  |  |  |  |
| Α      | -                         | -        | 1.60 |  |  |  |
| A1     | 0.05                      | -        | 0.15 |  |  |  |
| A2     | 1.35                      | 1.40     | 1.45 |  |  |  |
| b      | 0.13                      | 0.18     | 0.23 |  |  |  |
| С      | 0.09                      | -        | 0.20 |  |  |  |
| D      | 9.00 BSC                  |          |      |  |  |  |
| D1     |                           | 7.00 BSC |      |  |  |  |
| E      |                           | 9.00 BSC |      |  |  |  |
| E1     |                           | 7.00 BSC |      |  |  |  |
| е      |                           | 0.40 BSC |      |  |  |  |
| L      | 0.45 0.60 0.75            |          |      |  |  |  |
| L1     |                           | 1.00 REF |      |  |  |  |
| θ      | <b>0</b> °                | 3.5°     | 7°   |  |  |  |

#### Notes:

- Dimensions D1 and E1 do not include mold protrusion. Allowable protrusion is 0.25mm per side. D1 and E1 are maximum plastic body size dimensions including mold mismatch.
- Dimension b does not include dambar protrusion. Allowable Dambar protrusion shall not cause the lead width to exceed the maximum b dimension by more than 0.08mm.

#### **DISCLAIMER AND DECLARATION**

1. Copyright © 2018 Integrated Silicon Solution, Inc. All rights reserved. ISSI reserves the right to make changes to this specification and its products at any time without notice. ISSI assumes no liability arising out of the application or use of any information, products or services described herein. Customers are advised to obtain the latest version of this device specification before relying on any published information and before placing orders for products.

Integrated Silicon Solution, Inc. does not recommend the use of any of its products in life support applications where the failure or malfunction of the product can reasonably be expected to cause failure of the life support system or to significantly affect its safety or effectiveness. Products are not authorized for use in such applications unless Integrated Silicon Solution, Inc. receives written assurance to its satisfaction, that:

- a.) the risk of injury or damage has been minimized;
- b.) the user assume all such risks; and
- c.) potential liability of Integrated Silicon Solution, Inc is adequately protected under the circumstances.

2. Applications in medical appliances, life support devices system or flight vehicle using ISSI's products are not authorized without express written approval of ISSI.

<sup>-</sup> Reference Document: JEDEC MS-026, BBD.