

# PIC SERIES MICRO-COMPUTER OPTIONS

#### **EXTENDED TEMPERATURE RANGE**

PIC series microcomputers are available in two temperature ranges. The preceding data sheets describe the commercial grade device, 0°C to 70°C centigrade. An industrial/automotive temperature range version is available. The -40° to 85° centigrade option is specified with the addition of a suffix, I, to the part number.

The specifications for these devices differ from their commercial grade counterparts in a few electrical parameters, typically interface voltage/current levels. Refer to the data sheets for details.

#### **OPEN DRAIN OPTIONS**

#### PIC1650A, PIC1670 Open-Drain I/O Ports

Any or all of the I/O lines may be specified by the customer to be open drain, that is, the internal pull-up device will be removed. This enables the outputs to be pulled up to  $\pm 10.0$ V maximum with an external pull-up resistor, allowing easy interface to external devices requiring a logic one level greater than  $V_{DD}$  of the PIC. In the logic one state, the leakage current of the I/O port is  $\pm 5\mu A$ , maximum

The customer shall specify on the "PIC Series Order Form" the pin number and port name (e.g., "RB3") of each port required to be open drain.

#### PIC1655A, PIC1656

#### Open Drain I/O, Input and Output Ports

Any or all of the I/O, input only or output only lines may be specified by the customer to be open drain, that is, the internal pull-up device will be removed. This enables the outputs to be pulled up to +10.0V maximum with an external pull-up register, allowing easy interface to external devices requiring a logic one

level greater than  $V_{DD}$  of the PIC. In the logic one state, the leakage current of the I/O port is  $\pm 5\mu A$ , maximum.

The customer shall specify on the "PIC Series Order Form" the pin number and port name (e.g., "RB3") of each port required to be open drain.

#### PIC16C55

#### Input-only, Output-only and I/O Ports

Any or all of the input-only and I/O lines may be specified to have an internal pull-up resistor inserted via a mask option. This allows easy interface to an external transistor or switch without the need for an external pull-up resistor. Furthermore, any or all of the output-only or I/O pull-down transistors can be specified to be removed via a mask option. This facilitates interfacing with external circuitry which has signal swings below  $V_{SS}$ . In this case the maximum voltage permitted to be applied to the pin is -12V with respect to  $V_{\rm DD}$ .

#### PIC1654

## **Optional Internal Connection to RTCC**

A mask option will allow an internal clock signal whose period is equal to the instruction execution time to drive the real time clock/counter register. In this mode, transitions in the RTCC pin will be disregarded.

#### PIC1655XT

#### **Prescaler Division Ratio**

A mask option will allow the division ratio of the RTCC prescaler to be selected as 1, 2, 4, 8 or 16. Consult the data sheet for the details.

# 8 Bit Microcomputer

#### **FEATURES**

- User programmable
- Intelligent controller for stand-alone applications
- 32 8-bit RAM registers
- 512 x 12-bit program ROM
- Arithmetic Logic Unit
- Real Time Clock/Counter
- Self-contained crystal oscillator
- Access to RAM registers inherent in instruction
- Wide power supply operating range (4.5V to 7.0V)
- Available in two temperature ranges: 0° to 70° C and --40° to 85° C
- 4 inputs, 8 outputs, 8 bi-directional I/O lines
- 2 level stack for subroutine nesting
- Mask programmable prescaler for RTCC
- Mask programmable open drain option on all I/O tines

#### DESCRIPTION

The PIC1655XT microcomputer is an MOS/LSI device containing RAM, I/O, and a central processing unit as well as customer-defined ROM on a single chip. This combination produces a low cost solution for applications which require sensing individual inputs and controlling individual outputs. Keyboard scanning, display driving, and other system control functions can be done at the same time due to the power of the 8-bit CPU.

The internal ROM contains a customer-defined program using the PIC's powerful instruction set to specify the overall functional characteristics of the device. The 8-bit input/output registers provide latched lines for interfacing to a limitless variety of applications. The PIC can be used to scan keyboards, drive displays, control electronic games and provide enhanced capabilities to vending machines, traffic lights, radios, television, consumer appliances, industrial timing and control applications. The 12-bit instruction word format provides a powerful yet easy to use

instruction repertoire emphasizing single bit manipulation as well as logical and arithmetic operations using bytes.

The PIC1655XT is fabricated with N-Channel Ion Implant technology resulting in a high performance product with proven reliability and production history. Only a single wide range power supply is required for operation, and an on-chip oscillator provides the operating clock with an external crystal, ceramic resonator or LC network to establish the frequency. Inputs and outputs are TTL-compatible.

