SANTIAGO CRUZ 02/05/2006 07:45

## **COMUNICACIÓN PARALELA**

Puertos A, B, E y K.

## Características comunes:

- Bidireccionales
- Programables pin a pin como entrada o salida.
- Tienen un registro para habilitar o deshabilitar "pull-resistor" 1
- Registro para habilitar o deshabilitar salida en baja potencia.
- Registro para programar modos de operación.

A continuación se presenta un diagrama a bloques de lo que es un pin de un puerto en el HC12:

<sup>&</sup>lt;sup>1</sup> Pull-up resistor: resistencia conectada a Vcc pull-down resistor: resistencia conectada a tierra.

Las direcciones de algunos puertos se presentan a continuación:

| PORTA | \$0000 |  |
|-------|--------|--|
| PORTB | \$0001 |  |
| DDRA  | \$0002 |  |
| DDRB  | \$0003 |  |

EJEMPLO: encendido de un led vía interruptor de contacto momentáneo.

### Función and.

O5/P5



|   | * | * | * | * | * | * | * | 0 |
|---|---|---|---|---|---|---|---|---|
|   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| I | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

Resultado = 0 => interruptor abierto (Z=1)

| * | * | * | * | * | * | * | 1 |
|---|---|---|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |

Resultado = 1 => interruptor cerrado (Z=0)



| PORTA<br>DDRA | EQU<br>EQU<br>LDX<br>LDAA<br>STAA  | \$00<br>\$02<br>#\$0000<br>#\$80<br>DDRA, X | ;define pseudo operadores<br>; define pseudo operador<br>; carga el índice X de manera inmediata con 0000<br>; carga el acumulador A con 1000 0000h, bit7 a '1'<br>; almacénalo en el registro DDRA |
|---------------|------------------------------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| REV           | ANDA<br>BNE<br>CLRA<br>STAA<br>BRA | PORTA, X #\$01 PRENDE  PORTA, X REV         | ; carga el acumulador A con lo que lee en el puerto A<br>; operación and, A con 01<br>; salta si Z=0 (a la etiqueta PRENDE                                                                          |
| PRENDE        | LDAA<br>STAA<br>BRA                | #\$80<br>PORTA, X<br><b>REV</b>             |                                                                                                                                                                                                     |

Otra forma seria programándolo con la instrucción BSET

| PORTA<br>DDRA | EQU<br>EQU<br>LDX                  | \$00<br>\$02<br>#\$0000             | ; define pseudo operadores<br>; define pseudo operador<br>; carga el índice X de manera inmediata con 0000                                                                                   |
|---------------|------------------------------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | BSET                               | DDRA,X,\$80                         | ; bit set pone un '1' en el bit7 del registro DDRA<br>de manera indexada. OJO, ya que esta<br>instrucción solo pone un '1' en el bit que le<br>indiquemos, los demás bits quedan sin cambios |
| REV           | ANDA<br>BNE<br>CLRA<br>STAA<br>BRA | PORTA, X #\$01 PRENDE  PORTA, X REV | ; carga el acumulador A con lo que lee en el<br>puerto A<br>; operación and, A con 01<br>; salta si Z=0 a la etiqueta PRENDE                                                                 |
| PRENDE        | LDAA<br>STAA<br>BRA                | #\$80<br>PORTA, X<br><b>REV</b>     |                                                                                                                                                                                              |

Otra manera seria como sigue, las instrucciones se reducen:

| PORTA<br>DDRA | EQU<br>EQU<br>LDX | \$00<br>\$02<br>#\$0000     | ;define pseudo operadores<br>; define pseudo operador<br>; carga el índice X de manera<br>inmediata con 0000                                                                        |
|---------------|-------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | BSET              | DDRA,X,\$80                 | ; bit set pone un '1' en el bit7 del registro DDRA de manera indexada. OJO, ya que esta instrucción solo pone un '1' en el bit que le indiquemos, los demás bits quedan sin cambios |
|               | BRSET             | PORTA,X,\$01, <b>PRENDE</b> | ; Salta a la etiqueta PRENDE si hay un<br>'1' en el bit0 del puerto A, de manera<br>indexada.                                                                                       |
|               | BCLR              | PORTA,X,\$80                | ; pone un '0' en el bit7 del puerto A<br>de manera indexada.                                                                                                                        |
|               | BRA               | REV                         | ; salta a la etiqueta REV                                                                                                                                                           |
| PRENDE        | BSET              | PORTA,X,\$80                | ; pone un '1' en el bit7 del puerto A<br>de manera indexada.                                                                                                                        |
|               | BRA               | REV                         | de manera maexada.                                                                                                                                                                  |

