# 65816 **16 Bit Card**



# **AE APPLIED ENGINEERING**

## Special Applied Engineering (Beta )16 Bit Card Software Developer's Package

':

The version of the 16 Bit Card that is being sent to software developers is "only" capable of addressing up to 8 Meg of memory. The version that will be shipped to customers will be capable of addressing up to 16 Meg of memory, the full capability of the 65816 processor. This Beta version of the 16 Bit Card is provided with only one ribbon cable to connect it to a RamWorks II memory expansion card. Ordinarilly it would have another shorter ribbon cable to connect the 16 Bit Card (P2) to a 2 Meg. RamWorks memory expander piggy-back card. This "2 Meg." cable is not required when using the 512K version of the RamWorks memory expander piggy-back card.

## Applied Engineering Technical Support

Applied Engineering has a staff of technicians dedicated to answering specific questions about Applied Engineering products and software. If your question cannot be resolved by the technician, he will refer the question to the appropriate engineer. The technical support representatives are available Monday through Friday, between the hours of 9 AM to 5 PM (Central); The technical support telephone number is (214)241-6069. Please have as much information as possible available about your problem if you call.

## Soldered MMU chip on the //e main logic board

Important!: Some (very few) Apple //e's were manufactured with the MMU chip soldered in. If your //e does not have a socket for the MMU, the MMU will have to be desoldered and a socket installed. This is very tricky and should only done by a professional with the proper tools. Apple Computer, Inc has assured us that /Ie's are now assembled with socketed MMU chips.



# Installing the 16 Bit Card

- Turn the //e power switch to the OFF position, but leave the computer plugged in.
- Remove the //e top lid.
- Make sure the power-on indicator light inside the computer is OFF. (See Illustration 1.)





- If installed, remove the RamWorks II card from the //e auxiliary slot.
- Remove the 74LS273 chip from the RamWorks II socket marked "CPU." (Refer to Illustration 2.) Carefully set the RamWorks II aside and store the 74LS273 in a safe place.

## **Installation**



- Locate the CPU chip and the MMU chip on the /Ie main logic board. (Refer to Illustration 1.)
- Remove the MMU chip from the //e main logic board. Use a small flatblade screwdriver to gently lift alternate ends of the chip until it is free from its socket. Carefully set the MMU chip aside.
- Remove the CPU chip in the same manner. The //e's CPU chip is not required with the 16 Bit Card installed. Store it in a safe place.
- Verify that all pins on the 16 Bit Card CPU and MMU header connectors are straight. (Refer to Illustration 3.)





l.

- Plug one of the ribbon cable header connectors (both ends are the same) into the 16 Bit Card socket marked "P1" exactly as shown in Illustration 4.
- Invert the 16 Bit Card (solder side up; component side down) and position it above the CPU and MMU sockets on the //e main logic board. The red LED on the 16 Bit Card should be pointing toward the keyboard.

 $\mathbb{I}$  , I

• Using the viewport to align the header pins on the 16 Bit Card with the socket holes on the //e main logic board, install the 16 Bit Card into the CPU and MMU sockets. Press gently but firmly until the card is securely seated.

 $\frac{1}{2}$  :  $\frac{1}{2}$ 



• Position the keyboard end of the RamWorks II card near the installed 16 Bit Card. Install the free end of the 16 Bit Card ribbon cable to the Ram\Norks II socket marked "CPU." Verify that all header connector pins are fully seated in the socket and that the cable is installed as shown in Illustration 6.

"

## **Installation**



6

국

## Installation

For developers with the 2 Meg. RamWorks memory expansion piggy-back card, a special ribbon cable is required to connect the 16 Bit Card to the 2 Meg. expander card. This cable is available from Applied Engineering.

To install this cable you must first remove the PAL 16L8 chip from the 2 Meg. expander and install it on the 16 Bit Card. This chip is to be inserted in the socket NEXT to socket "P2." One end of the ribbon cable is then connected to socket "P2" with the cable trailing toward the keyboard when installed. The other end of this cable is to be connected to the empty 16L8 socket on the 2 Meg. expander. The cable should also trail toward the keyboard end of the card when installed.

## Illustration 7:

/



## **Operation and Architecture**

=

=

=

=

 $\equiv$ 

=

=

 $\overline{ }$ 

=

 $=$ 

 $\equiv$ 

 $=$ 

The 16 Bit Card will allow you to address up to 16 Meg linearly, using the 65816 processor's native mode of operation. In 65C02 emulation mode, the memory on the Ramworks II card will look and act exactly like the memory on a Ramworks II without the 16 Bit Card installed, with one exception: with the 16 Bit Card installed, hitting CONTROL-RESET will always put you back in BANK 0; on a Ramworks II without the 16 Bit Card, CONTROL-RESET has no effect on the bank register.

i

If you have a 1 Meg Ramworks II; you will get banks 00 thru OF, whether you are in 65C02 emulation mode or in the 65816 native mode. If you have a 1 Meg Ramworks II with a 1/2 Meg (512 K) piggy back, you will get banks 00-17, whether you are in 65C02 emulation mode or in 65815 native mode.

If you have worked with the Applied Engineering 2 Meg piggy back board before, you probably know of its unique memory mapping scheme. Banks are arranged in the order 00 through OF (on Ramworks II), then from 10-17,30-37,50-57,70-77 (on the 2 Meg piggy back). This is. done to maintain compatibility with other piggy back cards from Applied Engineering, and with the original Ramworks. In 65C02 emulation mode, the banks retain this partially non linear mapping; however, in 65816 native mode, the banks become linearized, from 00 thru 2F.

In an Apple lie equipped with a Ramworks II but not a 16 Bit Card, the memory on the Ramworks II is accessed as alternate banks of auxiliary memory. The 64K of memory on the Apple lie motherboard is accessed when the MMU's softswitches are set one way (MAIN memory) and the memory on the Ramworks II card is accessed when the MMU's softswitches are set the other way (AUXILIARY memory). One unique bank of 64K of memory is chosen from the available banks on the Ramworks II card by the BANK SELECT REGISTER, which is in the lie's memory map at location \$C073. Bank 0 on the Ramworks II card is where the video generator circuits in the Apple lie look for the 80 column video and Double High Resolution graphics information. No matter what 64K bank the BANK SELECT REGISTER is pointing to, all video access goes to bank o. ,(This feature is patented by Applied Engineering.)

All hardware locations, including the MMU's softswitches, are, located in the \$COOO to \$CFFF range of memory (hereafter referred to as \$CXXX), which is called the HARDWARE PAGE. With a Ramworks II installed, access to \$CXXX range of memory IN ANY BANK will' access the hardware page. In other words, the \$CXXX range of ANY BANK is mapped into the HARDWARE PAGE.

