### **INTEGRATED CIRCUITS** # **ERRATA SHEET** Date: 2008 July 9 Document Release: Version 1.0 Device Affected: LPC2106/01 This errata sheet describes both the known functional problems and any deviations from the electrical specifications known at the release date of this document. Each deviation is assigned a number and its history is tracked in a table at the end of the document. 2008 July 9 ## **Document revision history** | Rev | Date | Description | |-----|--------------|------------------| | 1.0 | July 9, 2008 | 1. First Version | 2008 July 9 2 #### Identification: The LPC2106/01 devices typically have the following top-side marking: LPC2106xxx /01 XXXXXX **xxYYWWR** The last letter in the last line (field 'R') will identify the device revision. This Errata Sheet covers the following revisions of the LPC2106/01: | Revision Identifier (R) | Comment | |-------------------------|-------------------------| | 'E' | Initial device revision | Field 'YY' states the year the device was manufactured. Field 'WW' states the week the device was manufactured during that year. 2008 July 9 3 #### **Errata Overview - Functional Problems** | Functional<br>Problem | Short Description | Device Revision<br>the problem<br>occurs in | |-----------------------|-------------------------------------|---------------------------------------------| | Core.1 | Incorrect load of the link register | Е | #### **Errata Overview - AC/DC Deviations** | AC/DC<br>Deviation | Short Description | Device Revision<br>the deviation<br>occurs in | |--------------------|-------------------|-----------------------------------------------| | N/A | N/A | N/A | #### **Errata Notes** | | Note | Short Description | |---|------|-------------------| | ľ | N/A | N/A | #### Functional Problems of LPC2106/01 #### Core.1 Incorrect update of the Abort Link register in Thumb state Introduction: If the processor is in Thumb state and executing the code sequence STR, STMIA or PUSH followed by a PC relative load, and the STR, STMIA or PUSH is aborted, the PC is saved to the abort link register. Problem: In this situation the PC is saved to the abort link register in word resolution, instead of half-word resolution. Conditions: The processor must be in Thumb state, and the following sequence must occur: <any instruction> <STR, STMIA, PUSH> <---- data abort on this instruction LDR rn, [pc,#offset] In this case the PC is saved to the link register R14\_abt in only word resolution, not half-word resolution. The effect is that the link register holds an address that could be #2 less than it should be, so any abort handler could return to one instruction earlier than intended. Work around: In a system that does not use Thumb state, there will be no problem. In a system that uses Thumb state but does not use data aborts, or does not try to use data aborts in a recoverable manner, there will be no problem. Otherwise the workaround is to ensure that a STR, STMIA or PUSH cannot precede a PC-relative load. One method for this is to add a NOP before any PC-relative load instruction. However this is would have to be done manually. 2008 July 9 5