# 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

| Product Status             | Obsolete                                                                 |
|----------------------------|--------------------------------------------------------------------------|
| Core Processor             | HC05                                                                     |
| Core Size                  | 8-Bit                                                                    |
| Speed                      | 2.1MHz                                                                   |
| Connectivity               | SCI, SPI                                                                 |
| Peripherals                | POR, WDT                                                                 |
| Number of I/O              | 24                                                                       |
| Program Memory Size        | 16KB (16K x 8)                                                           |
| Program Memory Type        | OTP                                                                      |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 352 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                                |
| Data Converters            | -                                                                        |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 44-QFP                                                                   |
| Supplier Device Package    | 44-QFP (10x10)                                                           |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc68hc705c9acfbe |

Email: info@E-XFL.COM

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

# MC68HC705C9A

### **Advance Information Data Sheet**

To provide the most up-to-date information, the revision of our documents on the World Wide Web will be the most current. Your printed copy may be an earlier revision. To verify you have the latest information available, refer to:

http://www.freescale.com/

The following revision history table summarizes changes contained in this document. For your convenience, the page number designators have been linked to the appropriate location.

| Date                             | Date Revision Description |                                                                                                      |            |  |  |  |
|----------------------------------|---------------------------|------------------------------------------------------------------------------------------------------|------------|--|--|--|
| Ostobor                          |                           | Format update to current publication standards                                                       | N/A        |  |  |  |
| 2001                             | 3.0                       | Figure 12-10. SPI Slave Timing Diagram — Corrected labels for MISO and MOSI and subtitle for part b. | 145        |  |  |  |
| February, 4.0 Fig<br>2002 4.0 ad |                           | Figure 8-3. Timer Status Register (TSR) — Corrected address designator from \$0012 to \$0013.        | 78         |  |  |  |
| September,<br>2005               | 4.1                       | Updated to meet Freescale identity guidelines.                                                       | Throughout |  |  |  |

### **Revision History**



#### General Description

- The port D data direction register (\$0007) is disabled and the seven port D pins become input only.
- SPI output signals (MOSI, MISO, and SCK) do not require the data direction register control for output capability.
- The port D wire-OR mode control bit (bit 5 of SPCR \$000A) is disabled, preventing open-drain configuration of port D.
- The RESET pin becomes input only.

### 1.4 Mask Options

The following two mask option registers are used to select features controlled by mask changes on the MC68HC05C9A and the MC68HC05C12A:

- Port B mask option register (PBMOR)
- C12 mask option register (C12MOR)

The mask option registers are EPROM locations which must be programmed prior to operation of the microcontroller.

### 1.4.1 Port B Mask Option Register (PBMOR)

The PBMOR register, shown in Figure 1-2, contains eight programmable bits which determine whether each port B bit (when in input mode) has the pullup and interrupt enabled. The port B interrupts share the vector and edge/edge-level sensitivity with the IRQ pin. For more details, (see 4.3 External Interrupt (IRQ or Port B)).

| \$3FF0 | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
|        | PBPU7 | PBPU6 | PBPU5 | PBPU4 | PBPU3 | PBPU2 | PBPU1 | PBPU0 |

Figure 1-2. Port B Mask Option Register

PBPU7–PBPU0 — Port B Pullup/Interrupt Enable Bits

- 1 = Pullup and CPU interrupt enabled
- 0 = Pullup and CPU interrupt disabled

#### NOTE

The current capability of the port B pullup devices is equivalent to the MC68HC05C9A, which is less than the MC68HC05C12A.

### 1.4.2 C12 Mask Option Register (C12MOR)

The C12MOR register, shown in Figure 1-3, controls the following options:

- Select between MC68HC05C9A/C12A configuration
- Enable/disable stop mode (C12A mode only)
- Enable/disable COP (C12A mode only)
- Edge-triggered only or edge- and level-triggered external interrupt pin (IRQ pin) (C12A mode only).



General Description

### 1.5 Software-Programmable Options (MC68HC05C9A Mode Only)

The C9A option register (OR), shown in Figure 1-4, is enabled only if configured in C9A mode. This register contains the programmable bits for the following options:

- Map two different areas of memory between RAM and EPROM, one of 48 bytes and one of 128 bytes
- Edge-triggered only or edge- and level-triggered external interrupt (IRQ pin and any port B pin configured for interrupt)

