

# TECHNICAL UPDATE

## MC68HC05P9

Technical Update contains updates to documented information appearing in other Motorola technical documents as well as new information not covered elsewhere.

We are confident that your Motorola product will satisfy your design needs. This Technical Update and the accompanying manuals and reference documentation are designed to be helpful, informative, and easy to use.

Should your application generate a question or a problem not covered in the current documentation, please call your local Motorola distributor or sales office. Technical experts at these locations are eager to help you make the best use of your Motorola product. As appropriate, these experts will coordinate with their counterparts in the factory to answer your questions or solve your problems. To obtain the latest document, call your local Motorola sales office.

Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters can and do vary in different applications. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even in the design or manufacture of the part. Motorola and are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

# **TABLE OF CONTENTS**

## **Modules**

| CPU                                                        | 3  |
|------------------------------------------------------------|----|
| Correction to SUB in Applications Guide                    | 3  |
| External Interrupt Timing                                  |    |
| I Bit in CCR During Stop Mode                              | 4  |
| BSET and BCLR are Read-Modify-Write Instructions           | 4  |
| I Bit in CCR During Wait Mode                              | 5  |
| Stop Mode Application Example                              | 5  |
| Computer Operating Properly (COP)                          | 8  |
| COP Timeout Period                                         | 8  |
| Serial Input/Output Port (SIOP)                            | 9  |
| SIOP Applications Example                                  | 9  |
| SIOP Pin Functions                                         | 11 |
| Timer                                                      | 12 |
| Input Capture/Output Compare Code Snippet                  | 12 |
| Interrupt-Driven Output Compare Code                       |    |
| Input Capture Test                                         | 16 |
| Analog to Digital                                          | 19 |
| A/D Example Code                                           | 19 |
| A/D Converter Source Impedance                             | 21 |
| A/D Accuracy Specification                                 | 22 |
| Part Specific                                              |    |
| Control Specification Error                                | 23 |
| SDO Upon Enable of SIOP                                    | 23 |
| Impedance of I/O Pins at Reset                             | 24 |
| Mask Set Errata 1 Serial Input/Output Port (SIOP)          | 25 |
| Port C and Analog-to-Digital Converter                     | 26 |
| I <sub>DD</sub> Specificiations                            | 27 |
| Mask Set Errata                                            | 28 |
| Mask Set Errata 1 to MC68HC05P9 8-Bit Microcontroller Unit | 28 |

## **TECHNICAL UPDATE**

## **Modules**

### **CPU**

#### HC05CPU

#### **Revision History**

| Date   | Revision | Description                                                                                           |
|--------|----------|-------------------------------------------------------------------------------------------------------|
| 8/7/95 | 2.00     | Includes trackers HC05CPU.001, HC705C8.002R2, HC705C8.017, HC705C8.018R2, HC705C8.019 and HC05P4.002. |

### **Correction to SUB in Applications Guide**

Reference Documents: M68HC05 Applications Guide MC68HC05AG/AD, page A-62; M68HC05 Applications Guide MC68HC05AG/AD Rev. 1, page A-62

Tracker Number: HC05CPU.001 Revision: 1.00

Replace the C bit description with:

The C bit (carry flag) in the condition code register gets set if the absolute value of the contents of memory is larger than the absolute value of the accumulator, cleared otherwise.

MOTOROLA Modules

### **External Interrupt Timing**

Reference Documents: MC68HC705C8/D Rev. 1, page 3-5; MC68HC05B6/D, Rev. 3, page 11-11, note 4; MC68HC705C8/D, Rev. 1, page 3-5; MC68HC05C9/D, page 13-7, note 3; MC68HC05C12/D, page 13-9, note 4; MC68HC05D9/D, Rev. 1, page 10-4, note 1; MC68HC05J3/D, page 9-6, note 3; and MC68HC05X16/D, page 12-6, note 4

Tracker Number: HC705C8.002 Revision: 2.00

This time  $(t_{ILIL})$  is obtained by adding 19 instruction cycles to the total number of cycles needed to complete the service routine. The return to interrupt (RTI) is included in the 19 cycles.

## I Bit in CCR During Stop Mode

Reference Document: M68HC05 Applications Guide, page 3-93

Tracker Number: HC705C8.017 Revision: 1.00

The stop mode flow chart shows that the I bit is set when stop mode is entered. However, this is not true. The I bit actually is cleared when stop mode is entered so that an external IRQ may release the processor from stop mode.

This error is present in the original applications guide as well as the revision.

## **BSET and BCLR are Read-Modify-Write Instructions**

Reference Documents: MC68HC705C8/D Rev. 1, page 7-6; MC68HC05J1/D Rev. 1, page 5-7; MC68HC05J3/D, page 8-4; MC68HC705J2/D, page 4-16; HC05J3/705J3 Technical Data - MC68HC05J3/D, page 8-6; MC68HC05K1/D, page 10-10; MC68HC705K1/D, page 11-10; MC68HC05P8/D, page 4-15

Tracker Number: HC705C8.018 Revision: 2.00

