

# MOS 6509 DATASHEET

## REVISION 10/86

### WARNING

This datasheet contains an error in the pinout: pins 38 and 40 are swapped. Pin 38 should be  $\phi_2$  and Pin 40 should be  $\phi_1$ . For verification, see the CBM-II computer schematics. The error was discovered by Jim Brain on Feb 27, 2018.



# COMMODORE SEMICONDUCTOR GROUP

a division of Commodore Business Machines, Inc.

950 Rittenhouse Road, Norristown, PA 19403 • 215/666-7950 • TWX 510-660-4168

## NMOS

## 6509 MICROPROCESSOR WITH MEMORY MANAGEMENT

### DESCRIPTION

The 6509 is a low-cost microprocessor capable of solving a broad range of small-systems and memory management problems at minimum cost to the user.

A memory management system allows for up to One Mega-Byte of memory for ease in down loading languages, operating systems or other data.

The Three-State sixteen-bit Address Bus allows Direct Memory Accessing (DMA) and multi-processor systems sharing a common memory while the Four-bit Extended Address Register allows for up to one Mega-byte of data storage.

The internal processor architecture is identical to the Commodore Semiconductor Group 6502 to provide software compatibility.

### FEATURES OF THE 6509

- Memory management
- On board clock logic
- Addressable memory range of up to 1 M bytes
- Single +5 volt supply
- N channel, silicon gate, depletion load technology
- Eight bit parallel processing
- 56 Instructions
- Decimal and binary arithmetic
- Thirteen addressing modes
- True indexing capability
- Programmable stack pointer
- Variable length stack
- Interrupt capability
- 8 Bit Bi-Directional Data Bus
- Program Addressable memory range of up to 65K bytes
- Direct memory access capability
- Bus compatible with M6800
- Pipeline architecture
- 1 MHz, 2 MHz, and 3 MHz operation
- Use with any type or speed memory

### PIN CONFIGURATION

|       |    |    |                   |
|-------|----|----|-------------------|
| READY | 1  | 40 | Ø <sub>2</sub> IN |
| IRQ   | 2  | 39 | RESET             |
| SYNC  | 3  | 38 | Ø <sub>1</sub> IN |
| NMI   | 4  | 37 | R/W               |
| AEC   | 5  | 36 | D0                |
| VDD   | 6  | 35 | D1                |
| A0    | 7  | 34 | D2                |
| A1    | 8  | 33 | D3                |
| A2    | 9  | 32 | D4                |
| A3    | 10 | 31 | D5                |
| A4    | 11 | 30 | D6                |
| A5    | 12 | 29 | D7                |
| A6    | 13 | 28 | SO                |
| A7    | 14 | 27 | P0                |
| A8    | 15 | 26 | P1                |
| A9    | 16 | 25 | P2                |
| A10   | 17 | 24 | P3                |
| A11   | 18 | 23 | A15               |
| A12   | 19 | 22 | A14               |
| A13   | 20 | 21 | VSS               |



6509 BLOCK DIAGRAM

## 6509 CHARACTERISTICS

### MAXIMUM RATINGS

| RATING                | SYMBOL           | VALUE         | UNIT |
|-----------------------|------------------|---------------|------|
| SUPPLY VOLTAGE        | V <sub>CC</sub>  | -0.3 to + 7.0 | Vdc  |
| INPUT VOLTAGE         | V <sub>IN</sub>  | -0.3 to + 7.0 | Vdc  |
| OPERATING TEMPERATURE | T <sub>A</sub>   | 0 to + 70     | C    |
| STORAGE TEMPERATURE   | T <sub>STG</sub> | -55 to + 150  | C    |

This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating.

### ELECTRICAL CHARACTERISTICS (V<sub>CC</sub> = 5.0V ± 5%, V<sub>SS</sub> = 0, T<sub>A</sub> = 0 to + 70 C)