This register must be written to by user software during operation of the microcontroller.



Figure 1-4. C9A Option Register

### RAM0 — Random Access Memory Control Bit 0

This read/write bit selects between RAM or EPROM in location \$0020 to \$004F. This bit can be read or written at any time.

1 = RAM selected

0 = EPROM selected

### RAM1— Random Access Memory Control Bit 1

This read/write bit selects between RAM or EPROM in location \$0100 to \$017F. This bit can be read or written at any time.

- 1 = RAM selected
- 0 = EPROM selected

#### IRQ — Interrupt Request Bit

This bit selects between an edge-triggered only or edge- and level- triggered external interrupt pin. This bit is set by reset, but can be cleared by software. This bit can be written only once.

- 1 = Edge and level interrupt option selected
- 0 = Edge-only interrupt option selected

\_\_\_\_\_

#### I/O Registers

| Addr   | Register Name                             |
|--------|-------------------------------------------|
| \$0000 | Port A Data Register                      |
| \$0001 | Port B Data Register                      |
| \$0002 | Port C Data Register                      |
| \$0003 | Port D Data Register                      |
| \$0004 | Port A Data Direction Register            |
| \$0005 | Port B Data Direction Register            |
| \$0006 | Port C Data Direction Register            |
| \$0007 | Port D Data Direction Register (C9A Only) |
| \$0008 | Unused                                    |
| \$0009 | Unused                                    |
| \$000A | Serial Peripheral Control Register        |
| \$000B | Serial Peripheral Status Register         |
| \$000C | Serial Peripheral Data Register           |
| \$000D | Baud Rate Register                        |
| \$000E | Serial Communications Control Register 1  |
| \$000F | Serial Communications Control Register 2  |
| \$0010 | Serial Communications Status Register     |
| \$0011 | Serial Communications Data Register       |
| \$0012 | Timer Control Register                    |
| \$0013 | Timer Status Register                     |
| \$0014 | Input Capture Register High               |
| \$0015 | Input Capture Register Low                |
| \$0016 | Output Compare Register High              |
| \$0017 | Output Compare Register Low               |
| \$0018 | Timer Register High                       |
| \$0019 | Timer Register Low                        |
| \$001A | Alternate Timer Register High             |
| \$001B | Alternate Timer Register Low              |
| \$001C | EPROM Programming Register                |
| \$001D | C9A COP Reset Register                    |
| \$001E | C9A COP Control Register                  |
| \$001F | Reserved                                  |

Figure 2-3. I/O Register Summary



#### I/O Registers

