

## **Errata Sheet**

Rel. 1.2, 24.11.2006

Device XC886C-8FF

Marking/Step ES AB

Package PG-TQFP-48

This Errata Sheet describes the deviations from the current user documentation. The module oriented classification and numbering system uses an ascending sequence over several derivatives, including already solved deviations. So gaps inside this enumeration can occur.

#### Table 1 Current Documentation

XC886/888CLM User's Manual V0.3 Aug 2006 XC886/888CLM Data Sheet V0.2 Oct 2006

Each erratum identifier follows the pattern Module Arch. Type Number:

- · Module: subsystem or peripheral affected by the erratum
- Arch: microcontroller architecture where the erratum was firstly detected.
  - AI: Architecture Independent (detected on module level)
  - CIC: Companion ICs
  - TC: TriCore (32 bit)X: XC1xx / XC2xx (16 bit)
  - XC8: XC8xx (8 bit)
  - none: C16x (16 bit)
- Type: none Functional Deviation; 'P' Parametric Deviation; 'H' -Application Hint; 'D' - Documentation Update
- Number: ascending sequencial number within the three previous fields. As
  this sequence is used over several derivatives, including already solved
  deviations, gaps inside this enumeration can occur.



Note: Devices marked with EES or ES are engineering samples which may not be completely tested in all functional and electrical characteristics, therefore they should be used for evaluation only.

The specific test conditions for EES and ES are documented in a separate Status Sheet.



## 1 History List / Change Summary

| Table 2 | History List |        |  |
|---------|--------------|--------|--|
| Version | Date         | Remark |  |
| 1.0     | 22.09.2006   |        |  |
| 1.1     | 09.10.2006   |        |  |

Table 3 Errata fixed in this step

| Errata        | Short Description                                                          | Chg   |  |
|---------------|----------------------------------------------------------------------------|-------|--|
| ADC_XC8.003   | Limitation during power-down mode                                          | Fixed |  |
| BROM_XC8.008  | MultiCAN Bootstrap Loader functionality not available.                     | Fixed |  |
| OCDS_XC8.H001 | Write to OCDS registers can disturb the Debug Function                     | Fixed |  |
| OSC_XC8.002   | OSC_CON register is not reset following a wake-up reset                    |       |  |
| PIN_XC8.004   | Reset values of PUDSEL and PUDEN registers in Port 4 and Port 5 are wrong. |       |  |
| PLL_XC8.001   | PLL N-Divider is reset to default value after a WDT reset                  |       |  |
| WDT_XC8.001   | WDT is not default suspended in Monitor Mode                               |       |  |
| WDT_XC8.002   | WDT should not be refreshed during Prewarning period                       |       |  |



Table 4 Functional Deviations

| Functional Short Description Deviation                                           |                                                                                                                  | Chg        | Pg |  |
|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|------------|----|--|
| BROM_XC8.006                                                                     | IRAM data is corrupted after any warm reset                                                                      | Upd<br>ate | 7  |  |
| BROM_XC8.010                                                                     | SYSCON0.RMAP Switching Error                                                                                     |            | 7  |  |
| CD_XC8.001                                                                       | Set and Clear of Error Bit in CORDIC Linear Vectoring Mode                                                       |            | 8  |  |
| EVR_XC8.005                                                                      | Reset toggling issue for repeated power up                                                                       | New        | 8  |  |
| FLASH_XC8.004                                                                    | Wrong data fetched during backward read-<br>access in P-Flash with Parallel Read Mode<br>enabled                 |            | 10 |  |
| INT_XC8.004                                                                      | Unable to Detect New Interrupt Request if Any One of Timer 2/UART1 Interrupt Flags Is Not Cleared (Unexpectedly) |            | 15 |  |
| INT_XC8.005                                                                      | Write to IRCON0 Blocks Interrupt Request of External Interrupt 0,1                                               |            | 18 |  |
| MultiCAN_TC.025                                                                  | RXUPD behavior                                                                                                   |            | 19 |  |
| MultiCAN_TC.026                                                                  | MultiCAN Timestamp Function                                                                                      |            | 19 |  |
| MultiCAN_TC.027                                                                  | MultiCAN Tx Filter Data Remote                                                                                   |            | 20 |  |
| MultiCAN_TC.028                                                                  | SDT behavior                                                                                                     |            | 20 |  |
| MultiCAN_TC.029                                                                  | Tx FIFO overflow interrupt not generated                                                                         |            | 21 |  |
| MultiCAN_TC.030 Wrong transmit order when CAN error at start of CRC transmission |                                                                                                                  |            | 23 |  |
| MultiCAN_TC.031                                                                  | List Object Error wrongly triggered                                                                              |            | 23 |  |
| MultiCAN_TC.032                                                                  | MSGVAL wrongly cleared in SDT mode                                                                               |            | 24 |  |
| MultiCAN_TC.035                                                                  | Different bit timing modes                                                                                       |            | 24 |  |
| MultiCAN_TC.037                                                                  | Clear MSGVAL                                                                                                     |            | 26 |  |
| MultiCAN_TC.038 Cancel TXRQ                                                      |                                                                                                                  |            | 27 |  |



**Table 4** Functional Deviations

| Functional Deviation                                                                   | Short Description                                                                         | Chg | Pg |
|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|-----|----|
| OCDS_XC8.008 Watchdog Timer behavior during Debug with Suspend                         |                                                                                           |     | 27 |
| PIN_XC8.005 Glitches on TCK when switching between clock sources                       |                                                                                           |     | 28 |
| PIN_XC8.006 Port 4 pads (excluding P4.2) toggle once upon a power-on or hardware reset |                                                                                           |     | 28 |
| UART_XC8.001                                                                           | Bits RB8, TI and RI in UART1_SCON SFR cannot be Written by SETB, CLR and CPL Instructions |     | 29 |

