

# PIC16C924

# PIC16C924 Rev. A Silicon Errata Sheet

The PIC16C924 (Rev. A) parts you have received conform functionally to the Device Data Sheet (DS30444**D**), except for the anomalies described below.

All the problems listed here will be addressed in future revisions of the PIC16C924 silicon.

## 1. Module: 8-bit A/D Module

If the Analog Port is configured so that all analog pins are digital inputs (PCFG2:PCFG0 = 11xb), then doing a conversion on any pin of the analog port will give a result of ADRES = 0xFF.

## Work Around

Configure the PCFG2:PCFG0 bits to a value that has any pin of the analog port configured as an analog input (such as PCFG2:PCFG0 = 100b). Conversion on any pin of the analog port (analog or digital) will now convert as expected.

# 2. Module: CCP (Compare Mode)

The Compare mode may not operate as expected when configuring the compare match to drive the I/O pin low (CCPxM<3:0> = 1001).

When the CCP module is changed to compare output low (CCPxM<3:0> = 1001) from any other noncompare CCP mode, the I/O pin will immediately be driven low regardless of the state of the I/O data latch. The pin will remain low when the compare match occurs (see Table 1).

However, when the CCP module is changed to compare output high (CCPxM<3:0> = 1000) from any other CCP mode, the I/O pin will immediately be driven low regardless of the state of the I/O data latch. The pin will be driven high when the compare match occurs.

TABLE 1: Compare Output Low Switching

| CCP Mode<br>CCPxM<3:0> = | I/O pin<br>State | Change CCP to CCPxM<3:0> = |      |  |  |
|--------------------------|------------------|----------------------------|------|--|--|
| CCFXW(<3.0> =            | State            | 1001                       | 1000 |  |  |
| 0xxx                     | Н                | L                          | L    |  |  |
| OXXX                     | L                | L                          | L    |  |  |
| 1000                     | Н                | Н                          | _    |  |  |
| 1000                     | L                | L                          | _    |  |  |
| 1001                     | Н                | _                          | L    |  |  |
| 1001                     | L                | _                          | L    |  |  |
| 101x                     | Н                | L                          | L    |  |  |
| 101x                     | L                | L                          | L    |  |  |
| 11xx                     | Н                | L                          | L    |  |  |
| 1133                     | L                | L                          | L    |  |  |

# Work Around

To have the I/O pin high until the compare match low occurs, force a compare match high to get the I/O pin into the high state, then reconfigure the compare match to force the I/O low, when the compare condition occurs.

Note: As with any windowed EPROM device, please cover the window at all times, except when erasing.

# 3. Module: CCP (Compare Mode)

The special event trigger of the Compare mode may not occur if both of the following conditions exist:

- An instruction one cycle (TcY) prior to a Timer1/ Compare register match has literal data equal to the address of a CCP register being used.<sup>(1)</sup>
- An instruction in the same cycle as a Timer1/ Compare register match has an MSb of '0'.

The interrupt for the compare event will still be generated, but no special event trigger will occur.

Note 1: 15h(CCPR1L), 16h(CCPR1H) or 17h(CCP1CON) for CCP1.

## Work Around

Use the interrupt service routine instead of using the special event trigger to reset Timer1 (and start an A/D conversion, if applicable).

# 4. Module: SSP Module (I<sup>2</sup>C mode)

If the bus is active when the  $I^2C$  mode is enabled, and the next 8-bits of data on the bus match the address of the device, then the SSP module will generate an acknowledge pulse.

## Work Around

Before enabling the I<sup>2</sup>C mode, ensure that the bus is not active.

# 5. Module: SSP (SPI Mode)

The Synchronous Serial Port module in SPI Master mode only allows the transmission of 1 byte of data at a time. The module must be disabled and then reenabled between each byte transmission.

# Work Around

Once the SSP module has been configured in SPI Master mode and one byte of data has been transmitted, wait for the interrupt flag bit SSPIF (PIR1<3>) or BF(SSPSTAT<0>) to be set. This indicates that the byte of data has been transmitted. Then, disable the SSP by clearing the SSPEN bit of the SSPCON register. Re-enable the SSP by setting the SSPEN bit. The SPI module will now transmit the next data byte written to SSPBUF.

# **Example Code:**

```
movwf SSPBUF ;data byte is ;in W register bsf STATUS, RPO ;change to bank1 wait btfss PIR1, SSPIF ;wait for xmit ;buffer to empty goto wait bcf STATUS, RPO ;change to bank0 bcf SSPCON, SSPEN ;disable SSP bsf SSPCON, SSPEN ;enable SSP
```

When the SSP is disabled, the PORTC data latch value is placed on the pins. The value in bit 3 of PORTC (SCK) should have the same value as the

idle state of SCK. For example, if the clock idles high, then bit 3 of PORTC must be set high. If bit 3 of PORTC is not configured the same as the idle state of the clock, you may experience an additional clock when the SPI is disabled then re-enabled.

# 6. Module: SSP (SPI Mode)

When the SPI is using Timer2/2 as the clock source, a shorter-than-expected SCK pulse may occur on the first bit of the transmitted/received data.

## Example:



# Work Around

To avoid producing the short pulse, turn off Timer2 and clear the TMR2 register, load the SSPBUF with the data to transmit, and then turn Timer2 back on.

## **Example Code:**

```
BSF
          STATUS, RP0
                         ;Bank 1
LOOP BTFSS SSPSTAT, BF
                        ;Data received?
                        ;(Xmit complete?)
    GOTO LOOP
                        ;No
    BCF STATUS, RPO ; Bank 0
    MOVF SSPBUF, W
                       ;W = SSPBUF
    MOVWF RXDATA
                        ;Save in user RAM
    MOVF TXDATA, W
                        ;W = TXDATA
    BCF
          T2CON, TMR2ON ; Timer2 off
          TMR2
                        ;Clear Timer2
    MOVWF SSPBUF
                        ;Xmit New data
    BSF T2CON, TMR2ON ; Timer2 on
```

## 7. Module: Timer0

The TMR0 register may increment when the WDT postscaler is switched to the Timer0 prescaler. If TMR0 = FFh, this will cause TMR0 to overflow (setting T0IF).

# Work Around

Follow the following sequence:

- a) Read the 8-bit TMR0 register into the W register
- b) Clear the TMR0 register
- c) Assign WDT postscaler to Timer0
- d) Write W register to TMR0