When the 16 Bit Card is installed and running in the 65C02 emulation mode, the softswitches still work exactly as they do without the 16 Bit Card. However, when the processor is in the 65816 native mode accesses to the hardware page can only be accomplished from 65816 BANK O. Any bank other than 65816 BANK 0 will not allow you to access the hardware page. If you are in a 65816 bank other than BANK 0, and you access the \$CXXX range, you will be accessing RAM MEMORY, NOT the hardware page. When you are in 65816 BANK 0, the Apple lie softswitches, which are in the hardware page, will allow you to flip back and forth between main memory or auxililary memory. If you are in a bank other than BANK 0, the softswitches will have no effect. That is, even if you go into 65816 BANK 0 and flip MMU softswitches so that you are looking at AUX memory, when you go into a 65816 bank other than BANK 0, the softswitches will have no effect. This is because there is no auxiliary memory associated with 65816 banks other than BANK O. In 65816 native mode, BANK 0 main memory is the 64K on the Apple lie motherboard, and BANK 0 auxiliary memory is the first 64K on the Ramworks card. This allows you to use the softswitches to flip between main memory and aux memory (as long as you are in BANK 0); this makes using the 80 column video and double high resolution graphics easier. If the 65816 is in a bank other than BANK 0, it will map into a corresponding bank on the Ramworks II or a piggy back card.

r

 $\lceil$ 

/ /

The softswitches that control access to the LANGUAGE CARD area of memory that overlays the motherboard ROM space can only be accessed from 65816 BANK O. Further, they only have an effect in 65816 BANK O. Because the 65816 looks for its interrupt vectors in BANK 0 at locations \$FFF4 through \$FFFF, you must use the language card RAM space to store these vectors.

One further note on using softswitches: The 65816 can have 8-bit wide registers or 16-bit wide registers. In the 65C02 emulation mode all registers (except the PC) are 8-bits wide, but in the native mode you can set the width of the X and Y registers with the X bit in the Processor Status Register (P). If X=0 the X and Y registers are 16-bits wide, and if X=1 then X and Y are 8-bits wide. The M bit in the P register controls the width of the Accumulator. If M=0 then the Accumulator is 16-bits wide, and if M=1 then the accumulator is 8-bits wide. You should only access the hardware page if  $M=1$  and  $X=1$ . This will prevent unwanted problems because of writes to two successive addresses.



**16 Bit Memory Maps** 

The following pages have been excerpted from the W65C816 Data Sheet and are reprinted with permission from Western Design Center, Inc.

## W65C816 Processor Programming Model



## **Status Register Coding**

 $-1$ 



Đ.

#### **Functional Description**

The W65C802 offers the design engineer the opportunity to utilize both existing software programs and hardware configurations, while also achieving the arbled advantages of increased register lengths and faster execution times. The W65C802's "ease of use" design and implementation features provide the designer with increased flexibility and reduced implementation costs. In the Emulation mode, the W65C802 not only offers software compatibility, but is also hardware (pin-to-pin) compatible with 6502 designs...plus it provides the advantages of 10-bit internal operation in 6502-compatible applications. The W65C802 is an excellent direct replacement microprocessor for 6502 designs.

ίü,

The W65C816 provides the design engineer with upward mobility and software compatibility in applications where a 16-bit system configuration is desired. The W65C816's 16-bit hardware configuration, coupled with current software allows a wide selection of system applications. In the Emulation mode, the W65C816 offers many advantages, including full software compatibility with 6502 coding. In addition, the W65C816's powerful instruction set and addressing modes make it an excellent choice for new 16-bit designs.

Internal organization of the W65C802 and W65C816 can be divided into two parts: 1) The Register Section, and 2) The Control Section. Instructions (or opcodes) obtained from program memory are executed by implementing a series of data transfers within the Register Section. Signals that cause data transfers to be executed are generated within the Control Section. Both the W65C802 and the W65C816 have a 16-bit internal architecture with an 8-bit external data bus.

#### **Instruction Register and Decode**

An opcode enters the processor on the Data Bus, and is latched into the Instruction Register during the instruction fetch cycle. This instruction is then decoded, along with timing and interrupt signals, to generate the various Instruction Register control signals.

#### **Timing Control Unit (TCU)**

The Timing Control Unit keeps track of each instruction cycle as it is executed. The TCU is set to zero each time an instruction fetch is executed, and is advanced at the beginning of each cycle for as many cycles as is required to complete the instruction. Each data transfer between registers depends upon decoding the contents of both the Instruction Register and the Timing Control Unit.

## Arithmetic and Logic Unit (ALU)

All arithmetic and logic operations take place within the 16-bit ALU. In addition to data operations, the ALU also calculates the effective address for relative and indexed addressing modes. The result of a data operation is stored in either memory or an internal register. Carry, Negative, Overflow and Zero flags may be updated following the ALU data operation.

### Internal Registers (Refer to Programming Model)

#### Accumulators (A, B, C)

The Accumulator is a general purpose register which stores one of the operands, or the result of most arithmetic and logical operations. In the Native mode (E=0), when the Accumulator Select Bit (M) equals zero, the Accumulator is established as 16 bits wide  $(A + B = C)$ . When the Accumulator Select Bit (M) equals one, the Accumulator is 8 bits wide (A). In this case, the upper 8 bits (B) may be used for temporary storage in conjunction with the Exchange Accumulator (XBA) instruction.

#### Data Bank Register (DBR)

During modes of operation, the 8-bit Data Bank Register holds the default bank address for memory transfers. The 24-bit address is composed of the 16-bit instruction effective address and the 8-bit Data Bank ad-

R,

dress. The register value is multiplexed with the data value and is present on the Data/Address lines during the first half of a data transfer memory cycle for the W65C816. The Data Bank Register is initialized to zero dur-Ing Reset

#### Direct (D)

The 16-bit Direct Register provides an address offset for all instructions using direct addressing. The effective bank zero address is formed by adding the 8-bit instruction operand address to the Direct Register. The Direct Register is initialized to zero during Reset.

#### Index (X and Y)

There are two Index Registers (X and Y) which may be used as general purpose registers or to provide an index value for calculation of the effective address. When executing an instruction with indexed addressing, the microprocessor fetches the opcode and the base address, and then modifies the address by adding the Index Register contents to the address prior to performing the desired operation. Pre-indexing or postindexing of indirect addresses may be selected. In the Native mode (E=0), both Index Registers are 16 bits wide (providing the Index Select Bit (X) equals zero). If the Index Select Bit (X) equals one, both registers will be 8 bits wide, and the high byte is forced to zero.

### Processor Status (P)

The 8-bit Processor Status Register contains status flags and mode select bits. The Carry (C), Negative (N), Overflow (V), and Zero (Z) status flags serve to report the status of most ALU operations. These status flags are tested by use of Conditional Branch instructions. The Decimal (D), IRQ Disable (I), Memory/Accumulator (M), and Index (X) bits are used as mode select flags. These flags are set by the program to change microprocessor operations.

The Emulation (E) select and the Break (B) flags are accessible only through the Processor Status Register. The Emulation mode select flag is selected by the Exchange Carry and Emulation Bits (XCE) instruction. Table 1, W65C802 and W65C816 Mode Comparison, illustrates the features of the Native (E=0) and Emulation (E=1) modes. The M and X flags are always equal to one in the Emulation mode. When an interrupt occurs during the Emulation mode, the Break flag is written to stack memory as bit 4 of the Processor Status Register.

## Program Bank Register (PBR)