Table 5 Deviations from Electrical- and Timing Specification

| AC/DC/ADC | Short Description | Chg | Pg |
|-----------|-------------------|-----|----|
| Deviation |                   |     |    |

Table 6 Application Hints

| Hint                                                                                       | Short Description                             | Chg | Pg |  |
|--------------------------------------------------------------------------------------------|-----------------------------------------------|-----|----|--|
| ADC_XC8.H001 Arbitration mode when using external trigger at the selected input line REQTR |                                               |     | 31 |  |
| BROM_XC8.H001                                                                              | SYSCON0.RMAP handling in ISR                  |     | 31 |  |
| BROM_XC8.H002 Obtain Product Derivative Information With Chip Identification Number        |                                               |     | 32 |  |
| INT_XC8.H003                                                                               | Interrupt Flags of External Interrupt 0 and 1 |     | 32 |  |



## Table 6 Application Hints

| Hint                                                                      | Short Description                                                           | Chg | Pg |  |
|---------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----|----|--|
| INT_XC8.H004                                                              | NT_XC8.H004 NMI Interrupt Request With No NMI Flag Set                      |     |    |  |
| INT_XC8.H005                                                              | XC8.H005 Not all Flags are qualified for clearing Pending Interrupt Request |     | 35 |  |
| MultiCAN_TC.H002                                                          | Double Synchronization of receive input                                     |     | 37 |  |
| MultiCAN_TC.H003 Message may be discarded before transmission in STT mode |                                                                             |     | 38 |  |
| OCDS_XC8.H002 Any NMI request is lost on Debug entry and during Debug     |                                                                             |     | 38 |  |

## 2 Functional Deviations

### BROM XC8.006 IRAM data is corrupted after any warm reset

After any warm reset (i.e. reset without powering off the device), boot up via User Mode affects certain IRAM data.

The affected IRAM address ranges are:

- $(1) 00_{H} 07_{H}$
- $(2) 80_{H} C7_{H}$

#### Workaround

None

## BROM XC8.010 SYSCONO.RMAP Switching Error

When executing from XRAM, if SYSCONO.RMAP is switched using an one-machine-cycle read-modify-write instruction (e.g. ORL dir,A) and the SFR is accessed immediately by an one-machine-cycle instruction (e.g. MOV A,dir) or a PUSH instruction, the SFR from the previous mapping might be accessed instead.

This RMAP switching error does not occur if code is executed from the Flash memory.

#### Workaround

When executing code from XRAM, use two-machine-cycle instructions to either switch RMAP or access the SFR. Alternatively, add one or more instructions



(e.g. NOP) between the one-machine-cycle RMAP switching and SFR accessing instructions.

### CD XC8.001 Set and Clear of Error Bit in CORDIC Linear Vectoring Mode

In linear vectoring mode, the Error bit of register CD\_STATC is set immediately on detecting overflow. When detected between iterations – the Error status is not held internally till the end of the calculation.

As the Error bit is defined such that it is cleared on any read access to the register (e.g. JB BSY), SW checking of the Error bit only at the end of calculation may miss to detect an overflow error condition.

#### Workaround

Especially in linear vectoring mode, if the error condition setting of Error bit must be detected, any read access should be done on the whole CD\_STATC register (e.g. MOV) and the Error bit checked in all read instances.

## EVR XC8.005 Reset toggling issue for repeated power up

Due to the limitation of the EVR, the reset toggling may occur during the power up. To prevent the reset toggling issue for power up, the following conditions must be met:

- 1. For power up, the rising time must be less than 2ms/V.
- 2. The power down time must be more than 0.2ms/V.
- 3. A permanent  $V_{\rm DDP}$  residual voltage is less than 500mV.

In case of  $V_{\rm DDP}$  residual voltage is more than 500mV, the holding time of residal voltage affects the reset toggling issue. **Figure 1** shows the critical cases for power up/power down when the residual voltages is held for some time. **Figure 2** shows the uncritical case for power up and power down when the power up is triggered immediately after power down. In case of a residual voltage due to immediate power up after power down, the users have to contact IFX to ensure no power up failure.







Figure 1 Critical Cases for Power up/ Power down when  $V_{\rm residual}$  >500mV



Figure 2 Uncritical Case for Power up/Power down when  $V_{\rm residual}$  >500mV



#### Workaround

None.

### <u>FLASH\_XC8.004</u> Wrong data fetched during backward read-access in P-Flash with Parallel Read Mode enabled

Program Flash Banks 0 to 5 (address range  $0000_{\rm H}$  to  $5{\rm FFF}_{\rm H}$ ) implement the parallel read feature for an increased performance during Flash read-access. For that, the Flash contains a 2-Byte wide cache (even and odd), and an address comparison circuitry that decides if access is served from the Flash Array or from this cache. Note that this mechanism applies, regardless of whether the Flash read-access is a code fetch or a data access. For the purpose of simplicity, the term "data byte" is used to mean either code or data. If a read-access is requested on an even address, and the requested data byte is not available in the cache, the Flash reads from the Flash Array the even data byte. In parallel, it also prefetches another data byte from the following odd address in the Flash Array. This 2-byte even-odd pair is stored respectively in the even and odd cache, and the data byte in the even cache is also sent to the CPU.

If a read-access is requested on an odd address, and the requested data byte is not available in the cache, the Flash reads from the Flash Array the odd data byte. However, it does not perform an additional prefetch of the preceeding even address. While the odd data byte is stored in the odd cache and sent to the CPU, the even cache remains unchanged and is therefore not up-to-date.

In the current implementation, when parallel read access mode is enabled, performing a read-access to an odd address in the Program Flash, followed by a subsequent read access to its preceding even address causes the access to the even address to return wrong data. This is because the data byte is not read from the Flash Array but is read from the even cache which contains an out-of-date data.