| CHARACTERISTIC                                                                                                                                                           | SYMBOL                                                                         | MIN.                         | TYP.                                      | MAX.                        | UNIT       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------|-------------------------------------------|-----------------------------|------------|
| Input High Voltage<br>Ø <sub>1</sub> , Ø <sub>2</sub> (in)<br>Input High Voltage<br>RES, P <sub>0</sub> -P <sub>7</sub> , IRQ, Data                                      | V <sub>IH</sub>                                                                | V <sub>CC</sub> - 0.2<br>2.0 | —<br>—                                    | V <sub>CC</sub> + 1.0V<br>— | Vdc<br>Vdc |
| Input Low Voltage<br>Ø <sub>1</sub> , Ø <sub>2</sub> (in)<br>RES, P <sub>0</sub> -P <sub>7</sub> , IRQ, Data                                                             | V <sub>IL</sub>                                                                | —<br>—                       | —<br>—                                    | 0.2<br>0.8                  | Vdc<br>Vdc |
| Input Leakage Current<br>(V <sub>IN</sub> = 0 to 5.25V, V <sub>CC</sub> = 5.25V)<br>Logic<br>Ø <sub>1</sub> , Ø <sub>2</sub> (in)                                        | I <sub>IN</sub>                                                                | —<br>—                       | —<br>—                                    | 2.5<br>100                  | µA<br>µA   |
| Three State (Off State) Input Current<br>(V <sub>IN</sub> = 0.4 to 2.4V, V <sub>CC</sub> = 5.25V)<br>Data Lines                                                          | I <sub>TSI</sub>                                                               | —                            | —                                         | 10                          | µA         |
| Output High Voltage<br>(I <sub>OH</sub> = -100µAdc, V <sub>CC</sub> = 4.75V)<br>Data, A0-A15, R/W, P <sub>0</sub> -P <sub>7</sub>                                        | V <sub>OH</sub>                                                                | 2.4                          | —                                         | —                           | Vdc        |
| Out Low Voltage<br>(I <sub>OL</sub> = 1.6mA <sub>dc</sub> , V <sub>CC</sub> = 4.75V)<br>Data, A0-A15, R/W, P <sub>0</sub> -P <sub>7</sub>                                | V <sub>OL</sub>                                                                | —                            | —                                         | +0.60                       | Vdc        |
| Power Supply Current                                                                                                                                                     | I <sub>CC</sub>                                                                | —                            | 125                                       |                             | mA         |
| Capacitance<br>V <sub>IN</sub> = 0, T <sub>A</sub> = 25 C, f = 1 MHz<br>Logic, P <sub>0</sub> -P <sub>7</sub><br>Data<br>A0-A15, R/W<br>Ø <sub>1</sub><br>Ø <sub>2</sub> | C<br>C <sub>IN</sub><br>C <sub>OUT</sub><br>C <sub>Ø1</sub><br>C <sub>Ø2</sub> | —<br>—<br>—<br>30<br>50      | —<br>—<br>—<br>10<br>15<br>12<br>50<br>80 |                             | pF         |

### CLOCK TIMING



**TIMING FOR READING DATA FROM  
MEMORY OR PERIPHERALS**

## CLOCK TIMING



TIMING FOR WRITING DATA TO  
MEMORY OR PERIPHERALS

## AC CHARACTERISTICS

**1 MHz TIMING**

**2 MHz TIMING**

**3 MHz TIMING**

ELECTRICAL CHARACTERISTICS (VCC = 5V + 5%, VSS = OV, TA = 0° -70°C)

### Clock Timing

| CHARACTERISTIC                                             | SYMBOL                                 | MIN.       | MAX. | MIN.       | MAX. | MIN.       | MAX. | UNITS    |
|------------------------------------------------------------|----------------------------------------|------------|------|------------|------|------------|------|----------|
| Cycle Time                                                 | T <sub>CYC</sub>                       | 1000       | —    | 500        | —    | 333        | —    | ns       |
| Clock Pulse Width Ø1<br>(Measured at VCC - 0.2V) Ø2        | PWHØ <sub>1</sub><br>PWHØ <sub>2</sub> | 430<br>470 | —    | 215<br>235 | —    | 145<br>165 | —    | ns<br>ns |
| Fall Time, Rise Time<br>(Measured from 0.2V to VCC - 0.2V) | T <sub>F</sub> , T <sub>R</sub>        | —          | 25   | —          | 15   | —          | 15   | ns       |
| Delay Time between Clocks<br>(Measured at 0.2V)            | T <sub>D</sub>                         | 0          | —    | 0          | —    | 0          | —    | ns       |

### Read/Write Timing (Load = 1 TTL)

