

## Freescale Semiconductor Mask Set Errata

MSE9S08SG8\_2M84G Rev. 4, 4/2009

## Mask Set Errata for Mask 2M84G

#### Introduction

This report applies to mask 2M84G for these products:

- MC9S08SG8
- MC9S08SG4

## MCU device mask set identification

The mask set is identified by a 5-character code consisting of a version number, a letter, two numerical digits, and a letter, for example 0J27F. All standard devices are marked with a mask set number and a date code.

## MCU device date codes

Device markings indicate the week of manufacture and the mask set used. The date is coded as four numerical digits where the first two digits indicate the year and the last two digits indicate the work week. For instance, the date code "0301" indicates the first week of the year 2003.

# MCU device part number prefixes

Some MCU samples and devices are marked with an SC, PC, or XC prefix. An SC prefix denotes special/custom device. A PC prefix indicates a prototype device which has undergone basic testing only. An XC prefix denotes that the device is tested but is not fully characterized or qualified over the full range of normal manufacturing process variations. After full characterization and qualification, devices will be marked with the MC or SC prefix.

SE162-SGx-IO-POR: Brief Pulse on Input/Output Pins during Power-On-Reset

Errata type: Silicon
Affected component: I/O





**Description:** During a power-on-reset, a brief pulse occurs on I/O pins. The brief pulse,

which is due to the gating of the integrated pullup resistors, may be able to drive active-high output circuits (for example, relay drivers or NPN transistors)

momentarily. Input circuits are not affected.

Workaround: Add an external RC filter to the output port pin, where necessary, for control

sensitive applications. Refer to Engineering Bulletin EB709 for information.

## SE156-ADC-COCO: COCO bit may not get cleared when ADCSC1 is written to

Errata type: Silicon

Affected component: ADC

**Description:** If an ADC conversion is near completion when the ADC Status and Control

1 Register (ADCSC1) is written to (i.e., to change channels), it is possible for the conversion to complete, setting the COCO bit, before the write instruction is fully executed. In this scenario, the write may not clear the COCO bit, and the data in the ADC Result register (ADCR) will be that of the recently

completed conversion.

If interrupts are enabled, then the interrupt vector will be taken immediately

following the write to the ADCSC1 register.

**Workaround:** It is recommended when writing to the ADCSC1 to change channels or stop

continuous conversion, that you write to the register twice. The first time should be to turn the ADC off and disable interrupts, and the second should

be to select the mode/channel and re-enable the interrupts.

# SE157-ADC-INCORRECT-DATA: Boundary case may result in incorrect data being read in 10- and 12-bit modes

iii io ana iz bitinot

Errata type: Silicon

Affected component: ADC

**Description:** In normal 10-bit or 12-bit operation of the ADC, the coherency mechanism

will freeze the conversion data such that when the high byte of data is read, the low byte of data is frozen, ensuring that the high and low bytes represent

result data from the same conversion.

In the errata case, there is a single-cylce (bus clock) window per conversion cycle when a high byte may be read on the same cycle that subsequent a conversion is completing. Although extremely rare due to the precise timing required, in this case, it is possible that the data transfer occurs, and the low byte read may be from the most recently completed conversion.

In systems where the ADC is running off the bus clock, and the data is read immediately upon completion of the conversion, the errata will not occur. Also, in single conversion mode, if the data is read prior to starting a new conversion, then the errata will not occur.

The errata does not impact 8-bit operation.

Introducing significant delay between the conversion completion and reading the data, while a following conversion is executing/pending, could increase the probability for the errata to occur. Nested interrupts, significant differences

Mask Set Errata for Mask 2M84G, Rev. 4, 4/2009

2 Freescale Semiconductor



between the bus clock and the ADC clock, and not handling the result register reads consecutively, can increase the delay and therefore the probability of the errata occuring.

Workaround: Using the device in 8-bit mode will eliminate the possibility of the errata

occuring.

Using the ADC in single conversion mode, and reading the data register prior to initiating a subsequent conversion will eliminate the possibility of the errata occuring.

Minimizing the delay between conversion complete and processing the data can minimize the risk of the errata occuring. Disabling interrupts on higher priority modules and avoiding nested interrupts can reduce possible contentions that may delay the time from completing a conversion and handling the data. Additionally, increasing the bus frequency when running the ADC off the asynchronous clock, may reduce the delay from conversion complete to handling of the data.

## SE147-GNGC: Ganged Output Drive Control Register is not one-time writable

Errata type: Silicon

Affected component: ICS

**Description:** The ganged output drive control register (GNGC) is intended to be a write

once register that enables the ganged output to take over up to 8 pins, enabling them as outputs and tying their data, drive strength, and slew rate control to PTC0 control bits. In normal usage, these pins would be shorted externally to be able to drive higher mA currents to an external component

(i.e., H-bridge).

For this maskset, the ganged port control register can be written more than

once.

In the scenario of code runaway, it might be possible to overwrite this register, relinquishing control of certain pins back to their respective control bits (i.e., PTCD\_PTCD1, PTCDD\_PTCDD1, PTCDS\_PTCDS1, etc). In this scenario, depending on what is in those control bits for the shorted pins, it is possible to end up with shorted output trying to drive different logic levels. This may result in a large current short, that could lead to damage of the MCU.

Workaround: Assuming user code avoids improperly configuring pins, this condition would