The problem is caused by the following read sequence to P-Flash:

1. Read access to X (where X is located at an odd address)



#### Read access to X-1

The error occurs during the read-access to even address X-1. The read-access will not read out the data byte at address X-1, but instead will return the out-of-date data byte in the even cache.

Read-access can be generated with code fetch or a data access. The problem is encountered only when there is backward flowing read-access to Program Flash.

In the case of data access, MOVC A,@A+DPTR and MOVC A,@A+PC instructions are the only possible instructions that can create the problem. In view of this, there are only 3 possible scenarios that can create the problem.

#### Scenario 1

- perform data access at odd address in P-Flash. (via MOVC instruction).
- perform code fetch at odd-1 address P-Flash.

For example:

Table 7

| Address                 | Code |                 |                               |
|-------------------------|------|-----------------|-------------------------------|
| 1280 <sub>H</sub>       | 04   | inc a           |                               |
| 1281 <sub>H</sub>       | 93   | movc a, @a+dptr | ;; a+dptr = 1283 <sub>H</sub> |
| 1282 <sub>H</sub> (X-1) | 14   | dec a           |                               |
| 1283 <sub>H</sub> (X)   | E4   | clr a           |                               |

After the MOVC instruction (located at  $1281_{\rm H}$ ) performs a read access to address  $1283_{\rm H}$ , which reads out E4<sub>H</sub>, the program counter increments to the next read access at address  $1282_{\rm H}$ . The latter read access should fetch code  $14_{\rm H}$  from the Flash Array, but instead it fetches  $04_{\rm H}$  from the even cache which has not been updated with new code but rather still contains the code ( $04_{\rm H}$  inc a) from the last read access on an even address. The CPU receives the wrong codes in the sequence  $04_{\rm H}$   $93_{\rm H}$  E4<sub>H</sub>  $04_{\rm H}$  E4<sub>H</sub>. The correct code sequence should be  $04_{\rm H}$   $93_{\rm H}$  E4<sub>H</sub>  $14_{\rm H}$  E4<sub>H</sub>. The code at  $1282_{\rm H}$  is skipped. Hence, this is an example of a wrong code fetch.



#### Scenario 2

- 1. perform branch to odd address P-Flash.
- 2. perform data access odd-1 address P-Flash. (via MOVC instruction).

For example:

Table 8

| Address                 | Code |                        |                               |
|-------------------------|------|------------------------|-------------------------------|
| 1280 <sub>H</sub>       | 80   | sjmp label             |                               |
| 1281 <sub>H</sub>       | 01   |                        |                               |
| 1282 <sub>H</sub> (X-1) | E4   | clr a                  |                               |
| 1283 <sub>H</sub> (X)   | 93   | label: movc a, @a+dptr | ;; a+dptr = 1282 <sub>H</sub> |

After the SJMP instruction (located at  $1280/81_{\rm H}$ ) to the MOVC instruction, the latter performs a read access to address  $1282_{\rm H}$ . This read access should fetch code E4<sub>H</sub> from the Flash Array, but instead it fetches  $80_{\rm H}$  from the even cache which has not been updated with new byte code but rather still contains the data byte from the last read access on an even address. The CPU receives the wrong codes in the sequence  $80_{\rm H}$   $93_{\rm H}$   $80_{\rm H}$ . The correct code sequence should be  $80_{\rm H}$   $93_{\rm H}$  E4<sub>H</sub>. The MOVC data access returns wrong readout. Hence, this is an example of a wrong data readout.

#### Scenario 3

- 1. From anywhere outside P-Flash (eg. XRAM or D-Flash), perform data access to odd address in P-Flash.
- 2. From anywhere outside P-Flash (eg. XRAM or D-Flash), perform data access to odd 1 address in P-Flash.

#### For example:

(the following code is executing out of D-Flash or XRAM)

#### Table 9

| movc a,@a+dptr | ;; a+dptr = any odd address (X) in P-Flash |
|----------------|--------------------------------------------|
| mov r1,a       |                                            |



#### Table 9

dec a

movc a,@a+dptr ;; a+dptr = even address (X-1) in P-Flash

#### Workaround #1 for scenarios 1, 2 and 3

The parallel read feature can be disabled before performing the data access on P-Flash described in the above three scenarios. The feature can then be enabled again after the data access. Disabling the parallel access to P-Flash does not have any adverse impact on the code execution other than a longer execution time.

Parallel access can be disabled and enabled via the Flash In-Application Programming routines, PARALLEL\_READ\_DISABLE and PARALLEL\_READ\_ENABLE, which are located at 0xDFFC and 0xDFFF respectively.

For example, the workaround for scenario 3 will be:

(the following code is executing out of D-Flash or XRAM)

#### Table 10

LCALL 0xDFFC ;; disable parallel access

mov a,#1

movc a,@a+dptr = ;; a+dptr = any odd address (X) in P-Flash

mov r1,a mov a.#0

movc a,@a+dptr ;; a+dptr = even address (X-1) in P-Flash

LCALL 0xDFFF ;; enable parallel access

#### Workaround #2 for scenarios 1 and 2

A dummy NOP instruction can be added before and after any MOVC instruction (applies to both movc a,@a+dptr, movc a,@a+pc). The NOP instructions act as dummy instructions and when executed or skipped, does not have any adverse impact on the code execution other than a longer execution time.

For example, the workaround for scenario 1 will be:



Table 11

| Address           | Code |                 |                               |
|-------------------|------|-----------------|-------------------------------|
| 127F <sub>H</sub> | 04   | inc a           |                               |
| 1280 <sub>H</sub> | 00   | nop             | ;; dummy                      |
| 1281 <sub>H</sub> | 93   | movc a, @a+dptr | ;; a+dptr = 1283 <sub>H</sub> |
| 1282 <sub>H</sub> | 00   | nop             | ;; dummy                      |
| 1282 <sub>H</sub> | 14   | dec a           |                               |
| 1283 <sub>H</sub> | E4   | clr a           |                               |