## 8. Module: Timer1

The Timer1 value may unexpectedly increment if either the TMR1H or the TMR1L register is written. If Timer1 is ON, then turned OFF, performing any write instruction with TMR1H as the destination may cause TMR1L to increment.

# Example 1:

```
BSF T1CON, TMR1ON
    :
BCF T1CON, TMR1ON
MOVF TMR1H, 1
```

TMR1 value before MOVF instruction:

TMR1H:TMR1L = 3F:00

TMR1 value after MOVF instruction:

TMR1H:TMR1L = 3F:01

# Example 2:

```
BSF T1CON, TMR1ON
     BCF T1CON, TMR1ON
     MOVF TMR1H, 1
TMR1 value before MOVF instruction:
```

TMR1H:TMR1L = FF:FF

TMR1 value after MOVF instruction:

TMR1H:TMR1L = FF:00

If Timer1 is ON, then turned OFF when TMR1H:TMR1L = xx:FF, performing any write instruction with TMR1L as the destination may cause TMR1H to increment.

# Example 1:

```
BSF T1CON, TMR1ON
BCF T1CON, TMR1ON
CLRF TMR1L
```

TMR1 value before CLRF instruction:

TMR1H:TMR1L = FF:FF

TMR1 value after CLRF instruction:

TMR1H:TMR1L = 00:00

(TMR1IF is **not** set.)

## Work Around

To preserve Timer1 register values:

Read Timer1 register values into "shadow" registers. Perform any write instruction(s) on the shadow registers. Write the shadow register values back into the Timer1 registers.

# Clarifications/Corrections to the Data Sheet:

In the Device Data Sheet (DS30444**D**), the following clarifications and corrections should be noted.

## 1. Module: I/O Ports

The specification for the High Voltage Open Drain I/O (The RA4 pin on most devices) cannot be met without possible long term reliability issues on that I/O pin. If a high voltage drive is required, use an external transistor that can support the required voltage.

TABLE 2: DC SPECIFICATION CHANGES FROM DATA SHEET

| Param<br>No. | Sym. | Characteristic          | New Specification |     |     | Data Sheet<br>Specification |     |     | Units |
|--------------|------|-------------------------|-------------------|-----|-----|-----------------------------|-----|-----|-------|
| NO.          | 0.   |                         | Min               | Тур | Max | Min                         | Тур | Max |       |
| D150         | Vod  | Open-drain High Voltage | _                 | _   | 10  | _                           | _   | 14  | V     |

2. Module: 8-Bit A/D

a) The minimum A/D reference voltage has been improved to the values shown in Table 3.

TABLE 3: DC SPECIFICATION CHANGES FROM DATA SHEET

