

**TEMA 1****INTRODUCCIÓN A LA FAMILIA MCS-51**

Texto basado en el documento:

"Procesadores de propósito general"

Departamento de Ingeniería  
Electrónica, de Sistemas Informáticos  
y Automática - Universidad de Huelva**Objetivos**

- Conocer los microcontroladores más representativos de la familia MCS-51 de Intel y los recursos que éstos poseen.
- Indicar qué otros fabricantes producen microcontroladores compatibles con la familia MCS-51.
- Analizar la arquitectura interna básica de los dispositivos de esta familia.
- Conocer los distintos tipos de encapsulado de los microcontroladores 8051/8052 y las funciones de los diferentes pines.
- Conocer qué condiciones deben cumplirse para provocar un *reset* al microcontrolador y su efecto sobre el mismo.
- Conocer cuáles son los elementos mínimos necesarios para la implementación de un sistema mediante un integrante de la familia MCS-51 en modos Microcontrolador y Microporcesador.

**Contenido**

|                                                                                                |    |
|------------------------------------------------------------------------------------------------|----|
| Objetivos.....                                                                                 | 1  |
| Contenido.....                                                                                 | 1  |
| 1.1 La familia MCS-51.....                                                                     | 2  |
| 1.2 Arquitectura general de los microcontroladores 8051/8052.....                              | 3  |
| 1.3 Patillaje de los microcontroladores 8051/52.....                                           | 4  |
| 1.4 Fuente de alimentación.....                                                                | 6  |
| 1.5 Circuito de reloj.....                                                                     | 7  |
| 1.6 Inicialización del microcontrolador.....                                                   | 7  |
| 1.6.1 Concepto de ciclo máquina.....                                                           | 8  |
| 1.6.2 Circuito de <i>reset</i> .....                                                           | 8  |
| 1.7 Sistema mínimo para el procesador AT89S52 en modo microcontrolador.....                    | 9  |
| 1.8 Sistema mínimo para el procesador AT82S52 en modo<br>microcontrolador/microporcesador..... | 10 |
| 1.9 Sistema mínimo para el procesador AT82S52 en modo<br>microporcesador.....                  | 11 |

## 1.1 La familia MCS-51

La MCS-51, ó simplemente 51, es una familia de microcontroladores desarrollada por la empresa Intel. El miembro original de dicha familia fue el microcontrolador 8051, que da nombre a la misma, y cuya arquitectura sirvió de base para el desarrollo del resto de los dispositivos.

En la Tabla 1.1 se representan las principales características de los miembros más populares de esta familia. Para más información se remite al lector al manual de usuario de la familia MCS-51 de Intel.

| Dispositivo | ROM (Bytes) | RAM (Bytes) | Frecuencia (MHz) | I/O | C/T | UART | Fuentes de Interrupción | Canales PCA | Canales A/D | Bits Seguridad | Idle y PD |
|-------------|-------------|-------------|------------------|-----|-----|------|-------------------------|-------------|-------------|----------------|-----------|
| 8031AH      | -           | 128         | 12               | 32  | 2   | 1    | 5                       | 0           | 0           | 0              | No        |
| 8051AH      | 4K ROM      | 128         | 12               | 32  | 2   | 1    | 5                       | 0           | 0           | 0              | No        |
| 8751BH      | 4K EPROM    | 128         | 12               | 32  | 2   | 1    | 5                       | 0           | 0           | 2              | No        |
| 8032AH      | -           | 256         | 12               | 32  | 3   | 1    | 6                       | 0           | 0           | 0              | No        |
| 8052AH      | 8K ROM      | 256         | 12               | 32  | 3   | 1    | 6                       | 0           | 0           | 0              | No        |
| 8752BH      | 8K EPROM    | 256         | 12               | 32  | 3   | 1    | 6                       | 0           | 0           | 2              | No        |
| 80C31BH     | -           | 128         | 16               | 32  | 2   | 1    | 5                       | 0           | 0           | 0              | Si        |
| 80C51BH     | 4K ROM      | 128         | 16               | 32  | 2   | 1    | 5                       | 0           | 0           | 0              | Si        |
| 87C51       | 4K EPROM    | 128         | 24               | 32  | 2   | 1    | 5                       | 0           | 0           | 3              | Si        |
| 80C32       | -           | 256         | 24               | 32  | 3   | 1    | 6                       | 0           | 0           | 0              | Si        |
| 80C52       | 8K ROM      | 256         | 24               | 32  | 3   | 1    | 6                       | 0           | 0           | 1              | Si        |
| 87C52       | 8K EPROM    | 256         | 24               | 32  | 3   | 1    | 6                       | 0           | 0           | 3              | Si        |
| 87C54       | 16K EPROM   | 256         | 24               | 32  | 3   | 1    | 6                       | 0           | 0           | 3              | Si        |
| 87C58       | 32K EPROM   | 256         | 24               | 32  | 3   | 1    | 6                       | 0           | 0           | 3              | Si        |
| 87L58       | 32K OTP ROM | 256         | 20               | 32  | 3   | 1    | 6                       | 0           | 0           | 3              | Si        |
| 87C51FC     | 32K EPROM   | 256         | 24               | 32  | 3   | 1    | 7                       | 5           | 0           | 3              | Si        |
| 87C51GB     | 32K EPROM   | 256         | 16               | 48  | 3   | 1    | 15                      | 10          | 8           | 3              | Si        |