| CHARACTERISTIC                                | SYMBOL            | MIN. | MAX. | MIN. | MAX. | MIN. | MAX. | UNITS |
|-----------------------------------------------|-------------------|------|------|------|------|------|------|-------|
| Read, Write Setup Time from 6509              | T <sub>RWS</sub>  | —    | 300  | —    | 150  | —    | 125  | ns    |
| Address Setup Time from 6509                  | T <sub>AADS</sub> | —    | 300  | —    | 150  | —    | 125  | ns    |
| Memory Read Access Time                       | T <sub>ACC</sub>  | —    | 575  | —    | 300  | —    | 250  | ns    |
| Data Stability Time Period                    | T <sub>DSU</sub>  | 100  | —    | 50   | —    | 50   | —    | ns    |
| Data Hold Time-Read                           | T <sub>HR</sub>   | 10   | —    | 10   | —    | 10   | —    | ns    |
| Data Hold Time-Write                          | T <sub>HW</sub>   | 10   | —    | 10   | —    | 10   | —    | ns    |
| Data Setup Time from 6509                     | T <sub>MDS</sub>  | —    | 200  | —    | 100  | —    | 100  | ns    |
| Address Hold Time                             | T <sub>HA</sub>   | 10   | —    | 10   | —    | 10   | —    | ns    |
| R/W Hold Time                                 | T <sub>HRW</sub>  | 10   | —    | 10   | —    | 10   | —    | ns    |
| Port Output Data Valid<br>(Memory Management) | T <sub>PDW</sub>  | —    | 300  | —    | 150  | —    | 125  | μs    |
| RDY Setup Time                                | T <sub>RDY</sub>  | 100  | —    | 50   | —    | 15   | —    | ns    |
| S.O. Setup Time                               | T <sub>SO</sub>   | 100  | —    | 50   | —    | 50   | —    | ns    |
| SYNC Setup Time from 6509                     | T <sub>SYNC</sub> | —    | 350  | —    | 175  | —    | 120  | ns    |
| Address Enable Setup Time                     | T <sub>AES</sub>  | —    | 75   | —    | 75   | —    | 75   | ns    |
| Data Enable Setup Time                        | T <sub>DES</sub>  | —    | 120  | —    | 120  | —    | 120  | ns    |
| Address Disable *See Note 1                   | T <sub>AED</sub>  | —    | 120  | —    | 120  | —    | 120  | ns    |
| Data Disable *See Note 1                      | T <sub>DED</sub>  | —    | 130  | —    | 130  | —    | 130  | ns    |

\*Note 1 — 1TTL Load

CL = 30pf

## SIGNAL DESCRIPTION

### Clocks (Ø<sub>1</sub>, Ø<sub>2</sub>)

The 6509 requires a two phase non-overlapping clock that runs at the Vcc voltage level.

### Address Bus (A<sub>0</sub>-A<sub>15</sub>)

The tri-state outputs are TTL compatible, capable of driving one standard TTL load and 130 pf.

### Data Bus (D<sub>0</sub>-D<sub>7</sub>)

Eight pins are used for the data bus. This is a Bi-Directional bus, transferring data to and from the device and peripherals. The outputs are tri-state buffers capable of driving one standard TTL load and 130 pf.

### Reset

This input is used to reset or start the microprocessor from a power down condition. During the time that this line

is held low, writing to or from the microprocessor is inhibited. When a positive edge is detected on the input, the microprocessor will immediately begin the reset sequence.

After a system initialization time of six clock cycles, the mask interrupt flag will be set and the microprocessor will load the program counter from the memory vector locations FFFC and FFFD. This is the start location for program control.

After Vcc reaches 4.75 volts in a power up routine, reset must be held low for at least two clock cycles. At this time the R/W signal will become valid.

When the reset signal goes high following these two clock cycles, the microprocessor will proceed with the normal reset procedure detailed above.

### **Interrupt Request (IRQ)**

This TTL level input requests that an interrupt sequence begin within the microprocessor. The microprocessor will complete the current instruction being executed before recognizing the request. At that time, the interrupt mask bit in the Status Code Register will be examined. If the interrupt mask flag is not set, the microprocessor will begin an interrupt sequence. The Program Counter and Processor Status Register are stored in the stack. The microprocessor will then set the interrupt mask flag high so that no further interrupts may occur. At the end of this cycle, the program counter low will be loaded from address FFFE, and program counter high from location FFFF, therefore transferring program control to the memory vector located at these addresses.

### **Address Enable Control (AEC)**

The Address Bus, Data Bus, and R/W signal are valid only when the Address Enable Control line is high. When low, the Address Bus is in a high-impedance state. This feature allows easy DMA and multiprocessor systems.

### **Read/Write (R/W)**

This signal is generated by the microprocessor to control the direction of data transfers on the Data Bus. This line is high except when the microprocessor is writing to memory or a peripheral device.

### **Ready (RDY)**