In many data books, the read-modify-write instruction table located in the instruction set and addressing mode section does not list the BSET and BCLR instructions. These data books list BSET and BCLR as bit-manipulation instructions only.

While this is correct, it is not complete. These operations use a read-modify-write method to accomplish their task and, therefore, should be included in the table of read-modify-write instructions.

NOTE: These instructions do not use the same addressing modes as the other read-modify-write instructions. Only direct addressing is valid for BSET and BCLR.

Because BSET and BCLR are read-modify-write instructions, they may not be used with write-only registers. These registers will read back undefined data. Therefore, a readmodify-write operation will read undefined data, modify it as appropriate, and then write it back to the register. Because the original data is undefined, the data written back will be undefined also.

#### I Bit in CCR During Wait Mode

Reference Document: M68HC05 Applications Guide, page 3-93

Tracker Number: HC705C8.019 Revision: 1.00

The wait mode flow chart does not show that the I bit gets cleared upon entering wait mode. The I bit is cleared when wait is entered. An external IRQ or any of the internal interrupts (timer, SCI, SPI) can release the processor from wait mode.

This error is present in the original applications guide as well as the revision.

## **Stop Mode Application Example**

Reference Document: MC68HC05P4/D, page 3-24

Tracker Number: HC05P4.002 Revision: 1.00

```
STOP program example for HC05P4
          *****************
* Program Name: STOPP4.ASM
* Date: 12/16/91
* Written By: Robert Chretien & David Yoder
          Motorola CMCU Applications
* Assembled Under: P&E Microcomputer Systems, Inc. IASM05
```

**MOTOROLA** Modules

```
* Program Description:
            This program shows how to use the MC68HC705P9 STOP
            instruction. It is meant to be used in a stand a lone mode,
            or with an appropriate evaluation/emulation system.
            Upon executing the program, PAO will toggle. When PA1
            is pulled high, the MCU will enter STOP mode and PAO
            will cease to toggle.
            An external reset or an event on IRQ will cause the MCU
            to exit from stop mode.
              START
               Toggle
                PA0
           n / PA1
              High ? >
                 | У
              STOP
* Revision Descriptions:
* Rev 1.0: Original program.
* Rev 2.0: Discaimer added
* MCU Equates
PortA equ $0000
PortB equ $0001
DDRA equ $0004
DDRB equ $0005
**********
* Interrupt vectors
***********
       org
            $1FF8
      fdb TRAP
TIMER
      fdb IRQISR
IRO
SWI
       fdb TRAP
RESET
      fdb START
```

MOTOROLA

```
*********
* Start
* Main Loop of code
**********
ORG $0180
Start LDA #$01
STA DDRA
                            ; Begin code in EPROM
                            ; Set port AO to output, leave
Toggle LDA PORTA ; Toggle port AO. This will toggle EOR #%00000001 ; while the code is running.

STA PORTA ; This will stop toggling when STOP mode ; mode is entered. When STOP mode
                            ; is exited with IRQ or RESET, this
                             ; will resume toggling.
             PORTA
       LDA
                            ; See if PA1 has been pulled high
       AND
                            ; If not, branch to TOGGLE to toggle
             #$02
       BEQ
              TOGGLE
                            ; PAO again.
                             ; If so, enter STOP mode.
       STOP
                             ; Enter STOP mode.
                             ; This will:
                                Clear interrupt flag in status
                                 register - no need to do CLI for
                                 IRQ to exit from STOP
                               Disable the oscilltor - you will
                               see OSC2 stop toggling when STOP
                                 mode is successfully entered.
       BRA
              TOGGLE
                             ; Stay in main loop toggling
*********
**********
* Service routine for
* external interrupts
* Does nothing, only returns to
* main routine.
IROISR:
      RTT
*********
* Routine for unused interrupts
* Traps in a branch to self
**********
TRAP BRA TRAP ; Trap interrupts
```

END

## **Computer Operating Properly (COP)**

#### COPOCOP A

#### **Revision History**

| Date   | Revision | Description                  |
|--------|----------|------------------------------|
| 8/4/95 | 1.00     | Includes tracker HC705P6.012 |

#### **COP Timeout Period**

Reference Document: HC05C4AGRS/D Rev 1.2; HC05C5GRS/D Rev 1.2; HC705C5GRS/D Rev 1.3, page 49; MC68HC705C8AD/D Rev 4.0, page 14 (705C4A); MC68HC705C8AD/D Rev 4.0, page 31 (705C8A); MC68HC705C8AD/D Rev. 4.0, page 51 (HSC705C8A); MC68HC05C12/D; HC05P1AGRS/D Rev. 1.3; MC68HC05P4/D, page 4-2; HC05P5GRS/D Rev. 1.3; MC68HC05P7/D, page 4-2; HC05P15GRS/D Rev. 0.0, page 33; HC05P18GRS/D Rev. 0.5, page 12

Tracker Number: HC705P6.012 Revision: 1.00

The timeout period for the COP0COP\_A computer operating properly watchdog timer is a direct function of the crystal frequency. The equation is:

For example, the timeout period for a 4-MHz crystal is 65.536 ms.

## **Serial Input/Output Port (SIOP)**

#### SIOP\_A

#### **Revision History**

| Date   | Revision | Description                                      |
|--------|----------|--------------------------------------------------|
| 8/4/95 | 1.00     | Includes trackers HC705P9.008R2 and HC705P9.015. |

### **SIOP Applications Example**

Reference Document: MC68HC705P9/D, page 9-1

Tracker Number: HC705P9.008 Revision: 2.00

SIOP program example for HC705P9

\* Program Name: SIOPP9.ASM

\* Date: 12/12/91

\* Written By: Robert Chretien

Motorola CMCU Applications

\* Assembled Under: P&E Microcomputer Systems, Inc. IASM05

\* Program Description:

This was written for the timer module SIOP\_A and tested on the HC705P9. In order to use this with other HC05 MCU's, reset vectors and memory map equates may have to be changed. See the Technical Databook for the appropriate part for this memory map information.

This program shows how to use the basics of the MC68HC705P9 SIOP subsystem. It is meant to be used in a stand alone mode, or with an appropriate evaluation/emulation system.

This program writes constant data out the SIOP and ignores any data that may be transferred in.

```
* Revision Descriptions:
* 1. Rev 0.00: Original program.
* 2. Rev 1.00: Documentation touchup. David Yoder 6/14/93
* 3. Rev 2.00: Reduced cycle count. David Yoder 6/17/93
******************
    ***********************
SDR
                $000C
          equ
                $000A
SCR
          equ
                $000B
SSR
          equ
          org
                $0180
               #$50
start
          lda
                SCR
                              ; Enable the SIOP system in master mode.
          sta
                              ; Load the status register so that writing
          lda
               SSR
                              ; to the data register will clear the
                              ; complete flag (SPIF).
send
          lda
                #$AA
                              ; Send $AA out of the SIOP. Writing to
          sta
               SDR
                              ; SDR initiates the transfer and clears
                              ; the complete flag (SPIF).
                              ; To view output (SDO) and/or SCK adjust
                              ; scope for 2usec horizontal resolution.
chkflag
          lda
                SSR
                              ; Load status register and test bit 7
                              ; (SPIF) to see if transfer is complete.
          and
                #$80
          bea
                chkflag
                              ; If SIOP transfer is not finished, reload
                              ; status register.
*flagset
           lda
                SSR
                              ; Uncomment these instructions in order to
           bra
                              ; view the status register after the
                              ; transfer is complete. Just hit abort and
                              ; the value of the status register will be
                              ; left in the accumulator.
                              ; Branch in order to send another byte.
          bra
                send
          org
                $1FFE
          fdb
                start
                              ; Reset vector
```

end

### **SIOP Pin Functions**

Reference Document: MC68HC705P9 Technical Data book Rev. 1,

page 9-2

Tracker Number: HC705P9.015 Revision: 1.00

When the serial input/output port (SIOP) is enabled and then disabled, data values in the port B data register and port B data direction register are changed. This occurs because the SIOP uses these two registers. Operation of both the master and slave modes of the SIOP have this effect.

### **Timer**

#### TIM1IC1OC

#### **Revision History**

| Date   | Revision | Description                                                      |
|--------|----------|------------------------------------------------------------------|
| 8/4/95 | 1.00     | Includes trackers HC05C4.002R2, HC05C4.003R2, and HC705P9.005R3. |

### **Input Capture/Output Compare Code Snippet**

**Reference Document: Not applicable** 

Tracker Number: HC05C4.002 Revision: 2.00

```
*******************
      Program Name: ICOCC4.ASM
      Revision: 1.0
      Date: 9/6/93
      Written By: Mark Johnson
               Motorola CSIC Applications
      Assembled Under: P&E Microcomputer Systems
                    IASM05 Version 3.02m
               * Revision History *
      Revision 1.00 9/1/93 Original Release
        2.00 Memory map disclaimer added
******************
      Program Description:
      This was written for the timer module {\tt TIMlIC1OC\_A} and tested
       on the HC05C4. In order to use this with other HC05 MCU's,
       reset vectors and memory map equates may have to be changed.
       See the Technical Databook for the appropriate part for this
       memory map information.
```

```
This simple program was written to demonstrate the input
       capture and output compare functions of the MC68HC(8)05C4
       timer. The routine generates a level transition on port A
       which is fed into the input capture pin (TCAP). When
       the input capture occurs an offset of 50us is added to
       value in the input capture registers and stored in the
       output compare registers. The output compare generates
       a level transition on the TCMP pin and then the entire
       process is repeated.
       The program was run on the M68HC05EVM using the
       following setup conditions:
       1) HC705C8 Resident Processor
       2) Fop = 2MHz
       3) Pin 11 (PAO) on target header J19 jumpered to pin
          37 (TCAP).
       4) The user should see a level transition on the
          TCMP pin approximately* 50us after the level
          transition on port A.
   *NOTE: The level transition on the TCMP pin will occur at
          50us + 1 count of the free-running counter = 52us.
          This is the result of an internal synchronization
          delay which occurs during an input capture.
          ( 1 count = 4 internal bus cycles)
*******************
       Register Equates
```