| Addr.  | Register Name                          |                 | Bit 7               | 6                   | 5      | 4        | 3           | 2      | 1          | Bit 0 |  |  |
|--------|----------------------------------------|-----------------|---------------------|---------------------|--------|----------|-------------|--------|------------|-------|--|--|
| \$000D | SCI Baud Rate Register<br>BAUD         | Read:<br>Write: |                     |                     | SCP1   | SCP0     |             | SCR2   | SCR1       | SCR0  |  |  |
|        | See page 69.                           | Reset:          | _                   |                     | 0      | 0        |             | U      | U          | U     |  |  |
| \$000E | SCI Control Register 1<br>(SCCR1)      | Read:<br>Write: | R8                  | Т8                  |        | М        | WAKE        |        |            |       |  |  |
|        | See page 65.                           | Reset:          | U                   | U                   | 0      | U        | U           | 0      | 0          | 0     |  |  |
| \$000F | SCI Control Register 2<br>(SCCR2)      | Read:<br>Write: | TIE                 | TCIE                | RIE    | ILIE     | TE          | RE     | RWU        | SBK   |  |  |
|        | See page 66.                           | Reset:          | 0                   | 0                   | 0      | 0        | 0           | 0      | 0          | 0     |  |  |
| \$0010 | SCI Status Register                    | Read:           | TDRE                | TC                  | RDRF   | IDLE     | OR          | NF     | FE         |       |  |  |
|        | (SCSR)                                 | Write:          |                     |                     |        |          |             |        |            |       |  |  |
|        | See page 68.                           | Reset:          | 1                   | 1                   | 0      | 0        | 0           | 0      | 0          | —     |  |  |
| \$0011 | SCI Data Register<br>(SCDR)            | Read:<br>Write: | SCD7                | SDC6                | SCD5   | SCD4     | SCD3        | SCD2   | SCD1       | SCD0  |  |  |
|        | See page 65.                           | Reset:          |                     | Unaffected by reset |        |          |             |        |            |       |  |  |
| \$0012 | Timer Control Register                 | Read:           | ICIE                | OCIE                | TOIF   | 0        | 0           | 0      | IEDG       |       |  |  |
|        | (TCR)                                  | Write:          | 1012                | 0012                | 1012   |          |             |        | 1200       | 0272  |  |  |
|        | See page 53.                           | Reset:          | 0                   | 0                   | 0      | 0        | 0           | 0      | U          | 0     |  |  |
|        | Timer Status Register                  | Read:           | ICF                 | OCF                 | TOF    | 0        | 0           | 0      | 0          | 0     |  |  |
| \$0013 | (TSR)                                  | Write:          |                     |                     |        |          |             |        |            |       |  |  |
|        | See page 54.                           | Reset:          | U                   | U                   | U      | 0        | 0           | 0      | 0          | 0     |  |  |
|        | Input Capture Register High            | Read:           | Bit 15              | Bit 14              | Bit 13 | Bit 12   | Bit 11      | Bit 10 | Bit 9      | Bit 8 |  |  |
| \$0014 | (ICRH)                                 | Write:          |                     |                     |        |          |             |        |            |       |  |  |
|        | See page 56.                           | Reset:          |                     |                     | 1      | Unaffect | ed by reset |        | 1          |       |  |  |
|        | Input Capture Register Low             | Read:           | Bit 7               | Bit 6               | Bit 5  | Bit 4    | Bit 3       | Bit 2  | Bit 1      | Bit 0 |  |  |
| \$0015 | (ICRL)                                 | Write:          |                     |                     |        |          |             |        |            |       |  |  |
|        | See page 50.                           | Reset:          | Unaffected by reset |                     |        |          |             |        |            |       |  |  |
| \$0016 | Output Compare Register<br>High (OCRH) | Read:<br>Write: | Bit 15              | Bit 14              | Bit 13 | Bit 12   | Bit 11      | Bit 10 | Bit 9      | Bit 8 |  |  |
|        | See page 56.                           | Reset:          | Unaffected by reset |                     |        |          |             |        |            |       |  |  |
| \$0017 | Output Compare Register<br>Low (OCRL)  | Read:<br>Write: | Bit 7               | Bit 6               | Bit 5  | Bit 4    | Bit 3       | Bit 2  | Bit 1      | Bit 0 |  |  |
|        | See page 56.                           | Reset:          |                     |                     |        | Unaffect | ed by reset |        |            |       |  |  |
|        | Timer Register High                    | Read:           | Bit 15              | Bit 14              | Bit 13 | Bit 12   | Bit 11      | Bit 10 | Bit 9      | Bit 8 |  |  |
| \$0018 | (TRH)                                  | Write:          |                     |                     |        |          |             |        |            |       |  |  |
|        | See page 55.                           | Reset:          | 1                   | 1                   | 1      | 1        | 1           | 1      | 1          | 1     |  |  |
|        |                                        |                 |                     | = Unimpler          | mented | R        | = Reserved  |        | U = Unaffe | cted  |  |  |

Figure 2-4. Input/Output Registers (Sheet 2 of 3)



# Chapter 4 Interrupts

### 4.1 Introduction

The MCU can be interrupted by five different sources, four maskable hardware interrupts, and one non-maskable software interrupt:

- External signal on the IRQ pin or port B pins
- 16-bit programmable timer
- Serial communications interface
- Serial peripheral interface
- Software interrupt instruction (SWI)

Interrupts cause the processor to save register contents on the stack and to set the interrupt mask (I bit) to prevent additional interrupts. The RTI instruction causes the register contents to be recovered from the stack and normal processing to resume.

Unlike reset, hardware interrupts do not cause the current instruction execution to be halted, but are considered pending until the current instruction is complete.

### NOTE

### The current instruction is the one already fetched and being operated on.

When the current instruction is complete, the processor checks all pending hardware interrupts. If interrupts are not masked (CCR I bit clear) and if the corresponding interrupt enable bit is set, the processor proceeds with interrupt processing; otherwise, the next instruction is fetched and executed.