The 8-bit Program Bank Register holds the bank address for all instruction fetches. The 24-bit address consists of the 16-bit instruction effective address and the 8-bit Program Bank address. The register value is multiplexed with the data value and presented on the Data/Address lines during the first half of a program memory read cycle. The Program Bank Register is initialized to zero during Reset. The PHK instruction pushes the PBR register onto the Stack.

#### Program Counter (PC)

The 16-bit Program Counter Register provides the addresses which are used to step the microprocessor through sequential program instructions. The register is incremented each time an instruction or operand is fetched from program memory.

#### **Stack Pointer (S)**

The Stack Pointer is a 16-bit register which is used to indicate the next available location in the stack memory area. It serves as the effective address in stack addressing modes as well as subroutine and interrupt processing. The Stack Pointer allows simple implementation of nested subroutines and multiple-level interrupts. During the Emulation mode, the Stack Pointer high-order byte (SH) is always equal to one. The bank address for all stack operations is Bank zero.





## **W65C816 Compatibility Issues**



Note 1. See Caveat section for additional information.

Y.

R

 $\sim$ 

~--------------------------------------------------------------------------------------------~~

#### W65C802 and W65C816

#### Microprocessor Addressing Modes

The W65C816 is capable of directly addressing 16 MBytes of memory. This address space has special significance within certain addressing modes, as fo'iows: i

#### Reset and Interrupt Vectors

The Reset and Interrupt vectors use the majority of the fixed addresses between 00FFE0 and 00FFFF.

#### Stack

- ---'"

The Stack may use memory from 000000 to OOFFFF. The effective address of Stack and Stack Relative addressing modes will always be within this range.

#### **Direct**

The Direct addressing modes are usually used to store memory registers and pointers. The effective address generated by Direct, Direct, X and Direct,Y addressing modes is always in Bank 0 (OOOOoo-OOFFFF).

#### Program Address Space

The Program Bank register is not affected by the Relative, Relative Long, Absolute, Absolute Indirect, and Absolute Indexed Indirect addressing modes or by incrementing the Program Counter from FFFF. The only instructions that affect the Program Bank register are: RTI, RTL, JML, JSL, and JMP Absolute Long. Program code may exceed 64K bytes although code segments may not span bank boundaries.

#### Data Address Space

The data address space is contiguous throughout the 16 MByte address space. Words, arrays, records, or any data structures may span 64 KByte bank boundaries with no compromise in code efficiency. The following addressing modes generate 24-bit effective addresses:

- Direct Indexed Indirect (d,x)
- Direct Indirect Indexed (d),y
- ,Direct Indirect (d)
- Direct Indirect Long [d]
- Direct Indirect Long Indexed [d).y
- Absolute a
- Absolute a,x
	- Absolute a,y
	- Absolute Long al
	- Absolute Long Indexed al,x
	- Stack Relative Indirect Indexed (d,s),y

The following addressing mode desc'iptions provide additional detail as to how effective addresses are calculated.

Twenty-four addressing modes are available for use with the W65C802 and W65C816 microprocessors. The "long" addressing modes may be used with the W65C802; however, the high byte of the address is not available to the hardware. Detailed descriptions of the 24 addressing modes are as follows:

#### 1. Immediate Addressing-#

The operand is the second byte (second and third bytes when in the IS-bit mode) of the instruction,

#### $2.$  Absolute-a

With Absolute addressing the second and third bytes of the instruction form the low-order 16 bits of the effective address. The Data Bank Register contains the high-order 8 bits of the operand address.



#### Address: DBR addrh addri

#### 3. Absolute Long-al

The second, third, and fourth byte of the instruction form the 24-bit effective address.



#### 4. Direct-d

The second byte of the instruction is added to the Direct Register (D) to form the effective address, An additional cycle is required

when the Direct Register is not page aligned (DL not equal 0). The Bank register is always 0.



#### 5. Accumulator-A

This form of addressing always uses a Single byte instruction. The operand is the Accumulator.

#### 6. Implied-i

Implied addressing uses a single byte instruction. The operand is implicitly defined by the instruction.

### 7. Direct Indirect Indexed--(d),y

This address mode is often referred to as Indirect,Y. The second byte of the instruction is added to the Direct Register (D). The IS-bit contents of this memory location is then combined with the Data Bank register to form a 24-bit base address. The Y Index Register is added to the base address to form the effective address.



#### 8. Direct Indirect Long Indexed-[d],y

With this addressing mode, the 24-bit base address is pointed to by the sum of the second byte of the instruction and the Direct Register. The effective address is this 24-bit base address plus the Y Index Register.



#### 9. Direct Indexed Indirect--(d,x)

This address mode is often referred to as Indlrect,X. The second byte of the instruction is added to the sum of the Direct Register and the X Index Register. The result points to the low-order 16 bits of the effective address. The Data Bank Register contains the highorder 8 bits of the effective address.



#### 10. Direct Indexed With X-d,x

The second byte of the instruction is added to the sum of the Direct Register and the X Index Register to form the 16-bit effective address. The operand is always in Bank 0.



#### 11. Direct Indexed With Y-d,y

The second byte of the instruction is added to the sum of the Direct Register and the Y Index Register to form the 16-bit effective address. The operand is always in Bank 0.



12. Absolute Indexed With X-a,x

The second and third bytes of the instruction are added to the X Index Register to form the low-order 16 bits of the effective address. The Data Bank Register contains the high-order 8 bits of the effective address.



## 13. Absolute Long Indexed With X-al,x

The second, third and fourth bytes of the instruction form a 24-bit base address. The effective address is the sum of this 24-bit address and the X Index Register.



#### 14. Absolute Indexed With Y-a,y

The second and third bytes of the instruction are added to the Y Index Register to form the low-order 16 bits of the effective address. The Data Bank Register contains the high-order 8 bits of the effective address.



## 15. Program Counter Relative-r

This address mode, referred to as Relative Addressing, is used only with the Branch instructions. If the condition being tested is met, the second byte of the instruction is added to the Program Counter, which has been updated to point to the opcode of the next instruction. The offset is a signed 8-bit quantity in the range from -128 to 127. The Program Bank Register is not affected.

### 16. Program Counter Relative Long-ri

This address mode, referred to as Relative Long Addressing, is used This autress model, reterned to as meanwealing instruction (BRL) and the<br>Push Effective Relative instruction (PER). The second and third<br>bytes of the instruction are added to the Program Counter, which<br>has been updated to the branch instruction, the Program Counter is loaded with the<br>result. With the Push Effective Relative instruction, the result is stored on the stack. The offset is a signed 16-bit quantity in the range from -32768 to 32767. The Program Bank Register is not affected.

#### 17. Absolute Indirect-(a)

The second and third bytes of the instruction form an address to a pointer in Bank 0. The Program Counter is loaded with the first and<br>second bytes at this pointer. With the Jump Long (JML) instruction,<br>the Program Bank Register is loaded with the third byte of the pointer.



with JML:

New PC = (indirect address)

New PBR = (indirect address +2)

#### 18. Direct Indirect-(d)

The second byte of the instruction is added to the Direct Register to form a pointer to the low-order 16 bits of the effective address. The Data Bank Register contains the high-order 8 bits of the effective address.



19. Direct Indirect Long-[d]

The second byte of the instruction is added to the Direct Register to form a pointer to the 24-bit effective address.