| Parm<br>No. | Sym. | Characteristic | New Specification |       |     | Data Sheet<br>Specification |     |     | Units       |   |
|-------------|------|----------------|-------------------|-------|-----|-----------------------------|-----|-----|-------------|---|
|             | NO.  |                |                   | Min   | Тур | Max                         | Min | Тур | Max         |   |
|             | A20  | VREF           | Reference Voltage | 2.5 * | _   | VDD +<br>0.3 V              | 3.0 | 1   | VDD + 0.3 V | V |

<sup>\*</sup> This parameter is characterized but not tested

# 3. Module: SSP (SPI Mode Timing Specificatios)

a) The SPI interface timings have been modified to the values shown in Table 3.

# TABLE 4: DC SPECIFICATION CHANGES FROM DATA SHEET

| Parm<br>No. | Sym. | Characteristic                                                  |                 | New Specification  |     |     | Data Sheet<br>Specification |      |     | Units |
|-------------|------|-----------------------------------------------------------------|-----------------|--------------------|-----|-----|-----------------------------|------|-----|-------|
|             |      |                                                                 |                 | Min                | Тур | Max | Min                         | Тур  | Max |       |
| 71          | TscH | SCK input high<br>time<br>(slave mode)                          | Continuous      | 1.25Tcy<br>+ 30 ns | _   | _   | Tcy + 20 ns                 | _    | _   | ns    |
| 71A         |      |                                                                 | Single Byte (1) | 40                 | _   | _   |                             | N.A. |     | ns    |
| 72          | TscL | SCK input low time                                              | Continuous      | 1.25Tcy<br>+ 30 ns | _   | _   | Tcy + 20 ns                 | _    | _   | ns    |
| 72A         |      | (slave mode)                                                    | Single Byte (1) | 40                 | _   | _   |                             | N.A. |     | ns    |
| 73A         | Тв2в | Last clock edge of the Byte1 to 1st clock edge of the Byte2 (1) |                 | 1.5 Tcy<br>+ 40 ns | _   | _   |                             | N.A. |     | ns    |

<sup>\*</sup> This parameter is characterized but not tested

Note 1: Specification 73A is only required if specifications 71A and 72A are used.

## 4. Module: Timer1

 The operation of Timer1 needs some clarification when the timer registers are written when the TMR1ON bit is set.

The internal clock signal that is the input to the TMR1 presaler affects the incrementing of Timer1 (TMR1H:TMR1L registers and the Timer1 prescaler). When the Timer1 registers are NOT written, the Timer1 will increment on the rising edge of the TMR1 increment clock.

When the TMR1H and/or TMR1L registers are written while this clock is high, TMR1 will increment on the next rising edge of this clock.

When the TMR1H and/or TMR1L registers are written while this clock is low, TMR1 will not increment on the next rising edge of this clock, but must first have a falling clock and the the rising clock for TMR1 to increment.

Figure 1 shows the two cases of writes to the TMR1H and/or TMR1L registers. Due to the VIH and VIL thresholds on the oscillator/clock pins, external Timer1 oscillator components, and external clock frequency, the Timer1 increment clock may not be of a 50% duty cycle.

The TMR1 increment clock is out of phase of the T1OSO/T1CKI pin by a small propagation delay.

FIGURE 1: WRITES TO TIMER1 (EXTERNAL CLOCK / OSCILLATOR MODE)





# WORLDWIDE SALES AND SERVICE

## **AMERICAS**

# **Corporate Office**

Microchip Technology Inc. 2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-786-7200 Fax: 480-786-7277 Technical Support: 480-786-7627 Web Address: http://www.microchip.com

#### Atlanta

Microchip Technology Inc. 500 Sugar Mill Road, Suite 200B Atlanta, GA 30350 Tel: 770-640-0034 Fax: 770-640-0307

## **Boston**

Microchip Technology Inc. 5 Mount Royal Avenue Marlborough, MA 01752 Tel: 508-480-9990 Fax: 508-480-8575

## Chicago

Microchip Technology Inc. 333 Pierce Road, Suite 180 Itasca, IL 60143

Tel: 630-285-0071 Fax: 630-285-0075

#### **Dallas**

Microchip Technology Inc. 4570 Westgrove Drive, Suite 160 Addison, TX 75248 Tel: 972-818-7423 Fax: 972-818-2924

## Dayton

Microchip Technology Inc. Two Prestige Place, Suite 150 Miamisburg, OH 45342

Tel: 937-291-1654 Fax: 937-291-9175

## Detroit