Extensive hardware and software support is available to aid the user in developing an application program and to verify performance before committing to mask tooling. Programs can be assembled into machine language using PICAL, eliminating the burden of coding with ones and zeros. PICAL is available in a Fortran IV version that can be run on many popular computer systems. Once the application program is developed several options are available to insure proper performance. The PIC's operation can be verified in any hardware application by using the PIC1664. The PIC1664 is a ROM-less PIC microcomputer with additional pins to connect external PROM or RAM and to accept HALT commands. The PFD1000 Field Demo System is available containing a PIC1664 with sockets for erasable CMOS PROMs. Finally, the PICES II (PIC In-Circuit Emulation System) provides the user with emulation and debugging capability in either a stand-alone mode or operation as a peripheral to a larger computer system. Easy program debugging and changing is facilitated because the user's program is stored in RAM. With these development tools, the user can quickly and confidently order the masking of the PIC's ROM and bring his application into the market

A PIC Series Microcomputer Data Manual is available which gives additional detailed data on PIC based system design.



PIC1655XT



#### **ARCHITECTURAL DESCRIPTION**

The firmware architecture of the PIC series microcomputer is based on a register file concept with simple yet powerful commands designed to emphasize bit, byte, and register transfer operations. The instruction set also supports computing functions as well as these control and interface functions.

Internally, the PIC is composed of three functional elements connected together by a single bidirectional bus: the Register File composed of 32 addressable 8-bit registers, an Arithmetic Logic Unit, and a user-defined Program ROM composed of 512 words each 12 bits in width. The Register File is divided into two functional groups: operational registers and general registers. The operational registers include, among others, the Real Time Clock Counter Register, the Program Counter (PC), the Status Register,

and the I/O Registers. The general purpose registers are used for data and control information under command of the instructions.

The Arithmetic Logic Unit contains one temporary working register or accumulator (W Register) and gating to perform Boolean functions between data held in the working register and any file register.

The Program ROM contains the operational program for the rest of the logic within the controller. Sequencing of microinstructions is controlled via the Program Counter (PC) which automatically increments to execute in-line programs. Program control operations can be performed by Bit Test and Skip instructions, Jump instructions, Call instructions, or by loading computed addresses into the PC. In addition, an on-chip two-level stack is employed to provide easy to use subroutine nesting. Activating the MCLR input on power up initializes the ROM program to address 777<sub>8</sub>.

#### **PIN FUNCTIONS**

| Signal                      | Function                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC1 (input), OSC2 (output) | Oscillator pins. The oscillator frequency can be set by a crystal, ceramic resonator, external LC network or driven externally. The oscillator frequency is sixteen times the instruction frequency.                                                                                                                                                                                       |
| RTCC (input)                | Real Time Clock Counter. Used by the microprogram to keep track of elapsed time between events. The Real Time Clock Counter, Register increments on falling edges applied to this pin. This register can be loaded and read by the program. This is a Schmitt trigger input except when a prescaler division ratio of 2, 4, 8 or 16 is selected in which case the input is TTL compatible. |
| RA0-3 (input)               | 4 input lines                                                                                                                                                                                                                                                                                                                                                                              |
| RB0-7 (output)              | 8 output lines                                                                                                                                                                                                                                                                                                                                                                             |
| RC0-7 (input/output)        | 8 user programmable input/output lines All inputs and outputs are under direct control of the program.                                                                                                                                                                                                                                                                                     |
| MCLR (Input)                | Master Clear. Used to initialize the internal ROM program to address 777₀ and latch all I/O registers high. Should be held low at least 1ms past the time when power supply is valid. This is a Schmitt trigger input.                                                                                                                                                                     |
| CLK OUT (output)            | A signal derived from the internal oscillator. Used by external devices to synchronize themselves to PIC timing.                                                                                                                                                                                                                                                                           |
| $V_{DD}$                    | Primary power supply.                                                                                                                                                                                                                                                                                                                                                                      |
| V <sub>XX</sub>             | Output Buffer power supply. Used to enhance output current sinking capability.                                                                                                                                                                                                                                                                                                             |
| V <sub>ss</sub>             | Ground                                                                                                                                                                                                                                                                                                                                                                                     |



#### REGISTER FILE ARRANGEMENT