Tabla 1.1. Principales características de los miembros más populares de la familia 51.

Como se puede apreciar en la tabla anterior, los modelos denotados como 80X3X no poseen memoria de programa interna, los denotados como 80X5X poseen memoria tipo ROM de máscara programable en fábrica, y los denotados como 87X5X incorporan una memoria de programas interna de tipo EPROM, programable y borrable por el usuario.

Por otro lado, los dispositivos denotados como 8XX2 (en adelante 8052) presentan una mayor capacidad de memoria, tanto de programas como de datos, así como un *timer* (contador/temporizador) más que los denotados como 8XX1 (en adelante 8051). Al margen de estas diferencias y de otras que derivan de ellas, se puede afirmar que “todo programa que funcione correctamente en un 8051 lo hará en un 8052”, aunque no siempre ocurre al contrario. En lo sucesivo, se resaltarán las diferencias entre dichos dispositivos, con objeto de que se puedan reconocer perfectamente las características de unos y otros.

En la actualidad, existen numerosos fabricantes (Atmel, Cypress, Daewoo, Dallas, Maxim, Phillips, Sharp, Siemens, etc.) que comercializan microcontroladores compatibles con la familia MCS-51, algunos de los cuales incorporan recursos o características especiales tales

como un mayor (o menor) número de líneas de E/S, memoria de programa tipo FLASH, bus I<sup>2</sup>C, watchdog, doble DPTR, mayor número de niveles de prioridad en las interrupciones, etc.

**En esta asignatura utilizaremos el procesador de Atmel: AT89S52. (Para mayor detalles consultar la hoja de datos AT89S52\_DS.PDF)**

## 1.2 Arquitectura general de los microcontroladores 8051/8052

El diagrama de bloques de la Figura 1.1 muestra la arquitectura general de los microcontroladores 8051/52.



Figura 1.1. Diagrama de bloques de los microcontroladores 8051/52.

Las características generales de estos dispositivos son las siguientes:

- CPU de 8 bits.
- Procesador booleano (operación sobre bits individuales).
- 4 puertos de 8 bits.
- Para el 8051, 128 bytes útiles para el usuario y 151 bytes incluyendo el área de los registros especiales (SFR). Para el 8052, 256 bytes de memoria interna RAM útil para el usuario y 283 bytes en total considerando el SFR.
- 4 Kbytes de ROM (8051) o EPROM (8751). 8 Kbytes para el 8X52.
- Espacio de memoria de 64 Kbytes para programa externo.
- Espacio de memoria de 64K para datos externos.
- El 8051 contiene dos contadores-temporizadores (*timers*). El 8052 presenta tres *timers*.
- Comunicación serial asíncrona *full-duplex*.
- 1 fuente de interrupción no enmascarable (Reset)
- 5 fuentes de interrupción enmascarables con niveles de prioridad (6 para el 8052).
  - 2 interrupciones externas.
  - 2 interrupciones de los timers (3 para el 8052).
  - 1 interrupción de la comunicación serie.
- Oscilador interno.

En la Figura 1.2 se puede apreciar con mayor detalle la arquitectura de los microcontroladores 8051/52.



Figura 1.2. Arquitectura detallada de los microcontroladores 8051/52.

### 1.3 Patillaje de los microcontroladores 8051/52.

Los microprocesadores de la familia 51 se comercializan con varios tipos de encapsulado, entre los que destacan el DIP y el PLCC representados en la Figura 1.3.



Figura 1.3. Encapsulados DIP y PLCC correspondientes al 8052.

Como puede observarse, con objeto de reducir el número de pines del encapsulado, la mayoría de las patillas poseen funciones alternativas (expresadas entre paréntesis). A continuación se detalla la nomenclatura de los pines que aparecen en dichos encapsulados, realizando una breve descripción de las funciones desempeñadas por los mismos.

**Vcc:** Terminal positivo de la alimentación (+5 voltios).

**Vss:** Masa de la alimentación (0 voltios).