| *        |          |      |                                  |
|----------|----------|------|----------------------------------|
| porta    | equ      | \$00 | ;port A data register            |
| ddra     | equ      | \$04 | ;port A data dir. reg.           |
| tcr      | equ      | \$12 | timer control register;          |
| tsr      | equ      | \$13 | timer status register;           |
| inpcaph  | equ      | \$14 | ;input capture (MSB)             |
| inpcapl  | equ      | \$15 | ;input capture (LSB)             |
| outcomph | equ      | \$16 | ;output compare (MSB)            |
| outcompl | equ      | \$17 | <pre>;output compare (LSB)</pre> |
| *        |          |      |                                  |
| * RAM V  | ariables |      |                                  |

|       | org | \$50 | ;RAM address | space        |
|-------|-----|------|--------------|--------------|
| templ | rmb | 1    | ;storage for | O/C low byte |
| *     |     |      |              |              |

Beginning of main routine

| * |  |  |
|---|--|--|
|   |  |  |

| start | org<br>lda  | \$200<br>#\$ff | ;EPROM/ROM address space                     |
|-------|-------------|----------------|----------------------------------------------|
|       | sta<br>clra | ddra           | ;all port A pins are outputs                 |
|       | sta<br>lda  | porta<br>#3    | output a low on port A                       |
|       | sta         | tcr            | ;IEDG = positive edge<br>;OLVL = high output |

| loop | lda              | tsr      | read timer status register;     |
|------|------------------|----------|---------------------------------|
|      | lda              | outcompl | ;clear OCF                      |
|      | com              | porta    | ;toggle port A                  |
|      | lda              | #!25     | ;I/C low byte offset            |
|      | add              | inpcapl  | add I/C low byte value          |
|      | sta              | templ    | ;save new value in temp storage |
|      | lda              | inpcaph  | get high byte of I/C reg.       |
|      | adc              | #0       | ;add carry from last addition   |
|      | sta              | outcomph | store value to O/C high byte    |
|      | lda              | templ    | get low byte offset;            |
|      | sta              | outcompl | store value in O/C low byte     |
|      | lda              | inpcapl  | enable input captures;          |
|      | brclr            | 6,tsr,*  | ;wait for output compare        |
|      | lda              | tcr      | get Timer Control Register;     |
|      | eor              | #3       | toggle IEDG and OLVL;           |
|      | sta              | tcr      | store new IEDG and OLVL values  |
|      | bra              | loop     | repeat process indefinitely     |
| *    |                  |          |                                 |
| * I  | Reset vector set | up       |                                 |
| *    |                  |          |                                 |
|      | org              | \$1ffe   |                                 |
|      | fdb              | start    |                                 |

## **Interrupt-Driven Output Compare Code**

Reference Document: MC68HC05C4/D (ADI-991-R2), page 4-7

Tracker Number: HC05C4.003 Revision: 2.00

The following code listing shows the procedure of using the output compare function driven by an interrupt to produce a square wave.

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

```
* Program Description:
       This was written for the timer module TIM1IC10C_A and tested
         on the HC05C4. In order to use this with other HC05 MCU's,
         reset vectors and memory map equates may have to be changed.
         See the Technical Databook for the appropriate part for this
         memory map information.
       This program uses the Output Compare function of the
         timer to generate a square wave. The output compare
         interrupt is utilized to take care of adding the
         appropriate value to the 16 bit output compare
         register to create the square wave. With some
         modification, this routine can perform pulse width
         modulation.
       Use the HC705C8 resident MCU on the HC05EVM to
         run this test.
       Download the program.
       Make sure the PC is at $1000. Type GO.
       OR, hit USER RESET on the EVM.
       Look at pin #35 of header J19. This is the Timer
         Compare Output pin (TCMP) of the timer. You should
         see a 3.906kHz square wave on this pin with a
         256 usec period.
       Press ABORT on the EVM to halt program execution.
*******************
***
       Equates for 705C8
TCR
       equ
               $12
                                       ;timer ctrl reg
TSR
               $13
                                      ;timer status req
       eau
OCH
       equ
               $16
                                      ;output compare high reg
OCL
       equ
               $17
                                      ;output compare low req
TCH
       equ
               $18
                                      ;timer counter high reg
               $19
                                      ;timer counter low reg
TCL
       equ
TEMP
               $50
                                      ;temp loc for OCL
       equ
***
       Start of program
               $1000
                                      ;start of user code
       org
START
       lda
                                      ;output compare interrupt
               #$41
                                      ; enabled, output level 0
               TCR
                                      ;store to timer ctrl reg
       sta
                                      ; clear the I bit in CCR
       cli
DUMLOOP bra
               DUMLOOP
                                       ;dummy loop waiting for
                                       ; timer interrupt
***
       Interrupt Service Routine
OCISR
       lda
               TSR
                                      ;read timer status
                                       ; to clear flag
       Flip the OLVL bit in the TCR reg
       lda
            TCR
                                      ;load ACCA w/ TCR
       eor
               #$01
                                       ;flip bit 0 of ACCA
                                      ;store ACCA to TCR
               TCR
       sta
```