#### 20. Absolute Indexed Indirect- $(a,x)$

The second and third bytes of the instruction' are added to the X Index Registerto form a 16-bit pointer in Bank O. The contents of this pointer are loaded in the Program Counter. the Program Bank Register is not changed.



#### 21. Stack-s

-

-

-

-

Stack addressing refers to all instructions that push or pull data from the stack, such as Push, Pull, Jump to Subroutine, Return from Subroutine, Interrupts, and Return from Interrupt. The bank ad-dress is always O. Interrupt Vectors are always fetched from Bank O.

#### 22. Stack Relative-d,s

The low-order 16 bits of the effective address is 'formed from the sum of the second byte of the instruction and the Stack Pointer. The high-order 8 bits of the effective address is always zero. The relative offset is an unsigned a-bit quantity in the range of 0 to 255.



## 23. Stack Relative Indirect Indexed—(d,s),y

The second byte of the instruction is added to the Stack Pointer to form a pointer to the low-order 16-bit base address in Bank 0. The Data Bank Register contains the high-order 8 bits of the base address. The effective address is the sum of the 24-bit base address and the Y Index Register.



#### 24. Block Source Bank, Destination Bank-xyc

This addressing mode is used by the Block Move instructions. The second byte of the instruction contains the high-order 8 bits of the<br>destination address. The Y index Register contains the low-order 16<br>bits of the destination address. The third byte of the instruction<br>contains the high-Register contains the low-order 16 bits of the source address. The C Accumulator contains one less than the number of bytes to move. The second byte of the block move instructions is also loaded into<br>the Data Bank Register.



Increment (MVN) or decrement (MVP) X and Y. Decrement C (if greater than zero), then  $PC+3 \rightarrow PC$ .

" "

"

## **W65C802 and W65C816 Instruction Set-Alphabetical Sequence**



PER Push Effective Program Counter Relative Address on Stack

For **alternate** mnemonics. **see Table 7.** 

PHA PHB PHD **PHK** PHP; PHXI PHY<sub>1</sub> PLA PLB PLD PLP PLX PLY REP **ROL** ROR RTI **RTL** RTS SBC SEC SED : SEI<sup>T</sup> **STA** STP **STX STY** STZ TAX TAY **TCD** TCS **TDC** TR9 TSB TSC TSX TXA TXS TXY TYA TYX WAI WDM XBA Push Accumulator on Stack Push Data Bank Register on Stack Push Direct Register on Stack Push Program Bank Register on Stack Push Processor Status on Stack Push Index X on Stack Push Index Y on Stack Pull Accumulator from Stack Pull Data Bank Register from Stack Pull Direct Register from Stack Pull Processor Status from Stack Pull Index X from Stack Pull Index Y form Stack Reset Status Bits Rotate One Bit Left (Memory or Accumulator) Rotate One Bil Right (Memory or Accumulator) Return from Interrupt Return from Subroutine Long Return from Subroutine Subtract Memory from Accumulator with Borrow Set Carry Flag Set Decimal Mode Set Interrupt Disable Status Set Processor Status Bite Store Accumulator in Memory Stop the Clock Store Index X in Memory Store Index Y in Memory Store Zero in Memory Transfer Accumulator to Index X Transfer Accumulator to Index Y Transfer C Accumulator to Direct Register Transfer C Accumulator to Stack Pointer Register Transfer Direct Register to C Accumulator Test and Reset Bit Test and Set Bit Transfer Stack Pointer Register to C A'ccumulator Transfer Stack Pointer Register to Index X Transfer Index X to Accumulator Transfer Index X to Stack Pointer Register Transfer Index X to Index Y Transfer Index Y to Accumulator Transfer Index Y to Index X Wait for Interrupt Reserved for Future Use Exchange B and A Accumulator

- 
- **XCE** Exchange Carry and Emulation Bits

### **Vector Locations**



The VP output is low during the two cycles used for vector location access. When an interrupt is executed,  $D = 0$  and  $I = 1$  in Status Register P.

**Opcode Matrix** 