be caused by code runaway. As such, proper precautions need to be taken to protect against code runaway and minimize any stresses on the part or

application failures.

The COP/watchdog timer should be used to reset the part in the instance of code runaway. And, the LVD should be used to ensure device integrity with

proper operating voltage.

Additionally, stress to the MCU can be minimized by configuring any shorted ganged ports as inputs when not controlled by the ganged output. This way, if runaway code affects the GNGC register, any outputs will be driving inputs,

as opposed to outputs.

## SE143-ICS: ICS Internal Reference Can Remain Enabled in Stop3 Mode

Mask Set Errata for Mask 2M84G, Rev. 4, 4/2009

Freescale Semiconductor 3



Errata type: Silicon
Affected component: ICS

**Description:** When transitioning from FEI or FBI modes to FEE or FBE modes, the internal

reference clock may remain active in stop3 mode if the STOP instruction is executed soon after the IREFST bit in the ICSSC register clears. This can

lead to elevated stop3 I<sub>DD</sub>.

Workaround: To ensure the internal reference clock is disabled before entering stop3, wait

three internal reference clock periods after the IREFST bit has cleared before entering stop3. On a device with a trimmed internal reference, one period will be between 25.6  $\mu$ s and 32  $\mu$ s, therefore waiting 100  $\mu$ s is adequate for all

trimmed devices.

Or

To ensure the internal reference clock is disabled before entering stop3, transition into FEE mode and wait until the LOCK status bit indicates the FLL has attained lock before entering stop3 or transitioning into FBE mode and

entering stop3.

## SE133-FLASH: Unexpected Flash Block Protection Errors

Errata type: Silicon

Affected component: Flash

**Description:** If a portion of the nonvolatile memory (NVM) is block protected, unexpected

flash block protect violation (FPVIOL) errors can result. These errors can occur during an attempt to program or erase locations in areas of the NVM that are not block protected. Software methods can be used to avoid this potential problem. The problem is more likely to be seen on devices that have multiple nonvolatile blocks, including devices with two or more separate flash blocks or with flash plus EEPROM. If block protection is not enabled, no errors

occur.

This error is related to logic that compares current block protection settings to an internally latched address. This internal address is written (latched) at reset, at the end of most flash commands, and whenever there is a write to a location in NVM. If a read access to the partially protected NVM is performed immediately before the write to unprotected memory that starts a new flash command, the erroneous address that was previously in the internal latch can cause a false indication of a protection violation. A short sequence of instructions can be performed before starting normal flash commands to ensure that the address in the internal latch is not a protected address.

**Workaround:** The preferred workaround starts a command to a known unprotected address

(which internally latches the known-unprotected address), forces an access error to abort that command, and then clears the resulting error flags before starting any new flash command. This workaround assumes the H:X index register points to the location or sector you want to program or erase, and accumulator A has the data value you plan to write to that location. Start your

program or erase routine with the following instructions.

STA ,X ;latch the unprotected address from H:X NOP ;brief delay to allow the command state machine to start

Mask Set Errata for Mask 2M84G, Rev. 4, 4/2009

4 Freescale Semiconductor



```
STA
                        , X
                               ;intentionally cause an access
error to abort this command
                PSHA
                               ;temporarily save data value
                       #$30
                               ;1's in PVIOL and ACCERR bit
                LDA
positions
                STA
                       FSTAT
                              ;clear any error flags
                PULA
                               ;restore data value
                STA
                               ;STEP 1 write data to start new
                        ,Х
command
```

The only new instructions compared to the normal routine for flash commands are the first three instructions, which take three bytes of code space and five bus cycles. These instructions may be located anywhere in memory, including in the protected area of the flash memory.



#### How to Reach Us:

#### **Home Page:**

www.freescale.com

### Web Support:

http://www.freescale.com/support

#### **USA/Europe or Locations Not Listed:**

Freescale Semiconductor
Technical Information Center, EL516
2100 East Elliot Road
Tempe, Arizona 85284
+1-800-521-6274 or +1-480-768-2130
www.freescale.com/support

#### Europe, Middle East, and Africa:

Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German)

Japan:

Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com

+33 1 69 35 48 48 (French)

www.freescale.com/support

#### Asia/Pacific:

Freescale Semiconductor China Ltd.
Exchange Building 23F
No. 118 Jianguo Road
Chaoyang District
Beijing 100022
China
+86 10 5879 8000
support.asia@freescale.com

#### For Literature Requests Only:

Freescale Semiconductor Literature Distribution Center 1-800-441-2447 or +1-303-675-2140

Fax: +1-303-675-2150

 $LDCF or Free scale Semiconductor @\,hibbert group.com$ 

Information in this document is provided solely to enable system and sofware implementers to use Freescale Semiconductors products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document.

Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation, or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any liability, including without limitation consequential or incidental damages. "Typical" parameters that may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals", must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor prodcuts are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which failure of the Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify Freescale Semiconductor and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claims alleges that Freescale Semiconductor was negligent regarding the design or manufacture of the part.

RoHS-compliant and/or Pb-free versions of Freescale products have the functionality and electrical characteristics as their non-RoHS-complaint and/or non-Pb-free counterparts. For further information, see http://www.freescale.com or contact your Freescale sales representative.

For information on Freescale's Environmental Products program, go to http://www.freescale.com/epp.

Freescale<sup>TM</sup> and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners.

© Freescale Semiconductor, Inc.2009. All rights reserved.