# PROGRAMA (TOGGLE)

Encender el led y apagar el led cada vez que se presione una vez el interruptor. El puerto A es el que se muestra:





| UNAM, FACULTAD DE INGENIERÍA<br>CARLOS                  | SANTIAGO CRUZ    |
|---------------------------------------------------------|------------------|
| APUNTES DE MICROPROCESADORES Y MICROCONTROLADORES 05/P5 | 02/05/2006 07:45 |
| CODIGO <sup>2</sup>                                     |                  |

| PORTA<br>DDRA | EQU<br>EQU<br>LDX | \$00<br>\$02<br>#\$0000      | ;define pseudo operadores<br>; define pseudo operador<br>; carga el índice X de manera<br>inmediata con 0000                                                                           |
|---------------|-------------------|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | BSET              | DDRA,X,\$80                  | ; bit set pone un '1' (entrada) en el<br>bit7 del registro DDRA de manera<br>indexada. OJO, ya que esta<br>instrucción solo pone un '1' en el bit<br>que le indiquemos, los demás bits |
|               | BCLR              | DDRA,X,\$01                  | quedan sin cambios<br>; bit clear pone un '0' (salida) en el<br>bit0 del registro DDRA de manera<br>indexada.                                                                          |
| LEER          | BRCLR             | PORTA,X,\$01,LEER            | ; Salta si hay un 'O' a la etiqueta<br>LEER en el bitO del puerto A, de<br>manera indexada.                                                                                            |
|               | LDAA<br>STAA      | #\$80<br>PORTA,X             | manera muexada.                                                                                                                                                                        |
| AUN           | BRSET             | PORTA,X,\$01, <b>AUN</b>     | ; Salta si hay un '1' a la etiqueta AUN<br>en el bit0 del puerto A, de manera<br>indexada.                                                                                             |
| CERRADO       | BRCLR             | PORTA,X,\$01, <b>CERRADO</b> | ; Salta si hay un '0' a la etiqueta<br>CERRADO en el bit0 del puerto A, de<br>manera indexada.                                                                                         |
|               | LDAA              | #\$00                        |                                                                                                                                                                                        |
|               | STAA              | PORTA,X                      |                                                                                                                                                                                        |
| AUN2          | BRSET             | PORTA,X,\$01, AUN2           | ; Salta si hay un 'O' a la etiqueta<br>AUN2 en el bitO del puerto A, de<br>manera indexada.                                                                                            |
|               | BRA               | LEER                         | ; salta a la etiqueta leer.                                                                                                                                                            |

<sup>&</sup>lt;sup>2</sup> Cada ciclo (~) es típicamente de 125[ns] para un bus de 8[MHz] (oscilador de 16[MHz])

### **PROBLEMA**

05/P5

Desarrollar un programa que haga parpadear un led cuando el interruptor 'S' de contacto sostenido se cierre.