which results in the execution sequence  $04_{\rm H}$   $00_{\rm H}$   $93_{\rm H}$   $E4_{\rm H}$   $00_{\rm H}$   $14_{\rm H}$   $E4_{\rm H}$ . For example, the workaround for scenario 2 will be:

Table 12

| Address           | Code |                        |                               |
|-------------------|------|------------------------|-------------------------------|
| 1280 <sub>H</sub> | 80   | sjmp label             |                               |
| 1281 <sub>H</sub> | 01   |                        |                               |
| 1282 <sub>H</sub> | E4   | clr a                  |                               |
| 1283 <sub>H</sub> | 00   | nop                    | ;; dummy                      |
| 1284 <sub>H</sub> | 93   | label: movc a, @a+dptr | ;; a+dptr = 1282 <sub>H</sub> |
| 1285 <sub>H</sub> | 00   | nop                    | ;; dummy                      |

which results in the execution sequence 80<sub>H</sub> 93<sub>H</sub> E4<sub>H</sub> 00<sub>H</sub>.

#### Workaround #3 for scenarios 1 and 2

Any MOVC instruction (applies to both movc a,@a+dptr, movc a,@a+pc) must be located in the even byte address. This can be achieved by forcing the alignment in the compiler, or by adding one or more instructions (e.g. NOP) to push the MOVC instruction into an even byte address.

For example, the workaround for scenario 1 with a NOP instruction inserted will be:



Table 13

| Address           | Code |                 |                                   |
|-------------------|------|-----------------|-----------------------------------|
| 1280 <sub>H</sub> | 04   | inc a           |                                   |
| 1281 <sub>H</sub> | 00   | nop             | ;; dummy                          |
| 1282 <sub>H</sub> | 93   | movc a, @a+dptr | ;; a+dptr = (1283+1) <sub>H</sub> |
| 1283 <sub>H</sub> | 14   | dec a           |                                   |
| 1284 <sub>H</sub> | E4   | clr a           |                                   |

which results in the execution sequence  $04_{H}$   $00_{H}$   $93_{H}$   $E4_{H}$   $14_{H}$   $E4_{H}$ .

For example, the workaround for scenario 2 with a NOP instruction inserted will be:

Table 14

| Address           | Code |                        |                               |
|-------------------|------|------------------------|-------------------------------|
| 1280 <sub>H</sub> | 80   | sjmp label             |                               |
| 1281 <sub>H</sub> | 01   |                        |                               |
| 1282 <sub>H</sub> | E4   | clr a                  |                               |
| 1283 <sub>H</sub> | 00   | nop                    | ;; dummy                      |
| 1284 <sub>H</sub> | 93   | label: movc a, @a+dptr | ;; a+dptr = 1282 <sub>H</sub> |

which results in the execution sequence 80<sub>H</sub> 93<sub>H</sub> E4<sub>H</sub>.

## INT\_XC8.004 Unable to Detect New Interrupt Request if Any One of Timer 2/UART1 Interrupt Flags Is Not Cleared (Unexpectedly)

As illustrated in the simplified figure, the UART1 interrupt flags RI and TI are combined as one interrupt request output. These flags are located within the UART1 kernel, with a single interrupt request line as output from the kernel.





### Figure 3

Being of interrupt structure 2, the interrupt request of UART1 is detected on the rising edge of a positive pulse.

The problem is that it may occur at some point in the application, that any new UART1 interrupt request can no longer be detected after a return-from-interrupt (reti) due to service of earlier event(s). This happens when the following conditions are true:

- 1. UART1 events are serviced by interrupt (i.e. flags are checked and cleared only in the interrupt routine ISR),
- Either RI or TI is set at any one time throughout the ISR (even while the
  other is cleared) such that at least one of the flags is still set after reti,
  causing the UART1 request line, which is an OR-function of the two flags RI
  and TI, to remain set throughout the ISR and after reti.

Two example scenerios are illustrated in the following figure:





## Figure 4

This means, any future UART1 RI or TI event is not able to cause a rising edge and therefore not able to trigger an interrupt request to the core – as if the UART1 interrupts had been disabled, until both RI and TI flags are cleared at some time. The clearing of flags would have to be done by user's code additionally outside of the UART1 interrupt routine, which is however normally not feasible with an interrupt service scheme.

Note: This condition affects only the detection of UART1 interrupt events RI and TI. It does not block the detection of other interrupt events belonging to the same interrupt node.

#### Workaround

There are two suggested workaround:

- If other events of interrupt node XINTR8 (EX2) need not be enabled for interrupt, disable this interrupt node and use software polling of the flags instead.
- Before return from interrupt, check again if RI or TI is (still) set (due to new request since the last check). If so, jump and execute the ISR routine from start. Exit only when all flags are checked to be cleared. However, dummy



interrupt of the node may occur after return from interrupt, and should be ignored. Another drawback is if UART1 events are occurring at high rate, the CPU may be 'stuck' in the service routine of the UART1 interrupt for a long time.

```
<entry point of interrupt node service routine>
.....
Start:
check flag RI
.....
clear flag RI
.....
check flag TI
.....
clear flag TI
.....
Finish:
if RI or TI is set, jump to Start
reti (return from interrupt)
```

### Figure 5

Note: The Boolean CLR and CPL instructions cannot be used to clear RI and TI bits of UART1. Refer to UART\_XC8.001.

## <u>INT\_XC8.005</u> Write to IRCON0 Blocks Interrupt Request of External Interrupt 0,1

Any write (read-modify-write or direct MOV) to the SFR IRCON0 will block an incoming interrupt request from external interrupt 0 or 1, even though the respective flag (EXINT0 or EXINT1) is set.

