### 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 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 sets of 8 user defined TTL-compatible Input/Output lines
- 2 level stack for subroutine nesting

#### DESCRIPTION

The PIC1650A 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 PIC1650A 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 only an external RC network (or buffered crystal oscillator signal, for greater accuracy) 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.



PIC1650A GENERAL INSTRUMENT

#### 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 word 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 7778.

#### **PIN FUNCTIONS**

| Signal                                       | Function                                                                                                                                                                                                                                                                |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| OSC (input)                                  | Oscillator input. This signal can be driven by an external oscillator if a precise frequency of operation is required or an external RC network can be used to set the frequency of operation of the internal clock generator. This is a Schmitt trigger input.         |
| RTCC (input)                                 | Real Time Clock Counter. Used by the microprogram to keep track of elapsed time between events. The RTCC 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.                |
| RA0-7, RB0-7, RC0-7, RD0-7<br>(input/output) | User programmable input/output lines. These lines can be inputs and/or outputs and are under direct control of the program.                                                                                                                                             |
| MCLR (input)                                 | Master Clear. Used to initialize the internal ROM program to address 777 <sub>8</sub> and latch all I/O register high. Should be held low at least 1-10ms past the time when the power supply is valid for the oscillator to start up. This is a Schmitt trigger input. |
| CLK OUT (output)                             | A signal derived from the internal oscillator. Used by external devices to synchronize them-<br>selves to PIC timing.                                                                                                                                                   |
| TEST                                         | Used for testing purposes only. Must be grounded for normal operation.                                                                                                                                                                                                  |
| V <sub>DD</sub>                              | Primary power supply.                                                                                                                                                                                                                                                   |
| $V_{xx}$                                     | Output Buffer power. Used to enhance output current sinking capability.                                                                                                                                                                                                 |
| V <sub>ss</sub>                              | Ground                                                                                                                                                                                                                                                                  |



| INSTRUMENT | PIC1650A |
|------------|----------|
|------------|----------|

### REGISTER FILE ARRANGEMENT