| M<br>s<br>D             |                                       |                                  |                             |                             |                                    |                                           |                                    | LSD                            |                                    |                                                        |                                               |                                                    |                                    |                                    |                           |                     | M<br>S<br>D    |
|-------------------------|---------------------------------------|----------------------------------|-----------------------------|-----------------------------|------------------------------------|-------------------------------------------|------------------------------------|--------------------------------|------------------------------------|--------------------------------------------------------|-----------------------------------------------|----------------------------------------------------|------------------------------------|------------------------------------|---------------------------|---------------------|----------------|
|                         | $\Omega$                              | 1                                | $\overline{2}$              | 3                           | 4                                  | 5                                         | 6                                  | 7                              | 8                                  | $\bullet$                                              | A                                             | в                                                  | c                                  | D                                  | Ε                         | F                   |                |
| $\Omega$                | <b>BRK s</b><br>28                    | ORA (d.x)<br>2 <sub>6</sub>      | COP <sub>s</sub><br>$2 * 8$ | ORA d,s<br>$2 * 4$          | TSB <sub>d</sub><br>$2^{\bullet}5$ | ORA d<br>2 <sub>3</sub>                   | ASL <sub>d</sub><br>2 <sub>5</sub> | ORA [d]<br>$2*6$               | PHP <sub>s</sub><br>1 <sub>3</sub> | ORA <sup>#</sup><br>$2^{2}$                            | ASL A PHD s<br>$\overline{c}$<br>$\mathbf{1}$ | $1^*4$                                             | TSB a<br>$3^{\bullet}6$            | ORA a<br>3 <sub>4</sub>            | ASL <sub>a</sub><br>36    | ORA al<br>$4 * 5$   | $\Omega$       |
| 1                       | BPL r<br>2 <sub>2</sub>               | ORA (d), y<br>2 <sub>5</sub>     | ORA (d)<br>$2^{\bullet}5$   | ORA (d,s),y<br>$2 * 7$      | TRB d<br>$2^{\bullet}5$            | ORA d.x<br>.214                           | ASL d.x<br>2 <sub>6</sub>          | ORA [d],y<br>$2 \times 6$      | CLC i<br>1 <sub>2</sub>            | ORA a.vl<br>$\mathbf{3}$<br>4 <sub>i</sub>             | INC A<br>٠<br>$\overline{2}$                  | TCS <sub>i</sub><br>$1*2$                          | TRB a<br>$3^{\circ}6$              | ORA a,x<br>3 <sub>4</sub>          | ASL a,x<br>3 <sub>7</sub> | ORA al.x<br>$4 * 5$ | 1              |
| $\overline{\mathbf{c}}$ | JSR a<br>3 <sub>6</sub>               | $AND$ $(d, x)$<br>2 <sub>6</sub> | JSL al<br>$4 * R$           | AND d.s<br>$2 * 4$          | BIT d<br>2 <sub>3</sub>            | AND d<br>2 <sup>3</sup>                   | ROL d<br>2 <sub>5</sub>            | AND [d]<br>$2 \times 6$        | PLP <sub>s</sub><br>$1 \quad 4$    | AND #<br>2 <sub>2</sub>                                | ROL A PLD s<br>$\overline{2}$<br>$\mathbf{1}$ | $1 \times 5$                                       | BIT a<br>3 <sub>4</sub>            | AND <sub>a</sub><br>$3\quad 4$     | ROL a<br>36               | AND al<br>$4 * 5$   | $\overline{2}$ |
| 3                       | BMI r<br>2 <sub>2</sub>               | AND (d), y<br>25                 | AND (d)<br>2 <sup>o</sup> 5 | AND (d,s),y<br>$2 \times 7$ | BIT d.x<br>$2^{\bullet}4$          | AND d.x<br>$\mathbf{2}$<br>4              | <b>IROL d.x</b><br>2 <sub>6</sub>  | AND [d],y<br>$2 \times 6$      | SEC <sub>i</sub><br>1 <sub>2</sub> | AND a.y<br>3 <sub>4</sub>                              | DEC A TSC i<br>$1^{\bullet}2$                 | $1*2$                                              | BIT a.x<br>$3^{\bullet}4$          | AND a.x<br>3 <sub>4</sub>          | ROL a.x<br>3 <sub>7</sub> | AND al,x<br>$4 * 5$ | 3              |
| 4                       | RTI <sub>s</sub><br>1 <sub>7</sub>    | EOR(d,x)<br>2 <sub>6</sub>       | <b>WDM</b><br>$2 * 2$       | EOR d.s<br>$2 * 4$          | MVP xyc<br>$3 \times 7$            | EOR d<br>$\overline{2}$<br>3              | LSR d<br>2 <sub>5</sub>            | EOR <sub>[d]</sub><br>$2 * 6$  | PHA <sub>s</sub><br>$1 \quad 3$    | EOR #<br>2 <sub>2</sub>                                | LSR A PHK s<br>$\overline{2}$<br>$\mathbf{1}$ | $1 * 3$                                            | JMP <sub>a</sub><br>3 <sub>3</sub> | EOR a<br>3 <sub>4</sub>            | LSR a<br>36               | EOR al<br>$4 * 5$   | 4              |
| 5                       | BVC r<br>2 <sub>2</sub>               | $EOR$ (d), $y$<br>25             | EOR (d)<br>2 <sup>0</sup> 5 | EOR(d,s),y<br>$2 \times 7$  | MVN xyclEOR d.x<br>$3 \star 7$     | $\mathbf{2}$<br>4                         | lLSR d.x<br>2 <sub>6</sub>         | EOR [d],y<br>$2 \times 6$      | CLI i<br>1 <sub>2</sub>            | EOR a.y<br>$\mathbf{3}$<br>$\overline{\mathbf{4}}$     | PHY s TCD i<br>$1^{\bullet}3$                 | $*_{2}$<br>$\mathbf{1}$                            | JMP al<br>$4 - 4$                  | EOR a.x<br>3 <sub>4</sub>          | LSR a,x<br>3 <sub>7</sub> | EOR al,x<br>$4*5$   | 5              |
| 6                       | RTS <sub>s</sub><br>6<br>$\mathbf{1}$ | ADC (d.x)<br>26                  | PER <sub>s</sub><br>$3 * 6$ | ADC d.s.<br>$2 * 4$         | STZ <sub>d</sub><br>$2^{\bullet}3$ | ADC d<br>2 <sub>3</sub>                   | ROR <sub>d</sub><br>2 <sub>5</sub> | ADC [d]<br>$2 * 6$             | PLA <sub>s</sub><br>14             | ADC#<br>2 <sub>2</sub>                                 | <b>ROR AIRTLS</b><br>$\overline{2}$<br>1      | $*_{6}$<br>$\mathbf{1}$                            | JMP(a)<br>3 <sub>5</sub>           | ADC a<br>3.4                       | ROR a<br>36               | ADC al<br>$4 * 5$   | 6              |
| $\overline{7}$          | BVS r<br>2 <sub>2</sub>               | ADC (d),y<br>25                  | ADC (d)<br>$2^{\bullet}5$   | ADC (d,s),y<br>$2 * 7$      | STZ d.x<br>$2^{\bullet}4$          | ADC d.x<br>$2 \quad 4$                    | ROR d.x<br>2 <sub>6</sub>          | ADC [d],y<br>$2 \times 6$      | SEI i<br>1 <sup>2</sup>            | ADC a <sub>'</sub> y<br>3 <sup>1</sup><br>$\mathbf{A}$ | PLY s ITDC i<br>$1^{\bullet}4$                | $*_{2}$<br>$\mathbf{1}$                            | JMP( a, x)<br>$3 \bullet 6$        | ADC a.x<br>3 <sub>4</sub>          | ROR a.x<br>3 <sub>7</sub> | ADC al.x<br>$4 * 5$ | $\overline{7}$ |
| 8                       | <b>BRAr</b><br>$2^{\bullet}2$         | STA (d.x)<br>2 <sub>6</sub>      | <b>BRL</b> rl<br>$3 * 3$    | STA d,s<br>$2 * 4$          | STY d<br>2 <sub>3</sub>            | STA <sub>d</sub><br>2 <sub>3</sub>        | STX d<br>2 <sub>3</sub>            | STA <sub>[d]</sub><br>$2*6$    | DEY i<br>1 <sub>2</sub>            | BIT #<br>$2^{\bullet}2$                                | TXA i<br>1 <sub>2</sub>                       | <b>PHB</b> s<br>$1 \times 3$                       | STY <sub>a</sub><br>$3\quad 4$     | STA a<br>3 <sub>4</sub>            | STX a<br>3 <sub>4</sub>   | STA al<br>$4 * 5$   | 8              |
| 9                       | BCC <sub>r</sub><br>2 <sub>2</sub>    | STA (d) v<br>2 <sub>6</sub>      | STA (d)<br>$2^{\bullet}5$   | STA(d,s),y<br>$2 \times 7$  | STY d.x<br>$2 \quad 4$             | STA d.x<br>$2 \quad 4$                    | lSTX d.y<br>24                     | STA [d],y<br>$2*6$             | TYA i<br>1 <sub>2</sub>            | STA a.v<br>3 <sub>5</sub>                              | TXS i<br>1 <sub>2</sub>                       | TXY i<br>$*_{2}$<br>1                              | STZ <sub>a</sub><br>$3^{\circ}4$   | STA a.x<br>3 <sub>5</sub>          | STZ a.x<br>$3^{\circ}5$   | STA al,x<br>$4 * 5$ | 9              |
| А                       | LDY #<br>2 <sub>2</sub>               | $LDA$ $(d, x)$<br>2 6            | LDX #<br>2 <sub>2</sub>     | LDA d,s<br>$2 * 4$          | LDY d<br>2 <sub>3</sub>            | LDA d<br>2 <sub>3</sub>                   | LDX d<br>2 <sub>3</sub>            | LDA (d)<br>$2*6$               | TAY i<br>1 <sub>2</sub>            | LDA #<br>2 <sub>2</sub>                                | <b>TAX1</b><br>$1 \quad 2$                    | PLB <sub>s</sub><br>$*_{4}$<br>$\mathbf{1}$        | LDY a<br>3 <sub>4</sub>            | LDA a<br>3 <sub>4</sub>            | LDX a<br>3 <sub>4</sub>   | LDA al<br>$4 * 5$   | А              |
| B                       | BCS r<br>2 <sub>2</sub>               | $LDA$ (d), $y$<br>2 <sub>5</sub> | LDA (d)<br>$2^{\bullet}5$   | LDA (d.s).y<br>$2 \times 7$ | LDY d,x<br>$2 \quad 4$             | LDA d.x<br>$2 \quad 4$                    | DX d.y<br>$2 \quad 4$              | $LDA$ $[d], y$<br>$2 \times 6$ | CLV <sub>i</sub><br>1 <sub>2</sub> | LDA a,y<br>$3 - 4$                                     | TSX i<br>$\overline{2}$<br>$\mathbf{1}$       | <b>TYX1</b><br>$1 * 2$                             | LDY a.x<br>3 <sub>4</sub>          | LDA a.x<br>3 <sub>4</sub>          | LDX a,y<br>34             | LDA al.x<br>$4 * 5$ | в              |
| C                       | CPY#<br>2 2                           | CMP(d, x)<br>2 <sub>6</sub>      | REP #<br>$2 * 3$            | CMP d.s<br>$2 \times 4$     | CPY d<br>2 <sub>3</sub>            | CMP <sub>d</sub><br>$\overline{a}$<br>3   | DEC d<br>2 <sub>5</sub>            | CMP [d]<br>$2*6$               | INY i<br>1 <sub>2</sub>            | CMP <sup>#</sup><br>$\overline{2}$<br>2 <sup>1</sup>   | DEX i<br>$\overline{2}$<br>1.                 | WAI i<br>$1^{\bullet}3$                            | CPY a<br>3 <sub>4</sub>            | CMP <sub>a</sub><br>3 <sub>4</sub> | DEC a<br>3<br>6           | CMP al<br>$4 * 5$   | C              |
| D                       | BNE <sub>r</sub><br>2 <sub>2</sub>    | CMP (d).y<br>2 <sub>5</sub>      | CMP (d)<br>$2o$ 5           | CMP (d,s),y<br>$2 * 7$      | PEI s<br>$2*6$                     | CMP d.x<br>$2^{4}$                        | IDEC d.x<br>2 <sub>6</sub>         | CMP [d],y<br>$2 \times 6$      | CLD i<br>1 <sub>2</sub>            | CMP a.y<br>3<br>4                                      | PHX <sub>s</sub><br>$1^{\bullet}3$            | STP <sub>i</sub><br>$^{\bullet}$ 3<br>$\mathbf{1}$ | JML (a)<br>$3 \times 6$            | CMP a.x<br>3 <sub>4</sub>          | DEC a,x<br>3 <sub>7</sub> | CMP al,x<br>$4 * 5$ | D              |
| E                       | CPX#<br>2 <sub>2</sub>                | SBC (d,x)<br>2 <sub>6</sub>      | SEP #<br>$2*3$              | SBC d.s<br>$2 * 4$          | CPX d<br>2 <sub>3</sub>            | SBC <sub>d</sub><br>2 <sub>3</sub>        | INC <sub>d</sub><br>2 <sub>5</sub> | SBC [d]<br>$2 * 6$             | INX i<br>$1 \quad 2$               | SBC#<br>2 <sub>2</sub>                                 | NOP i XBA i<br>$\overline{c}$<br>$\mathbf{1}$ | $*_{3}$<br>1                                       | CPX a<br>$3\quad 4$                | SBC a<br>34                        | INC a<br>36               | SBC al<br>$4 * 5$   | Ε              |
| F                       | BEQ r<br>2 <sub>2</sub>               | SBC (d), y<br>2 <sub>5</sub>     | SBC (d)<br>$2 \cdot 5$      | SBC (d,s) v<br>$2 * 7$      | PEA <sub>s</sub><br>$3 \times 5$   | SBC d.x<br>$\mathbf{2}$<br>$\overline{4}$ | INC d.x<br>2 <sub>6</sub>          | SBC [d],y<br>$2 \times 6$      | SED i<br>1 <sub>2</sub>            | SBC a.v<br>3 <sub>4</sub>                              | PLX <sub>s</sub><br>$1^{\bullet}4$            | IXCE i<br>$*_{2}$<br>$\blacksquare$                | JSR( a, x)<br>$3 \times 6$         | SBC a.x<br>3 <sub>4</sub>          | INC a,x<br>3 <sub>7</sub> | SBC al,x<br>$4 * 5$ | F              |
|                         | $\mathbf{0}$                          | 1                                | $\overline{2}$              | з                           | 4                                  | 5                                         | 6                                  | $\overline{ }$                 | 8                                  | 9                                                      | A                                             | в                                                  | c                                  | D                                  | Ε                         | F                   |                |