#### Workaround

After any write to the IRCON0, check (read IRCON0) the flags EXINT0 and EXINT1. If any flag is set, run the service routine; otherwise proceed.



In case of enabled for interrupt, the service routine should be duplicated: one copy as the interrupt service routine (with reti executed); another copy in main code memory for software call (with ret executed).

#### MultiCAN TC.025 RXUPD behavior

When a CAN frame is stored in a message object, either directly from the CAN node or indirectly via receive FIFO or from a gateway source object, then bit MOCTR.RXUPD is set in the message object before the storage process and is automatically cleared after the storage process.

#### **Problem description**

When a standard message object (MOFCR.MMC) receives a CAN frame from a CAN node, then it processes its own RXUPD as described above (correct).

In addition to that, it also sets and clears bit RXUPD in the message object referenced by pointer MOFGPR.CUR (wrong behavior).

#### Workaround

The "foreign" RXUPD pulse can be avoided by initializing MOFGPR. CUR with the message number of the object itself instead of another object (which would be message object 0 by default, because MOFGPR. CUR points to message object 0 after reset initialization of MultiCAN).

## MultiCAN TC.026 MultiCAN Timestamp Function

The timestamp functionality does not work correctly.

#### Workaround

Do not use timestamp.



#### MultiCAN TC.027 MultiCAN Tx Filter Data Remote

Message objects of priority class 2 (MOAR.PRI = 2) are transmitted in the order as given by the CAN arbitration rules. This implies that for 2 message objects which have the same CAN identifier, but different DIR bit, the one with DIR = 1 (send data frame) shall be transmitted before the message object with DIR = 0, which sends a remote frame. The transmit filtering logic of the MultiCAN leads to a reverse order, i.e the remote frame is transmitted first. Message objects with different identifiers are handled correctly.

#### Workaround

None.

#### MultiCAN TC.028 SDT behavior

#### Correct behavior

Standard message objects:

MultiCAN clears bit MOCTR.MSGVAL after the successful reception/transmission of a CAN frame if bit MOFCR.SDT is set.

Transmit Fifo slave object:

MultiCAN clears bit MOCTR.MSGVAL after the successful reception/transmission of a CAN frame if bit MOFCR.SDT is set. After a transmission, MultiCAN also looks at the respective transmit FIFO base object and clears bit MSGVAL in the base object if bit SDT is set in the base object and pointer MOFGPR.CUR points to MOFGPR.SEL (after the pointer update).

Gateway Destination/Fifo slave object:

MultiCAN clears bit MOCTR.MSGVAL after the storage of a CAN frame into the object (gateway/FIFO action) or after the successful transmission of a CAN frame if bit MOFCR.SDT is set. After a reception, MultiCAN also looks at the respective FIFO base/Gateway source object and clears bit MSGVAL in the base object if bit SDT is set in the base object and pointer MOFGPR.CUR points to MOFGPR.SEL (after the pointer update).



#### **Problem description**

Standard message objects:

After the successful transmission/reception of a CAN frame, MultiCAN also looks at message object given by MOFGPR.CUR. If bit SDT is set in the referenced message object, then bit MSGVAL is cleared in the message object CUR is pointing to.

Transmit FIFO slave object:

Same wrong behaviour as for standard message object. As for transmit FIFO slave objects CUR always points to the base object, the whole transmit FIFO is set invalid after the transmission of the first element instead after the base object CUR pointer has reached the predefined SEL limit value.

Gateway Destination/Fifo slave object:

Correct operation of the SDT feature.

#### Workaround

Standard message object:

Set pointer MOFGPR. CUR to the message number of the object itself.

Transmit FIFO:

Do not set bit MOFCR.SDT in the transmit FIFO base object. Then SDT works correctly with the slaves, but the FIFO deactivation feature by CUR reaching a predefined limit SEL is lost.

## MultiCAN TC.029 Tx FIFO overflow interrupt not generated

## Specified behaviour

After the successful transmission of a Tx FIFO element, a Tx overflow interrupt is generated if the FIFO base object fulfils these conditions:

- Bit MOFCR.OVIE=1, AND
- MOFGPR.CUR becomes equal to MOFGPR.SEL



#### Real behaviour

A Tx FIFO overflow interrupt will not be generated after the transmission of the Tx FIFO base object.

#### Workaround

If Tx FIFO overflow interrupt needed, take the FIFO base object out of the circular list of the Tx message objects. That is to say, just use the FIFO base object for FIFO control, but not to store a Tx message.



Figure 6 FIFO structure



## <u>MultiCAN\_TC.030</u> Wrong transmit order when CAN error at start of CRC transmission

The priority order defined by acceptance filtering, specified in the message objects, define the sequential order in which these messages are sent on the CAN bus. If an error occurs on the CAN bus, the transmissions are delayed due to the destruction of the message on the bus, but the transmission order is kept. However, if a CAN error occurs when starting to transmit the CRC field, the arbitration order for the corresponding CAN node is disturbed, because the faulty message is not retransmitted directly, but after the next transmission of the CAN node.



Figure 7

#### Workaround

None.

## MultiCAN\_TC.031 List Object Error wrongly triggered

If the first list object in a list belonging to an active CAN node is deallocated from that list position during transmit/receive acceptance filtering (happening during message transfer on the bus), then a "list object" error may occur (NSRx.LOE=1\_B), which will cause that effectively no acceptance filtering is performed for this message by the affected CAN node.

#### As a result:

 for the affected CAN node, the CAN message during which the error occurs will not be stored in a message object. This means that although the message is acknowledged on the CAN bus, its content will be ignored.



- the message handling of an ongoing transmission is not disturbed, but the transmission of the subsequent message will be delayed, because transmit acceptance filtering has to be started again.
- message objects with pending transmit request might not be transmitted at all due to failed transmit acceptance filtering.

#### Workaround