This input signal allows the user to single cycle the microprocessor on all cycles except write cycles. A negative transition to the low state during or coincident with phase one ( $\emptyset_1$ ) and up to 100ns after phase two ( $\emptyset_2$ ) will halt the microprocessor with the output address lines reflecting the current address being fetched. This condition will remain through a subsequent phase two ( $\emptyset_2$ ) in which the Ready signal is low. This feature allows microprocessor interfacing with low speed PROMS as well as fast (max. 2 cycle) Direct Memory Access (DMA). If Ready is low during a write cycle, it is ignored until the following read operation.

### **Non-Maskable Interrupt (NMI)**

A negative going edge on this input requests that a non-maskable interrupt sequence be generated within the microprocessor.

NMI is an unconditional interrupt. Following completion of the current instruction, the sequence of operations defined for IRQ will be performed, regardless of the interrupt mask flag status. The vector address loaded into the program counter, low and high, are locations FFFA and FFFB respectively, thereby transferring program control to the memory vector located at these addresses. The instructions loaded at these locations cause the microprocessor to branch to a non-maskable interrupt routine in memory.

NMI also requires an external 3K resistor to V<sub>cc</sub> for proper wire-OR operations.

Inputs IRQ and NMI are hardware interrupt lines that are sampled during  $\emptyset_2$  (phase 2) and will begin the appropriate interrupt routine on the  $\emptyset_1$  (phase 1) following the completion of the current instruction.

### **Set Overflow Flag (.S.O.)**

A NEGATIVE going edge on this input sets the overflow bit in the Status Code Register. This signal is sampled on the trailing edge of  $\emptyset_1$ .

### **SYNC**

This output line is provided to identify those cycles in which the microprocessor is doing an OP CODE fetch. The SYNC line goes high during  $\emptyset_1$  of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the  $\emptyset_1$  clock pulse in which SYNC went high, the processor will stop in its current state and will remain in the state until the RDY line goes high. In this manner, the SYNC signal can be used to control RDY to cause single instruction execution.

### **Memory Management Control (P0-P3)**

The four extended address pins, P<sub>0</sub>-P<sub>3</sub>, enable the processor to align to one of sixteen banks of 64K memory space. The use of the instructions; Load A indirect Y (B1<sub>16</sub>) and Store A indirect Y (91<sub>16</sub>), transfers the processor from the normal execute mode to the indirect mode. In the execute mode, the processor is aligned to a particular memory bank. The indirect mode aligns the processor to a predetermined memory block. The contents of the extended address registers is controlled by software with the execute register at location 0000 and indirect register at 0001.

During fetch and execution of the indirect mode instructions, the processor remains in execute mode until data transfer is to occur. At this time the processor switches to the indirect mode aligning itself to the new memory block. After one cycle the processor returns to the execute mode.

The upper four bits of the data bus are logic "0"s during a read/write to the extended address registers. Also, these registers are set to logic "1"s during reset.

The extended address pins are not under control of AEC and are not tri-statable.

## ADDRESSING MODES

### Accumulator Addressing

This form of addressing is represented with a one byte instruction, implying an operation on the accumulator.

### Immediate Addressing

In immediate addressing, the operand is contained in the second byte of the instruction, with no further memory addressing required.

### Absolute Addressing

In absolute addressing, the second byte of the instruction specified the eight low order bits of the effective address while the third byte specifies the eight high order bits. Thus, the absolute addressing mode allows access to the entire 65K bytes of addressable memory.

### Zero Page Addressing

The zero page instructions allow for shorter code and execution times by only fetching the second byte of the instruction and assuming a zero high address byte. Careful use of the zero page can result in significant increase in code efficiency.

### Indexed Zero Page Addressing

(X, Y indexing). This form of addressing is used in conjunction with the index register and is referred to as "Zero Page, X" or "Zero Page, Y." The effective address is calculated by adding the second byte to the contents of the index register. Since this is a form of "Zero Page" addressing, the content of the second byte references a location in page zero. Additionally, due to the "Zero Page" addressing nature of this mode, no carry is added to the high order 8 bits of memory and crossing of page boundaries does not occur.

### Indexed Absolute Addressing

(X, Y indexing). This form of addressing is used in conjunction with X and Y index register and is referred to as "Absolute, X," and "Absolute, Y." The effective address is formed by adding the contents of X and Y to the address contained in the second and third bytes of the instruction. This mode allows the index register to contain the index or count value and the instruction to contain the base address. This type of indexing allows any location referencing and the index to modify multiple fields resulting in reduced coding and execution time.

### Implied Addressing

In the implied addressing mode, the address containing the operand is implicitly stated in the operation code of the instruction.

### Relative Addressing