| UNAM, FACULTA<br>CARLOS | d de ingeniería                                            |                            |     |     | SANTIAGO CRUZ                                                                                                              |
|-------------------------|------------------------------------------------------------|----------------------------|-----|-----|----------------------------------------------------------------------------------------------------------------------------|
| APUNTES DE MIC<br>O5/P5 | APUNTES DE MICROPROCESADORES Y MICROCONTROLADORES<br>05/P5 |                            |     |     | 02/05/2006 07:45                                                                                                           |
| PORTA                   | EQU                                                        | \$00                       |     |     | ;define pseudo operadores                                                                                                  |
| DDRA                    | EQU                                                        | \$02                       |     |     | ;define pseudo operador                                                                                                    |
|                         | LDX                                                        | #\$0000                    |     |     |                                                                                                                            |
|                         | LDAA                                                       | #\$80                      |     |     |                                                                                                                            |
|                         | STAA                                                       | DDRA,X                     |     |     |                                                                                                                            |
| INICIA                  | BCLR                                                       | PORTA,X,\$80               |     |     |                                                                                                                            |
| LEER                    | BRCLR                                                      | PORTA,X\$01, <b>INICIA</b> |     |     |                                                                                                                            |
|                         | BSET                                                       | PORTA,X,\$80               |     |     |                                                                                                                            |
|                         | JSR                                                        | RETARDO                    |     | (4) | Para programar el retardo observe:                                                                                         |
|                         | BCLR                                                       | PORTA,X,\$80               |     |     | FFFFh=65535d                                                                                                               |
|                         | JSR                                                        | RETARDO                    |     |     |                                                                                                                            |
|                         | BRA                                                        | LEER                       |     |     | Por 5 ciclos veces que se realiza el lazo, se<br>Realizan un LDY, un DECA y BNE, el cual suman<br>6 ciclos de instrucción. |
| RETARDO                 | LDAA                                                       | <b>#\$∆</b>                |     | (1) | 4 .4 .50.5055514.5                                                                                                         |
| LAZO                    | LDY                                                        | #\$FFFF                    |     | (2) | $4_{JSR}+1_{LDAA}+[6+5(65535)]\Delta+5_{RTS}$<br>ESTO DEBEMOS IGUALARLO A:                                                 |
| SUBLAZO                 | NOP                                                        |                            |     | (1) |                                                                                                                            |
|                         | DEY                                                        |                            | (5) | (1) |                                                                                                                            |
|                         | BNE                                                        | SUBLAZO                    |     | (3) | 250 000 [Ms]={4 <sub>JSR</sub> +1 <sub>LDAA</sub> +[6+5(65535)]Δ+5 <sub>RTS</sub> }0.125[Ms]                               |
|                         | DECA                                                       |                            |     | (1) |                                                                                                                            |
|                         | BNE                                                        | LAZO                       |     | (3) | Δ={(250000/0.125)-4-1-5}/(6+5(65535))                                                                                      |
|                         | RTS                                                        |                            |     | (5) | Δ=6.10347 en decimal                                                                                                       |
|                         |                                                            |                            |     |     |                                                                                                                            |
|                         |                                                            |                            |     |     | POR LO TANTO:                                                                                                              |
|                         |                                                            |                            |     |     | Δ=6h                                                                                                                       |
|                         |                                                            |                            |     |     |                                                                                                                            |
|                         |                                                            |                            |     |     |                                                                                                                            |
|                         |                                                            |                            |     |     |                                                                                                                            |

UNAM, FACULTAD DE INGENIERÍA CARLOS APUNTES DE MICROPROCESADORES Y MICROCONTROLADORES O5/P5 SANTIAGO CRUZ 02/05/2006 07:45

$$\Delta$$
={(50000/0.125)-4-1-5}/(6+5(65535))  $\Delta$ =1.220

¿Qué pasa si deseamos tener un retardo de 50 [ms]?, hay diferentes formas de hacerlo, como nos damos cuenta es la quinta parte del tiempo de retardo del ejemplo anterior, por lo que el cálculo quedaría de la siguiente manera:

$$[Ms] = {4_{JSR} + 1_{LDAA} + [6 + (65535)]\Delta + 5_{RTS}}0.125[Ms]$$

### **PROBLEMA**

Desarrollar un programa que encienda el led durante 5 segundos cada vez que se cierra el interruptor 's' de contacto sostenido.