## Op Code Matrix Legend

 $\bar{1}$ 

÷,



## 65C816 Data Sheet  $\mathcal{A}$

 $\frac{1}{2}$  .  $\bar{\bar{z}}$ 





voies:<br>\_1.\_Bit immediate N and V flags not affected. When M = 0, M<sub>15</sub> — N and M<sub>14</sub> —V.<br>\_2.\_Break Bit (B) in Status register indicates hardware or software break.

■ = New W65C616/602 Instructions<br>■ = New W65C02 Instructions<br>Blank = NMOS 6502

- Subtract<br>A AND

n

## $65C816$  Data Sheet $\parallel$

## Detailed Instruction Operation

!



## **Detailed Instruction Operation (continued)**





### Recommended W65C816 and W65C802 Assembler Syntax Standards

#### **Directives**

Assembler directives are those parts of the assembly language source program which give directions to the assembler; this includes the definition of data area and constants within a program. This standard excludes any definitions of assembler directives.

Comments<br>An assembler should provide a way to use any line of the source program as a comment. The recommended way of doing this Is tp treat any blank ine, or any line that starts with a semi-colon or an asterisk as a comment.<br>Other special characters may be used as well.

#### The Source Line

Any line which causes the generation' of a single W65C816 or W65C802 machine language instruction should be divided into four fields: a label field, the operation code, the operand, and the comment field.

The Label Field-The label field begins in column one of the line. A label must start with an alphabetic character, and may be followed by zero or more alphanumeric characters. An assembler may define an upper limit on the number of characters that can be in a label, so long as that upper limit is greater than or equal to six characters. An assembler may limit the alphabetic characters to upper-case characters if desired. If lowercase characters are allowed, they should be treated as identical to their upper-case equivalents. Other characters may be allowed in the label, so long as their use does not conflict with the coding of operand fields.

The Operation Code Field-The operation code shall consist of a three character sequence (mnemonic) from Table 3. It shall start no sooner than column 2 of the line, or one space after the label if a label is coded.

Many of the operation codes in Table3 have duplicate mnemonics; when two or more machine language instructions have the same mnemonic, the assembler resolves the difference based on the operand.

If an assembler allows lower-case letters in labels, it must also allow lower-case letters in the mnemonic. When lower-case letters are used in the mnemonic, they shall be treated as equivalent to the upper-case counterpart. Thus, the mnemonics LOA, Ida, and LdA must all be recognized, and are equivalent,

In addition to the mnemonics shown in Table 3, an assembler may provide the alternate mnemonics shown in Table 6.