#### EITHER:

- Avoid deallocation of the first element on active CAN nodes. Dynamic reallocations on message objects behind the first element are allowed, OR
- Avoid list operations on a running node. Only perform list operations, if CAN node is not in use (e.g. when NCRx.INIT=1<sub>B</sub>)

### MultiCAN TC.032 MSGVAL wrongly cleared in SDT mode

When Single Data Transfer Mode is enabled (MOFCRn.SDT= $\mathbf{1}_B$ ), the bit MOCTRn.MSGVAL is cleared after the reception of a CAN frame, no matter if it is a data frame or a remote frame.

In case of a remote frame reception and with MOFCR.FRREN =  $0_B$ , the answer to the remote frame (data frame) is transmitted despite clearing of MOCTRN.MSGVAL (incorrect behaviour). If, however, the answer (data frame) does not win transmit acceptance filtering or fails on the CAN bus, then no further transmission attempt is made due to cleared MSGVAL (correct behaviour).

#### Workaround

To avoid a single trial of a remote answer in this case, set MOFCR.FRREN =
 1<sub>B</sub> and MOFGPR.CUR = this object.

## MultiCAN TC.035 Different bit timing modes

Bit timing modes (NFCRx.CFMOD= $10_B$ ) do not conform to the specification.



When the modes  $001_B$ - $100_B$  are set in register NFCRx.CFSEL, the actual configured mode and behaviour is different than expected.

Table 15

| Bit timing mode (NFCR.CFSEL) according to spec | Value to be written to NFCR.CFSEL instead     | Measurement                                                                                                                                                                                            |
|------------------------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 001 <sub>B</sub>                               | Mode is missing (not implemented) in MultiCAN | Whenever a recessive edge (transition from 0 to 1) is monitored on the receive input the time (measured in clock cycles) between this edge and the most recent dominant edge is stored in CFC.         |
| 010 <sub>B</sub>                               | 011 <sub>B</sub>                              | Whenever a dominant edge is received as a result of a transmitted dominant edge the time (clock cycles) between both edges is stored in CFC.                                                           |
| 011 <sub>B</sub>                               | 100 <sub>B</sub>                              | Whenever a recessive edge is received as a result of a transmitted recessive edge the time (clock cycles) between both edges is stored in CFC.                                                         |
| 100 <sub>B</sub>                               | 001 <sub>B</sub>                              | Whenever a dominant edge that qualifies for synchronization is monitored on the receive input the time (measured in clock cycles) between this edge and the most recent sample point is stored in CFC. |

### Workaround

None.



#### MultiCAN TC.037 Clear MSGVAL

#### Correct behaviour:

When MSGVAL is cleared for a message object in any list, then this should not affect the other message objects in any way.

Message reception (wrong behaviour):

Assume that a received CAN message is about to be stored in a message object A, which can be a standard message object, FIFO base, FIFO slave, gateway source or gateway destination object.

If during of the storage action the user clears <code>MOCTR.MSGVAL</code> of message object B in any list, then the MultiCAN module may wrongly interpret this temporarily also as a clearing of <code>MSGVAL</code> of message object A. The result of this is that the message is not stored in message object A and is lost. Also no status update is performed on message object A (setting of <code>NEWDAT</code>, <code>MSGLST</code>, <code>RXPND</code>) and no message object receive interrupt is generated. Clearing of <code>MOCTR.MSGVAL</code> of message object B is performed correctly.

Message transmission (wrong behaviour):

Assume that MultiCAN is about to copy the message content of a message object A into the internal transmit buffer of the CAN node for transmission.

If during of the copy action the user clears <code>MOCTR.MSGVAL</code> of message object B in any list, then the MultiCAN module may wrongly interpret this also as a clearing of <code>MSGVAL</code> of message object A. The result of this is that the copy action for message A is not performed, bit <code>NEWDAT</code> is not cleared and no transmission takes place (clearing <code>MOCTR.MSGVAL</code> of message object B is performed correctly). In case of idle CAN bus and the user does not actively set the transmit request of any message object, this may lead to not transmitting any further message object, even if they have a valid transmit request set.

## Single data transfer feature:

When the MultiCAN module clears MSGVAL as a result of a single data transfer (MOFCR.SDT = 1 in the message object), then the problem does not occur. The problem only occurs if MSGVAL of a message object is cleared via CPU.



#### Workaround

Do not clear MOCTR.MSGVAL of any message object during CAN operation. Use bits MOCTR.RXEN, MOCTR.TXEN0 instead to disable/reenable reception and transmission of message objects.

#### MultiCAN TC.038 Cancel TXRQ

When the transmit request of a message object that has won transmit acceptance filtering is cancelled (by clearing MSGVAL, TXRQ, TXENO or TXEN1), the CAN bus is idle and no writes to MOCTR of any message object are performed, then MultiCAN does not start the transmission even if there are message objects with valid transmit request pending.

#### Workaround

To avoid that the CAN node ignores the transmission:

take a dummy message object, that is not allocated to any CAN node.
 Whenever a transmit request is cleared, set TXRQ of the dummy message object thereafter. This retriggers the transmit acceptance filtering process.

or:

 whenever a transmit request is cleared, set one of the bits TXRQ, TXENO or TXEN1, which is already set, again in the message object for which the transmit request is cleared or in any other message object. This retriggers the transmit acceptance filtering process.

## OCDS\_XC8.008 Watchdog Timer behavior during Debug with Suspend

The WDT may be enabled for suspend (stops counting) in debug mode.

In this suspended state, when the WDT is refreshed by writing WDTCON.WDTRS, the timer base counter which provide the clock to WDT is not refreshed to zero.

The effect is that on exiting Monitor Mode in user mode, the WDT may count a little shorter to overflow. This shortened time is less than one WDT count.



#### Workaround