| UNAM, FACULTAI | D DE INGENIERÍA                                   |                          |   | SANTIAGO CRUZ |                                                                                                |
|----------------|---------------------------------------------------|--------------------------|---|---------------|------------------------------------------------------------------------------------------------|
|                | APUNTES DE MICROPROCESADORES Y MICROCONTROLADORES |                          |   |               | 02/05/2006 07:45                                                                               |
| DDRA           | EQU                                               | \$02                     |   |               | ; define pseudo operador                                                                       |
|                | LDX                                               | #\$0000                  |   |               |                                                                                                |
|                | LDAA                                              | #\$80                    |   |               |                                                                                                |
|                | STAA                                              | DDRA,X                   |   |               |                                                                                                |
|                | BCLR                                              | PORTA,X,\$80             |   |               |                                                                                                |
| LEER           | BRCLR                                             | PORTA,X,\$01,LEER        |   |               |                                                                                                |
|                | BSET                                              | PORTA,X,\$80             |   |               |                                                                                                |
|                | JSR                                               | RETARDO5S                |   | (4)           | Para programar el retardo observe:                                                             |
|                | BCLR                                              | PORTA,X,\$80             |   |               | <br>  FFFFh=65535d                                                                             |
| AUN            | BRSET                                             | PORTA,X,\$01, <b>AUN</b> |   |               | 111111-055530                                                                                  |
|                | BRA                                               | LEER                     |   |               | Por 5 ciclos veces que se realiza el lazo, se                                                  |
|                |                                                   |                          |   |               | Realizan un LDY, un DECA y BNE, el cual suman 6 ciclos de instrucción.                         |
| RETARDO<br>5S  | LDAA                                              | #\$ <b>∆</b>             |   | (1)           | 4 <sub>JSR</sub> +1 <sub>LDAA</sub> +[6+5(65535)]Δ+5 <sub>RTS</sub>                            |
| LAZO           | LDY                                               | #\$FFFF                  |   | (2)           | ESTO DEBEMOS IGUALARLO A:                                                                      |
| SUBLAZO        | NOP                                               |                          |   | (1)           |                                                                                                |
|                | DEY                                               |                          | 5 | (1)           | 5 000 000 [Ms]={4 <sub>JSR</sub> +1 <sub>LDAA</sub> +[6+5(65535)]Δ+5 <sub>RTS</sub> }0.125[Ms] |
|                | BNE                                               | SUBLAZO                  |   | (3)           | 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2                                                          |
|                | DECA                                              |                          |   | (1)           |                                                                                                |
|                | BNE                                               | LAZO                     |   | (3)           | Δ={(5000000/0.125)-4-1-5}/(6+5(65535))                                                         |
|                | RTS                                               |                          |   | (5)           | Δ=122.07 en decimal                                                                            |
|                |                                                   |                          |   |               | POR LO TANTO:                                                                                  |
|                |                                                   |                          |   |               | Δ=7Ah                                                                                          |
|                |                                                   |                          |   |               |                                                                                                |
|                |                                                   |                          |   |               |                                                                                                |

En caso de que no nos alcanzara el conteo del acumulador A, utilizaríamos alternativamente el acumulador B, pero esto a su vez, implicaría ocupar todos los registros disponibles para programar un solo retardo, estos ejercicios se realizan para practicar con las instrucciones del hc12, más sin embargo, el microcontrolador cuenta con contadores específicos, que se verán más adelante.

### **PROBLEMA**

Realizar un programa que genere señales de alarma independientes por nivel alto o nivel bajo en el tanque, mediante el parpadeo de los leds correspondientes, si el nivel es normal, el led N debe prender, en condiciones de alarma se debe apagar, (prueba de leds), se cierra en cualquier tiempo y condición, los tres leds deben prender y permanecer así, hasta que el interruptor PL se abra para regresar al estado anterior.



APUNTES DE MICROPROCESADORES Y MICROCONTROLADORES 05/P5

02/05/2006 07:45



| UNAM, FACULTAD DE INGENIERÍA                             | SANTIAGO CRUZ    |
|----------------------------------------------------------|------------------|
| CARLOS APUNTES DE MICROPROCESADORES Y MICROCONTROLADORES | 02/05/2006 07:45 |
| O5/P5                                                    |                  |