#### Alternate Mnemonics



JSL should be recognized as equivalent to JSR wher it is specified with a long absolute address. JML is equivalent to JMP with long addressing forced.

The Operand Field-The operand field may start no sooner than one space atter the operation code field. The assembler must be capable of at least twenty-four bit address calculations. The assembler should be capable of specifying addresses as labels, integer constants, and hexadecimal constants. The assembler must allow addition and subtraction in the operand field. Labels shall be recognized by the fact that they start alphabetic characters. Decimal numbers shall be recognized as containing only the decimal digits 0... 9. Hexadecimal constants shall be recognized by prefixing the constant with a "\$" character, followed by zero or more of either the decimal digits or the hexadecimal digits "A" .. . "F". If lower-case letters are allowed in the label field, then they shall also be allowed as hexadecimal digits.

All constants, no matter what their format, shall provide at least enough precision to specify all values that can be represented by a twenty-four bit signed or uns'igned integer represented in two's complement notation.

, xxrs" ex- Gallery ex- Gallery and Construction and

I I I

Table 8 shows the operand formats which shall be recognized by the assembler. The symbol d is a label or value which the assembler can recognize as being less than \$100. The symbol a is a label or value which the assembler can recognize as greater the \$FF but less than \$10000; the symbol al is a label or value that the assembler can recognize as being greater than \$FfFF. The symbol EXT is a label which cannot be located by the assembler at the time the instruction is assembled. Unless instructed otherwise: an assembler shall assume that EXT labels are two bytes long. The symbols rand rI are 8 and 16 bit signed displacements calculated by the assembler.

Note that the operand does not determine whether or not immediate addressing loads one or two bytes; this is determined by the setting of the status register. This forces the requirement for a directive or directives that tell the assembler to generate one or two bytes of space for immediate loads. The. directives provided shall allow separate settings for the accumulator and index registers.

The assembler shall use the  $\lt$ ,  $>$ , and  $\land$  characters after the # character in immediate address to specify which byte or bytes will be selected from the value of the operand. Any calculations in the operand must be performed before the byte selection takes place. Table 7 defines the action taken by each operand by showing the effect of the operator on an address. The column that shows a two byte immediate value show the bytes in the order in which they appear in memory. The coding of the operand is for an assembler which uses 32 bit address calculations, showing the way that the address should be reduced to a 24 bit value.

#### Byte Selection Operator



In any location in an operand where an address, or expression resulting in an address, can be coded, the assembler shall recognize the prefix char $acts < |$ , and  $>$ , which force one byte (direct page), two byte (absolute) or three byte (long absolute) addressing. In cases where the addressing mode is not forced, the assembler shall assume that the address is two bytes unless the assembler is able to determine the type of addressing required by context, in which case that addressing mode will be used. Addresses shall be truncated without error if an addressing mode is forced which does not require the entire value of the address. For example,

#### LOA \$0203 LOA 1\$010203

are completely equivalent. If the addressing mode is not forced, and the type of addressing cannot be determined from context, the assembler shall assume that a two byte address is to be used. If an instruction does not have a short addressing mode (as in LDA, which has no direct page indexed by V) and a short address is used in the operand, the assembler shall automatically extend the address by padding the most significant bytes with zeroes in order to extend the address to the length needed. As with immediate addressing, any expression evaluation shall take place before the address is selected; thus, the address selection character is only used once, before the address of expression.

The! (exclamation point) character should be supported as an alternative to the | (vertical bar).

A long indirect,address is indicated in the operand field of an instruction by surrounding the direct page address where the indirect address is found by square brackets; direct page addresses which contain sixteenbit addresses are indicated by being surrounded by parentheses.

The operands of a block move instruction are specified as source bank, destination bank-the opposite order of the object bytes generated.

Comment Fleld-The comment field may start no sooner than one space after the operation code field or operand field depending on instruction type.

## **Address Mode Formats**

 $\frac{1}{4}$ 

r



## **Addressing Mode Summary**



NOTES:

à.

VOTES:<br>1. Page boundary, add 1 cycle if page boundary is crossed when forming address.<br>2. Branch taken, add 1 cycle if branch is taken.<br>3. M = 0 or X = 0, 16 bit operation, add 1 cycle, add 1 byte for immediate.<br>4. Direct

24

Y.

÷

#### Caveats and Application Information

#### Stack Addressing

When in the Native mode, the Stack may use memory locations 000000 to OOFFFFF. The effective address of Stack, Stack Relative, and Stack Relative Indirect Indexed addressing modes will always be within this range. In the Emulation mode, the Stack address, range is 000100 to 0001 FF. The following opcodes and addressing modes will increment or decrement beyond this range when accessing 1wo or three bytes:

JSL; JSR(a,x); PEA; PEI; PER; PHD; PLD; RTL; d,s; (d,s),y

#### Direct Addressing

The Direct Addressing modes are often used to access memory registers and pointers. The effective address generated by Direct; Direct,X and Direct,Y addressing modes will always be in 'the Native mode range 000000 to OOFFFF. When in the Emulation mode', the direct addressing range is 000000 to OOOOFF, except for [Direct] and [Direct],Y addressing modes and the PEl instruction which will increment from OOOOFE or OOOOFF into the Stack area.

When in the Emulation mode and DH is not equal to zero, the direct addressing range is OODHOO to OODHFF, except for [Direct] and [Direct],Y addressing modes and the PEl instruction which will increment from ' OODHFE or OODHFF into the next higher page.

When in the Emulation mode and DL in not equal to zero, the direct addressing range is 000000 to OOFFFF.

#### Absolute Indexed Addressing (W65CB16 Only)

The Absolute Indexed addressing modes are used to address data outside the direct addressing range. The W65C02 and W65C802 addressing range is 0000 to FFFF. Indexing from page FFXX may result in a OOYY data fetch when using the W65C02 or W65C802. In contrast, indexing from page ZZFFXX may result in ZZ+1 ,OOYY when using the W65C816.

#### Future Microprocessors (i.e., W65CB32)

Future WDC microprocessors will support all current W65C816 operating modes for both index and offset address generation.

#### ABORT Input (W65CB16 Only)

ABORT should be held low for a period not to exceed one cycle. Also, if ABORT is held low during the Abort Interrupt sequence, the Abort Interrupt will be aborted. It is not recommended to abort the Abort Interrupt. The ABORT internal latch is cleared during the second cycle of the Abort Interrupt. Asserting the ABORT input after the following instruction 'cycles will cause registers to be modified:

- Read-Modify-Write: Processor status modified if  $\overline{ABORT}$  is asserted after a modify cycle.
- RTI: Processor status will be modified if ABORT is asserted after after a modify cycle.<br>● RTI: Processor status will be modified if ABORT is asserted after<br>cycle 3.<br>● IRQ, NMI, ABORT BRK, COP: When ABORT is asserted after cycle 2,
- PBR and DBR will become 00 (Emulation mode) or PBR will become 00 (Native mode).

The Abort Interrupt has been designed for virtual memory systems. For this reason, asynchronous ABORT's may cause undesirable results due to the above conditions.

#### VDA and VPA Valid Memory Address Output Signals (W65CB16 Only)