If an external interrupt and a timer, SCI, or SPI interrupt are pending at the end of an instruction execution, the external interrupt is serviced first. The SWI is executed the same as any other instruction, regardless of the I-bit state.

Table 4-1 shows the relative priority of all the possible interrupt sources. Figure 4-1 shows the interrupt processing flow.

### 4.2 Non-Maskable Software Interrupt (SWI)

The SWI is an executable instruction and a non-maskable interrupt: It is executed regardless of the state of the I bit in the CCR. If the I bit is zero (interrupts enabled), SWI executes after interrupts which were pending when the SWI was fetched, but before interrupts generated after the SWI was fetched. The interrupt service routine address is specified by the contents of memory locations \$3FFC and \$3FFD.



### 5.5 MC68HC05C9A Compatible COP

This COP is controlled with two registers; one to reset the COP timer and the other to enable and control COP and clock monitor functions. Figure 5-3 shows a block diagram of the MC68HC05C9A COP.



Figure 5-3. C9A COP Block Diagram

### 5.5.1 C9A COP Reset Register

This write-only register, shown in Figure 5-4, is used to reset the COP.



### Figure 5-4. COP Reset Register (COPRST)

The sequence required to reset the COP timer is:

- Write \$55 to the COP reset register
- Write \$AA to the COP reset register

Both write operations must occur in the order listed, but any number of instructions may be executed between the two write operations provided that the COP does not time out between the two writes. The elapsed time between software resets must not be greater than the COP timeout period. If the COP should time out, a system reset will occur and the device will be re-initialized in the same fashion as a power-on reset or reset.

Reading this register does not return valid data.

### 5.5.2 C9A COP Control Register

The COP control register, shown in Figure 5-5, performs these functions:

- Enables clock monitor function
- Enables MC68HC05C9A compatible COP function
- Selects timeout duration of COP timer

and flags the following conditions:

- A COP timeout
- Clock monitor reset



# Chapter 6 Low-Power Modes

### 6.1 Introduction

This section describes the low-power modes.

### 6.2 Stop Mode

The STOP instruction places the MCU in its lowest-power consumption mode. In stop mode, the internal oscillator is turned off, halting all internal processing, including timer operation.

During the stop mode, the TCR bits are altered to remove any pending timer interrupt request and to disable any further timer interrupts. The timer prescaler is cleared. The I bit in the CCR is cleared to enable external interrupts. All other registers and memory remain unaltered. All input/output lines remain unchanged. The processor can be brought out of the stop mode only by an external interrupt or reset. See Figure 6-1.



### Figure 6-1. Stop Recovery Timing Diagram







Capture/Compare Timer

### 8.2 Timer Operation

The core of the capture/compare timer is a 16-bit free-running counter. The counter provides the timing reference for the input capture and output compare functions. The input capture and output compare functions provide a means to latch the times at which external events occur, to measure input waveforms, and to generate output waveforms and timing delays. Software can read the value in the 16-bit free-running counter at any time without affecting the counter sequence.

Because of the 16-bit timer architecture, the I/O registers for the input capture and output compare functions are pairs of 8-bit registers.

Because the counter is 16 bits long and preceded by a fixed divide-by-4 prescaler, the counter rolls over every 262,144 internal clock cycles. Timer resolution with a 4-MHz crystal is 2  $\mu$ s.

### 8.2.1 Input Capture

The input capture function is a means to record the time at which an external event occurs. When the input capture circuitry detects an active edge on the TCAP pin, it latches the contents of the timer registers into the input capture registers. The polarity of the active edge is programmable.

Latching values into the input capture registers at successive edges of the same polarity measures the period of the input signal on the TCAP pin. Latching values into the input capture registers at successive edges of opposite polarity measures the pulse width of the signal.

### 8.2.2 Output Compare

The output compare function is a means of generating an output signal when the 16-bit counter reaches a selected value. Software writes the selected value into the output compare registers. On every fourth internal clock cycle the output compare circuitry compares the value of the counter to the value written in the output compare registers. When a match occurs, the timer transfers the programmable output level bit (OLVL) from the timer control register to the TCMP pin.

The programmer can use the output compare register to measure time periods, to generate timing delays, or to generate a pulse of specific duration or a pulse train of specific frequency and duty cycle on the TCMP pin.

### 8.3 Timer I/O Registers

The following I/O registers control and monitor timer operation:

- Timer control register (TCR)
- Timer status register (TSR)
- Timer registers (TRH and TRL)
- Alternate timer registers (ATRH and ATRL)
- Input capture registers (ICRH and ICRL)
- Output compare registers (OCRH and OCRL)



#### Capture/Compare Timer

### 8.3.2 Timer Status Register

The timer status register (TSR), shown in Figure 8-3, contains flags to signal the following conditions:

- An active signal on the TCAP pin, transferring the contents of the timer registers to the input capture registers
- A match between the 16-bit counter and the output compare registers, transferring the OLVL bit to the TCMP pin
- A timer roll over from \$FFFF to \$0000



#### ICF — Input Capture Flag

The ICF bit is set automatically when an edge of the selected polarity occurs on the TCAP pin. Clear the ICF bit by reading the timer status register with ICF set and then reading the low byte (\$0015) of the input capture registers. Resets have no effect on ICF.

#### OCF — Output Compare Flag

The OCF bit is set automatically when the value of the timer registers matches the contents of the output compare registers. Clear the OCF bit by reading the timer status register with OCF set and then reading the low byte (\$0017) of the output compare registers. Resets have no effect on OCF.

#### TOF — Timer Overflow Flag

The TOF bit is set automatically when the 16-bit counter rolls over from \$FFFF to \$0000. Clear the TOF bit by reading the timer status register with TOF set, and then reading the low byte (\$0019) of the timer registers. Resets have no effect on TOF.



Serial Communications Interface (SCI)

### 9.4 SCI Transmitter Features

Features of the SCI transmitter include:

- Transmit data register empty flag
- Transmit complete flag
- Send break



Figure 9-1. Serial Communications Interface Block Diagram

NOTE

The serial communications data register (SCI SCDR) is controlled by the internal R/W signal. It is the transmit data register when written to and the receive data register when read.



Serial Communications Interface (SCI)

### 9.11 Start Bit Detection

When the input (idle) line is detected low, it is tested for three more sample times (referred to as the start edge verification samples in Figure 9-4). If at least two of these three verification samples detect a logic 0, a valid start bit has been detected; otherwise, the line is assumed to be idle. A noise flag is set if all three verification samples do not detect a logic 0. Thus, a valid start bit could be assumed with a set noise flag present.

If a framing error has occurred without detection of a break (10 0s for

8-bit format or 11 0s for 9-bit format), the circuit continues to operate as if there actually was a stop bit, and the start edge will be placed artificially. The last bit received in the data shift register is inverted to a logic 1, and the three logic 1 start qualifiers (shown in Figure 9-4) are forced into the sample shift register during the interval when detection of a start bit is anticipated (see Figure 9-6); therefore, the start bit will be accepted no sooner than it is anticipated.

If the receiver detects that a break (RDRF = 1, FE = 1, receiver data register = 003B) produced the framing error, the start bit will not be artificially induced and the receiver must actually detect a logic 1 before the start bit can be recognized (see Figure 9-7).



b) Case 2: Receive line high during expected start edge





Figure 9-7. SCI Start Bit Following a Break





### 9.12 Transmit Data Out (TDO)

Transmit data is the serial data from the internal data bus that is applied through the SCI to the output line. Data format is as discussed in 9.6 Data Format and shown in Figure 9-3. The transmitter generates a bit time by using a derivative of the RT clock, thus producing a transmission rate equal to 1/16th that of the receiver sample clock.

### 9.13 SCI I/O Registers

The following I/O registers control and monitor SCI operation:

- SCI data register (SCDR)
- SCI control register 1 (SCCR1)
- SCI control register 2 (SCCR2)
- SCI status register (SCSR)

### 9.13.1 SCI Data Register

The SCI data register (SCDR), shown in Figure 9-8, is the buffer for characters received and for characters transmitted.



Figure 9-8. SCI Data Register (SCDR)

### 9.13.2 SCI Control Register 1

The SCI control register 1 (SCCR1), shown in Figure 9-9, has these functions:

- Stores ninth SCI data bit received and ninth SCI data bit transmitted
- Controls SCI character length
- Controls SCI wakeup method



Figure 9-9. SCI Control Register 1 (SCCR1)

#### R8 — Bit 8 (Received)

When the SCI is receiving 9-bit characters, R8 is the ninth bit of the received character. R8 receives the ninth bit at the same time that the SCDR receives the other eight bits. Resets have no effect on the R8 bit.



