# E·XFL



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Breduct Ctatus             | Net For New Designs                                                  |
|----------------------------|----------------------------------------------------------------------|
| Product Status             | NOT FOR NEW Designs                                                  |
| Core Processor             | HC05                                                                 |
| Core Size                  | 8-Bit                                                                |
| Speed                      | 2.1MHz                                                               |
| Connectivity               | SIO                                                                  |
| Peripherals                | POR, WDT                                                             |
| Number of I/O              | 21                                                                   |
| Program Memory Size        | 4.5KB (4.5K × 8)                                                     |
| Program Memory Type        | ОТР                                                                  |
| EEPROM Size                | -                                                                    |
| RAM Size                   | 176 x 8                                                              |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                            |
| Data Converters            | A/D 4x8b                                                             |
| Oscillator Type            | Internal                                                             |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                    |
| Mounting Type              | Surface Mount                                                        |
| Package / Case             | 28-SOIC (0.295", 7.50mm Width)                                       |
| Supplier Device Package    | 28-SOIC                                                              |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc705p6acdwe |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong



#### **Table of Contents**

| 14.8  | EPROM Programming Characteristics | 88 |
|-------|-----------------------------------|----|
| 14.9  | SIOP Timing.                      | 89 |
| 14.10 | Control Timing                    | 90 |

# Chapter 15

| 15.1 | Introduction                                         | 93 |
|------|------------------------------------------------------|----|
| 15.2 | Plastic Dual In-Line Package (Case 710)              | 93 |
| 15.3 | Small Outline Integrated Circuit Package (Case 751F) | 94 |

# Chapter 16 Ordering Information

| 16.1 | Introduction     | 95 |
|------|------------------|----|
| 16.2 | MC Order Numbers | 95 |



#### **General Description**



### Figure 1-1. MC68HC705P6A Block Diagram

#### NOTE

A line over a signal name indicates an active low signal. For example, RESET is active high and RESET is active low.

Any reference to voltage, current, or frequency specified in the following sections will refer to the nominal values. The exact values and their tolerances or limits are specified in Chapter 14 Electrical Specifications.



### 1.3.8 TCMP

This pin is the output from the 16-bit timer's output compare function. It is low after reset. Refer to Chapter 8 Capture/Compare Timer.

### 1.3.9 IRQ/V<sub>PP</sub> (Maskable Interrupt Request)

This input pin drives the asynchronous interrupt function of the MCU in user mode and provides the  $V_{PP}$  programming voltage in bootloader mode. The MCU will complete the current instruction being executed before it responds to the IRQ interrupt request. When the IRQ/V<sub>PP</sub> pin is driven low, the event is latched internally to signify an interrupt has been requested. When the MCU completes its current instruction, the interrupt latch is tested. If the interrupt latch is set and the interrupt mask bit (I bit) in the condition code register is clear, the MCU will begin the interrupt sequence.

Depending on the MOR LEVEL bit, the  $\overline{IRQ}/V_{PP}$  pin will trigger an interrupt on either a negative edge at the  $\overline{IRQ}/V_{PP}$  pin and/or while the  $\overline{IRQ}/V_{PP}$  pin is held in the low state. In either case, the  $\overline{IRQ}/V_{PP}$  pin must be held low for at least one t<sub>ILIH</sub> time period. If the edge- and level-sensitive mode is selected (LEVEL bit set), the  $\overline{IRQ}/V_{PP}$  input pin requires an external resistor connected to  $V_{DD}$  for wired-OR operation. If the IRQ/V\_{PP} pin is not used, it must be tied to the  $V_{DD}$  supply. The  $\overline{IRQ}/V_{PP}$  pin input circuitry contains an internal Schmitt trigger to improve noise immunity. Refer to Chapter 5 Interrupts.

### NOTE

If the voltage level applied to the  $\overline{IRQ}/V_{PP}$  pin exceeds  $V_{DD}$ , it may affect the MCU's mode of operation. See Chapter 3 Operating Modes.



**General Description** 

# NP

#### Memory

| Addr.  | Register Name                                            | _               | Bit 7               | 6                   | 5         | 4             | 3          | 2       | 1           | Bit 0        |
|--------|----------------------------------------------------------|-----------------|---------------------|---------------------|-----------|---------------|------------|---------|-------------|--------------|
| \$0000 | Port A Data Register<br>(PORTA)                          | Read:<br>Write: | PA7                 | PA6                 | PA5       | PA4           | PA3        | PA2     | PA1         | PA0          |
|        | See page 37.                                             | Reset:          | Unaffected by reset |                     |           |               |            |         |             |              |
|        | Port B Data Register                                     | Read:           | PB7                 | PB6                 | PB5       | 0             | 0          | 0       | 0           | 0            |
| \$0001 | (PORTB)                                                  | Write:          | 107                 | 1 80                | 1 00      |               |            |         |             |              |
|        | See page 38.                                             | Reset:          |                     | Unaffected by reset |           |               |            |         |             |              |
| \$0002 | Port C Data Register<br>(PORTC)                          | Read:<br>Write: | PC7                 | PC6                 | PC5       | PC4           | PC3        | PC2     | PC1         | PC0          |
|        | See page 38.                                             | Reset:          |                     |                     |           | Unaffecte     | d by reset |         |             |              |
|        | Port D Data Register                                     | Read:           | PD7                 | 0                   | PD5       | 1             | 0          | 0       | 0           | 0            |
| \$0003 | (PORTD)                                                  | Write:          |                     |                     |           |               |            |         |             |              |
|        | See page 39.                                             | Reset:          |                     |                     | 1         | Unaffecte     | d by reset |         | r           |              |
| \$0004 | Port A Data Direction<br>Register (DDRA)                 | Read:<br>Write: | DDRA7               | DDRA6               | DDRA5     | DDRA4         | DDRA3      | DDRA2   | DDRA1       | DDRA0        |
|        | See page 37.                                             | Reset:          | 0                   | 0                   | 0         | 0             | 0          | 0       | 0           | 0            |
|        | Port B Data Direction                                    | Read:           | DDRB7               | DDRB6               | DDRB5     | 1             | 1          | 1       | 1           | 1            |
| \$0005 | Register (DDRB)                                          | Write:          |                     |                     |           |               |            |         |             |              |
|        | See page 30.                                             | Reset:          | 0                   | 0                   | 0         | 0             | 0          | 0       | 0           | 0            |
| \$0006 | Port C Data Direction<br>Register (DDRC)<br>See page 38. | Read:<br>Write: | DDRC7               | DDRC6               | DDRC5     | DDRC4         | DDRC3      | DDRC2   | DDRC1       | DDRC0        |
|        |                                                          | Reset:          | 0                   | 0                   | 0         | 0             | 0          | 0       | 0           | 0            |
|        | Port D Data Direction                                    | Read:           | 0                   | 0                   | DDBD5     | 0             | 0          | 0       | 0           | 0            |
| \$0007 | Register (DDRD)                                          | Write:          |                     |                     |           |               |            |         |             |              |
|        | See page 59.                                             | Reset:          | 0                   | 0                   | 0         | 0             | 0          | 0       | 0           | 0            |
| \$0008 | Unimplemented                                            | Į               |                     |                     |           |               |            |         |             |              |
|        |                                                          | Г               |                     |                     |           |               |            |         |             |              |
| \$0009 | Unimplemented                                            | Į               |                     |                     |           |               |            |         |             |              |
|        |                                                          | Dood            | 0                   |                     | 0         |               | 0          | 0       | 0           | 0            |
| ¢0004  | SIOP Control Register                                    | Read:           | 0                   | SPE                 | 0         | MSTR          | 0          | 0       | 0           | 0            |
| φ000A  | See page 43.                                             | Pocot:          | 0                   | 0                   | 0         | 0             | 0          | 0       | 0           | 0            |
|        |                                                          | Road            | SDIE                |                     | 0         | 0             | 0          | 0       | 0           | 0            |
| \$000P | SIOP Status Register                                     | Write           | 0111                | DOOL                | 0         | 0             | 0          | 0       | 0           | 0            |
| φ000D  | See page 44.                                             | Reset:          | 0                   | 0                   | 0         | 0             | 0          | 0       | 0           | 0            |
|        | SIOP Data Register                                       | Read:           | SDR7                | SDR6                | SDR5      | SDR4          | SDR3       | SSDR2   | SDR1        | SDR0         |
| \$000C | (SDR)<br>See page 44.                                    | vvrite:         |                     |                     |           | l lo affa sta | d by resst |         | <u> </u>    |              |
|        |                                                          | Heset:          |                     | m <sup>2</sup>      | mto d     | Unattecte     | a by reset |         | 11 11-1-2   | una lua a al |
|        |                                                          | Į               |                     | = Unimplen          | nentea    | К             | = Reserved |         | U = Undeter | minea        |
|        | Figure                                                   | e 2-3. I/       | O and C             | ontrol R            | egister S | Summary       | (Sheet     | 1 of 3) |             |              |

MC68HC705P6A Advance Information Data Sheet, Rev. 2.1



# 2.8 Computer Operating Properly (COP) Clear Register

The computer operating properly (COP) watchdog timer is located at address \$1FF0. Writing a logical 0 to bit zero of this location will clear the COP watchdog counter as described in 4.3.2 Computer Operating Properly (COP) Reset.







Memory



#### Resets

The POR will generate the RST signal and reset the MCU. If any other reset function is active at the end of this 4064 internal clock cycle delay, the RST signal will remain active until the other reset condition(s) end.

### 4.3.2 Computer Operating Properly (COP) Reset

When the COP watchdog timer is enabled (COP bit in the MOR is set), the internal COP reset is generated automatically by a timeout of the COP watchdog timer. This timer is implemented with an 18-stage ripple counter that provides a timeout period of 65.5 ms when a 4-MHz oscillator is used. The COP watchdog counter is cleared by writing a logical 0 to bit zero at location \$1FF0.

The COP watchdog timer can be disabled by clearing the COP bit in the MOR or by applying 2 x V<sub>DD</sub> to the  $\overline{IRQ}/V_{PP}$  pin (for example, during bootloader). When the  $\overline{IRQ}/V_{PP}$  pin is returned to its normal operating voltage range (between V<sub>SS</sub>-V<sub>DD</sub>), the COP watchdog timer's output will be restored if the COP bit in the mask option register (MOR) is set.

The COP register is shared with the least significant byte (LSB) of an unused vector address as shown in Figure 4-2. Reading this location will return the programmed value of the unused user interrupt vector, usually 0. Writing to this location will clear the COP watchdog timer.



= Unimplemented

### Figure 4-2. Unused Vector and COP Watchdog Timer

When the COP watchdog timer expires, it will generate the RST signal and reset the MCU. If any other reset function is active at the end of the COP reset signal, the RST signal will remain in the reset condition until the other reset condition(s) end. When the reset condition ends, the MCU's operating mode will be selected (see Table 3-1. Operating Mode Conditions After Reset).

**Input/Output Ports** 

| DDRA | I/O Pin Mode | Accesses to<br>DDRA @ \$0004 | Accesses to Data<br>Register @ \$0000 |          |  |
|------|--------------|------------------------------|---------------------------------------|----------|--|
|      |              | Read/Write                   | Read                                  | Write    |  |
| 0    | IN, Hi-Z     | DDRA0-DDRA7                  | I/O Pin                               | See Note |  |
| 1    | OUT          | DDRA0-DDRA7                  | PA0-PA7                               | PA0-PA7  |  |

### Table 6-1. Port A I/O Functions

Note: Does not affect input, but stored to data register

### Table 6-2. Port B I/O Functions

| DDRB | I/O Pin Mode | Accesses to<br>DDRB @ \$0005 | Accesses to Data<br>Register @ \$0001 |          |  |
|------|--------------|------------------------------|---------------------------------------|----------|--|
|      |              | Read/Write                   | Read                                  | Write    |  |
| 0    | IN, Hi-Z     | DDRB5–DDRB7                  | I/O Pin                               | See Note |  |
| 1    | OUT          | DDRB5–DDRB7                  | PB5–PB7                               | PB5–PB7  |  |

Note: Does not affect input, but stored to data register

#### Table 6-3. Port C I/O Functions

| DDRC | I/O Pin Mode | Accesses to<br>DDRC @ \$0006 | Accesses to Data<br>Register @ \$0002 |          |  |
|------|--------------|------------------------------|---------------------------------------|----------|--|
|      |              | Read/Write                   | Read                                  | Write    |  |
| 0    | IN, Hi-Z     | DDRC0-DDRC7                  | I/O Pin                               | See Note |  |
| 1    | OUT          | DDRC0-DDRC7                  | PC0–PC7                               | PC0-PC7  |  |

Note: Does not affect input, but stored to data register

#### Table 6-4. Port D I/O Functions

| DDRD | I/O Pin Mode | Accesses to<br>DDRD @ \$0007 | Accesses to Data<br>Register @ \$0003 |            |  |
|------|--------------|------------------------------|---------------------------------------|------------|--|
|      |              | Read/Write                   | Read                                  | Write      |  |
| 0    | IN, Hi-Z     | DDRD5                        | I/O Pin                               | See Note 1 |  |
| 1    | OUT          | DDRD5                        | PD5                                   | PD5        |  |

Notes:

1. Does not affect input, but stored to data register 2. PD7 is input only

#### NOTE

To avoid generating a glitch on an I/O port pin, data should be written to the I/O port data register before writing a logic 1 to the corresponding data direction register.

At power-on or reset, all DDRs are cleared, which configures all port pins as inputs. The DDRs are capable of being written to or read by the processor. During the programmed output state, a read of the data register will actually read the value of the output data latch and not the level on the I/O port pin.

MC68HC705P6A Advance Information Data Sheet, Rev. 2.1



Serial Input/Output Port (SIOP)

# 7.2 SIOP Signal Format

The SIOP subsystem is software configurable for master or slave operation. No external mode selection inputs are available (for instance, slave select pin).

# 7.2.1 Serial Clock (SCK)

The state of the SCK output normally remains a logic 1 during idle periods between data transfers. The first falling edge of SCK signals the beginning of a data transfer. At this time, the first bit of received data may be presented at the SDI pin and the first bit of transmitted data is presented at the SDO pin (see Figure 7-2). Data is captured at the SDI pin on the rising edge of SCK. The transfer is terminated upon the eighth rising edge of SCK.

The master and slave modes of operation differ only by the sourcing of SCK. In master mode, SCK is driven from an internal source within the MCU. In slave mode, SCK is driven from a source external to the MCU. The SCK frequency is dependent upon the SPR0 and SPR1 bits located in the mask option register. Refer to 11.2 Mask Option Register for a description of available SCK frequencies.



Figure 7-2. SIOP Timing Diagram

## 7.2.2 Serial Data Input (SDI)

The SDI pin becomes an input as soon as the SIOP subsystem is enabled. New data may be presented to the SDI pin on the falling edge of SCK. However, valid data must be present at least 100 nanoseconds before the rising edge of SCK and remain valid for 100 nanoseconds after the rising edge of SCK. See Figure 7-2.

## 7.2.3 Serial Data Output (SDO)

The SDO pin becomes an output as soon as the SIOP subsystem is enabled. Prior to enabling the SIOP, PB5 can be initialized to determine the beginning state. While the SIOP is enabled, PB5 cannot be used as a standard output since that pin is connected to the last stage of the SIOP serial shift register. Mask option register bit LSBF permits data to be transmitted in either the MSB first format or the LSB first format. Refer to 11.2 Mask Option Register for MOR LSBF programming information.

On the first falling edge of SCK, the first data bit will be shifted out to the SDO pin. The remaining data bits will be shifted out to the SDO pin on subsequent falling edges of SCK. The SDO pin will present valid data at least 100 nanoseconds before the rising edge of the SCK and remain valid for 100 nanoseconds after the rising edge of SCK. See Figure 7-2.



Analog Subsystem

### 9.4.1 Conversion Times

Each input conversion requires 32 internal clock cycles, which must be at a frequency equal to or greater than 1 MHz.

### 9.4.2 Internal versus External Oscillator

If the internal clock is 1 MHz or greater (i.e., external oscillator 2 MHz or greater), the internal RC oscillator must be turned off and the external oscillator used as the conversion clock.

If the MCU internal clock frequency is less than 1 MHz (2 MHz external oscillator), the internal RC oscillator (approximately 1.5 MHz) must be used for the A/D converter clock. The internal RC clock is selected by setting the ADRC bit in the ADSC register.

When the internal RC oscillator is being used, these limitations apply:

- 1. Since the internal RC oscillator is running asynchronously with respect to the internal clock, the conversion complete bit (CC) in register ADSC must be used to determine when a conversion sequence has been completed.
- 2. Electrical noise will slightly degrade the accuracy of the A/D converter. The A/D converter is synchronized to read voltages during the quiet period of the clock driving it. Since the internal and external clocks are not synchronized, the A/D converter will occasionally measure an input when the external clock is making a transition.

### 9.4.3 Multi-Channel Operation

An input multiplexer allows the A/D converter to select from one of four external analog signals. Port C pins PC3 through PC6 are shared with the inputs to the multiplexer.

# 9.5 A/D Status and Control Register (ADSC)

The ADSC register reports the completion of A/D conversion and provides control over oscillator selection, analog subsystem power, and input channel selection. See Figure 9-1.





### CC — Conversion Complete

This read-only status bit is set when a conversion sequence has completed and data is ready to be read from the ADC register. CC is cleared when the ADSC is written to or when data is read from the ADC register. Once a conversion has been started, conversions of the selected channel will continue every 32 internal clock cycles until the ADSC register is written to again. During continuous conversion operation, the ADC register will be updated with new data, and the CC bit set every 32 internal clock cycles. Also, data from the previous conversion will be overwritten regardless of the state of the CC bit.



Analog Subsystem

# 9.7 A/D Subsystem Operation during Halt/Wait Modes

The A/D subsystem continues normal operation during wait and halt modes. To decrease power consumption during wait or halt mode, the ADON and ADRC bits in the A/D status and control register should be cleared if the A/D subsystem is not being used.

# 9.8 A/D Subsystem Operation during Stop Mode

When stop mode is enabled, execution of the STOP instruction will terminate all A/D subsystem functions. Any pending conversion is aborted. When the oscillator resumes operation upon leaving stop mode, a finite amount of time passes before the A/D subsystem stabilizes sufficiently to provide conversions at its rated accuracy. The delays built into the MC68HC705P6A when coming out of stop mode are sufficient for this purpose. No explicit delays need to be added to the application software.

MC68HC705P6A Advance Information Data Sheet, Rev. 2.1





Figure 10-2. MC68HC705P6A EPROM Programming Flowchart





# **11.3 MOR Programming**

The contents of the MOR should be programmed in bootloader mode using the hardware shown in Figure 10-2. MC68HC705P6A EPROM Programming Flowchart. In order to allow programming, all the implemented bits in the MOR are essentially read-write bits in bootloader mode as shown in Figure 11-1.

The programming of the MOR is the same as user EPROM.

- 1. Set the ELAT bit in the EPROG register.
- 2. Write the desired data to the desired MOR address.
- 3. Set the EPGM bit in the EPROG.
- 4. Wait for the programming time (t<sub>EPGM</sub>).
- 5. Clear the ELAT and EPGM bits in the EPROG.
- 6. Remove the programming voltage from the  $\overline{IRQ}/V_{PP}$  pin.

A sample routine to program a byte of EPROM is shown in Table 11-2.

Once the MOR bits have been programmed, the options are not loaded into the MOR registers until the part is reset.

#### Table 11-2. MOR Programming Routine

| 001C<br>00FF |          | EPROG<br>DATA2 | EQU<br>EQU | \$1C<br>\$FF | PROGRAMMING REG<br>SAMPLE MOR VALUES |
|--------------|----------|----------------|------------|--------------|--------------------------------------|
| 0023         |          | DATA1          | EQU        | #23          |                                      |
| 1EFF         |          | MOR2           | EQU        | \$1EFF       | MOPR ADDRESSES                       |
| 1F00         |          | MOR1           | EQU        | \$1F00       |                                      |
| 0000         |          | EPGM           | EQU        | \$00         | EPGM BIT IN EPROG REG                |
| 00E0         |          |                | ORG        | \$E0         |                                      |
| 00E0         | A6 04    |                | LDA        | #\$04        | SET ELAT BIT                         |
| 00E2         | B7 1C    |                | STA        | EPROG        | IN EPGM REG AT \$1C                  |
| 00E4         | A6 FF    |                | LDA        | #DATA2       | DATA BYTE                            |
| 00E6         | C7 1E FF |                | STA        | MOR2         | WRITE IT TO MOR LOC                  |
| 00E9         | 12 1C    |                | BSET       | EPGM, EPROG  | TURN ON PGM VOLTAGE                  |
| 00EB         | AD 03    |                | BSR        | DELAY        | WAIT 4 ms MINIMUM                    |
| 00ED         | 3F 1C    |                | CLR        | EPROG        | CLR EPGM REGISTER                    |
| OOEF         | 81       |                | RTS        |              |                                      |



Central Processor Unit (CPU) Core





# 13.3 Instruction Types

The MCU instructions fall into the following five categories:

- Register/memory instructions
- Read-modify-write instructions
- Jump/branch instructions
- Bit manipulation instructions
- Control instructions

### 13.3.1 Register/Memory Instructions

These instructions operate on CPU registers and memory locations. Most of them use two operands. One operand is in either the accumulator or the index register. The CPU finds the other operand in memory.

| Instruction                                         | Mnemonic |
|-----------------------------------------------------|----------|
| Add Memory Byte and Carry Bit to Accumulator        | ADC      |
| Add Memory Byte to Accumulator                      | ADD      |
| AND Memory Byte with Accumulator                    | AND      |
| Bit Test Accumulator                                | BIT      |
| Compare Accumulator                                 | CMP      |
| Compare Index Register with Memory Byte             | CPX      |
| EXCLUSIVE OR Accumulator with Memory Byte           | EOR      |
| Load Accumulator with Memory Byte                   | LDA      |
| Load Index Register with Memory Byte                | LDX      |
| Multiply                                            | MUL      |
| OR Accumulator with Memory Byte                     | ORA      |
| Subtract Memory Byte and Carry Bit from Accumulator | SBC      |
| Store Accumulator in Memory                         | STA      |
| Store Index Register in Memory                      | STX      |
| Subtract Memory Byte from Accumulator               | SUB      |

Table 13-1. Register/Memory Instructions



| Source<br>Form                                                     | Operation                                    | Description                                                                                                                                                                                                                                                                              | Effect<br>on CCR |   |   |   |   | ress<br>ode                           | ode                              | rand                             | cles                       |
|--------------------------------------------------------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---|---|---|---|---------------------------------------|----------------------------------|----------------------------------|----------------------------|
|                                                                    |                                              |                                                                                                                                                                                                                                                                                          | Н                | I | Ν | z | С | Add<br>Mo                             | Opc                              | Opei                             | Š                          |
| CLR opr<br>CLRA<br>CLRX<br>CLR opr,X<br>CLR ,X                     | Clear Byte                                   | $\begin{array}{c} M \leftarrow \$00\\ A \leftarrow \$00\\ X \leftarrow \$00\\ M \leftarrow \$00\\ M \leftarrow \$00\\ M \leftarrow \$00 \end{array}$                                                                                                                                     |                  |   | 0 | 1 |   | DIR<br>INH<br>INH<br>IX1<br>IX        | 3F<br>4F<br>5F<br>6F<br>7F       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| CMP #opr<br>CMP opr<br>CMP opr<br>CMP opr,X<br>CMP opr,X<br>CMP ,X | Compare Accumulator with Memory Byte         | (A) – (M)                                                                                                                                                                                                                                                                                |                  |   | ţ | t | ţ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A1<br>B1<br>C1<br>D1<br>E1<br>F1 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| COM opr<br>COMA<br>COMX<br>COM opr,X<br>COM ,X                     | Complement Byte (One's Complement)           | $\begin{array}{l} M \leftarrow (\overline{M}) = \$FF - (M) \\ A \leftarrow (\overline{A}) = \$FF - (A) \\ X \leftarrow (\overline{X}) = \$FF - (X) \\ M \leftarrow (\overline{M}) = \$FF - (M) \\ M \leftarrow (\overline{M}) = \$FF - (M) \end{array}$                                  |                  |   | ţ | ţ | 1 | DIR<br>INH<br>INH<br>IX1<br>IX        | 33<br>43<br>53<br>63<br>73       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| CPX #opr<br>CPX opr<br>CPX opr<br>CPX opr,X<br>CPX opr,X<br>CPX ,X | Compare Index Register with Memory Byte      | (X) – (M)                                                                                                                                                                                                                                                                                |                  |   | ţ | ţ | ţ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A3<br>B3<br>C3<br>D3<br>E3<br>F3 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| DEC <i>opr</i><br>DECA<br>DECX<br>DEC <i>opr</i> ,X<br>DEC ,X      | Decrement Byte                               | $\begin{array}{l} M \leftarrow (M) - 1 \\ A \leftarrow (A) - 1 \\ X \leftarrow (X) - 1 \\ M \leftarrow (M) - 1 \\ M \leftarrow (M) - 1 \end{array}$                                                                                                                                      |                  |   | ţ | t |   | DIR<br>INH<br>INH<br>IX1<br>IX        | 3A<br>4A<br>5A<br>6A<br>7A       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| EOR #opr<br>EOR opr<br>EOR opr,X<br>EOR opr,X<br>EOR ,X            | EXCLUSIVE OR Accumulator with Memory<br>Byte | A ← (A) ⊕ (M)                                                                                                                                                                                                                                                                            |                  |   | ţ | ţ |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A8<br>B8<br>C8<br>D8<br>E8<br>F8 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| INC <i>opr</i><br>INCA<br>INCX<br>INC <i>opr</i> ,X<br>INC ,X      | Increment Byte                               | $\begin{array}{l} M \leftarrow (M) + 1 \\ A \leftarrow (A) + 1 \\ X \leftarrow (X) + 1 \\ M \leftarrow (M) + 1 \\ M \leftarrow (M) + 1 \end{array}$                                                                                                                                      |                  |   | ţ | ţ |   | DIR<br>INH<br>INH<br>IX1<br>IX        | 3C<br>4C<br>5C<br>6C<br>7C       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| JMP opr<br>JMP opr<br>JMP opr,X<br>JMP opr,X<br>JMP ,X             | Unconditional Jump                           | $PC \gets Jump \; Address$                                                                                                                                                                                                                                                               |                  | _ | _ |   |   | DIR<br>EXT<br>IX2<br>IX1<br>IX        | BC<br>CC<br>DC<br>EC<br>FC       | dd<br>hh II<br>ee ff<br>ff       | 2<br>3<br>4<br>3<br>2      |
| JSR opr<br>JSR opr<br>JSR opr,X<br>JSR opr,X<br>JSR ,X             | Jump to Subroutine                           | $\begin{array}{l} \text{PC} \leftarrow (\text{PC}) + n \ (n = 1, 2, \text{ or } 3) \\ \text{Push} \ (\text{PCL}); \text{SP} \leftarrow (\text{SP}) - 1 \\ \text{Push} \ (\text{PCH}); \text{SP} \leftarrow (\text{SP}) - 1 \\ \text{PC} \leftarrow \text{Effective Address} \end{array}$ | _                | _ | _ |   |   | DIR<br>EXT<br>IX2<br>IX1<br>IX        | BD<br>CD<br>DD<br>ED<br>FD       | dd<br>hh ll<br>ee ff<br>ff       | 5<br>6<br>7<br>6<br>5      |

### Table 13-6. Instruction Set Summary (Sheet 3 of 6)



Instruction Set

| Source<br>Form                                                     | Operation                            | Description                                                                                                                                                                                           | Effect<br>on CCR |   |     |   |   | ress<br>ode                           | ode                              | rand                             | cles                       |
|--------------------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---|-----|---|---|---------------------------------------|----------------------------------|----------------------------------|----------------------------|
|                                                                    |                                      |                                                                                                                                                                                                       | н                | I | Ν   | z | С | Add<br>Mo                             | Opc                              | Ope                              | cyc                        |
| LDA #opr<br>LDA opr<br>LDA opr<br>LDA opr,X<br>LDA opr,X<br>LDA ,X | Load Accumulator with Memory Byte    | A ← (M)                                                                                                                                                                                               |                  |   | t t | ţ |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A6<br>B6<br>C6<br>D6<br>E6<br>F6 | ii<br>dd<br>hh ll<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| LDX #opr<br>LDX opr<br>LDX opr<br>LDX opr,X<br>LDX opr,X<br>LDX ,X | Load Index Register with Memory Byte | X ← (M)                                                                                                                                                                                               |                  |   | t   | ţ |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | AE<br>BE<br>CE<br>DE<br>EE<br>FE | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| LSL opr<br>LSLA<br>LSLX<br>LSL opr,X<br>LSL ,X                     | Logical Shift Left (Same as ASL)     | C ←                                                                                                                                                                                                   |                  |   | t t | ţ | ţ | DIR<br>INH<br>INH<br>IX1<br>IX        | 38<br>48<br>58<br>68<br>78       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| LSR <i>opr</i><br>LSRA<br>LSRX<br>LSR <i>opr</i> ,X<br>LSR ,X      | Logical Shift Right                  | 0 → C<br>b7 b0                                                                                                                                                                                        |                  |   | 0   | ţ | ţ | DIR<br>INH<br>IX1<br>IX               | 34<br>44<br>54<br>64<br>74       | dd<br>ff                         | 53365                      |
| MUL                                                                | Unsigned Multiply                    | $X:A \leftarrow (X) \times (A)$                                                                                                                                                                       | 0                | _ | _   |   | 0 | INH                                   | 42                               |                                  | 1<br>1                     |
| NEG <i>opr</i><br>NEGA<br>NEGX<br>NEG <i>opr</i> ,X<br>NEG ,X      | Negate Byte (Two's Complement)       | $\begin{array}{l} M \leftarrow -(M) = \$00 - (M) \\ A \leftarrow -(A) = \$00 - (A) \\ X \leftarrow -(X) = \$00 - (X) \\ M \leftarrow -(M) = \$00 - (M) \\ M \leftarrow -(M) = \$00 - (M) \end{array}$ |                  | - | t t | ţ | ţ | DIR<br>INH<br>INH<br>IX1<br>IX        | 30<br>40<br>50<br>60<br>70       | dd<br>ff                         | 5 3 3 6 5                  |
| NOP                                                                | No Operation                         |                                                                                                                                                                                                       |                  | - | —   |   | _ | INH                                   | 9D                               |                                  | 2                          |
| ORA #opr<br>ORA opr<br>ORA opr<br>ORA opr,X<br>ORA opr,X<br>ORA ,X | Logical OR Accumulator with Memory   | $A \gets (A) \lor (M)$                                                                                                                                                                                |                  |   | ţ.  | ţ |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | AA<br>BA<br>CA<br>DA<br>EA<br>FA | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| ROL <i>opr</i><br>ROLA<br>ROLX<br>ROL <i>opr</i> ,X<br>ROL ,X      | Rotate Byte Left through Carry Bit   | b7 b0                                                                                                                                                                                                 |                  |   | t t | ţ | ţ | DIR<br>INH<br>INH<br>IX1<br>IX        | 39<br>49<br>59<br>69<br>79       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| ROR <i>opr</i><br>RORA<br>RORX<br>ROR <i>opr</i> ,X<br>ROR ,X      | Rotate Byte Right through Carry Bit  | b7 b0                                                                                                                                                                                                 |                  |   | ţ.  | ţ | ţ | DIR<br>INH<br>INH<br>IX1<br>IX        | 36<br>46<br>56<br>66<br>76       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| RSP                                                                | Reset Stack Pointer                  | $SP \gets \$00FF$                                                                                                                                                                                     |                  |   | —   |   |   | INH                                   | 9C                               |                                  | 2                          |

# Table 13-6. Instruction Set Summary (Sheet 4 of 6)



Instruction Set





#### Notes:

- Internal timing signal and bus information are not available externally.
  OSC1 line is not meant to represent frequency. It is only used to represent time.
  The next rising edge of the internal clock following the rising edge of RESET initiates the reset sequence.

### Figure 14-2. Power-On Reset and External Reset Timing Diagram