**P0.0 - P0.7 (Puerto P0):** Puerto bidireccional de 8 bits con salidas en colector abierto. Además de actuar como líneas de E/S, a través de estos 8 pines se multiplexa en el tiempo la parte baja del bus de direcciones y el bus de datos, durante los accesos a la memoria externa de programas y de datos. El Puerto 0 también recibe los *bytes* de código durante la programación de la memoria EPROM integrada y suministra los *bytes* de código durante la verificación de la memoria EPROM o ROM.

**P1.0 - P1.7 (Puerto P1):** Puerto quasibidireccional de 8 bits. Recibe la parte baja de las direcciones durante la programación y verificación de la memoria EPROM interna. Además (solamente en el microcontrolador 8052), los bits P1.0 y P1.1 poseen otras funciones especiales que se indican en la Tabla 1.2.

| Pines | Función alternativa                                                |
|-------|--------------------------------------------------------------------|
| P1.0  | T2: Entrada externa del <i>timer</i> 2.                            |
| P1.1  | T2EX: Entrada de captura e impulsos de recarga del <i>timer</i> 2. |

Tabla 1.2. Funciones alternativas del Puerto 1.

**P2.0 - P2.7 (Puerto P2):** Puerto quasibidireccional de 8 bits. En su función alternativa, estas 8 líneas actúan como parte alta del bus de direcciones en los accesos a memoria externa, tanto de código como de datos, cuando se utilizan 16 bits de dirección. En los accesos a la memoria de datos externa con direccionamiento de 8 bits, estos pines actúan como líneas de E/S del Puerto 2. Durante la programación y verificación de la memoria EPROM interna, a través de estos 8 pines se recibe la parte alta de la dirección.

**P3.0 - P3.7 (Puerto P3):** Puerto quasibidireccional de 8 bits. Las funciones alternativas de estos pines se muestran en la Tabla 1.3.

| Pines | Función alternativa                                       |
|-------|-----------------------------------------------------------|
| P3.0  | RXD: Entrada del puerto serie.                            |
| P3.1  | TXD: Salida del puerto serie.                             |
| P3.2  | INT0: Entrada de la interrupción externa 0.               |
| P3.3  | INT1: Entrada de la interrupción externa 1.               |
| P3.4  | T0: Entrada externa del <i>timer</i> 0.                   |
| P3.5  | T1: Entrada externa del <i>timer</i> 1.                   |
| P3.6  | WR: Habilitación de escritura para dispositivos externos. |
| P3.7  | RD: Habilitación de lectura para dispositivos externos.   |

Tabla 1.3. Funciones alternativas del Puerto 3.

**ALE/ PROG :** ALE (*Address Latch Enable*) es un pulso que emite el microcontrolador para almacenar en un *latch* externo el byte bajo del bus de direcciones en los accesos a la memoria externa. ALE se emite con una frecuencia igual a 1/6 de la frecuencia del reloj. PROG es la patilla de entrada de pulsos de programación de la memoria EPROM interna.

**PSEN** : **PSEN** (*Program Store ENable*) es la señal de habilitación de lectura para la memoria de externa de programa. La memoria externa tiene dos modalidades, de “programa” y de “datos”. Para diferenciarlas, en los accesos a memoria de código se activa la señal **PSEN** en vez de la señal **RD**. La señal **PSEN** no se activa en los accesos a la memoria ROM o EPROM interna.

**EA/VPP** : Cuando la señal **EA** (*External Access*) se mantiene a nivel alto, se ejecuta el programa de la ROM interna, a menos que el contador de programa exceda de 0FFF (4 Kbytes) para el 8051 o de 1FFF (8 Kbytes) para el 8052. Si **EA** se mantiene a nivel bajo, se ejecuta el programa ubicado en la memoria externa, independientemente de la dirección de programa. Es decir, si **EA** = 1 el circuito actúa como microcontrolador y si **EA** = 0 actúa como microprocesador. VPP es el pin a través del cual se aplica la tensión de programación durante la grabación de la memoria EPROM interna.

**XTAL1** y **XTAL2**: Entrada y salida, respectivamente, del circuito de reloj interno del microcontrolador.

**RESET**: Señal de inicialización del sistema.

## 1.4 Fuente de alimentación

Todos los elementos activos de un sistema electrónico necesitan de una fuente de alimentación que les suministre energía eléctrica para su funcionamiento.

Para que el funcionamiento de un microcontrolador sea correcto, la tensión aplicada al terminal de alimentación del mismo debe estar comprendida dentro de un rango definido (en forma de porcentaje) en torno al valor nominal especificado por el fabricante en las hojas de características técnicas del dispositivo. La desviación permitida con respecto a dicho valor suele ser del 5 %. Para asegurar el cumplimiento de esta restricción suelen emplearse fuentes de alimentación reguladas, que mantienen prácticamente constante el valor de su tensión de salida mientras el nivel de intensidad suministrado no supere un determinado valor ( $I_{O\max}$ ).