### 11.3.3 Jump/Branch Instructions

Jump instructions allow the CPU to interrupt the normal sequence of the program counter. The unconditional jump instruction (JMP) and the jump-to-subroutine instruction (JSR) have no register operand. Branch instructions allow the CPU to interrupt the normal sequence of the program counter when a test condition is met. If the test condition is not met, the branch is not performed.

The BRCLR and BRSET instructions cause a branch based on the state of any readable bit in the first 256 memory locations. These 3-byte instructions use a combination of direct addressing and relative addressing. The direct address of the byte to be tested is in the byte following the opcode. The third byte is the signed offset byte. The CPU finds the effective branch destination by adding the third byte to the program counter if the specified bit tests true. The bit to be tested and its condition (set or clear) is part of the opcode. The span of branching is from -128 to +127 from the address of the next location after the branch instruction. The CPU also transfers the tested bit to the carry/borrow bit of the condition code register.

| Instruction                    | Mnemonic |
|--------------------------------|----------|
| Branch if Carry Bit Clear      | BCC      |
| Branch if Carry Bit Set        | BCS      |
| Branch if Equal                | BEQ      |
| Branch if Half-Carry Bit Clear | BHCC     |
| Branch if Half-Carry Bit Set   | BHCS     |
| Branch if Higher               | BHI      |
| Branch if Higher or Same       | BHS      |
| Branch if IRQ Pin High         | BIH      |
| Branch if IRQ Pin Low          | BIL      |
| Branch if Lower                | BLO      |
| Branch if Lower or Same        | BLS      |
| Branch if Interrupt Mask Clear | BMC      |
| Branch if Minus                | BMI      |
| Branch if Interrupt Mask Set   | BMS      |
| Branch if Not Equal            | BNE      |
| Branch if Plus                 | BPL      |
| Branch Always                  | BRA      |
| Branch if Bit Clear            | BRCLR    |
| Branch Never                   | BRN      |
| Branch if Bit Set              | BRSET    |
| Branch to Subroutine           | BSR      |
| Unconditional Jump             | JMP      |
| Jump to Subroutine             | JSR      |

#### Table 11-3. Jump and Branch Instructions



Instruction Set

| Source                                                             | Operation                            | Description                                                                                                                                                                                           |   | E<br>on | iffe<br>n C | ct<br>CR | 2 | ress<br>ode                           | ode                              | rand                             | cles                       |
|--------------------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|-------------|----------|---|---------------------------------------|----------------------------------|----------------------------------|----------------------------|
| Form                                                               | operation                            | Besonption                                                                                                                                                                                            | н | I       | Ν           | z        | С | Add                                   | odo                              | 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>INH<br>IX1<br>IX        | 34<br>44<br>54<br>64<br>74       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| 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<br>3<br>3<br>6<br>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 ll<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 11-6. Instruction Set Summary (Sheet 4 of 6)



**Electrical Specifications** 

### **12.4 Power Considerations**

The average chip-junction temperature,  $T_J$ , in °C, can be obtained from:

$$T_{J} = T_{A} + (P_{D} \times \theta_{JA})$$
(1)

where:

$$\begin{split} T_A &= \text{Ambient temperature, }^\circ\text{C} \\ \theta_{JA} &= \text{Package thermal resistance, junction to ambient, }^\circ\text{C/W} \\ P_D &= P_{INT} + P_{I/O} \\ P_{INT} &= I_{DD} \times V_{DD} \text{ watts (chip internal power)} \\ P_{I/O} &= \text{Power dissipation on input and output pins (user determined)} \end{split}$$

For most applications  $P_{I/O} \ll P_{INT}$  and can be neglected.

The following is an approximate relationship between  $P_D$  and  $T_J$  (neglecting  $P_J$ ):

$$P_{\rm D} = K \div (T_{\rm L} + 273 \,^{\circ}{\rm C})$$
 (2)

Solving equations (1) and (2) for K gives:

$$K = P_{\rm D} \times (T_{\rm A} + 273 \,^{\circ}\text{C}) + \theta_{\rm JA} \times (P_{\rm D})^2 \tag{3}$$