| File<br>(Octal) | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                   |              |                 |                 |                |                |                |                 |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-----------------|-----------------|----------------|----------------|----------------|-----------------|--|--|
| F0              | select a file re                                                                                                                                                                                                                                                                                                                                                                                                                                             | Not a physically implemented register. F0 calls for the contents of the File Select Register (low order 5 bits) to be used to select a file register. F0 is thus useful as an indirect address pointer. For example, W+F0-W will add the contents of the file register pointed to by the FSR (F4) to W and place the result in W. |              |                 |                 |                |                |                |                 |  |  |
| F1              | Real Time Clock Counter Register. This register can be loaded and read by the microprogram. The RTCC register keeps counting up after zero is reached. The counter increments on the falling edge of the input RTCC. However, if data are being stored in the RTCC register simultaneously with a negative transition on the RTCC pin, the RTCC register will contain the new stored value and the external transition will be ignored by the microcomputer. |                                                                                                                                                                                                                                                                                                                                   |              |                 |                 |                |                |                |                 |  |  |
| F2              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Program Counter (PC). The PC is automatically incremented during each instruction cycle, and can be written into under program control (MOVWF F2). The PC is nine bits wide, but only its low order 8 bits can be read under program control.                                                                                     |              |                 |                 |                |                |                |                 |  |  |
| F3              | Status Word                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Status Word Register. F3 can be altered under program control only via bit set, bit clear, or MOVWF F3 instruction.                                                                                                                                                                                                               |              |                 |                 |                |                |                |                 |  |  |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                              | (7)                                                                                                                                                                                                                                                                                                                               | (6)          | (5)             | (4)             | (3)            | (2)            | (1)            | (0)             |  |  |
|                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                                                                                                                                                                                                                                                                                 | 1            | 1               | 1               | 1              | Z              | DC             | С               |  |  |
|                 | C (Carry):                                                                                                                                                                                                                                                                                                                                                                                                                                                   | For ADD and resultant.                                                                                                                                                                                                                                                                                                            |              |                 |                 |                |                |                | icant bit of th |  |  |
|                 | DC (Digit Ca                                                                                                                                                                                                                                                                                                                                                                                                                                                 | rry): For ADD and                                                                                                                                                                                                                                                                                                                 | SUBinstruc   | tions, this bit | is set if there | is a carry out | from the 4th l | ow order bit o | of the resultan |  |  |
|                 | Z (Zero):                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                   |              |                 |                 |                |                |                |                 |  |  |
|                 | Bits: 3-7                                                                                                                                                                                                                                                                                                                                                                                                                                                    | These bits ar                                                                                                                                                                                                                                                                                                                     | e defined as | logic ones.     |                 |                |                |                |                 |  |  |
| F4              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              | egister (FSR). Lov<br>am control. Wher                                                                                                                                                                                                                                                                                            |              |                 |                 |                |                |                |                 |  |  |
| F5              | Input Registe                                                                                                                                                                                                                                                                                                                                                                                                                                                | er A (A0-A3) (A4-A                                                                                                                                                                                                                                                                                                                | 7 defined a  | s zeroes).      |                 |                |                |                |                 |  |  |
| F6              | Output Regis                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ster B (B0-B7)                                                                                                                                                                                                                                                                                                                    |              |                 |                 |                |                |                |                 |  |  |
| F7              | I/O Register                                                                                                                                                                                                                                                                                                                                                                                                                                                 | C (C0-C7)                                                                                                                                                                                                                                                                                                                         |              |                 |                 |                |                |                |                 |  |  |
| F10-F37         | General Purn                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ose Registers                                                                                                                                                                                                                                                                                                                     |              |                 |                 |                |                |                |                 |  |  |

The PIC1655XT has the same basic architecture as the PIC1655A with the additional enhancements described below:

#### **Real Time Clock Counter**

The Real Time Clock Counter can be read from and written to under software control. In addition, it can be used to count external events via the RTCC input. A prescaler counter between the RTCC input and the Real Time Clock Counter can be mask programmed to enable the RTCC register to increment every 1, 2, 4, 8, or 16 negative edges of the RTCC input pin.

This allows the maximum frequency of the RTCC input to be (assume an instruction cycle time of 4µs):

| Prescaler      | Maximum Input |  |  |  |  |
|----------------|---------------|--|--|--|--|
| Division Ratio | Frequency     |  |  |  |  |
| 1              | 0.238MHz      |  |  |  |  |
| 2              | 0.476MHz      |  |  |  |  |
| 4              | 0.952MHz      |  |  |  |  |
| 8              | 1.904MHz      |  |  |  |  |
| 16             | 3.808MHz      |  |  |  |  |

NOTE: The Schmitt trigger input is valid only when a division ratio of 1 is selected. Otherwise, the input is a normal TTL compatible input.

#### **Self-Contained Oscillator**

When a crystal, ceramic resonator or LC network is connected between the OSC1 and OSC2 pins, the self-contained oscillator will generate a frequency determined by the external components thus allowing an accurate timing reference, a crystal, to be used for time base control with a minimum of external parts.

The output of this oscillator is divided down by 16 to give the instruction cycle time of the microcomputer, thus with a 4MHz crystal the instruction cycle time is  $4\mu$ s.

When test mode is enabled, the basic instruction cycle time is a division of 4 of the frequency applied to OSC1 and OSC2 allowing simpler synchronizing of the device and tester.

PIC1655XT

# **Basic Instruction Set Summary**

Each PIC instruction is a 12-bit word divided into an OP code which specifies the instruction type and one or more operands which further specify the operation of the instruction. The following PIC instruction summary lists byte-oriented, bit-oriented, and literal and control operations.

For byte-oriented instructions, "f" represents a file register designator and "d" represents a destination designator. The file register designator specifies which one of the 32 PIC file registers is to be utilized by the instruction. The destination designator specifies where the result of the operation performed by the instruction is to be placed. If "d" is zero, the result is placed in the PIC W register. If "d" is one, the result is returned to the file register specified in the instruction.

For bit-oriented instructions, "b" represents a bit field designator which selects the number of the bit affected by the operation, while "f" represents the number of the file in which the bit is located.