Relative addressing is used only with branch instructions and establishes a destination for the conditional branch.

The second byte of the instruction becomes the operand which is an "Offset" added to the contents of the lower eight bits of the program counter when the counter is set at the next instruction. The range of the offset is -128 to +127 bytes from the next instruction.

### Indexed Indirect Addressing

In indexed indirect addressing (referred to as [Indirect, X]), the second byte of the instruction is added to the contents of the X index register, discarding the carry. The result of this addition points to a memory location on page zero whose contents is the low order eight bits of the effective address. The next memory location in page zero contains the high order eight bits of the effective address. Both memory locations specifying the high and low order bytes of the effective address must be in page zero.

### Indirect Indexed Addressing

In indirect indexed addressing (referred to as [Indirect, Y]), the second byte of the instruction points to a memory location in page zero. The contents of this memory location is added to the contents of the Y index register, the result being the low order eight bits of the effective address. The carry from this addition is added to the contents of the next page zero memory location, the result being the high order eight bits of the effective address.

### Absolute Indirect

The second byte of the instruction contains the low order eight bits of a memory location. The high order eight bits of that memory location is contained in the third byte of the instruction. The contents of the fully specified memory location is the low order byte of the effective address. The next memory location contains the high order byte of the effective address which is loaded into the sixteen bits of the program counter.

## INSTRUCTION SET—ALPHABETIC SEQUENCE

|     |                                            |     |                                              |
|-----|--------------------------------------------|-----|----------------------------------------------|
| ADC | Add Memory to Accumulator with Carry       | LDA | Load Accumulator with Memory                 |
| AND | "AND" Memory with Accumulator              | LDX | Load Index X with Memory                     |
| ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory                     |
| BCC | Branch on Carry Clear                      | LSR | Shift One Bit Right (Memory or Accumulator)  |
| BCS | Branch on Carry Set                        | NOP | No Operation                                 |
| BEQ | Branch on Result Zero                      | ORA | "OR" Memory with Accumulator                 |
| BIT | Test Bits in Memory with Accumulator       | PHA | Push Accumulator on Stack                    |
| BMI | Branch on Result Minus                     | PHP | Push Processor Status on Stack               |
| BNE | Branch on Result not Zero                  | PLA | Pull Accumulator from Stack                  |
| BPL | Branch on Result Plus                      | PLP | Pull Processor Status from Stack             |
| BRK | Force Break                                | ROL | Rotate One Bit Left (Memory or Accumulator)  |
| BVC | Branch on Overflow Clear                   | ROR | Rotate One Bit Right (Memory or Accumulator) |
| BVS | Branch on Overflow Set                     | RTI | Return from Interrupt                        |
| CLC | Clear Carry Flag                           | RTS | Return from Subroutine                       |
| CLD | Clear Decimal Mode                         | SBC | Subtract Memory from Accumulator with Borrow |
| CLI | Clear Interrupt Disable Bit                | SEC | Set Carry Flag                               |
| CLV | Clear Overflow Flag                        | SED | Set Decimal Mode                             |
| CMP | Compare Memory and Accumulator             | SEI | Set Interrupt Disable Status                 |
| CPX | Compare Memory and Index X                 | STA | Store Accumulator in Memory                  |
| CPY | Compare Memory and Index Y                 | STX | Store Index X in Memory                      |
| DEC | Decrement Memory by One                    | STY | Store Index Y in Memory                      |
| DEX | Decrement Index X by One                   | TAX | Transfer Accumulator to Index X              |
| DEY | Decrement Index Y by One                   | TAY | Transfer Accumulator to Index Y              |
| EOR | 'Exclusive-or' Memory with Accumulator     | TSX | Transfer Stack Pointer to Index X            |
| INC | Increment Memory by One                    | TXA | Transfer Index X to Accumulator              |
| INX | Increment Index X by One                   | TXS | Transfer Index X to Stack Register           |
| INY | Increment Index Y by One                   | TYA | Transfer Index Y to Accumulator              |
| JMP | Jump to New Location                       |     |                                              |
| JSR | Jump to New Location Saving Return Address |     |                                              |

## PROGRAMMING MODEL



## **INSTRUCTION SET – OP CODES, Execution Time, Memory Requirements**

Note: Commodore Semiconductor Group cannot assume liability for the use of inadequately CP Codes.

## 6509 MEMORY MAP



COMMODORE SEMICONDUCTOR GROUP reserves the right to make changes to any products herein to improve reliability, function or design. COMMODORE SEMICONDUCTOR GROUP does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others.