```
Add 64 counts to timer counter req
With a 2 MHz internal bus clock, the timer count
 period is 2 usec. 64 counts of the timer counter
 will produce a square wave half cycle of 128 usecs.
lda
                               ;load #$40 into acca
       #$40
add
       OCL
                               ;add OCL to ACCA
sta
       TEMP
                              ;store res to temp loc
lda
       #$00
                              ;add $00 to out comp hi
adc
       OCH
                              ; with carry
sta
       OCH
                              ;store res to out comp hi
lda
       TEMP
                               ;store temp to out
sta
       OCL
                               ; comp low
rti
                               ;return from interrupt
Set up vectors
       $1FF8
                             ;define timer
       OCISR
                               ; interrupt vector
dw
org
       $1FFE
                               ;define reset vector
dw
       START
```

### **Input Capture Test**

**Reference Document: Not applicable** 

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

Tracker Number: HC705P9.005 Revision: 3.00

```
* Program Name: P9_INCAP.ASM ( Input Capture Test for the P9EVS )
* Revision: 1.00
* Date: June 7, 1993
* Written By: Mark Glenewinkel
           Motorola CSIC Applications
* Assembled Under: P&E Microcomputer Systems IASM05
      *********
           Revision History
      *********
      Rev 1.00 06/07/93 M.R. Glenewinkel
                    Initial Release
             2.00
                   Docmentation
             3.00
                   Memory map note added
******************
* Program Description:
      This was written for the timer module TIM1IC1OC A and tested
       on the HC705P9. In order to use this with other HC05 MCU's,
        reset vectors and memory map equates may have to be changed.
        See the Technical Databook for the appropriate part for this
        memory map information.
```

```
Tests the Input capture pin.
       Use the HC705P9 resident MCU on the HC05P9EVS to
         run this test.
       Jumper pins PAO and PD7/TCAP on Target Header P4.
       We will use Port A, bit 0 to toggle the TCAP pin.
       Download the program.
       Make sure the PC is at $100.
       Type GO.
       ABORT the program and look at locations $80-$83.
         After the first Input Capture, the Input Capture
         Registers High and Low are loaded into RAM
         location \$80 and \$81, respectively. After the
         second Input Capture, the Input Capture Registers
         High and Low are loaded into RAM location $82
         and $83, respectively.
       If you trace this program, the Input capture
         flag will look like its not being set when you
         view with the emulator software. Remember, the
         flag gets cleared when a read of ICL and TSR occurs.
         The emulator software does this automatically when
         reading those locations to display in the
         emulator window.
*******************
***
       Equates
PORTA
       EQU
               $00
               $01
PORTB
      EQU
               $02
PORTC
      EQU
DDRA
       EQU
               $04
DDRB
       EQU
               $05
DDRC
       EQU
               $06
DDRD
       EQU
               $07
TCR
       EQU
               $12
TSR
       EOU
               $13
ICRH
       EQU
               $14
ICRL
       EQU
               $15
TEMP1
       EQU
               $0080
TEMP2
       EQU
               $0081
TEMP3
       EQU
               $0082
TEMP4
       EQU
               $0083
```

| ***   | Start o                  | f code                         |                                                                                               |
|-------|--------------------------|--------------------------------|-----------------------------------------------------------------------------------------------|
|       | ORG                      | \$0100                         | start of program                                                                              |
| START | LDA<br>STA<br>LDA        | #\$FF<br>PORTA<br>#\$00        | ;PortA is \$FF                                                                                |
|       | STA<br>LDA               | DDRD<br>#\$FF                  | ;PortD is input                                                                               |
|       | STA<br>STA<br>LDA        | DDRA<br>DDRC<br>#\$00          | ;PortA is output                                                                              |
|       | STA<br>LDA<br>LDA        | TCR<br>TSR<br>ICRL             | <pre>;set InCap to fall edge ;look at tsr ;look at input reg low ;this clears any flags</pre> |
|       | LDA<br>STA               | #\$00<br>PORTA                 | ;falling edge created<br>; on PortD/TCAP                                                      |
| LOOP  | LDA<br>AND<br>BEQ        | TSR<br>#\$80<br>LOOP           | <pre>;wait in loop for flag ; to be set</pre>                                                 |
|       | LDA<br>STA<br>LDA<br>STA | ICRH<br>TEMP1<br>ICRL<br>TEMP2 | <pre>;write counter values ;in memory</pre>                                                   |
|       | LDA<br>STA               | #\$02<br>TCR                   | ;set InCap to rising edge                                                                     |
|       | LDA<br>STA               | #\$FF<br>PORTA                 | rising edge created; on PortD/TCAP                                                            |
| LOOP2 | LDA<br>AND<br>BEQ        | TSR<br>#\$80<br>LOOP2          | ;wait in loop for flag<br>; to be set                                                         |
|       | LDA<br>STA<br>LDA<br>STA | ICRH<br>TEMP3<br>ICRL<br>TEMP4 | <pre>;write counter values ;in memory</pre>                                                   |
| LOOP3 | NOP<br>BRA               | LOOP3                          |                                                                                               |