Microchip Technology Inc. Tri-Atria Office Building 32255 Northwestern Highway, Suite 190 Farmington Hills, MI 48334 Tel: 248-538-2250 Fax: 248-538-2260

# Los Angeles

Microchip Technology Inc. 18201 Von Karman, Suite 1090 Irvine, CA 92612 Tel: 949-263-1888 Fax: 949-263-1338

# **New York**

Microchip Technology Inc. 150 Motor Parkway, Suite 202 Hauppauge, NY 11788 Tel: 631-273-5305 Fax: 631-273-5335

## San Jose

Microchip Technology Inc. 2107 North First Street, Suite 590 San Jose, CA 95131 Tel: 408-436-7950 Fax: 408-436-7955

# **AMERICAS** (continued)

#### **Toronto**

Microchip Technology Inc. 5925 Airport Road, Suite 200 Mississauga, Ontario L4V 1W1, Canada Tel: 905-405-6279 Fax: 905-405-6253

## ASIA/PACIFIC

## **Hong Kong**

Microchip Asia Pacific Unit 2101, Tower 2 Metroplaza 223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2-401-1200 Fax: 852-2-401-3431

# Beijing

Microchip Technology, Beijing Unit 915, 6 Chaoyangmen Bei Dajie Dong Erhuan Road, Dongcheng District New China Hong Kong Manhattan Building Beijing 100027 PRC Tel: 86-10-85282100 Fax: 86-10-85282104

#### India

Microchip Technology Inc. India Liaison Office No. 6, Legacy, Convent Road Bangalore 560 025, India Tel: 91-80-229-0061 Fax: 91-80-229-0062

#### Japan

Microchip Technology Intl. Inc. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa 222-0033 Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122

## Korea

Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea Tel: 82-2-554-7200 Fax: 82-2-558-5934

## Shanghai

Microchip Technology RM 406 Shanghai Golden Bridge Bldg. 2077 Yan'an Road West, Hong Qiao District Shanghai, PRC 200335 Tel: 86-21-6275-5700 Fax: 86 21-6275-5060

## ASIA/PACIFIC (continued)

## Singapore

Microchip Technology Singapore Pte Ltd. 200 Middle Road #07-02 Prime Centre Singapore 188980

Tel: 65-334-8870 Fax: 65-334-8850

# Taiwan, R.O.C

Microchip Technology Taiwan 10F-1C 207 Tung Hua North Road Taipei, Taiwan, ROC Tel: 886-2-2717-7175 Fax: 886-2-2545-0139

# **EUROPE**

## **United Kingdom** Arizona Microchip Technology Ltd.

505 Eskdale Road Winnersh Triangle Wokingham Berkshire, England RG41 5TU Tel: 44 118 921 5858 Fax: 44-118 921-5835

#### Denmark

Microchip Technology Denmark ApS Regus Business Centre Lautrup hoj 1-3 Ballerup DK-2750 Denmark Tel: 45 4420 9895 Fax: 45 4420 9910

## France

Arizona Microchip Technology SARL Parc d'Activite du Moulin de Massy 43 Rue du Saule Trapu Batiment A - Ier Etage 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

## Germany

Arizona Microchip Technology GmbH Gustav-Heinemann-Ring 125 D-81739 München, Germany Tel: 49-89-627-144 0 Fax: 49-89-627-144-44

# Italy

Arizona Microchip Technology SRL Centro Direzionale Colleoni Palazzo Taurus 1 V. Le Colleoni 1 20041 Agrate Brianza Milan, Italy Tel: 39-039-65791-1 Fax: 39-039-6899883



Microchip received QS-9000 quality system certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona in July 1999. The Company's quality system processes and procedures are QS-9000 compliant for its PICmicro® 8-bit MCUs, KEELOQ® code hopping devices, Serial EEPROMs and microperipheral products. In addition, Microchip's quality system for the design and manufacture of development systems is ISO 9001 certified.

All rights reserved. © 1999 Microchip Technology Incorporated. Printed in the USA. 11/99



Information contained in this publication regarding device applications and the like is intended for suggestion only and may be superseded by updates. No representation or warranty is given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infiningement of patents or other intellectual property rights arising from such use or otherwise. Use of Microchips products ac critical components in life support systems is not authorized except with express written approval by Microchip, No licenses are conveyed, implicitly or otherwise, under any intellectual property rights. The Microchip logo and name are registered trademarks of Microchip Technology Inc. in the U.S.A. and other countries. All rights reserved. All other trademarks mentioned herein are the property of their respective companies.