where K is a constant pertaining to the particular part. K can be determined from equation (3) by measuring  $P_D$  (at equilibrium) for a known  $T_A$ . Using this value of K, the values of  $P_D$  and  $T_J$  can be obtained by solving equations (1) and (2) iteratively for any value of  $T_A$ .



| $V_{DD} = 4.5 V$                              |        |        |       |
|-----------------------------------------------|--------|--------|-------|
| Pins                                          | R1     | R2     | С     |
| PA7–PA0<br>PB7–PB0<br>PC7–PC0<br>PD5–PD0, PD7 | 3.26 Ω | 2.38 Ω | 50 pF |







**Electrical Specifications** 

### 12.9 5.0-Vdc Serial Peripheral Interface Timing

| No. | Characteristic <sup>(1)</sup>                                                                                                          | Symbol                                         | Min        | Мах        | Unit                      |
|-----|----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|------------|------------|---------------------------|
|     | Operating frequency<br>Master<br>Slave                                                                                                 | f <sub>op(м)</sub><br>f <sub>op(s)</sub>       | dc<br>dc   | 0.5<br>2.1 | f <sub>op</sub><br>MHz    |
| 1   | Cycle time<br>Master<br>Slave                                                                                                          | t <sub>cyc(M)</sub><br>t <sub>cyc(s)</sub>     | 2.0<br>480 |            | t <sub>cyc</sub><br>ns    |
| 2   | Enable lead time<br>Master<br>Slave                                                                                                    | t <sub>lead(m)</sub><br>t <sub>lead(s)</sub>   | (2)<br>240 |            | ns                        |
| 3   | Enable lag time<br>Master<br>Slave                                                                                                     | t <sub>LAG(M)</sub><br>t <sub>LAG(S)</sub>     | (2)<br>720 | _          | ns                        |
| 4   | Clock (SCK) high time<br>Master<br>Slave                                                                                               | t <sub>w(scкн)м</sub><br>t <sub>w(scкн)s</sub> | 340<br>190 | _          | ns                        |
| 5   | Clock (SCK) low time<br>Master<br>Slave                                                                                                | t <sub>w(SCKL)M</sub><br>t <sub>w(SCKL)S</sub> | 340<br>190 | _          | ns                        |
| 6   | Data setup time (inputs)<br>Master<br>Slave                                                                                            | t <sub>su(м)</sub><br>t <sub>su(s)</sub>       | 100<br>100 |            | ns                        |
| 7   | Data hold time (inputs)<br>Master<br>Slave                                                                                             | t <sub>H(M)</sub><br>t <sub>H(S)</sub>         | 100<br>100 | _          | ns                        |
| 8   | Slave access time (time to data active from<br>high-impedance state)                                                                   | t <sub>A</sub>                                 | 0          | 120        | ns                        |
| 9   | Slave disable time (hold time to high-impedance state)                                                                                 | t <sub>DIS</sub>                               | _          | 240        | ns                        |
| 10  | Data valid<br>Master (before capture edge)<br>Slave (after enable edge) <sup>(3)</sup>                                                 | t <sub>V(M)</sub><br>t <sub>V(S)</sub>         | 0.25<br>—  | <br>240    | t <sub>cyc(M)</sub><br>ns |
| 11  | Data hold time (outputs)<br>Master (after capture edge)<br>slave (After Enable Edge)                                                   | t <sub>HO(M)</sub><br>t <sub>HO(S)</sub>       | 0.25<br>0  |            | t <sub>сүс(м)</sub><br>ns |
| 12  | Rise time (20% $V_{DD}$ to 70% $V_{DD}$ , $C_L$ = 200 pF)<br>SPI outputs (SCK, MOSI, and MISO)<br>SPI inputs (SCK, MOSI, MISO, and SS) | t <sub>RM</sub><br>t <sub>RS</sub>             |            | 100<br>2.0 | ns<br>μs                  |
| 13  | Fall time (70% $V_{DD}$ to 20% $V_{DD}$ , $C_L$ = 200 pF)<br>SPI outputs (SCK, MOSI, and MISO)<br>SPI inputs (SCK, MOSI, MISO, and SS) | t <sub>FM</sub><br>t <sub>FS</sub>             |            | 100<br>2.0 | ns<br>μs                  |

1.  $V_{DD}$  = 5.0 Vdc ± 10%;  $V_{SS}$  = 0 Vdc,  $T_A$  = -40 to +85°C, unless otherwise noted. Refer to Figure 12-9 and Figure 12-10. 2. Signal production depends on software. 3. Assumes 200 pF load on all SPI pins.