| File<br>(Octal) |                               |                                                                                 |                              |                             | Function                           |                                |                               |                |                  |
|-----------------|-------------------------------|---------------------------------------------------------------------------------|------------------------------|-----------------------------|------------------------------------|--------------------------------|-------------------------------|----------------|------------------|
| F0              | select a file re              | illy implemented<br>gister. F0 is thus<br>ed to by the FSR                      | useful as an i               | ndirect addr                | ess pointer. I                     |                                | •                             |                | •                |
| F1              | counting up a stored in the l | ock Counter Reg<br>fter zero is reach<br>RTCC register sin<br>lue and the exter | ed. The coun<br>nultaneously | ter incremer<br>with a nega | its on the falli<br>tive transitio | ing edge of th<br>n on the RTC | e input RTC(<br>C pin, the RT | 5. However, if | data are being   |
| F2              |                               | nter (PC). The Portion (MOVWF F2).                                              |                              |                             |                                    |                                |                               |                |                  |
| F3              | Status Word F                 | Register. F3 can b                                                              | e altered und                | der program                 | control only                       | via bit set, bi                | t clear, or MC                | DVWF F3 inst   | ruction.         |
|                 |                               | (7)                                                                             | (6)                          | (5)                         | (4)                                | (3)                            | (2)                           | (1)            | (0)              |
|                 |                               | 1                                                                               | 1                            | 1                           | 1                                  | 1                              | Z                             | DC             | С                |
|                 | C (Carry):                    | resultant.                                                                      |                              | ·                           |                                    | ere is a carry                 |                               | Ū              | icant bit of the |
|                 | DC (Digit Car                 | ry): For ADD and                                                                | SUB instruct                 | ions, this bit              | is set if there                    | is a carry out                 | from the 4th I                | ow order bit o | of the resultant |
|                 | Z (Zero):                     | Set if the res                                                                  | ult of an arith              | metic opera                 | tion is zero.                      |                                |                               |                |                  |
|                 | Bits: 3-7                     | These bits ar                                                                   | e defined as                 | logic ones.                 |                                    |                                |                               |                |                  |
| F4              |                               | gister (FSR). Lo<br>m control. Whei                                             |                              | •                           |                                    | •                              | -                             | •              |                  |
| F5              | I/O Register A                | A (A0-A7)                                                                       |                              |                             |                                    |                                |                               |                |                  |
| F6              | I/O Register E                | 3 (B0-B7)                                                                       |                              |                             |                                    |                                |                               |                |                  |
| F7              | I/O Register 0                | C (C0-C7)                                                                       |                              |                             |                                    |                                |                               |                |                  |
| F10             | I/O Register [                | , ,                                                                             |                              |                             |                                    |                                |                               |                |                  |
| F11-F37         | General Purp                  | ose Registers                                                                   |                              |                             |                                    |                                |                               |                |                  |

### **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

PIC1650A

GENERAL INSTRUMENT

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 1MHz 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  $\mu$ sec.

#### BYTE-ORIENTED FILE REGISTER OPERATIONS

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

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

| Inst | ructio | n-Bina | iry (Oc | :tai)  | Name                      | Mnemonic, O | )perands | Operation                                                         | Status Affected |
|------|--------|--------|---------|--------|---------------------------|-------------|----------|-------------------------------------------------------------------|-----------------|
| 000  | 000    | 000    | 000     | (0000) | No Operation              | NOP         |          | <u></u>                                                           | None            |
| 000  | 000    | 1 f f  | fff     | (0040) | Move W to f (Note 1)      | MOVWF       | f        | W→f                                                               | None            |
| 000  | 001    | 000    | 000     | (0100) | Clear W                   | CLRW        |          | 0 <b>→</b> W                                                      | Z               |
| 000  | 001    | 1 f f  | f f f   | , ,    | Clear f                   | CLRF        | f        | 0→f                                                               | Z               |
| 000  | 010    | dff    | fff     | (0200) | Subtract W from f         | SUBWF       | f, d     | f - W→d [f+ <del>W</del> +1→d]                                    | C,DC,Z          |
| 000  | 011    | dff    | fff     | (0300) | Decrement f               | DECF        | f, d     | f - 1→d                                                           | Z               |
| 000  | 100    | d f f  | fff     | . ,    | Inclusive OR W and f      | IORWF       | f, d     | W∨f→d                                                             | Z               |
| 000  | 101    | dff    | f f f   | (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    | d f f  | fff     |        | Add W and f               | ADDWF       | f, d     | W+f⊶d                                                             | C,DC,Z          |
| 001  | 000    | dff    | fff     | (1000) | Move f                    | MOVF        | f, d     | f-→d                                                              | Z               |
| 001  | 001    | dff    | fff     | (1100) | Complement f              | COMF        | f, d     | <del>f</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    |        |         |        | Rotate Right f            | RRF         | f, d     | f(n)→d(n-1), f(0)→C, C→d(7)                                       | r) C            |
| 001  | 101    | dff    | fff     | (1500) | Rotate Left f             | RLF         | f, d     | $f(n) \rightarrow d(n+1), f(7) \rightarrow C, C \rightarrow d(0)$ |                 |
| 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-ORIENTED             | (11-8)  | (7-5)     | (4-0)      |
|--------------------------|---------|-----------|------------|
| FILE REGISTER OPERATIONS | OP CODE | b (BIT #) | f (FILE #) |

/11\_8\

| Instruction-Bin | ary (Octal)  | Name                      | Mnemonic, ( | Operands | Operation                    | Status Affected |
|-----------------|--------------|---------------------------|-------------|----------|------------------------------|-----------------|
| 010 0bb bff     | fff (2000)   | Bit Clear f               | BCF         | f, b     | 0→f(b)                       | None            |
| 010 1bb bff     | fff (2400)   | Bit Set f                 | BSF         | f, b     | 1→f(b)                       | None            |
| 011 0bb bff     | f f f (3000) | Bit Test f, Skip if Clear | BTFSC       | f, b     | Bit Test f(b): skip if clear | None            |
| 011 1bb bff     | fff (3400)   | Bit Test f, Skip if Set   | BTFSS       | f, b     | Bit Test f(b): skip is set   | None            |

# LITERAL AND CONTROL OPERATIONS

| (11-0)  | (7-0)       |
|---------|-------------|
| OP CODE | k (LITERAL) |
|         |             |

/7-O\

| Inst | tructio | n-Bina | ry (Oc | tal)   | Name                          | Mnemonic, | Operands | Operation            | Status Affected |
|------|---------|--------|--------|--------|-------------------------------|-----------|----------|----------------------|-----------------|
| 100  | 0 k k   | kkk    | kkk    | (4000) | Return and place Literal in 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        | kVW→W                | Z               |
| 111  | 0 k k   | kkk    | kkk    | (7000) | AND Literal and W             | ANDLW     | k        | k∙W→W                | Z               |
| 111  | 1 k k   | k k k  | 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>8</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.

### 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 (Octal) |                    | ctal)            | Name                           | Mnemonic,<br>Operands | Equivalent<br>Operation(s) | Status<br>Affected |
|----------------------------|--------------------|------------------|--------------------------------|-----------------------|----------------------------|--------------------|
| 010 000 0                  | 000 011            | (2003)           | Clear Carry                    | CLRC                  | BCF 3, 0                   | _                  |
| 010 100 0                  | 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 0                  | 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 0                  | 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<br>001 010         | 1ff fff<br>dff fff | (1140)<br>(1200) | Negate File                    | NEGF f,d              | COMF f, 1<br>INCF f, d     | z                  |
| 011 000<br>001 010         | 000 011<br>dff fff | (3003)<br>(1200) | Add Carry to File              | ADDCF f, d            | BTFSC 3,0<br>INCF f, d     | z                  |
|                            | 000 011<br>dff fff | (3003)<br>(0300) | Subtract Carry from File       | SUBCF f,d             | BTFSC 3,0<br>DECF f, d     | z                  |
| 011 000<br>001 010         | 100 011<br>dff fff | (3043)<br>(1200) | Add Digit Carry to File        | ADDDCF f,d            | BTFSG 3,1<br>INCF f,d      | z                  |
|                            | 100 011<br>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                     | _                  |
|                            | 000 011<br>kkk kkk | (3003)<br>(5000) | Branch on Carry                | BC k                  | BTFSC 3,0<br>GOTO k        | _                  |
|                            | 000 011<br>kkk kkk | (3403)<br>(5000) | Branch on No Carry             | BNC k                 | BTFSS 3,0<br>GOTO k        | _                  |
| 011 100<br>101 kkk         | 100 011<br>kkk kkk | (3043)<br>(5000) | Branch on Digit Carry          | BDC k                 | BTFSC 3,1<br>GOTO k        | _                  |
|                            | 000 011<br>kkk kkk | (3443)<br>(5000) | Branch on No Digit Carry       | BNDC k                | BTFSS 3,1<br>GOTO k        | _                  |
|                            | 000 011<br>kkk kkk | (3103)<br>(5000) | Branch on Zero                 | BZ k                  | BTFSC 3,2<br>GOTO k        | _                  |
| 011 101<br>101 kkk         | 000 011<br>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  $Q_2$ , allowing the TTL open collector device to drive the pad, pulled up by  $Q_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.



### **Programming Cautions**

The use of the bidirectional I/O ports are subject to certain rules of operation. These rules must be carefully followed in the instruction sequences written for I/O operation.

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

would be no problem.

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.

#### 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_{po}$  (See I/O Timing Diagram) is greater than  $\frac{1}{2} t_{cy}$  (min). When in doubt, it is better to separate these instructions with a NOP or other instruction.





INSTRUMENT PIC1650A

#### **ELECTRICAL CHARACTERISTICS**

### Maximum Ratings\*

| Ambient temperature Under Bias                  | 25° C |
|-------------------------------------------------|-------|
| Storage Temperature                             | 50° C |
| Voltage on any pin with Respect to Vss0.3V to + | 10.0V |
| Power Dissipation                               | 0mW   |

### Standard Conditions (unless otherwise stated):

#### DC CHARACTERISTICS/PIC1650A

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.

| Characteristic                                            | Sym              | Min                | Тур†             | Max                                 | Units       | Conditions                                                                                                                                                                                                                                                                                                             |
|-----------------------------------------------------------|------------------|--------------------|------------------|-------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Primary Supply Voltage                                    | V <sub>DD</sub>  | 4.5                | <u> </u>         | 7.0                                 | ٧           |                                                                                                                                                                                                                                                                                                                        |
| Output Buffer Supply Voltage                              | V <sub>xx</sub>  | 4.5                | _                | 10.0                                | V           | (Note 2)                                                                                                                                                                                                                                                                                                               |
| Primary Supply Current                                    | IDD              | _                  | 30               | 55                                  | mA          | All I/O pins @ V <sub>DD</sub>                                                                                                                                                                                                                                                                                         |
| Output Buffer Supply Current                              | Ixx              |                    | 1                | 5                                   | mA          | All I/O pins @ V <sub>DD</sub> (Note 3)                                                                                                                                                                                                                                                                                |
| Input Low Voltage                                         | V <sub>IL</sub>  | -0.2               | _                | 0.8                                 | V           |                                                                                                                                                                                                                                                                                                                        |
| Input High Voltage (except MCLR, RTCC & OSC)              | V <sub>iH</sub>  | 2.4                | _                | V <sub>DD</sub>                     | v           |                                                                                                                                                                                                                                                                                                                        |
| Input Low-to-High Threshold Voltage<br>(MCLR, RTCC & OSC) | VILH             | V <sub>DD</sub> -1 | 2.6              | V <sub>DD</sub>                     | v           |                                                                                                                                                                                                                                                                                                                        |
| Output High Voltage                                       | V <sub>OH</sub>  | 2.4<br>3.5         | =                | V <sub>DD</sub>                     | V           | $I_{OH} = -100\mu A \text{ (Note 4)}$<br>$I_{OH} = 0$                                                                                                                                                                                                                                                                  |
| Output Low Voltage (I/O only)                             | V <sub>OL1</sub> | -<br>-<br>-<br>-   | _<br>_<br>_<br>_ | 0.45<br>0.90<br>0.90<br>1.20<br>2.0 | V<br>V<br>V | $ \begin{aligned} &I_{OL} = 1.6 \text{mA}, \ V_{XX} = 4.5 \text{V} \\ &I_{OL} = 5.0 \text{mA}, \ V_{XX} = 4.5 \text{V} \\ &I_{OL} = 5.0 \text{mA}, \ V_{XX} = 8.0 \text{V} \\ &I_{OL} = 10.0 \text{mA}, \ V_{XX} = 8.0 \text{V} \\ &I_{OL} = 20.0 \text{mA}, \ V_{XX} = 8.0 \text{V} \ (\text{Note 5}) \end{aligned} $ |
| Output Low Voltage (CLK OUT)                              | V <sub>OL2</sub> | _                  | _                | 0.45                                | V           | I <sub>OL</sub> = 1.6mA (Note 5)                                                                                                                                                                                                                                                                                       |
| Input Leakage Current (MCLR, RTCC)                        | I <sub>LC</sub>  | -5                 | _                | +5                                  | μΑ          | $V_{SS} \leqslant V_{IN} \leqslant V_{DD}$                                                                                                                                                                                                                                                                             |
| Output Leakage Current<br>(open drain I/O pins)           | I <sub>OLC</sub> | _                  | _                | 10                                  | μΑ          | V <sub>SS</sub> ≤ V <sub>PIN</sub> ≤ 10V                                                                                                                                                                                                                                                                               |
| Input Low Current (all I/O ports)                         | I <sub>IL</sub>  | -0.2               | -0.6             | -1.6                                | 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.4                                | 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:  $P_D = (V_{DD}) \; (I_{DD}) + \Sigma \; (V_{DD} V_{DI}) \; (|I_{IL}|) + \Sigma \; (V_{DD} V_{OH}) \; (|I_{OH}|) + \Sigma \; (V_{OL}) \; (I_{OL}).$  The term I/O refers to all interface pins; input, output or I/O.
- 2. V<sub>XX</sub> supply drives only the I/O ports.
- 3. The maximum  $I_{\chi\chi}$  current will be drawn when all I/O ports are outputting a High.
- Positive current indicates current into pin. Negative current indicates current out of pin.
- Total I<sub>OL</sub> for all output pins (I/O ports plus CLK OUT) must not exceed 225mA.

#### DC CHARACTERISTICS/PIC1650AI

Operating Temperature T<sub>A</sub> = -40° C to +85° C

| Characteristic                                            | Sym              | Min                | Тур†             | Max                                 | Units       | Conditions                                                                                                                                                                                                                                                                                                             |
|-----------------------------------------------------------|------------------|--------------------|------------------|-------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Primary Supply Voltage                                    | V <sub>DD</sub>  | 4.5                |                  | 7.0                                 | V           |                                                                                                                                                                                                                                                                                                                        |
| Output Buffer Supply Voltage                              | V <sub>xx</sub>  | 4.5                | _                | 10.0                                | V           | (Note 2)                                                                                                                                                                                                                                                                                                               |
| Primary Supply Current                                    | I <sub>DD</sub>  |                    | 30               | 60                                  | mA          | All I/O pins @ V <sub>DD</sub>                                                                                                                                                                                                                                                                                         |
| Output Buffer Supply Current                              | I <sub>xx</sub>  | <b>—</b>           | 1                | 5                                   | mA          | All I/O pins @ V <sub>DD</sub> (Note 3)                                                                                                                                                                                                                                                                                |
| Input Low Voltage                                         | V <sub>IL</sub>  | -0.2               | _                | 0.7                                 | V           |                                                                                                                                                                                                                                                                                                                        |
| Input High Voltage (except<br>MCLR, RTCC & OSC)           | V <sub>IH</sub>  | 2.4                | _                | V <sub>DD</sub>                     | v           |                                                                                                                                                                                                                                                                                                                        |
| Input Low-to-High Threshold Voltage<br>(MCLR, RTCC & OSC) | V <sub>ILH</sub> | V <sub>DD</sub> -1 | 2.6              | V <sub>DD</sub>                     | v           |                                                                                                                                                                                                                                                                                                                        |
| Output High Voltage                                       | V <sub>OH</sub>  | 2.4                | _                | V <sub>DD</sub>                     | V           | $I_{OH} = -100\mu A \text{ (Note 4)}$<br>$I_{OH} = 0$                                                                                                                                                                                                                                                                  |
| Output Low Voltage (I/O only)                             | V <sub>OL1</sub> | -<br>-<br>-<br>-   | _<br>_<br>_<br>_ | 0.45<br>0.90<br>0.90<br>1.20<br>2.0 | V<br>V<br>V | $ \begin{aligned} &I_{OL} = 1.6 \text{mA}, \ V_{XX} = 4.5 \text{V} \\ &I_{OL} = 5.0 \text{mA}, \ V_{XX} = 4.5 \text{V} \\ &I_{OL} = 5.0 \text{mA}, \ V_{XX} = 8.0 \text{V} \\ &I_{OL} = 10.0 \text{mA}, \ V_{XX} = 8.0 \text{V} \\ &I_{OL} = 20.0 \text{mA}, \ V_{XX} = 8.0 \text{V} \ (\text{Note 5}) \end{aligned} $ |
| Output Low Voltage (CLK OUT)                              | V <sub>OL2</sub> |                    | _                | 0.45                                | V           | I <sub>OL</sub> = 1.6mA (Note 5)                                                                                                                                                                                                                                                                                       |
| Input Leakage Current (MCLR, RTCC)                        | ILC              | -5                 | _                | +5                                  | μΑ          | $V_{SS} \leqslant V_{IN} \leqslant V_{DD}$                                                                                                                                                                                                                                                                             |
| Output Leakage Current<br>(open drain I/O pins)           | lorc             | _                  | _                | 10                                  | μΑ          | V <sub>SS</sub> ≤ V <sub>PIN</sub> ≤ 10V                                                                                                                                                                                                                                                                               |
| Input Low Current (all I/O ports)                         | I <sub>fL</sub>  | -0.2               | -0.6             | -1.8                                | 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.8                                | 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:  $P_D = (V_{DD}) \; (I_{DD}) + \Sigma \; (V_{DD} - V_{IL}) \; (|I_{IL}|) + \Sigma \; (V_{DD} - V_{OH}) \; (|I_{OH}|) + \Sigma \; (V_{OL}) \; (I_{OL}).$ The term I/O refers to all interface pins; input, output or I/O.
- 2.  $V_{XX}$  supply drives only the I/O ports.
- 3. The maximum I<sub>XX</sub> current will be drawn when all I/O ports are outputting a High.
- 4. Positive current indicates current into pin. Negative current indicates current out of pin.
- Total I<sub>OL</sub> for all output pins (I/O ports plus CLK OUT) must not exceed 225mA.

#### Standard Conditions (unless otherwise stated): AC CHARACTERISTICS/PIC1650A, PIC1650AI

Operating Temperature  $T_A = 0^{\circ} C$  to  $+70^{\circ} C$  (PIC1650A),  $T_A = -40^{\circ} C$  to  $+85^{\circ} C$  (PIC1650Al)

| Characteristic                | Sym              | Min                    | Typ <sup>†</sup> | Max                    | Units | Conditions                                  |
|-------------------------------|------------------|------------------------|------------------|------------------------|-------|---------------------------------------------|
| Instruction Cycle Time        | t <sub>CY</sub>  | 4                      | _                | 20                     | μs    | 0.2MHz — 1.0MHz external time base (Note 1) |
| RTCC Input                    |                  |                        |                  |                        |       |                                             |
| Period                        | t <sub>RT</sub>  | t <sub>CY</sub> +0.2µs | _                | -                      | ] —   |                                             |
| High Pulse Width              | t <sub>RTH</sub> | ½t <sub>RT</sub>       | _                | -                      | l –   | 1                                           |
| Low Pulse Width               | t <sub>RTL</sub> | ½t <sub>AT</sub>       | _                | -                      | -     | (Notes 2 and 3)                             |
| I/O Ports                     |                  |                        |                  |                        |       |                                             |
| Data Input Setup Time         | ts               | 1 - 1                  | _                | 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>  | -                      | 600              | 1000                   | ns    | Capacitive load = 50pF                      |
| OSC Input                     |                  |                        |                  |                        |       |                                             |
| External Input Impedance High | Rosch            | 120                    | 800              | 3500                   | Ω     | V <sub>OSC</sub> = 5V Applies to external   |
| External Input Impedance Low  | Roscu            | _                      | 10 <sup>6</sup>  | _                      | Ω     | V <sub>OSC</sub> =0.4V OSC drive only.      |

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

#### NOTES:

1. Instruction cycle period (t<sub>CY</sub>) 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. The maximum frequency which may be input to the RTCC pin is calculated as follows:  $f_{(max)} = \frac{1}{t_{RT (min)}} = \frac{1}{t_{CY (min)} + 0.2\mu s}$ For example: if  $t_{CY} = 4\mu s$ ,  $f_{(max)} = \frac{1}{4.2\mu s} = 238 \text{KHz}$ .









### PIC1650A OSCILLATOR OPTIONS (TYPICAL CIRCUITS)

#### **RC OPTION OPERATION**





 $V_{DD} = 5.0V$ C = 47pF

 $T_A = 25^{\circ} C$ 

INSTRUCTION CYCLE TIME (kHz)
Oscillator Frequency With Typical Unit To Unit Variance

Unit to Unit Variation at V<sub>DD</sub> = 5.0V, T<sub>A</sub> = 25° C is  $\pm 25\%$  Variation from V<sub>DD</sub> = 4.5V -7.0V referenced to 5V is -3%, +9% Variation from T<sub>A</sub> = 0° C -70° C referenced to 25° C is +3%, -5%

#### **BUFFERED CRYSTAL INPUT OPERATION**



The buffer must be capable of driving  $120\Omega$ , min.  $(800\Omega$ , typ.) to 2.0V. However, it is recommended that the pull-down transistor on the OSC pin be removed (an option) if OSC is to be driven externally.

### **EXTERNAL CLOCK INPUT OPERATION**





### 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.

### MASTER CLEAR (TYPICAL CIRCUIT)



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







#### 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.

#### PIC1650A EMULATION CAUTIONS

When emulating a PIC1650A 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 PIC1650A mode. (Refer to PICES II Manual). The PIC1664B 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 OSC1 pin #59 becomes a single clock input pin.
  - 3. The interrupt system becomes disabled and the RTCC always counts on the trailing edges.
  - 4. 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 used
- D. Be sure to use the 40 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 1msec after the supply voltage is applied to allow the oscillator to start up.
- F. If an external oscillator drive is used, be sure that it can drive the  $120\Omega$  input impedance of the OSC pin on the PIC1664.
- G. The cable length and internal variations may cause some parameter values to differ between the PICES II module and a production PIC1650A.

### **TELEVIEW Control Chip**

#### **FEATURES**

- Interfaces user to Teleview system
- Initializes Teleview system
- PIC1650A-518 4 x 4 Keyboard, Teletext and Viewdata
- PIC1650A-519 4 x 4 Keyboard, Viewdata only, local programing of EAROM
- PIC1650A-532 ASCII or IR remote, Teletext and Viewdata
- PIC1650A-533 ASCII or IR remote, Viewdata only, local programing of EAROM

#### **DESCRIPTION**

The Teleview control chip PIC1650A interfaces the user to the Teleview system and generally organizes the operation of the system.

It is available in several versions each providing alternative user inputs and operating features.

Customized versions can be provided if required.

The features of the various versions are shown in the appendices.

#### PIN CONFIGURATION Top View V<sub>SS</sub> (negative supply) □ •1 40 V<sub>xx</sub> (positive supply) 39 V<sub>DD</sub> 38 — A0 Address Input/Output 2 A1 Address Input/Output 3 37 RESET 36 D OSC A3 Address Input/Output 6 A4 Address Input/Output 7 35 Clock Output 34 D7 Data Input/Output 33 D6 Data Input/Output A5 Address Input/Output | 8 A6 Address Input/Output 9 A7 Address Input/Output 10 32 D5 Data Input/Output 31 D4 Data Input/Output A8 Address Input/Output [ 11 30 D3 Data Input/Output 29 D2 Data Input/Output 28 D1 Data Input/Output A9 Address Input/Output [ 12 Read/Write Output | 13 SS0 Store Select Output 14 SS1 Store Select Output 15 27 D0 Data Input/Output 26 KB7 Keyboard Interface SS2 Store Select Output [ 16 25 KB6 Keyboard Interface TS1 Timeslot Input | 17 24 KB5 Keyboard Interface TS2 Timeslot Input ☐ 18 KB0 Keyboard Interface ☐ 19 23 KB4 Keyboard Interface 22 KB3 Keyboard Interface 21 KB2 Keyboard Interface KB1 Keyboard Interface 20

#### **PIN FUNCTIONS**

| Pin No.  | Name                               | Function                                                                                                           |  |  |  |  |
|----------|------------------------------------|--------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 1        | V <sub>ss</sub>                    | Negative supply (Ground).                                                                                          |  |  |  |  |
| 2-12     | A0-A9                              | Address Input/Outputs which are connected to the Teleview Address Bus.                                             |  |  |  |  |
| 5        | V <sub>ss</sub>                    | Test pin — connect to V <sub>SS</sub> .                                                                            |  |  |  |  |
| 13       | Read/Write                         | Control output connected to the Teleview R/W input.                                                                |  |  |  |  |
| 14-16    | SS0-SS2                            | Store Select outputs.                                                                                              |  |  |  |  |
| 17, 18   | TS1, TS2                           | Time Slot Inputs from Video Generator.                                                                             |  |  |  |  |
| 19-26    | KB0-KB7                            | Keyboard Interface, may be Inputs, Outputs or Inputs/Outputs depending upon the version.                           |  |  |  |  |
| 27-34    | D0-D7                              | Data Inputs/Outputs which are connected to the Teleview Data Bus.                                                  |  |  |  |  |
| 35       | Clock Output                       | Not used except to check the Clock frequency (output frequency $f_x/4$ ).                                          |  |  |  |  |
| 36       | Oscillator                         | Oscillator resistor and capacitor connected to this pin.                                                           |  |  |  |  |
| 37       | Reset                              | Master reset input which must be kept at ground potential until the V <sub>DD</sub> power is within specification. |  |  |  |  |
| 38       |                                    | Not used.                                                                                                          |  |  |  |  |
| 39<br>40 | V <sub>DD</sub><br>V <sub>xx</sub> | Positive power supplies +5V Nom.                                                                                   |  |  |  |  |

#### **ELECTRICAL CHARACTERISTICS**

(See PIC1650A Data Sheet for full specification).

#### Maximum Ratings\*

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

$$\begin{split} &V_{SS} = 0V \\ &V_{DD} = +5V \pm 10\% \\ &V_{XX} = +5V \pm 10\% \\ &F_{clock} = 1\,\text{MHz} \\ &T_A = 0^{\circ}\,\text{C to } +70^{\circ}\,\text{C} \end{split}$$

\* 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.

| Characteristic                | Min                | Тур | Max   | Units | Conditions                |
|-------------------------------|--------------------|-----|-------|-------|---------------------------|
| Clock Frequency               | 0.8                |     | 1     | MHz   |                           |
| Input Low Voltage             | -0.2               | _   | 0.8   | V     |                           |
| Input High Voltage            | 2.4                | _   | _     | V     |                           |
| Input High Voltage (Reset)    | V <sub>DD</sub> -1 |     |       | v     |                           |
| Input Low Current             | -200               |     | -1600 | μΑ    | $V_{11} = 0.4V$           |
| Input High Current            | -100               | _   | -     | μΑ    | V <sub>IH</sub> = 2.4V    |
| Input Leakage Current (Reset) | -10                | _   | 10    | μΑ    |                           |
| Output Low Voltage            | _                  | _   | 0.4   | v     | $I_{Ol} = 1.6 \text{ mA}$ |
| Output High Voltage           | 2.4                | _   | _     | V     | $I_{OH} = -100 \mu A$     |
| Supply Current: Ipp           | -                  | _   | 55    | mA    |                           |
| I <sub>xx</sub>               | _                  | _   | 5     |       |                           |

#### **APPENDIX 1/PIC1650A-518**

This version interfaces with a 4 x 4 keyboard and provides basic Teletext/Viewdata operation. It replaces pattern 514.

4 x 4 matrix keyboard POWER UP MODE Picture Teleview White **POWER UP DISPLAY POWER UP PAGE** XOO in Store 7 KEYBOARD INTERFACE

Row Input/Output KB0 pin 19 KB1 pin 20 Row Input/Output KB2 pin 21 Row Input/Output Row Input/Output KB3 pin 22 Column Input/Output KB4 pin 23 KB5 pin 24 Column Input/Output KB6 pin 25 Column Input/Output Column Input/Output KB7 pin 26

**KEYBOARD CODES** 

KB0/KB4 7 KB2/KB4 1 KB2/KB5 2 KB0/KB5 8 KB0/KB6 KB2/KB6 3

KB0/KB7 Picture/Text KB2/KB7 Reveal/Conceal KB3/KB4 Page/\* KB1/KB4 4 KB3/KB5 0 5 KB1/KB5 KB1/KB6 6 KB3/KB6 Time/# KB1/KB7 Update KB3/KB7 Store Select

#### NOTES:

- 1. Details of the operating features are contained in the general Teleview documents.
- 2. Two double key operations are recognized:
  - (a) Store Select 9 is equivalent to Box Clock.
  - (b) Store Select 0 is equivalent to Hold.

#### **APPENDIX 2/PIC1650A-532**

This version interfaces either with an ASCII return to zero keyboard or with an AY-3-8475 remote control receiver. It replaces pattern 516.

INPUT (a) ASCII Return to zero

(b) Binary Return to zero (from local keyboard or AY-3-8475 remote control)

POWER UP MODE Picture

**POWER UP DISPLAY** (a) ASCII Teleview Cyan

(b) Binary Teleview Yellow XOO in Store 7

**KEYBOARD INTERFACE** 

**POWER UP PAGE** 

KB0 pin 19 LSB Input LSB Input KB1 pin 20 LSB Input KB2 pin 21 KB3 pin 22 LSB Input KB4 pin 23 LSB Input LSB Input KB5 pin 24 MSB Input KB6 pin 25

ASCII/Local Binary Input or KB7 pin 26

Remote Acknowledge

#### KEYBOARD CODES

(a) ASCII

Standard 7 Bit ASCII (These codes are only acted upon in Viewdata Mode)

(b) Binary (Local or Remote)

#### Binary Code Key Meaning

#### MSB LSB

1100000 Picture/Text 1100001 Mix Half Page Expansion 1100010 1100011 Store Select 1100100 7 1100101 8 1100110 1100111 **Box Clock** 1101000 1101001 1101010

1101011 Hold (Store Rotating Pages) (Release Line)

#### PIC1650A

#### Binary Code Key Meaning

| М | S | В | L | s | E |
|---|---|---|---|---|---|
|---|---|---|---|---|---|

| 1101100 | 1                       |
|---------|-------------------------|
| 1101101 | 2                       |
| 1101110 | 3                       |
| 1101111 | Reveal/Conceal          |
| 1110000 | Page (or * in Viewdata) |
| 1110001 | 0                       |
| 1110010 | Time (or # in Viewdata) |
| 1110011 | Update/Clear            |
| 1110100 | Rounding + Flash Off    |
| 1110101 | Cursor ON               |
| 1110110 | Cursor OFF              |
| 1110111 | Roll Headers            |

#### NOTES:

1. During initialization the PIC1650A-532 decides whether an ASCII keyboard or an AY-3-8475 remote control receiver is being used. If all Keyboard Interface inputs are low an ASCII keyboard is assumed.

#### (a) ASCII Mode

Return to zero signalling is employed, the KB7 input being used to switch from full ASCII to local Binary.

With KB7 equal to 1 the other 7 bits are read as standard ASCII. (Note this input must be pulsed with the other bits).

With KB7 equal to '0' the other 7 bits are read as binary with meanings detailed above.

#### (b) Remote Mode

In this case the same binary codes are used but an acknowledgement routine is performed by the PIC1650A-532. See AY-3-8475 data sheet for details.

The connections between the PIC1650A-532 and the AY-3-8475 are made as follows:

```
PIC1650A-532 AY-3-8475
KB0 pin 19
               1/O A pin 14
KB1 pin 20
               I/O B pin 15
KB2 pin 21
               I/O C pin 16
               I/O D pin 17
KB3 pin 22
KB4 pin 23
               I/O E pin 20
KB5 pin 24
               I/O F pin 21
KB6 pin 25
               I/O G pin 22
KB7 pin 26
               Digital Data Control + Data
               Available (pins 18, 19).
```

- 2. The codes should be valid for a minimum of 20ms. In the ASCII mode if the two key operation SS0 is used the Second code (0) should only be valid for a maximum of 120ms to avoid changing keyboard modes.
- 3. The double key operations are recognized:
  - (a) Store Select 9 is equivalent to Roll Headers.
  - (b) Store Select 0 is equivalent to Reset (Clear Stores).



#### **APPENDIX 3/PIC1650A-519**

This version interfaces with a 4 x 4 keyboard and as such may replace pattern 518.

It provides control of Viewdata functions only, together with local programing of Telephone numbers via PIC1650-536.

INPUT 4 x 4 matrix keyboard

POWER UP MODE Text (picture mode not available). Cursor off POWER UP DISPLAY Double height Teleview in yellow on blue

POWER UP STORE Store 1 (binary 000)

**KEYBOARD INTERFACE** 

Row Input/Output KB0 pin 19 KB1 pin 20 Row Input/Output KB2 pin 21 Row Input/Output KB3 pin 22 Row Input/Output KB4 pin 23 Column Input/Output KB5 pin 24 Column Input/Output KB6 pin 25 Column Input/Output KB7 pin 26 Column Input/Output

#### KEYBOARD CODES

| 0/4 | 7               | 2/4 | 1              |
|-----|-----------------|-----|----------------|
| 0/5 | 8               | 2/5 | 2              |
| 0/6 | 9               | 2/6 | 3              |
| 0/7 | Hold/Disconnect | 2/7 | Reveal/Conceal |
| 1/4 | 4               | 3/4 | Star           |
| 1/5 | 5               | 3/5 | 0              |
| 1/6 | 6               | 3/6 | Square         |
| 1/7 | Half page       | 3/7 | Store Select   |
|     | expansion       |     |                |

#### Operation

- (a) Star, Square and digits 0-9 transmitted to line via UAR/T and MODEM. If 536 autodialer fitted then the square key plus digits 1-4 are used to dial.
- (b) Hold. If 536 autodialer fitted this key will cause the telephone line to be released while maintaining the display.
- (c) Print. The two key sequence SS.9 is used to alternately put the system into MIX mode and back to normal. Mix mode enables monochrome video to be generated and removes colored backgrounds. When entering mix mode character rounding and flashing are inhibited until a new page is received (only for AY-3-9735).
- (d) Reveal/Conceal. Alternately reveals and conceals concealed characters. Reveal mode off when new page received or new store selected.
- (e) Store select. Followed by digits 1-8 will select one of eight possible Stores for display. If 536 autodialer fitted and system in "link-back" mode then local programing of telephone numbers may be enabled by selecting Store zero. SS0 will clear screen and digits 1-4 may be pressed to enable the programing of the appropriate telephone number. The numbers entered using digits 0-9 (0 displayed as :), star for access pause (displayed as :) and square for formatting and space filler (displayed as ?) to complete all 16 digits. SS0 followed by Reveal will display all the telephone numbers on the screen.

## PIC1650A

#### **APPENDIX 4/PIC1650A-533**

This version interfaces either with an ASCII, return to zero keyboard or with an AY-3-8475 remote control receiver and as such may replace pattern 532.

It provides control of Viewdata functions only together with Local Programing of Telephone numbers via PIC1650-536.

INPUT ASCII return to zero or binary return to zero from local keyboard or direct connection to remote receiver. **POWER UP MODE** Text. Cursor off **POWER UP DISPLAY** Double height Teleview in yellow on blue

**POWER UP STORE** Store number 1 (binary 000)

**KEYBOARD INTERFACE** 

LSB Input KB0 pin 19 KB1 pin 20 LSB Input KB2 pin 21 LSB Input KB3 pin 22 LSB Input KB4 pin 23 LSB Input KB5 pin 24 LSB Input KB6 pin 25 MSB Input

ASCII/Local Binary Input or Remote Acknowledge KB7 pin 26

#### **KEYBOARD CODES**

(a) ASCII

Full 7 bit ASCII set

(b) Binary (Local or Remote)

| Binary Code | Key Meaning             |
|-------------|-------------------------|
| 1100000     | Picture/Text            |
| 1100001     | Print                   |
| 1100010     | Half page expansion     |
| 1100011     | Store Select            |
| 1100100     | 7                       |
| 1100101     | 8                       |
| 1100110     | 9                       |
| 1100111     | (not used)              |
| 1101000     | 4                       |
| 1101001     | 5                       |
| 1101010     | 6                       |
| 1101011     | Hold/Disconnect line    |
| 1101100     | 1                       |
| 1101101     | 2                       |
| 1101110     | 3                       |
| 1101111     | Reveal/Conceal          |
| 1110000     | Star                    |
| 1110001     | 0                       |
| 1110010     | Square                  |
| 1110011     | Clear (inhibit display) |
| 1110100     | Rounding & Flashing off |
| 1110101     | Cursor ON               |
| 1110110     | Cursor OFF              |
| 1110111     | Reset                   |

Notes 1 and 2 as for pattern 532.

#### Operation

- ASCII codes transmitted directly to line via UAR/T and MODEM. If 536 autodialer fitted, square and digits 1-4 will enable dialing.
- Picture/Text. Switches display alternately between picture and text. If 536 autodialer fitted this key will drop the telephone (b)
- Print. Alternately puts system into MIX mode and back to normal. Mix mode enables monochrome video to be generated and removes colored backgrounds. When entering mix mode character rounding and flashing are inhibited until new page received (only for AY-3-9735).
- Store/Select. Followed by digits 1-8 will select one of eight possible Stores for display. If 536 autodialer fitted and system in "linkback" mode then Local Programing of telephone numbers may be enabled by selecting store zero. SS0 will clear screen and digits 1-4 may be pressed to enable the programing of the appropriate telephone number. The number is entered using digits 0-9 (0 displayed as :) star for access pause (displayed as ;) and square as formatter and space filler (displayed as ?) to complete all 16 digits. SS0 followed by Reveal will display all the telephone numbers on the screen.
- Hold. If the 536 autodialer is fitted this key will drop the telephone line.
- Reveal/Conceal. Will alternately reveal and conceal concealed characters. Initialized to conceal state for new page or new (f)
- Clear. Clears the screen of all text. Display restored by second depression of the key and by reception of a new page. (g)
- Rounding and Flashing Off. Character rounding and flashing may be inhibited in AY-3-9735 until a new page is received. (h)
- Cursor ON/OFF. The cursor may be locally controlled by these codes. (i)
- Reset. Simulate the power-on reset. All stores are cleared and initialized to "Teleview". (j)