## Analog to Digital

#### ATD4X8NVRL A

#### **Revision History**

| Date   | Revision | Description                                                 |
|--------|----------|-------------------------------------------------------------|
| 7/7/95 | 1.00     | Includes trackers HC05P6.005, HC705P9.002, and HC705P9.010. |

### A/D Example Code

Reference Document: MC68HC05P6/D, page 10-1

Tracker Number: HC05P6.005 Revision: 1.00

The following code shows a simple routine that will read ANO of the A/D converter. Port C bit 6 is the A/D converter input AN0. The code was tested on an M68HC05P9EVS evaluation system. It is assumed the reader is familiar with the IASM05 assembler and the EVM05 debugger from P&E Microcomputer Systems. These P&E software programs are used to assemble, download, and run the code. If the reader is unfamiliar with emulating the HC05P6 on the P9EVS, consult the P9EVS user's manual, M68HC05P9EVS/D1, for that system.

This code was tested on the HC05P6 but can be used on other parts that have the ATD4X8NVRL\_A module. Due to differences in memory maps, equates and orgs for RAM, EPROM and RESET vectors may need to be changed. Consult the applicable MCU data book for specific part information.

Assemble the following lines of code.

| ****<br>ADSCR<br>ADDR | Equates<br>EQU<br>EQU    | \$1E<br>\$1D                     | ;a/d status and ctrl reg;a/d data reg                                      |
|-----------------------|--------------------------|----------------------------------|----------------------------------------------------------------------------|
|                       | ORG                      | \$100                            | start of program                                                           |
| START                 | LDA<br>STA               | #\$20<br>ADSCR                   | turn on the a/d converter;                                                 |
| WAIT                  | LDA<br>DECA<br>BNE       | #33T<br>WAIT                     | <pre>;execute loop for 100 usecs ; so a/d can warm up</pre>                |
| CHCK                  | LDA<br>STA<br>LDA<br>AND | #\$20<br>ADSCR<br>ADSCR<br>#\$80 | <pre>;start a conversion ;check if conversion ; complete flag (COCO)</pre> |

**MOTOROLA** Modules

|      | BNE       | CHCK             | ; is set                                   |
|------|-----------|------------------|--------------------------------------------|
|      | LDA       | ADDR             | ;when conversion done ; put answer in ACCA |
| LOOP | BRA       | LOOP             | ;loop forever                              |
|      | ORG<br>DW | \$1FFE<br>\$0100 | define reset vector                        |

The connections needed for this routine are:



The  $V_{RH}$  is connected to +5 volts. The HC05P6 does not have a low voltage reference for its A/D. The  $V_{RL}$  is connected to the chip's  $V_{SS}$ . Connect the GND pin of the voltage divider potential to  $V_{SS}$ . The potential will vary the voltage between  $V_{RH}$  and  $V_{SS}$ . This voltage is also fed into the converter channel AN0.

To predict what the A/D converter will read, use this relationship:

Run the code by using these steps:

- 1. Download the code into the EVS with the EVM05 software.
- 2. Set the program counter to \$100.
- 3. 'PC 100'
- 4. Type 'GO'
- 5. The routine will run and eventually hit the infinite loop. Press the ABORT button on the EVS to get out of the loop.
- 6. The A/D reading is in accumulator A, which is shown on the EVM05 screen.

Various voltage inputs with their appropriate A/D readings:

- 1. 0.0 V --> \$00
- 2. 1.0 V --> \$33
- 3. 2.5 V --> \$80
- 4. 4.0 V --> \$CC
- 5. 5.0 V --> \$FF

The reading may be off by a couple of least significant bits (LSB) due to system noise.

### A/D Converter Source Impedance

Reference Documents: MC68HC705P9 Rev. 1, page 3-8; MC68HC05P6, page 13-7; MC68HC705P6 Rev. 1, page 13-7; MC68HC05P9, page 10-7; MC68HC705P9 Rev. 1, page 13-8

Tracker Number: HC705P9.002 Revision: 1.00

Note 3 in the data books states:

3. Source impedances greater than 10  $k\Omega$  adversely affect internal RC charging time during input sampling.

The A/D converter on the HC705P9 is a successive approximation converter. Thirty-two cycles are necessary for the A/D to execute one conversion. The first 12 cycles sample the voltage on the A/D input pin by charging an internal capacitor. During the last 20 cycles, a comparator successively compares the output of an internal D/A converter to the sampled analog input. Control logic changes the D/A converter value bit by bit until the D/A value and the sampled input match.

Note 3 refers to the first 12 cycles of the conversion process. If the source impedance is larger than 10 k $\Omega$ , more time will be needed for the internal RC charging of the capacitor to reach the voltage on the A/D input. The higher source impedance will affect A/D accuracy.

### A/D Accuracy Specification