### 12.10 3.3- Vdc Serial Peirpheral Interface Timing

| No. | Characteristic <sup>(1)</sup>                                                                                                                                 | Symbol                                          | Min        | Max        | Unit                      |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|------------|------------|---------------------------|
|     | Operating frequency<br>Master<br>Slave                                                                                                                        | f <sub>op(M)</sub><br>f <sub>op(S)</sub>        | dc<br>dc   | 0.5<br>1.0 | f <sub>op</sub><br>MHz    |
| 1   | Cycle time<br>Master<br>Slave                                                                                                                                 | t <sub>CYC(M)</sub><br>t <sub>CYC(S)</sub>      | 2.0<br>1.0 | _          | t <sub>cγc</sub><br>μs    |
| 2   | Enable lead time<br>Master<br>Slave                                                                                                                           | t <sub>lead(m)</sub><br>t <sub>lead(s)</sub>    | (2)<br>500 | _          | ns                        |
| 3   | Enable lag time<br>Master<br>Slave                                                                                                                            | t <sub>LAG(M)</sub><br>t <sub>LAG(S)</sub>      | (2)<br>1.5 | _          | ns<br>μs                  |
| 4   | Clock (SCK) high time<br>Master<br>Slave                                                                                                                      | t <sub>w(scкн)м</sub><br>t <sub>w(scкн)</sub> s | 720<br>400 |            | ns                        |
| 5   | Clock (SCK) low time<br>Master<br>Slave                                                                                                                       | t <sub>w(scкL)м</sub><br>t <sub>w(scкL)s</sub>  | 720<br>400 | _          | ns                        |
| 6   | Data setup time (inputs)<br>Master<br>Slave                                                                                                                   | t <sub>su(M)</sub><br>t <sub>su(s)</sub>        | 200<br>200 |            | ns                        |
| 7   | Data hold time (inputs)<br>Master<br>Slave                                                                                                                    | t <sub>H(M)</sub><br>t <sub>H(S)</sub>          | 200<br>200 | _          | ns                        |
| 8   | Slave access time (time to data active from<br>high-impedance state)                                                                                          | t <sub>A</sub>                                  | 0          | 250        | ns                        |
| 9   | Slave disable time (hold time to high-impedance state)                                                                                                        | t <sub>DIS</sub>                                | _          | 500        | ns                        |
| 10  | Data valid<br>Master (before capture edge)<br>Slave (after enable edge) <sup>(3)</sup>                                                                        | t <sub>v(M)</sub><br>t <sub>v(s)</sub>          | 0.25       | <br>500    | t <sub>сүс(м)</sub><br>ns |
| 11  | Data hold time (outputs)<br>Master (after capture edge)<br>Slave (after enable edge)                                                                          | t <sub>HO(M)</sub><br>t <sub>HO(S)</sub>        | 0.25<br>0  |            | t <sub>сүс(м)</sub><br>ns |
| 12  | Rise time (20% $V_{DD}$ to 70% $V_{DD}$ , $C_L = 200 \text{ pF}$ )<br>SPI outputs (SCK, MOSI, and MISO)<br>SPI inputs (SCK, MOSI, MISO, and $\overline{SS}$ ) | t <sub>RM</sub><br>t <sub>RS</sub>              |            | 200<br>2.0 | ns<br>μs                  |
| 13  | Fall time (70% $V_{DD}$ to 20% $V_{DD}$ , $C_L$ = 200 pF)<br>SPI outputs (SCK, MOSI, and MISO)<br>SPI inputs (SCK, MOSI, MISO, and SS)                        | t <sub>FM</sub><br>t <sub>FS</sub>              |            | 200<br>2.0 | ns<br>μs                  |

1.  $V_{DD}$  = 3.3 Vdc ± 0.3 Vdc;  $V_{SS}$  = 0 Vdc,  $T_A$  = -40 to +85 °C, unless otherwise noted. Refer to Figure 12-9 and Figure 12-10. 2. Signal production depends on software. 3. Assumes 200 pF load on all SPI pins.



Mechanical Specifications

### 13.5 44-Lead Quad Flat Pack (QFP) (Case 824A-01)



Figure 13-4. 44-Lead QFP (Case 824A-01)