None. This WDT behavior occurs only during debug where WDT is enabled for suspend.

#### PIN XC8.005 Glitches on TCK when switching between clock sources

The JTAG clock input, TCK, has 2 possible sources: P0.0 and P2.0. Unexpected glitches may occur when the clock source is switched from one source to the other.

These glitches may potentially bring the system into an undefined state.

#### Workaround

To prevent the occurrence of such glitches during the clock switching, the user has to configure both pins as input and drive them to either all zero or all one before switching the clock source from one pin to another.

## PIN XC8.006 Port 4 pads (excluding P4.2) toggle once upon a power-on or hardware reset

All Port 4 pads, excluding P4.2, are stated to have Hi-Z as the reset state. However, these pads are pulled up internally when a power-on or hardware reset is asserted. They are returned to the Hi-Z state with internal pull-ups disabled only after the reset is deasserted. The result is that these pads toggle once upon a power-on or hardware reset.

#### Workaround

There are two proposed workarounds:

- 1. Implement external pulls on the external circuitry to prevent the toggle of the Port 4 pins. In case low level is required, strong external pull-downs (in the range of 2 k $\Omega$  to 3 k $\Omega$ ) must be used.
- Use alternate pins of the same function from the other ports. For example, for motor control applications which make use of the CCU6 output pins, Port 3 pins can be used instead.



## <u>UART\_XC8.001</u> Bits RB8, TI and RI in UART1\_SCON SFR cannot be Written by SETB, CLR and CPL Instructions

The bits RB8, TI and RI in UART1\_SCON SFR, which is a bitaddressable SFR, are not updated when written with SETB, CLR and CPL instructions. As a result, the UART1 module is not fully compatible with standard 8051 code.

#### Workaround

Use MOV bit, C instruction to write to the bits RB8, TI and RI in UART1\_SCON SFR or target the write access on the whole register.



**Deviations from Electrical- and Timing Specification** 

# 3 Deviations from Electrical- and Timing Specification



Rel. 1.2, 24.11.2006

## 4 Application Hints

## <u>ADC\_XC8.H001</u> Arbitration mode when using external trigger at the selected input line REQTR

If an external trigger is expected at the selected input line REQTR to trigger a pending request, the arbitration mode should be set (PRAR.ARBM=1) where the arbitration is started by pending conversion request. This selection will minimize the jitter between asynchronous external trigger with respect to the arbiter and the start of the conversion. The jitter can only be minimized while no other conversion is running and no higher priority conversion can cancel the triggered conversion. In this case, a constant delay (no jitter) has to be taken into account between the trigger event and the start of the conversion.

## BROM\_XC8.H001 SYSCON0.RMAP handling in ISR

The ISR has to handle SYSCON0.RMAP correctly when Flash user routines provided in the Boot ROM are used together with the interrupt system. Any ISR with the possibility of interrupting these user routines has to do the following in the interrupt routine:

save the value of the RMAP bit at the beginning restore the value before the exit

This is to prevent access of the wrong address map upon return to the Flash user routine since the RMAP bit may be changed within the interrupt routine. The critical point is when Flash user routines sets RMAP to '1' and the interrupt occurs that needs RMAP at '0' in the ISR.

Please note that NMI is an interrupt as well.



## <u>BROM\_XC8.H002</u> Obtain Product Derivative Information With Chip Identification Number

The chip identification number is an unique 4-byte data that is assigned to each product derivative based on the following differentiations:

- product
- variant type
- device-step

Therefore, to identify a product derivative, the number can be obtained and matched to a list of product derivatives and their corresponding numbers, which can be found in the latest product data sheet.

The number is read using the in-application user subroutine, GET\_CHIP\_INFO, or BSL mode A. Description on the usage of GET\_CHIP\_INFO and BSL mode A can be found in the latest user's manual.

### INT XC8.H003 Interrupt Flags of External Interrupt 0 and 1

External interrupt 0 and 1 may individually be selected via respective bits (EXINTx) in EXICONO register, to request interrupt on falling edge, rising edge, both edges or to bypass the edge detection.





#### Figure 8

Edge detection is done in the system unit. If enabled, an active event will set the EXINTx flag and correspondingly set the IEx flag in TCON. It should be noted that after any external interrupt x event, flag EXINTx must be cleared. In case of falling edge as active event, this allows any future active event to be able to set the flag IEx as interrupt request. In case of low level as active event, this prevents unintended recurring triggering of interrupt request.

Besides the above notes, the following should be noted on the behavior regarding setting and clearing of the external interrupt x (x = 0 or 1) flags, applicable to both edge and bypass edge detection modes:

## Setting of External Interrupt x Flags

- 1. The flag TCON. IEX will be set in all modes selectable via EXICONO register.
- 2. Flag IRCONO.EXINTX will be set in all modes as long as an active edge is detected; flag EXINTX will not be set for low level as active event.



### Clearing of External Interrupt x Flags

- Flag IEx is cleared automatically by hardware when the interrupt is being vectored to.
- 2. Flag EXINTx has to be cleared by software.
- 3. Clearing one external interrupt x flag will not clear the other. Especially, clearing flag EXINTX will not clear the flag IEX. Being of interrupt structure 1, the flag IEX is the request polled by the CPU for interrupt servicing. Therefore user has to take care to clear the flag IEX before switching from SW polling method to enabling the external interrupt x node, to prevent potential dummy interrupt request.
- 4. Always clear both EXINTX and IEX flags before (if) changing the trigger select in EXICONO register.

### INT XC8.H004 NMI Interrupt Request With No NMI Flag Set

It might occur in the application, that sometimes NMI interrupt requests are serviced, but no active NMI interrupt flags are found.

Consider the following NMI interrupt service routine pseudo-code, and scenerio where a NMI interrupt source A event leads to interrupt request of the NMI node and CPU vectors to the NMI interrupt routine. Meanwhile, NMI interrupt source B and its flag becomes active any time in the duration indicated by T:



Figure 9

In this case, NMI flag B will be cleared as a standard procedure by the NMI interrupt routine in the current service. However, the pending interrupt request for the NMI node remains activated after RETI, as it is only cleared by hardware when CPU acknowledge the NMI interrupt and vectors to the NMI service routine.

This leads to following servicing of the NMI interrupt node again, but potentially no active NMI flag is found, i.e. dummy NMI interrupt service. The point to note is that the NMI interrupt source B is not lost, as it was actually serviced in the current service of the NMI interrupt node.

The recommendation is to ignore these dummy NMI interrupt vectoring.

## INT\_XC8.H005 Not all Flags are qualified for clearing Pending Interrupt Request

For interrupts of structure 2, qualified event (status) flags are used for clearing any pending interrupt request to the core. An event flag is qualified as long as the event is enabled for interrupt. By this means, as long as all qualified flags of the node are cleared, any still active pending interrupt request to the core will be cleared by hardware.

However with existing implementation, not all event flags are qualified for clearing the pending interrupt request to core. These flags are listed in the following table, corresponding to the interrupt node the flag belongs to.

Table 16

| Interrupt<br>Node | Vector<br>Address | Assignment          | Unqualified Flags<br>Belonging to Node |
|-------------------|-------------------|---------------------|----------------------------------------|
| NMI               | 0073 <sub>H</sub> | Watchdog Timer NMI  | NMIWDT                                 |
|                   |                   | PLL NMI             | NMIPLL                                 |
|                   |                   | Flash NMI           | NMIFLASH                               |
|                   |                   | OCDS NMI            | NMIOCDS                                |
|                   |                   | VDDC Prewarning NMI | NMIVDD                                 |
|                   |                   | VDDP Prewarning NMI | NMIVDDP                                |
|                   |                   | Flash ECC NMI       | NMIECC                                 |



Table 16

| Interrupt<br>Node | Vector<br>Address | Assignment                                         | Unqualified Flags<br>Belonging to Node |
|-------------------|-------------------|----------------------------------------------------|----------------------------------------|
| XINTR5            | 002B <sub>H</sub> | LIN                                                | EOFSYN, ERRSYN                         |
| XINTR8            | 0043 <sub>H</sub> | External Interrupt 2                               | EXINT2                                 |
|                   |                   | CORDIC                                             | EOC                                    |
|                   |                   | UART1                                              | RI, TI                                 |
|                   |                   | UART1 Fractional Divider (Normal Divider Overflow) | NDOV                                   |
|                   |                   | MDU                                                | IRDY, IERR                             |
| XINTR9            | 004B <sub>H</sub> | External Interrupt 3                               | EXINT3                                 |
|                   |                   | External Interrupt 4                               | EXINT4                                 |
|                   |                   | External Interrupt 5                               | EXINT5                                 |
|                   |                   | External Interrupt 6                               | EXINT6                                 |

Note: Some events e.g. TF2, EXF2 of Timer 2, Timer21; NDOV of UART; NDOV, RI and TI of UART1 do not have separate interrupt enable apart from its interrupt node enable. These event flags are therefore always qualified, if the interrupt node is enabled.

Consider the case where an enabled interrupt node is shared by more than 2 events, and where at least two of the events (A and B) are enabled for interrupt while at least one event (C) is not enabled for interrupt. In this case, flag C is one of the flags listed in above table.

While the interrupt routine is already running due to event A having occurred, event B and C occurs any time in the duration indicated by T:





#### Figure 10

This sets the pending interrupt request while flag B is set.Although event B is serviced and flag B is cleared in the following service routine, on return from interrupt, the pending interrupt request remains activated. This is because event C is not enabled for interrupt (and therefore flag C is neither checked nor cleared in the interrupt routine) while flag C is not qualified. This leads to following servicing of the interrupt node again, but potentially no active flag is found, i.e. dummy interrupt service. To prevent such dummy interrupt vectoring on the above listed interrupt nodes, do not use mixed interrupt servicing and polling scheme, i.e, enable all events of the node for interrupt if interrupt node is enabled. Otherwise if mixed interrupt servicing and polling scheme is to be used, ignore these dummy interrupt vectoring.

### MultiCAN TC.H002 Double Synchronization of receive input

The MultiCAN module has a double synchronization stage on the CAN receive inputs. This double synchronization, delays the receive data by 2 module clock cycles. If the MultiCAN is operating at a low module clock frequencies and high CAN baudrate, this delay may become significant and has to be taken into account when calculating the overall physical delay on the CAN bus (transceiver delay...).



## <u>MultiCAN\_TC.H003</u> Message may be discarded before transmission in STT mode

If MOFCRn.STT=1 (Single Transmit Trial enabled), bit TXRQ is cleared (TXRQ=0) as soon as the message object has been selected for transmission and, in case of error, no retransmission takes places.

Therefore, if the error occurs between the selection for transmission and the real start of frame transmission, the message is actually never sent.

#### Workaround

In case the transmission shall be guaranteed, it is not suitable to use the STT mode. In this case, MOFCRN.STT shall be 0.

## OCDS\_XC8.H002 Any NMI request is lost on Debug entry and during Debug

All NMI events are disabled while in debug mode. This has two main effects:

- On debug entry, any pending NMI request will be lost, although the status flag remains set. The probability of losing an NMI request in this way is very low, since NMI always has the highest priority to be serviced.
- Any NMI event that occurs during debugging is not able to generate an NMI
  request (event interrupt is lost) although the status flag will be set. It is
  normally not critical that on exit from debug mode, the CPU must service
  NMI requests that had occurred while in debug mode.

The fact that the debug system is not specified to support NMI interrupt while in debug mode makes the above trivial. As precaution, avoid starting any debug session while expecting an NMI event.