Reference Documents: MC68HC705P9, page 13-8; MC68HC05P6, page 13-7; MC68HC705P6 Rev. 1, page 13-7; MC68HC05P9, page 10-7; MC68HC705P9 Rev. 1, page 13-8

Tracker Number: HC705P9.010 Revision: 2.00

The A/D converter's accuracy specification has caused some confusion because of differing ways it can be interpreted.

The specification currently states:

Characteristic Min Max Unit

Absolute Accuracy  $(4.0 > V > V_{DD})$  (Note 2) - +/- 1-1/2 LSB

The correct reading is "plus or minus 1.5 LSBs."

However, some customers incorrectly read this as "plus or minus 1.0 LSB down to 0.5 LSBs."

## Part Specific

#### **Revision History**

| Date   | Revision | Description                                                                                               |
|--------|----------|-----------------------------------------------------------------------------------------------------------|
| 8/4/95 | 1.00     | Includes trackers HC05P9.001, HC05P9.002, HC05P9.004, HC05P9.006, HC05P9.008, HC05P9.012, and HC05P9mse1. |

## **Control Specification Error**

Reference Document: MC68HC05P9 Technical Data book, MC68HC05P9/

D, page10-8

Tracker Number: HC05P9.001 Revision: 1.00

Figure 10-6 TCAP Timing on page 10-8 of the *MC68HC05P9 Technical Data* book has a misprint on one of the timing parameter names.

The parameter labeled as t<sub>TLTL</sub> should be changed to the correct label t<sub>ILIL</sub>.

#### **SDO Upon Enable of SIOP**

Reference Document: MC68HC05P9 Technical Data book,

MC68HC05P9/D, page 7-4

Tracker Number: HC05P9.002 Revision: 1.00

In the SIOP data output entry on this page, the opening sentence reads: "The SDO pin becomes a serial output and goes to a logical one as soon as the SIOP is enabled." While this is a true statement, several qualifications are necessary.

For this to occur, the SIOP system must not have been used since the preceeding RESET of the MCU. In the event that the SIOP system has been used, the SDO pin will be driven to the state of the last bit that was transmitted. This can be either the LSB or MSB, depending on the mask option that was selected at order placement concerning LSB first or MSB first transmission.

Also, the SCK pin must be pulled high during reset and remain high afterward. If the SCK is not pulled high during reset or falls low after reset, SDO will output an unknown when SIOP is enabled for the first time. After the first transmission, SDO will act as described above.

## Impedance of I/O Pins at Reset

Reference Document: MC68HC05P9 Technical Data book, MC68HC05P9/

D, page 4-1

Tracker Number: HC05P9.004 Revision: 1.00

The bidirectional input/output (I/O) pins of the MC68HC05P9 will go into a high impedance state immediately when the reset line goes low or a power-on reset occurs.

For the pins to go to the high-impedance state, the presence of a clock is not necessary.

## Mask Set Errata 1 Serial Input/Output Port (SIOP)

#### Affected parts:

- MC68HC05P9
- C28W
- MC68HC705P9
- D54E
- MC68HC05P7
- C75G
- MC68HC05P4
- D25A

A design flaw has been identified that affects only the first transmission after enabling the SIOP (serial input-output port) in master mode on the above listed parts. Subsequent transmissions from the SIOP are correct.

This error is caused by a delay between the SIOP enable signal and the master mode signal. If the SPE and MSTR bits are set with the same write instruction, the master mode signal takes longer to settle, causing the SIOP to be enabled in slave mode before the SIOP recognizes it is supposed to be in master mode.

In this short time period, the SCK signal is propagated throughout the SIOP logic. When the master mode signal finally is recognized, the SCK line is pulled high. If the state of the SCK line was low initially before enabling the SIOP, then the SIOP logic will recognize a transition from zero to one on the SCK line and transmit one bit. When the next transmission is made, which is the first true transmission by the user, a data collision will result because a transmission already has been started by the previous SCK transition. Also note that the first transmission has only seven low-to-high transitions of SCK.

To avoid this problem, the user has two choices:

1. The master bit can be set first, and then the SIOP enabled in a subsequent write statement. An example is:

bset 4,\$0A bset 6,\$0A

2. The SCK line also can be pulled high when the SIOP system is enabled. This can be done by a pullup or by making PB7/SCK an output and setting it high. The pullup, however, does not cover the possibility that the pin is an output driving a low signal immediately before the SIOP is enabled in master mode. If PB7/SCK is held high, the SPE and MSTR bits may be set at the same time, as shown here:

> #\$90 lda \$0A sta

## Port C and Analog-to-Digital Converter

Reference Document: MC68HC05P9 Technical Data book, MC68HC05P9/

D, page 2-7

Tracker Number: HC05P9.008 Revision: 1.00

When the analog-to-digital (A/D) converter is enabled, pins PC3 through PC6 become analog inputs. Any unused analog inputs can be used as digital inputs. However, they cannot be used as digital output pins. Only pins PC0 through PC2 can be used as digital output pins when the A/D converter is enabled.

**MOTOROLA** Modules

## I<sub>DD</sub> Specifications