|        |       | _                           |      |                                                      |
|--------|-------|-----------------------------|------|------------------------------------------------------|
| PORTA  | EQU   | \$00                        |      | ;define pseudo operadores                            |
| DDRA   | EQU   | \$02                        |      | ; define pseudo operador                             |
|        | LDX   | #\$0000                     |      |                                                      |
|        | LDAA  | #\$E0                       |      | ;programa puerto A                                   |
|        | STAA  | DDRA,X                      |      | ;programa puerto A                                   |
| LEER   | LDAA  | PORTA,X                     |      | ;carga el acum, con el contenido de A                |
| REG    | BRSET | PORTA,X,\$08, <b>PRUEBA</b> |      | ;                                                    |
|        | ANDA  | #\$03                       |      | ; AND con 03h y modifica A                           |
|        | LDAA  | PORTA,X                     |      | ; volvemos a cargar A, debido a que ANDA lo modifica |
|        | CMPA  | #\$03                       |      | ;                                                    |
|        | BEQ   | NORMAL                      |      | ; salta a NORMAL, si (A)-03=0; Z=1                   |
|        | BRCLR | PORTA,X,\$01,ALTO           |      |                                                      |
|        | BCLR  | PORTA,X,\$60                |      | ; apaga N y H                                        |
|        | BSET  | PORTA,X,\$80                |      |                                                      |
|        | JSR   | RETRASO                     |      |                                                      |
|        | BCLR  | PORTA,X,\$80                |      |                                                      |
|        | JSR   | RETRASO                     | ;(4) |                                                      |
|        | BRA   | LEER                        |      |                                                      |
| PRUEBA | BSET  | PORTA,X,\$E0                |      |                                                      |
|        | BRA   | REG                         |      |                                                      |
| NORMAL | BCLR  | PORTA,X,\$C0                |      |                                                      |
|        | BSET  | PORTA,X,\$20                |      |                                                      |
|        | BRA   | LEER                        |      |                                                      |
| ALTO   | BCLR  | PORTA,X,\$CO                |      |                                                      |
|        | BSET  | PORTA,X,\$A0                |      |                                                      |
|        | JSR   | RETRASO                     |      |                                                      |
|        | BCLR  | PORTA,X,\$40                |      |                                                      |
|        | JSR   | RETRASO                     |      |                                                      |
|        | BRA   | LEER                        |      |                                                      |
|        |       |                             |      | Para programar el retardo observe:                   |

Para programar el retardo observe:

FFFFh=65535d

Por 5 ciclos veces que se realiza el lazo, se

| 03/F3   |  |      |  |             |   |                                                                        |                                                                                                |
|---------|--|------|--|-------------|---|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
|         |  |      |  |             |   | Realizan un LDY, un DECA y BNE, el cual suman 6 ciclos de instrucción. |                                                                                                |
| RETRASO |  | LDAA |  | <b>#\$∆</b> |   | (1)                                                                    | 6 Cictos de instrucción.                                                                       |
| LAZO    |  | LDY  |  | #\$FFFF     |   | (2)                                                                    | $4_{JSR}+1_{LDAA}+[6+5(65535)]\Delta+5_{RTS}$                                                  |
| SUBLAZO |  | NOP  |  |             |   | (1)                                                                    | ESTO DEBEMOS IGUALARLO A:                                                                      |
|         |  | DEY  |  |             | 5 | (1)                                                                    |                                                                                                |
|         |  | BNE  |  | SUBLAZO     |   | (3)                                                                    | 250 000 [N-1-(4 .4 ./6.5/65525)]A.5 .20 425[N-1                                                |
|         |  | DECA |  |             |   | (1)                                                                    | - 250 000 [Ms]={4 <sub>JSR</sub> +1 <sub>LDAA</sub> +[6+5(65535)]Δ+5 <sub>RTS</sub> }0.125[Ms] |
|         |  | BNE  |  | LAZO        |   | (3)                                                                    |                                                                                                |
|         |  | RTS  |  |             |   | (5)                                                                    | Δ={(250000/0.125)-4-1-5}/(6+5(65535))                                                          |
|         |  |      |  |             |   |                                                                        | Δ=6.10347 en decimal                                                                           |
|         |  |      |  |             |   |                                                                        | POR LO TANTO:                                                                                  |
|         |  |      |  |             |   |                                                                        |                                                                                                |
|         |  |      |  |             |   |                                                                        | Δ=6h                                                                                           |
|         |  |      |  |             |   |                                                                        |                                                                                                |
|         |  |      |  |             |   |                                                                        |                                                                                                |
|         |  |      |  |             |   |                                                                        |                                                                                                |