El diseño de estas fuentes de alimentación se simplifica extraordinariamente haciendo uso de reguladores de tensión integrados, tales como los de la serie 78XX (MC7805 para voltaje positivo de 5 volt) los cuales poseen una tolerancia en su tensión de salida comprendida entre el 2 y el 4 %.



Figura 1.4. Fuente de alimentación regulada para tensiones positivas.

## 1.5 Circuito de reloj

Como todos los dispositivos digitales síncronos, los microprocesadores y microcontroladores necesitan de una señal periódica para su funcionamiento, denominada señal de reloj.

Los microcontroladores de la familia MCS-51 poseen un oscilador interno para la generación de la señal de reloj, necesitando conectarle externamente sólo componentes pasivos, tales como condensadores, cristales de cuarzo, etc. En la Figura 1.5 se representa el circuito externo de reloj utilizado típicamente con los microcontroladores de esta familia.



Figura 1.5. Circuitería externa del oscilador de un 8051.

Otra alternativa consiste en la conexión de una señal de reloj externa al microcontrolador (ó un cristal oscilador), tal como se representa en la Figura 1.6.



Figura 1.6. Modo de conexión de una señal externa de reloj al 8051

## 1.6 Inicialización del microcontrolador

Cuando se conecta la alimentación al sistema, es necesario que se produzca una inicialización o *reset* del microcontrolador para que el programa empiece a ejecutarse a partir de la primera instrucción. En otras ocasiones, por ejemplo cuando el sistema se queda bloqueado, es preciso proceder a su reinicio durante su funcionamiento.

Además de provocar la lectura de la primera instrucción de la memoria, el *reset* del microcontrolador inicializa el contenido de los registros internos del mismo con unos ciertos valores, como se estudiará más adelante.

El *reset* del microcontrolador no afecta al contenido de la memoria RAM (excepto a la zona SFR, donde se encuentran los registros internos). Cuando el *reset* se produce tras aplicar la alimentación al sistema, el contenido de la RAM es indeterminado.

### 1.6.1 Concepto de ciclo máquina

Para esta familia de microcontroladores, un ciclo máquina o ciclo de máquina (Figura 1.7) consiste en una secuencia de 6 “estados” (S1 - S6), cada uno de los cuales se compone a su vez de dos períodos de la señal de reloj, denominados “fases” (P1 y P2). Por tanto, cada ciclo de máquina consta de un total de 12 períodos del oscilador (6 períodos x 2 fases). Así pues, el tiempo que dura la ejecución de un ciclo máquina ( $t_{CM}$ ) depende de la frecuencia del oscilador y se calcula de la siguiente manera:  $T = 1/f_{osc}$  lo que implica que  $t_{CM} = 12 T$ .



Figura 1.7. Ciclo máquina en la familia MCS-51.

### 1.6.2 Circuito de reset

Para que se produzca la inicialización de un microcontrolador 8051/52, es necesario aplicar un nivel alto a su entrada RESET durante al menos dos ciclos máquina.

El circuito típicamente utilizado para la inicialización del microcontrolador 8051/52 se muestra en la Figura 1.8. La conexión en serie del condensador y la resistencia produce un *reset* automático del microcontrolador al conectar la alimentación al sistema. Por su parte, el pulsador en paralelo con el condensador permite al usuario provocar la inicialización del microcontrolador en cualquier momento de forma manual.



Figura 1.8. Circuito de *reset* automático/manual para el 8051/52.

## 1.7 Sistema mínimo para el procesador AT89S52 en modo Microcontrolador

Teniendo en cuenta todo lo explicado en los apartados anteriores, podemos deducir que el circuito mínimo a implementar para construir un sistema alrededor de un microcontrolador AT89S52, debe ser similar al mostrado en la Figura 1.9.



Figura 1.9. Sistema mínimo para el AT89S52

En dicho circuito no se ha representado la fuente de alimentación, que tendría una estructura similar a la mostrada en la figura 1.4, usando un regulador de tensión MC7805.

Por otro lado, para hacer uso de la memoria de código interna y que el procesador funcione en modo microcontrolador, la línea EA se ha conectado a VCC.

## 1.8 Sistema mínimo para el procesador AT89S52 en modo Microcontrolador/Microprocesador (ROM externa)



## 1.9 Sistema mínimo para el procesador AT89S52 en modo Microporcesador (ROM, RAM y Puertos externos)

### Diagrama en Bloques



## Diagrama Esquemático