When VDA or VPA are high and during all write cycles, the Address Bus is always valid . VDA and VPA should be used to qualify all memory cycles. Note that when VDA and VPA are both low, invalid addresses may be generated. The Page and Bank addresses could also be invalid. This will be due to low byte addition only. The cycle when only low byte addition occurs is an optional cycle for instructions which,read memory when the Index Register consists of 8 bits. This optional cycle becomes a standard cycle for the Store instruction, all instructions using the 16-bit Index Register mode, and the Read-Modify-Write instruction when using 8- or 16-bit Index Register modes.

#### Apple II, lie, IIc and 11+ Disk Systems (W65CB16 Orily)

VDA and VPA should not be used to qualify addresses during disk operation on Apple systems. Consult your Apple representative for hardware/ software configurations.

#### DBIBA Operation when ROY is Pulled Low (W65CB16 Only)

When RDY is low, the Data Bus is held in the data transfer state (i.e.,  $\phi$ 2 high). The Bank address external transparent latch should be latched when the  $\phi$ 2 clock or RDY is low.

 $\cdot$  f I

.,

 $\frac{1}{2}$ 

#### MIX Output (W65CB16 Only)

The *MIX* output reflects the value of the M and X bits of the processor Status Register. The REP, SEP and PLP instructions may change the state of the M and X bits. Note that the *MIX* output is invalid during the instruction cycle following REP, SEP and PLP instruction execution. This cycle is used as the opcode fetch cycle of the next instruction.

#### All Opcodes Function in All Modes of Operation

It should be noted that all opcodes function in all modes of operation. However, some instructions and addressing modes are intended for W65C816 24-bit addressing and are therefore less useful forthe W65C802. The fOllowing is a list of instructions and addressing modes which are primarily intended for W65C816 use:

#### JSL; RTL; [d]; [d],y; JMP al; JML; al; al,x

The following Instructions may be used with the W65C802 even though a Bank Address is not multiplexed on the Data Bus:

#### PHK: PHB; PLB

The following instructions have "limited" use in the Emulation mode:

- The REP and SEP instructions cannot modify the M and X bits when in the Emulation mode. In this mode the M and X bits will always be high (logic 1).
- When in the Emulation mode, the MVP and MVN instructions use the X and Y Index Registers for the memory address. Also, the MVP and MVN instructions can only move data within the memory range 0000 (Source Bank) to DOFF (Destination Bank) for the W65C816, and 0000 to OOFF for the W65C802.

#### Indirect Jumps

The JMP (a) and JML (a) instructions use the direct Bank for indirect addressing, while JMP (a,x) and JSR (a,x) use the Program Bank for indirect address tables.

#### Switching Modes

When switching from the Native mode to the Emulation mode, the X and M bits of the Status Register are set high (logic 1). the high byte of the Stack is set to 01, and the high bytes of the X and Y Index Registers are set to 00. To save previous values, these bytes must always be stored before changing modes. Note that the low byte of the S, X and Y Registers and the low and high byte of the Accumulator (A and B) are not affected by a mode change.

#### How Hardware Interrupts, BRK, and COP Instructions Affect the Program Bank and the Data Bank Registers

When in the Native mode, the Program Bank register (PBR) is cleared to 00 when a hardware interrupt, BRK or COP is executed. In the Native mode, previous PBR contents is automatically saved on Stack.

In the Emulation mode, the PBR and DBR registers are cleared to 00 when a hardware interrupt, BRK or COP is executed. In this case, previous contents of the PBR are not automatically saved.

Npte that a Return from Interrupt (RTI) should always be executed from the same "mode" which originally generated the interrupt.

#### Binary Mode

The Binary ,mode is set whenever a hardware or software interrupt is executed. The D flag within the Status Register is cleared to zero.

#### **WAI Instruction**

The WAI instruction pulls RDY low and places the processor in the WAI "low power" mode. NMI, IRQ or RESET will terminate the WAI condition and transfer control to the interrupt handler routine. Note that an ABORT input will abort the WAI instruction, but will not restart the processor. When the Status Register I flag is set ( $\overline{\text{IRQ}}$  disabled), the  $\overline{\text{IRQ}}$  interrupt will cause the next instruction (following the WAI instruction) to be executed without going to the IRQ interrupt handler. This method results in the highest speed response to an  $\overline{\mathsf{IRQ}}$  input. When an interrupt

-......:;;,...;~--------------------'~ -----'-- --'--'----- <sup>~</sup>.... ,- >--

is received after an  $\overline{\mathsf{ABORT}}$  which occurs during the WAI instruction, the processor will return to the WAI instruction. Other than RES (highest priority). ABORT is the next highest priority, followed by NMI or IRQ interrupts.

I'

\_ ..

,.

,.

..

. - .

 $\blacksquare$ 

•

..

-..

~A"--*\_\_* ~~ *\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_* <sup>~</sup>*\_\_\_\_\_\_ \_* 

**STP Instruction**<br>The STP instruction disables the ø2 clock to all circuitry. When disabled, the  $\phi$ 2 clock is held in the high state. In this case, the Data Bus will remain in the data transfer state and the Bank address will not be multiplexed onto the Data Bus. Upon executing the STP instruction, the RES signal is the'only input which can restart the processor. The processor is restarted by enabling the  $\phi$ 2 clock, which occurs on the falling edge of the RES input. Note that the external oscillator must be stable and operating properly before RES goes high.

#### COP Signatures

Signatures 00-7F may be user defined. while signatures 80-FF are reserved for instructions on future microprocessors (i.e .. W65C832). Contact WDC for software emulation of future microprocessor hardware functions.

#### WOM Opcode Use

The WDM opcode will be used on future microprocessors. For example. the new W65C832 uses this opcode to provide 32-bit floating-point and other 32-bit math and data operations. Note that the W65C832 will be a plug-to-plug replacement for the W65C816, and can be used where highspeed. 32-bit math processing is required. The W65C832 will be available in the near future.

ROY Pulled During Write . The NMOS 6502 does not stop during a write operation. In contrast. both the W65C02 and the W65C816 do stop during write operations. The W65C802 stops during a write when in the Native mode. but does not stop when in the Emulation mode.

## MVN and MVP Affects on the Data Bank Register

The MVN and MVP instructions change the Dala Bank Register to the value of the second byte of the instruction (destination bank address).

#### Interrupt Priorilles

The following interrupt priorities will be in effect should more than one interrupt occur at the same time:



I .I r·

' .

## Transfers from 8-Bit to 16-BII, or 16-Blt to 8-BII Registers

All transfers from one register to another will result in a full 16-bit output from the source register. The destination register size will determine the number of bits actually stored in the destination register and the values stored in the processor Status Register. The following are always 16-bit transfers. regardless of the accumulator size:

TCS; TSC; TCO; TOC

#### Stack Transfers

When in the Emulation mode. a 01 Is forced into SH. In this case. the B Accumulator will not be loaded into SH during a TCS instruction. When in the Native mode. the B Accumulator is transferred to SH. Note that in both the Emulation and Native modes. the full 16 bits of the Stack Register are transferred to the A, B and C Accumulators, regardless of the state of the M bit in the Status Register.