Reference Document: MC68HC05P9 Technical Data book, MC68HC05P9/

D, pages 10-3 and 10-4

Tracker Number: HC05P9.012 Revision: 1.00

These are the  $I_{DD}$  specs for the HC05P9.

| Characteristic                                     | Тур  | Max   | Unit |
|----------------------------------------------------|------|-------|------|
| f <sub>op</sub> = 2.0 MHz V <sub>DD</sub> = 5.5 V  |      |       |      |
| Supply Current                                     |      |       |      |
| Run                                                | 3.1  | 6.5   | mA   |
| Wait (A/D ON)                                      | 1.2  | 2.9   | mA   |
| Wait (A/D OFF)                                     | 0.55 | 1.9   | mA   |
| Stop                                               |      |       |      |
| 0–90 °C                                            | 3.0  | 50.0  | μΑ   |
| 0–125 °C                                           | 11.0 | 100.0 | μΑ   |
| $f_{op} = 2.0 \text{ MHz}  V_{DD} = 5.5 \text{ V}$ |      |       |      |
| Supply Current                                     |      |       |      |
| Run                                                | 1.0  | 2.3   | mA   |
| Wait (A/D ON)                                      | .55  | 1.3   | mA   |
| Wait (A/D OFF)                                     | 140. | 600   | μΑ   |
| Stop                                               |      |       |      |
| 0–90 °C                                            | 1.0  | 40    | μΑ   |
| 0–125 °C                                           | 5.0  | 50    | μA   |

## Mask Set Errata 1 MC68HC05P9 8-Bit Microcontroller Unit

This errata provides information pertaining to the serial input-output port (SIOP) master mode initial faulty transmission applicable to the following MC68HC05P9 MCU mask set device:

2C28W

#### MCU DEVICE MASK SET IDENTIFICATION

The mask set is identified by a 4-character code consisting of a letter, two numerical digits, and a letter (for instance, C28W). Slight variations to the mask set identification code may result in an optional numerical digit preceding the standard 4-character code (for instance, 2C28W).

#### MCU DEVICE DATE CODES

Device markings indicate the week of manufacture and the mask set used. The data is coded as four numerical digits where the first two digits indicate the year and the last two digits indicate the work week. The date code "9115" would indicate the 15th week of the year 1991.

#### MCU DEVICE PART NUMBER PREFIXES

Some MCU samples and devices are marked with an "SC" or "XC" prefix. An "SC" prefix denotes special/custom device. An "XC" prefix denotes that the device is tested but is not fully characterized or qualified over the full range of normal manufacturing process variations. After full characterization and qualification, devices will be marked with the "MC" prefix.

Whenever contacting a Motorola representative for assistance, please have the MCU device mask set and date code information available.

Specifications and information herein are subject to change without notice.

#### SIOP MASTER MODE INITIAL FAULTY TRANSMISSION

A design flaw has been identified that affects only the first transmission after enabling the SIOP in the master mode. Subsequent transmissions from the SIOP are correct.

This error is caused by a delay between the serial port enable (SPE) and the master mode select (MSTR) bits in the SIOP control register. If the SPE and MSTR bits are set with the same write instruction, a race condition occurs in the SIOP logic. This race condition causes the SIOP to be enabled in the slave mode before recognizing the setting of the MSTR bit. In this short period of time, the serial clock (SCK) signal is propagated throughout the SIOP logic. When the MSTR bit is finally recognized, the SCK line is pulled high. If the state of the SCK line was initially low before enabling the SIOP, then the SIOP logic will recognize a low (zero) to high (one) transition on the SCK line and transmit one bit. When the next transmission is made, which is the first true transmission by the user, a data collision will result because a transmission has already been started by the previous SCK transition. The user may also notice that the first transmission has only 7 low to high SCK transitions.

One of two things may be done to avoid this problem. The MSTR bit can be set first, and then the SIOP enabled in a subsequent write operation. An example is:

bset 4,\$0A bset 6,\$0A

The SCK line may also be pulled high when the SIOP is enabled. This may be done by a pull-up device or by making PB7/SCK an output line and setting it high. The pull-up device, however, does not cover the possibility of the pin being an output line driving a low signal immediately before the SIOP is enabled in the master mode. If PB7/SCK line is held high, the SPE and MSTR bits may be set at the same time, as shown below:

lda #\$90 sta \$0A

Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters can and do vary in different applications. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part. Motorola and μ are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

#### Literature Distribution Centers:

USA: Motorola Literature Distribution; P.O. Box 20912; Phoenix, Arizona 85036.

EUROPE: Motorola Ltd.; European Literature Centre; 88 Tanners Drive, Blakelands, Milton Keynes, MK14 5BP, England.

JAPAN: Nippon Motorola Ltd.; 4-32-1, Nishi-Gotanda, Shinagawa-ku, Tokyo 141 Japan.

ASIA-PACIFIC: Motorola Semiconductors H.K. Ltd.; Silicon Harbour Center, No.2 Dai King Street, Tai Po Industrial Estate, Tai Po, N.T., Hong Kong.