For literal and control operations, "k" represents an eight or nine bit constant or literal value.

For an oscillator frequency of 4MHz the instruction execution time is 4  $\mu$ sec, unless a conditional test is true or the program counter is changed as a result of an instruction. In these two cases, the instruction execution time is 8 µsec.

BYTE-ORIENTED **FILE REGISTER OPERATIONS** 

(11-6)(4-0)(5)OP CODE f (FILE #) d

For d = 0,  $f \rightarrow W$  (PICAL accepts d = 0 or d = W in the mnemonic) d = 1,  $f \rightarrow f$  (If d is omitted, assembler assigns d = 1.)

| Inst   | ructio | n-Bina | ry (Oc | stal)  | Name                      | Mnemonic, C | Operands | Operation S                 | Status Affected |
|--------|--------|--------|--------|--------|---------------------------|-------------|----------|-----------------------------|-----------------|
| 000    | 000    | 000    | 000    | (0000) | No Operation              | NOP         |          | _                           | None            |
| 000    |        |        | fff    | (0040) | Move W to f (Note 1)      | MOVWF       | f        | W→f                         | None            |
| 000    | 001    | 000    | 000    | . ,    | Clear W                   | CLRW        |          | 0- <b>-</b> W               | Z               |
| 000    | 001    | 1 f f  | fff    | (0140) | Clear f                   | CLRF        | f        | 0f                          | Z               |
| 000    | 010    | dff    | fff    | (0200) | Subtract W from f         | SUBWF       | f, d     | f - W⊶d [f+₩+1→d]           | C.DC,Z          |
| 000    | 011    | dff    | fff    | (0300) | Decrement f               | DECF        | f, d     | f - 1⊶d                     | Z               |
| 000    | 100    | dff    | fff    | (0400) | Inclusive OR W and f      | IORWF       | f, d     | WVf⊸d                       | Z               |
| 000    | 101    | dff    | fff    | (0500) | AND W and f               | ANDWF       | f, d     | W∙f⊸d                       | Z               |
| 000    | 110    | dff    | fff    | (0600) | Exclusive OR W and f      | XORWF       | f, d     | W⊕f⊸d                       | Z               |
| 000    | 111    | dff    | fff    | (0700) | Add W and f               | ADDWF       | f, d     | W+fd                        | C,DC,Z          |
| 001    | 000    | dff    | fff    | (1000) | Move f                    | MOVF        | f, d     | <u>f</u> d                  | Z               |
| 001    | 001    | dff    | fff    | (1100) | Complement f              | COMF        | f, d     | <del>Ī</del> d              | Z               |
| 001    | 010    | dff    | fff    | (1200) | Increment f               | INCF        | f, d     | f+1→d                       | Z               |
| 001    | 011    | dff    | fff    | (1300) | Decrement f, Skip if Zero | DECFSZ      | f, d     | f - 1⊶d, skip if Zero       | None            |
| 001    | 100    | dff    | fff    | (1400) | Rotate Right f            | RRF         | f, d     | f(n)→d(n-1), f(0)→C, C→d(7) |                 |
| 001    | 101    | dff    | fff    | (1500) | Rotate Left f             | RLF         | f, d     | f(n)→d(n+1), f(7)→C, C→d(0) | D) C            |
| 001    | 110    | dff    | fff    | (1600) | Swap halves f             | SWAPF       | f, d     | f(0-3)⇔f(4-7)→d             | None            |
| 001    | 111    | dff    | fff    | (1700) | Increment f, Skip if Zero | INCFSZ      | f, d     | f+1-d, skip if zero         | None            |
| BIT-O  |        |        |        |        | (11-8)                    | (7-5)       | (4-0)    | ,                           |                 |
| FILE F |        |        |        |        | OP CODE b (               | (BIT #)     | f (FILE  | #)                          |                 |

| Instruct | tion-Binary (C | ctal)    | Name                      | Mnemonic, ( | Operands | Operation                    | Status Affected |
|----------|----------------|----------|---------------------------|-------------|----------|------------------------------|-----------------|
| 010 0b   | b bff ff       | (2000)   | Bit Clear f               | BCF         | f, b     | 0→f(b)                       | None            |
| 010 1b   | b bff ff       | (2400)   | Bit Set f                 | BSF         | f, b     | 1→f(b)                       | None            |
| 011 0b   | b bff ff       | (3000)   | Bit Test f, Skip if Clear | BTFSC       | f, b     | Bit Test f(b): skip if clear | None            |
| 011 1b   | b bff ff       | f (3400) | Bit Test f, Skip if Set   | BTFSS       | f, b     | Bit Test f(b): skip is set   | None            |

(11-8)(7-0)LITERAL AND CONTROL OP CODE k (LITERAL) **OPERATIONS** 

| Ins | Instruction-Binary (Octal) |     | tal) | Name   | Mnemonic, Operands            |         | Operation | Status Affected      |      |
|-----|----------------------------|-----|------|--------|-------------------------------|---------|-----------|----------------------|------|
| 100 | Okk                        | kkk | kkk  | (4000) | Return and place Literal in V | V RETLW | k         | k→W, Stack→PC        | None |
| 100 | 1 k k                      | kkk | kkk  | (4400) | Call subroutine (Note 1)      | CALL    | k         | PC+1 → Stack, k → PC | None |
| 101 | kkk                        | kkk | kkk  | (5000) | Go To address (k is 9 bits)   | GOTO    | k         | k→PC                 | None |
| 110 | 0 k k                      | kkk | kkk  | (6000) | Move Literal to W             | MOVLW   | k         | k→W                  | None |
| 110 | 1 k k                      | kkk | kkk  | (6400) | Inclusive OR Literal and W    | IORLW   | k         | kVWW                 | Z    |
| 111 | 0 k k                      | kkk | kkk  | (7000) | AND Literal and W             | ANDLW   | k         | k∙WW                 | Z    |
| 111 | 1 k k                      | kkk | kkk  | (7400) | Exclusive OR Literal and W    | XORLW   | k         | k⊕W→W                | Z    |

#### NOTES:

- 1. The 9th bit of the program counter in the PIC is zero for a CALL and a MOVWF F2. Therefore, subroutines must be located in program memory locations 0-377<sub>a</sub>. However, subroutines can be called from anywhere in the program memory since the Stack is 9 bits wide.
- 2. When an I/O register is modified as a function of itself, the value used will be that value present on the output pins. For example, an output pin which has been latched high but is driven low by an external device, will be relatched in the low state.
- 3. See notes on input only and output only ports (F5 and F6 respectively).

#### SUPPLEMENTAL INSTRUCTION SET SUMMARY

The following supplemental instructions summarized below represent specific applications of the basic PIC instructions. For example, the "CLEAR CARRY" supplemental instruction is equiv-

alent to the basic instruction BCF 3,0 ("Bit Clear, File 3, Bit 0"). These instruction mnemonics are recognized by the PIC Cross Assembler (PICAL).

| Instruction-Binary (Oc             | tal)             | Name                           | Mnemonic,<br>Operands | Equivalent<br>Operation(s) | Status<br>Affected |
|------------------------------------|------------------|--------------------------------|-----------------------|----------------------------|--------------------|
| 010 000 000 011                    | (2003)           | Clear Carry                    | CLRC                  | BCF 3, 0                   |                    |
| 010 100 000 011                    | (2403)           | Set Carry                      | SETC                  | BSF 3, 0                   |                    |
| 010 000 100 011                    | (2043)           | Clear Digit Carry              | CLRDC                 | BCF 3, 1                   | ~-                 |
| 010 100 100 011                    | (2443)           | Set Digit Carry                | SETDC                 | BSF 3, 1                   | ****               |
| 010 001 000 011                    | (2103)           | Clear Zero                     | CLRZ                  | BCF 3, 2                   | -                  |
| 010 101 000 011                    | (2503)           | Set Zero                       | SETZ                  | BSF 3, 2                   | _                  |
| 011 100 000 011                    | (3403)           | Skip on Carry                  | SKPC                  | BTFSS 3, 0                 | -                  |
| 011 000 000 011                    | (3003)           | Skip on No Carry               | SKPNC                 | BTFSC 3, 0                 |                    |
| 011 100 100 011                    | (3443)           | Skip on Digit Carry            | SKPDC                 | BTFSS 3, 1                 |                    |
| 011 000 100 011                    | (3043)           | Skip on No Digit Carry         | SKPNDC                | BTFSC 3, 1                 | _                  |
| 011 101 000 011                    | (3503)           | Skip on Zero                   | SKPZ                  | BTFSS 3, 2                 | _                  |
| 011 001 000 011                    | (3103)           | Skip on No Zero                | SKPNZ                 | BTFSC 3, 2                 | _                  |
| 001 000 1ff fff                    | (1040)           | Test File                      | TSTF f                | MOVF f, 1                  | Z                  |
| 001 000 Off fff                    | (1000)           | Move File to W                 | MOVFW f               | MOVF f, 0                  | z                  |
| 001 001 1ff fff<br>001 010 dff fff | (1140)<br>(1200) | Negate File                    | NEGF f,d              | COMF f, 1<br>INCF f, d     | z                  |
| 011 000 000 011<br>001 010 dff fff | (3003)<br>(1200) | Add Carry to File              | ADDCF f, d            | BTFSC 3,0<br>INCF f, d     | z                  |
| 011 000 000 011<br>000 011 dff fff | (3003)<br>(0300) | Subtract Carry from File       | SUBCF f,d             | BTFSC 3,0<br>DECF f, d     | z                  |
| 011 000 100 011<br>001 010 dff fff | (3043)<br>(1200) | Add Digit Carry to File        | ADDDCF f,d            | BTFSG 3,1<br>INCF f,d      | z                  |
| 011 000 100 011<br>000 011 dff fff | (3043)<br>(0300) | Subtract Digit Carry from File | SUBDCF f,d            | BTFSC 3,1<br>DECF f,d      | z                  |
| 101 kkk kkk kkk                    | (5000)           | Branch                         | Bk                    | GOTO k                     | ~                  |
| 011 000 000 011<br>101 kkk kkk kkk | (3003)<br>(5000) | Branch on Carry                | BC k                  | BTFSC 3,0<br>GOTO k        | -                  |
| 011 100 000 011<br>101 kkk kkk kkk | (3403)<br>(5000) | Branch on No Carry             | BNC k                 | BTFSS 3,0<br>GOTO k        | -                  |
| 011 100 100 011<br>101 kkk kkk kkk | (3043)<br>(5000) | Branch on Digit Carry          | BDC k                 | BTFSC 3,1<br>GOTO k        | _                  |
| 011 001 000 011<br>101 kkk kkk kkk | (3443)<br>(5000) | Branch on No Digit Carry       | BNDC k                | BTFSS 3,1<br>GOTO k        | _                  |
| 011 101 000 011<br>101 kkk kkk kkk | (3103)<br>(5000) | Branch on Zero                 | BZ k                  | BTFSC 3,2<br>GOTO k        | _                  |
| 011 101 000 011<br>101 kkk kkk kkk | (3503)<br>(5000) | Branch on No Zero              | BNZ k                 | BTFSS 3,2<br>GOTO k        | _                  |

# I/O Interfacing

The equivalent circuit for an I/O port bit is shown below as it would interface with either the input of a TTL device (PIC is outputting) or the output of an open collector TTL device (PIC is inputting). Each I/O port bit can be individually time multiplexed between input and output functions under software control. When outputting thru a PIC I/O Port, the data is latched at the port and the pin

can be connected directly to a TTL gate input. When inputting data thru an I/O Port, the port latch must first be set to a high level under program control. This turns off  $\Omega_2$ , allowing the TTL open collector device to drive the pad, pulled up by  $\Omega_1$ , which can source a minimum of  $100\mu A$ . Care, however, should be exercised when using open collector devices due to the potentially high TTL leakage current which can exist in the high logic state.



#### **Bidirectional I/O Ports**

The bidirectional ports may be used for both input and output operations. For input operations these ports are non-latching. Any input must be present until read by an input instruction. The outputs are latched and remain unchanged until the output latch is rewritten. For use as an input port the output latch must be set in the high state. Thus the external device inputs to the PIC circuit by forcing the latched output line to the low state or keeping the latched output high. This principle is the same whether operating on individual bits or the entire port.

Some instructions operate internally as input followed by output operations. The BCF and BSF instructions, for example, read the entire port into the CPU, execute the bit operation, and re-output the result. Caution must be used when using these instructions. As an example a BSF operation on bit 5 of F7 (port RC) will cause all eight bits of F7 to be read into the CPU. Then the BSF operation takes place on bit 5 and F7 is re-output to the output latches. If another bit of F7 is used as an input (say bit 0) then bit 0 must be latched high. If during the BSF instruction on bit 5 an external device is forcing bit 0 to the low state then the input/output nature of the BSF instruction will leave bit 0 latched low after execution. In this state bit 0 cannot be used as an input until it is again latched high by the programmer. Refer to the examples below.

#### Input Only Port: (Port RA)

The input only port of the PIC1655XT consists of the four LSB's of F5 (port RA). An internal pull-up device is provided so that external pull-ups on open collector logic are unnecessary. The four MSB's of this port are always read as zeroes. Output operations to F5 are not defined. Note that the BTFSC and BTFSS instructions are input only operations and so can be used with F5. Also, file register instructions which leave the results in W can be used.

#### **Output Only Port (Port RB)**

The output only port of the PIC1655XT consists of F6 (port RB). This port contains no input circuitry and is therefore not capable of instructions requiring an input followed by an output operation. The only instructions which can validly use F6 are MOVWF and CI RF

#### Successive Operations on Bidirectional I/O Ports

Care must be exercised if successive instructions operate on the same I/O port. The sequence of instructions should be such to allow the pin voltage to stabilize (load dependent) before the next instruction which causes that file to be read into the CPU (MOVF, BIT SET, BIT CLEAR, and BIT TEST) is executed. Otherwise, the previous state of that pin may be read into the CPU rather than the new state. This will happen if  $t_{\rm pd}$  (See I/O Timing Diagram) is greater than  $^{1/4}t_{\rm cy}$  (min). When in doubt, it is better to separate these instructions with a NOP or other instruction.





#### PIC1655XT

#### **ELECTRICAL CHARACTERISTICS**

Maximum Ratings\*

| Temperature Under Bias                 | 125°C |
|----------------------------------------|-------|
| Storage Temperature                    |       |
| Voltage on any Pin with Respect to Vss |       |
| Power Dissipation (Note 1)             |       |

#### Standard Conditions (unless otherwise stated):

DC CHARACTERISTICS Operating Temperature T<sub>A</sub> = 0°C to +70°C

\* Exceeding these ratings could cause permanent damage to the device. This is a stress rating only and functional operation of this device at these conditions is not implied—operating ranges are specified in Standard Conditions. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Data labeled "typical" is presented for design guidance only and is not guaranteed.

| Characteristics                                                             | Sym              | Min                | Тур† | Max                                | Units  | Conditions                                              |
|-----------------------------------------------------------------------------|------------------|--------------------|------|------------------------------------|--------|---------------------------------------------------------|
| Power Supply Voltage                                                        | V <sub>DD</sub>  | 4.5                | _    | 7.0                                | ٧      |                                                         |
| Primary Supply Current                                                      | I <sub>DD</sub>  |                    | _    | 65                                 | mA     | All I/O pins @ V <sub>DD</sub> (Note 5)                 |
| Output Buffer Supply Voltage                                                | V <sub>xx</sub>  | 4.5                | _    | 10.0                               | ٧      | (Note 2)                                                |
| Output Buffer Supply Current                                                | l <sub>xx</sub>  | _                  | 1    | 5                                  | mA     | All I/O pins @ V <sub>DD</sub>                          |
| Input Low Voltage                                                           | V <sub>IL</sub>  | -0.2               | _    | 0.8                                | ٧      |                                                         |
| Input High Voltage (except MCLR, RTCC, OSC1 When Prescaler = 2, 4, 8 or 16) | V <sub>IH1</sub> | 2.4                | _    | V <sub>DD</sub>                    | ٧      |                                                         |
| Input High Voltage (MCLR, RTCC,<br>OSC1 When Prescaler = 1)                 | V <sub>IH2</sub> | V <sub>DD</sub> -1 | _    | V <sub>DD</sub>                    | v      |                                                         |
| Output High Voltage                                                         | V <sub>OH</sub>  | 2.4<br>3.5         | =    | V <sub>DD</sub><br>V <sub>DD</sub> | V<br>V | I <sub>OH</sub> = 100μA (Note 3)<br>I <sub>OH</sub> = 0 |
| Output Low Voltage (I/O only)                                               | V <sub>OL</sub>  | _                  |      | 0.45                               | V      | I <sub>OL</sub> = 1.6mA (Note 4)                        |
| Input Leakage Current (MCLR, RTCC)                                          | ILC              | -5                 |      | +5                                 | μΑ     | $V_{SS} \leqslant V_{IN} \leqslant V_{DD}$              |
| Output Leakage Current (open drain pins)                                    | l <sub>OL</sub>  | <u> </u>           | _    | 10                                 | μΑ     | 0V ≤ V pin ≤ 10V                                        |
| Input Low Current (all I/O ports)                                           | l <sub>IL</sub>  | -0.2               | _    | -2.0                               | mA     | V <sub>IL</sub> = 0.4V internal pullup                  |
| Input High Current (all I/O ports)                                          | I <sub>IH</sub>  | -0.1               | -0.4 | -1.6                               | mA     | V <sub>IH</sub> = 2.4V                                  |

<sup>†</sup>Typical data is at  $T_A = 25^{\circ}$  C,  $V_{DD} = 5.0$ V

#### NOTES:

- 1. Total power dissipation for the package is calculated as follows:
  - $\mathsf{P}_{\mathsf{D}} = (\mathsf{V}_{\mathsf{DD}}) \; (\mathsf{I}_{\mathsf{DD}}) + \Sigma \; (\mathsf{V}_{\mathsf{DD}} \mathsf{V}_{\mathsf{IL}}) \; (\!| \mathsf{I}_{\mathsf{IL}} \!|) + \Sigma \; (\mathsf{V}_{\mathsf{DD}} \mathsf{V}_{\mathsf{OH}}) \; (\!| \mathsf{I}_{\mathsf{OH}} \!|) + \Sigma \; (\mathsf{V}_{\mathsf{OL}}) \; (\mathsf{I}_{\mathsf{OL}}).$
- 2. V<sub>XX</sub> supply drives only the I/O ports.
- 3. Positive current indicates current into pin. Negative current indicates current out of pin.
- 4. Total  $I_{OL}$  for all output pins must not exceed 175mA.
- 5.  $I_{\rm DD}$  max current spec is preliminary and subject to change.

#### Standard Conditions (unless otherwise stated):

#### AC CHARACTERISTICS

Operating Temperature T<sub>A</sub> = 0° C to +70° C

| Characteristic                | Sym              | Min                    | Тур† | Max                     | Units | Conditions                                  |
|-------------------------------|------------------|------------------------|------|-------------------------|-------|---------------------------------------------|
| Instruction Cycle Time        | t <sub>CY</sub>  | 4                      | _    | 20                      | μs    | 0.2MHz — 1.0MHz external time base (Note 1) |
| RTCC Input                    | -                | <u> </u>               |      |                         |       | Prescaler division ratio = 1                |
| Period                        | t <sub>RT</sub>  | t <sub>CY</sub> +0.2µs | _    | _                       | _     | Troccalor arribion ratio                    |
| High Pulse Width              | t <sub>RTH</sub> | ½t <sub>RT</sub>       | _    | -                       | _     |                                             |
| Low Pulse Width               | t <sub>RTL</sub> | ½t <sub>RT</sub>       |      | -                       | _     | (Notes 2 and 4)                             |
| I/O Ports                     |                  |                        |      |                         |       |                                             |
| Data Input Setup Time         | t <sub>s</sub>   |                        | _    | 1/4t <sub>CY</sub> —125 | ns    | ]                                           |
| Data Input Hold Time          | t <sub>h</sub>   | 0                      | _    | _                       | ns    |                                             |
| Data Output Propagation Delay | t <sub>pd</sub>  | -                      | 500  | 900                     | ns    | Capacitive load = 50pF                      |

<sup>&</sup>lt;sup>†</sup>Typical data is at  $T_A = 25^{\circ}$  C,  $V_{DD} = 5.0$ V.

- 1. Instruction cycle period ( $t_{CY}$ ) equals four times the input oscillator time base period.
- 2. Due to the synchronous timing nature between CLK OUT and the sampling circuit used on the RTCC input, CLK OUT may be directly tied to the RTCC input.
- 3. If an RTCC prescaler division ratio of 2, 4, 8 or 16 is selected, the maximum rise and fall times of the signal input to the RTCC pin is 200 nsecs and its duty cycle must be between 40% and 60%.
- 4. The maximum frequency which may be input to the  $\overline{\text{ATCC}}$  pin for a division ratio of 1 is calculated as follows:  $f_{(\text{max})} = \frac{1}{t_{\text{RT} \, (\text{min})}} = \frac{1}{t_{\text{CY} \, (\text{min})} + 0.2 \mu \text{s}}$  For example: if  $t_{\text{CY}} = 4\mu \text{s}$ ,  $f_{(\text{max})} = \frac{1}{4.2 \mu \text{s}} = 238 \text{KHz}$ .

$$f_{(max)} = \frac{1}{t_{BT/(min)}} = \frac{1}{t_{CY/(min)} + 0.2us}$$

if 
$$t_{CY} = 4\mu s$$
,  $f_{(max)} = \frac{1}{42\mu s} = 238 \text{KHz}$ 









## PIC1655XT OSCILLATOR OPTIONS (TYPICAL CIRCUITS)

#### LC INPUT OPERATION



$$\label{eq:fosc} \begin{split} f_{\rm OSC} \approx & \frac{1}{2\pi \, \sqrt{L \, \left(C_L \, + C_{\rm INT}\right)}} \; , \\ & \text{where } C_{\rm INT} = 10 \text{pF}. \end{split}$$

#### **CRYSTAL INPUT OPERATION**



\*OR CERAMIC RESONATOR

## **EXTERNAL CLOCK INPUT OPERATION**



### MASTER CLEAR (TYPICAL CIRCUIT)



Master Clear requires 10ms delay (assuming a 4MHz crystal) before activation after power is applied to the  $V_{DD}$  pin, for the crystal to start up. To achieve this, an external RC configuration as shown can be used (assuming  $V_{DD}$  is applied as a step function).

# OUTPUT SINK CURRENT GRAPH



The Output Sink Current is dependent on the  $V_{\chi\chi}$  supply and the output load. This chart shows the typical curves used to express the output drive capability.

I<sub>OL</sub> vs. V<sub>OL</sub> TYP @ 25°C



# V<sub>OH</sub> VS I<sub>OH</sub> (I/O PORTS) (TYPICAL) 5 4 7 7 8 7 1 1 200 400 800 1000



#### **POWER DISSIPATION DERATING GRAPH**



#### NOTES:

- 1.70°C is the maximum operating temperature for standard parts.
- 2.85°C is the maximum operating temperature for "I" suffix parts.

#### **PIC1655XT EMULATION CAUTIONS**

When emulating a PIC1655XT using a PICES II development system certain precautions should be taken.

- A. Be sure that the PICES II Module being used is programmed for the PIC165SXT mode. (Refer to PICES II Manual). The PIC1664 contained within the module should have the MODE pin #22 set to a high state.
  - 1. This causes the MCLR to force all I/O registers high.
  - 2. The interrupt system becomes disabled and the RTCC always counts on the trailing edges.
  - 3. Bits 3 through 7 on file register F3 are all ones.
- B. Make sure to only use two levels of stack within the program.

- C. Make sure all I/O cautions contained in this spec sheet are
- D. Be sure to use the 28 pin socket for the module plug.
- E. Make sure that during an actual application the MCLR input swings from a low to high level a minimum of 10msec after the supply voltage is applied to allow for the crystal to start up.
- F. The cable length and internal variations may cause some parameter values to differ between PICES II Module and a production PIC1655XT.
- G. The emulator PFD board or PICES II Module offers only "internal" oscillator operation (i.e. the crystal is on the PFD or Module Board) as the long cable might cause unreliable crystal operation.