86 Zejouy



#### UNIVERSIDAD NACIONAL AUTONOMA DE MEXICO

#### FACULTAD DE INGENIERIA

DISEÑO DE UN CONTROLADOR DIGITAL
CON UNIDAD DE DISCO

T E S I S
Que para obtener el Título de
INGENIERO MECANICO ELECTRICISTA
P r e s e n t a n

ABEL GONZALEZ CANCELA

JAIME ALBERTO GASPAR ELIZONDO HUERTA

JOSE ANTONIO MAZA MAGNUSSEN



Director de Tesis: M. I. Lauro Santiago Cruz

MEXICO, D. F.

1995

FALLA DE ORIGEN





UNAM – Dirección General de Bibliotecas Tesis Digitales Restricciones de uso

#### DERECHOS RESERVADOS © PROHIBIDA SU REPRODUCCIÓN TOTAL O PARCIAL

Todo el material contenido en esta tesis esta protegido por la Ley Federal del Derecho de Autor (LFDA) de los Estados Unidos Mexicanos (México).

El uso de imágenes, fragmentos de videos, y demás material que sea objeto de protección de los derechos de autor, será exclusivamente para fines educativos e informativos y deberá citar la fuente donde la obtuvo mencionando el autor o autores. Cualquier uso distinto como el lucro, reproducción, edición o modificación, será perseguido y sancionado por el respectivo titular de los Derechos de Autor.

# DISEÑO DE UN CONTROLADOR DIGITAL CON UNIDAD DE DISCO

Agradecemos el apoyo y la amistad siempre brindados por:

Ing. Rodolfo Peters L.

е

Ing. Lauro Santiago C.

A mi mamá por el ejemplo que me dejó,

Con mucho cariño para mi papá por su enorme apoyo,

A Claudia, con todo mi amor, por su apoyo, comprensión y empuje,

A mis hermanos,

A Samuel.

Alberto Elizondo

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

3

A ti papá, porque nunca has dejado de estar conmigo.

A mi mamá por su amor.

A mi fiel esposa Gaby.

A Tabé, Mábel y Lenchita.

A Beto, Claudia, Jorge y Pepe por su amistad.

Abel González

A Gabriela por su amor y apoyo, por tu ayer, tu hoy y tu mañana,

A Maria Isabel,

A mi padres por su ejemplo, cariño y consejo,

A Bestemor y Bestefar por sus consejos,

A mis hermanos y amigos.

Jose Antonio Maza

## INDICE

#### INTRODUCCION

#### CAPITULO I PLANTEAMIENTO Y CONFIGURACION DEL SISTEMA

- I.1) Planteamiento
- 1.2) Características del controlador
- 1.3) Enlace con dispositivos de medición
- 1.4) Interfaz con una unidad de discos flexibles
  - 1.4.1) Conceptos Generales de la Interfaz
  - 1.4.2) Requerimientos de la Interfaz
  - 1.4.3) Control de la Interfaz
- 1.5) Interfaz con el usuario
- I.6) Diagrama general de bioques

#### CAPITULO II MANEJO DE ARCHIVOS EN MS DOS

- II.1) Conceptos generales de la estructura de un disco
- II.2) Estructura en MS-DOS
  - II.2.1) Area de "Boot"
  - II.2.2) Area de "Fat"
  - II.2.3) Area del Directorio Raiz
  - II.2.4) Area de Archivos

#### CAPITULO III DISEÑO DEL CONTROLADOR

- III.1) Descripción general del controlador
- III.2) Principales componentes del controlador
- III.3) Diagramas de la tarjeta controladora

#### CAPITULO IV PROGRAMACION DEL CONTROLADOR

- IV.1) Diagrama general de flujo
- IV.2) Rutina de inicio
- IV.3) Manejador de disco y carga de programa
  - IV.3.1) Rutina de despliegue de directorioIV.3.2) Rutina para leer y ejecutar un archivoII.2.3) Rutina para escribir a disco
- IV.4) Interfaz con el usuario
- IV.5) Lineamientos para la programación del sensor

CONCLUSIONES

BIBLIOGRAFIA

**ANEXOS** 

## INTRODUCCION

El origen de esta tesis fue la necesidad de desarrollar un controlador digital flexible que controlará desde un sensor hasta una estación de muestreo almacenando los datos recabados por ésta.

Este trabajo surgió debido a que en el Instituto de Ingeniería de la UNAM se diseñan y desarrollan sistemas digitales de control con una finalidad específica, que al no ser flexibles no son aprovechados en proyectos nuevos.

El objetivo principal de este proyecto es el hacer una tarjeta flexible de bajo costo, con independencia en cuanto a capacidad de almacenamiento y por otro lado, compatible con los estándares del mercado para permitir el procesamiento de la información almacenada.

Este trabajo no intenta desarrollar los elementos para el control del sensor o estación de muestreo en específico ni para la captura de la información, que dependerá directamente del diseño de dicho dispositivo, sino más bien, crear la infraestructura de hardware y software necesarias para poder implementar el software de control y procesamiento que se desee en función de las necesidades particulares del sistema de medición y muestreo de que se trate.

La principal característica de este controlador será el poder almacenar información en un medio magnético (floppy disk) con formato MS-DOS y recibir información del mismo. Esto permitirá darle flexibilidad al diseño, ya que se podrá procesar la información almacenada en cualquier PC compatible y por otro lado, el hecho de que el controlador posea un medio magnético, permitirá hacer manejable su programación.

El "Device Driver" para el manejo de disco, será incluido en la ROM del sistema y se podrá tener acceso a él mediante una rutina de interrupción, de tal forma que para los desarrollos del software de control de un sensor o estación de muestreo, solamente será necesario llamar a dichas interrupciones para lograr el acceso a disco.

### **CAPITULO I**

## PLANTEAMIENTO Y CONFIGURACIÓN DEL SISTEMA

#### 1.1) PLANTEAMIENTO

Los sistemas de adquisición de datos de bajo costo que operan autónomamente son los instrumentos más eficientes y precisos de obtener información del medio ambiente que nos rodea.

Dado que el uso de estos sistemas autónomos de adquisición se ha multiplicado mucho en los últimos años, el Instituto de Ingeniería de la UNAM ha desarrollado controladores para la obtención de perfiles de distribución de agua y estaciones de muestreo para registrar información sísmica y climatológica.

Estos sistemas se adecuan a las necesidades específicas de estos proyectos pero carecen de flexibilidad al no poder ser utilizados para otro fin.

Todos los proyectos tienen en común la necesidad de controlar algún dispositivo externo que sense el entorno, así como almacenar esta información para poder ser analizada posteriormente.

A su vez, todos estos diseños tienen la limitante de no poder almacenar grandes cantidades de información y que el proceso de recuperación de la misma se realiza suspendiendo la obtención de datos.

La información obtenida por estos sensores era traducida y enviada vía serial hacia un PC., lo que implicaba transportar una PC al lugar de la adquisición y desarrollar y ejecutar un programa en la PC para la recepción de la información.

Por lo anterior, se planteó la necesidad de desarrollar un controlador flexible que pudiera adecuarse a las características de estos y otros proyectos permitiendo el almacenamiento y recuperación de grandes volúmenes de información.

#### 1.2) CARACTERISTICAS DEL CONTROLADOR

La idea básica de este diseño es contar con los elementos de salida para controlar el movimiento de sensores o estaciones de muestreo, tener la capacidad de recibir datos del mismo, y poder procesar y finalmente almacenar la información en un medio magnético con formato compatible con MS-DOS. También se prevee la posibilidad de recibir o enviar información vía serie a través de un puerto.

Además, el controlador contará con un teclado y un "display" que permita la comunicación elemental con el usuario, de tal manera que se pueda accesar un archivo y desplegarlo en el "display" o pedirle que tome instrucciones de algún archivo en disco.

La posibilidad de almacenar información en un medio magnético le da flexibilidad al sistema. Por un lado, le da independencia al permitir almacenar grandes cantidades de información, y por otro, ser versátil en su programación, ya que puede programársele en cualquier momento.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

14

Se pensó en darle la característica de guardar la información en formato MS-DOS, ya que esto facilitaría el procesamiento de la información almacenada en una PC compatible a través de cualquier hoja de cálculo comercial, lo que haría aun más versátil su funcionalidad.

#### 1.3) ENLACE CON DISPOSITIVOS DE MEDICION

El controlador debe contar con elementos de enlace que le permitan controlar un dispositivo de medición o sensor. El diseño del controlador contempla elementos comunes de hardware para el control del uno o varios sensores diferenciándolos entre sí por software.

De esta forma, el controlador no sólo podrá determinar cuando mover o no un sensor, sino cuando efectuar una lectura a través de este dispositivo.

Esta tesis no contempla en su alcance, el desarrollo del software para controlar un sensor o estación de muestreo en específico, ya que esto depende de las características particulares de estos dispositivos.

#### 1.4) INTERFAZ CON UNA UNIDAD DE DISCOS FLEXIBLE

El punto más importante de esta tesis es la interfaz con una unidad de disco flexible en formato compatible con el sistema operativo MS-DOS.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

15

Se consideraron dos alternativas para darle solución a esto. La primera de ellas es la opción de desarrollar todo el hardware necesario para hacer interfaz con una unidad de disco flexible. Esta opción además de resultar cara, implica alcances no contemplados en este proyecto, así como el limitar severamente la posibilidad de actualización de dicha interfaz, ya que se tendría que modificar lanto hardware como software.

La segunda opción, por la cual se decidió, es utilizar una tarjeta controladora de disco flexible para PC XT compatible, de tal forma que sólo se desarrolle el software de interfaz con dicha tarjeta controladora. Esto permite la posibilidad de reemplazar dicha tarjeta con la unidad de disco en caso de querer hacer una actualización al sistema.

#### 1.4.1) CONCEPTOS GENERALES DE LA INTERFAZ

A continuación se describen los requerimientos para hacer la interfaz con una tarjeta controladora de unidades de disco flexible de baja densidad (5 ¼ in.). Estos requerimientos son iguales para cualquier controladora de discos utilizada en una PC XT. Adicionalmente, se describirán las características de interfaz para una tarjeta controladora que maneje discos de alta densidad (3 1/2 in.) normalmente utilizados en las PC AT dejando la posibilidad en un futuro, si así lo requiere las necesidades del proyecto, de utilizar un medio magnético de mayor capacidad de almacenamiento.

#### 1.4.2) REQUERIMIENTOS DE LA INTERFAZ

Las tarjetas controladoras de discos flexibles basadas en el 82072 ocupan un "slot" sobre los canales de Entrada/Salida (E/S) de las computadoras personales.

Como es sabido, el canal de E/S de una PC AT difiere del canal de una PC XT, pero el conjunto de señales utilizado por la tarjeta controladora es el mismo en ambos casos.

La tarjeta controladora de disco requiere los recursos del procesador central, del DMA y del controlador de interrupciones.

El sistema de control de unidades de disco consiste en 5 elementos funcionales:

- 1) Interfaz entre la tarjeta controladora y el canal de E/S.
- 2) Generación de "Chip-Select"
- 3) Generación de Reloj para el 82072
- 4) Interfaz con el DMA
- 5) Interfaz con la unidad de discos

Los puntos 3 y 5 no son del interés de este trabajo, ya que internamente dentro de la tarjeta controladora se encuentra todo el hardware necesario para el manejo de la unidad de disco flexible así como la generación del reloj para el 82072.

La interfaz con el canal de E/S requiere de las siguientes líneas:

- 10 líneas de direcciones (A0 hasta A9)
- 8 líneas de datos (D0 hasta D7)
- 4 líneas para el control de escritura/lectura que son: MEMW^,
   MEMR^, IOW^, IOR^.
- 6 líneas para el control que son: RESET, T/C, AEN, DRQ2, DACK2^, IRQ6.

Las señales que tengan un " ^ " significa que son verificadas en estado bajo.

La interfaz con el DMA requiere de tres señales básicas que son T/C

· (Terminal Count), DRQ2 (Data Request en el canal 2 del DMA) y DACK2^ que es
la línea de reconocimiento para dicho canal.

Cabe hacer notar que en un ambiente de PC, la transferencia de información de disco o hacia disco tiene que hacerse en modo byte-byte. Sin embargo en la tarjeta controladora como en otro tipo de sistemas se puede realizar transferencias de bloques completos de información (modo "burst").

La señal IRQ6, es utilizada por la tarjeta controladora para interrumpir al microprocesador. Más adelante veremos la función específica de dicha interrupción.

Para soportar las diferentes capacidades de "drivers" y los diferentes tiempos de transferencia de datos, existen 3 registros incorporados en la tarjeta controladora de discos flexibles. Estos tres registros son los siguientes:

- DRR (Data Rate Register)
- DIR (Digital Input Register)
- + DOR (Digital Output Register)

#### **DRR (Data Rate Register)**

(Controladoras de diskette de alta densidad exclusivamente).

Este registro de sólo escritura y seleccionado en la dirección 3F7H especifica la unidad de disco y el tipo de disco utilizado. El valor de este registro es utilizado por la tarjeta controladora de alta densidad para seleccionar la velocidad de transferencia de datos y la velocidad de giro de la unidad de disco. A continuación se muestra una tabla con la decodificación para este registro.

| D1       | D0 | DESCRIPCION          |
|----------|----|----------------------|
|          |    | RESERVADO            |
|          | •  | DD DRIVE DD DISKETTE |
| > •      |    | QD DRIVE DD DISKETTE |
| <b>P</b> | •  | QD DRIVE QD DISKETTE |

DD = Doble Densidad y QD = Cuádruple Densidad

Tabla I.1

#### **DOR (Digital Output Register)**

Este registro es de sólo escritura y se encuentra en la dirección 3F2H. A continuación se presenta una tabla con el significado de cada uno de los bits que conforman este registro

| BITS . | DEFINICION                                                                                                                                                                                                                                                      |  |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|        | Selección de Drive: 0 en este bit indica que el drive A está seleccionado, 1 indica que el drive B está seleccionado.                                                                                                                                           |  |  |
|        | Reservado: Puede ser 0 ó 1                                                                                                                                                                                                                                      |  |  |
| 2      | Función de Reset: Cuando este bit es puesto a 1, la función de reset es deshabilitada                                                                                                                                                                           |  |  |
|        | Habilita DMA e Interrupción: Cuando este bit es puesto a 1, las<br>lineas para DMA y la de Interrupción son habilitadas                                                                                                                                         |  |  |
|        | Habilitador del Motor del Drive A: Cuando este bit es puesto a 1, la<br>señal de habilitar el motor A es activada. Un "timer" es dedicado a<br>realizar la función de deshabilitar el motor. El "timer" es inicializado<br>en función del comando seleccionado. |  |  |
|        | Habilitador del Motor del Drive B: Igual que el bit anterior                                                                                                                                                                                                    |  |  |
| 90     | Reservado: Igual que el bit 1                                                                                                                                                                                                                                   |  |  |
| 7 (1)  | Reservado: Igual que el bit 1                                                                                                                                                                                                                                   |  |  |

Tabla I.2

#### **DIR (Digital Input Register)**

(Controladoras de diskette de aita densidad exclusivamente).

Este registro es de sólo lectura y el único bit usado por la tarjeta controladora de discos flexibles es el 7.

Este bit es utilizado exclusivamente cuando se está manejando un drive de alta densidad. La función primordial de este bit es informar al sistema que un

diskette ha sido cambiado (cuando está puesto a 1). Este bit es automáticamente puesto a 0 cuando se realiza una operación de búsqueda (Seek).

A continuación se presenta una tabla mostrando el mapa de direcciones con los registros mencionados.

| DIRLCCION   | TIPO DE ACCESO | REGISTRO            | MODELO |
|-------------|----------------|---------------------|--------|
| <b>CONT</b> |                | NO USADO            |        |
| <b>**</b>   |                | NO USADO            | 5      |
| * ##        | ESCRITURA      | DIGITAL OUTPUT REG. | XT/AT  |
| 97.94       |                | NO USADO            |        |
| 7.6         | LECTURA        | MAIN STATUS REG.*   | FDC    |
|             | ESC./LEC.      | DATA REGISTER *     | FDC    |
|             |                | NO USADO            |        |
| 471         | ESCRITURA      | DATA RATE REGISTER  | AT     |
| en.         | LECTURA        | DIGITAL INPUT REG.  | AT     |

FDC = Floppy Disk Controler

Tabla 1.3

#### 1.4.3) CONTROL DE LA INTERFAZ

El FDC (Floppy Disk Controler) controla los motores de la unidad de discos y las cabezas, además de manejar el flujo de datos de y hacia los sectores del disco. Una tarjeta controladora puede manejar hasta 4 unidades de disco.

<sup>\*</sup> Estos registros son utilizados tanto en una XT ó AT

El FDC maneja 15 operaciones en total, de las cuales utilizaremos 8 :

- SPECIFY
- SENSE DRIVE STATUS
- SENSE INTERRUPT STATUS
- . SEEK
- RECALIBRATE
- \* READ DATA
- \* WRITE DATA
- READ ID

**SPECIFY**: Este comando coloca los valores iniciales para cada uno de los tres temporizadores o timers. El "Head Unload Time" (HUT), el "Step Rate Time" (SRT) y el "Head Load Time" (HLT).

SENSE DRIVE STATUS: Este comando se utiliza cuando el procesador desea obtener el estado de las unidades de disco.

SENSE INTERRUPT STATUS: Una señal es generada por el Floppy Disk Controler dependiendo de situaciones específicas que pueden ser de utilidad para el programador.

**SEEK**: Este comando permite posicionar la cabeza en un "track" ó cilindro determinado.

RECALIBRATE: Este comando es utilizado para colocar la cabeza de la unidad de discos al "track 0" y tener un punto de inicio.

WRITE DATA: Comando utilizado para escribir información a disco.

READ DATA: Comando utilizado para leer información de disco.

**READ ID**: Este comando es utilizado para dar la posición actual de la cabeza en función del agujero índice que traen todos los discos.

Las operaciones en el Floppy Disk Controler se realizan en tres fases: la fase de comando, la de ejecución y la de resultado.

En la fase de comando, uno o más bytes son enviados al "Data Register" del FDC. La secuencia de bytes es estricta y varia dependiendo del comando. El FDC reconoce el comando e inicia la fase de ejecución. Finalmente, durante la fase de resultado, un número de bytes se genera para informarle al procesador el estado de la operación. Es imperativo que no exista error en el número de bytes enviados o leídos a o del "Data Register".

El número de bytes enviados o leídos depende de la operación que realice el FDC. Para el caso de lectura o escritura a un sector, se necesitan 7 bytes adicionales al comando en sí. Estos siete bytes indican track, cabeza, sector y cuatro bytes adicionales. El primero de los cuales es el número de bytes por sector (en el caso más utilizado es 2 para 512 bytes por sector). El segundo indica el número de sectores por track (9 para un floppy de 360 kbytes). Los

últimos dos bytes indican el "Gap Lenght" y el "Data Lenght" (Normalmente 2AH y FFH respectivamente).

A continuación se describe los pasos a seguir por el procesador para leer un sector determinado en un disco.

- Enviar la señal para encender el motor y esperar a que estabilice su velocidad.
- 2) mover la cabeza del drive a la posición de inicio de lectura mediante la operación de búsqueda ("seek").
- 3) Monitorear el fin de la operación de búsqueda a través del cambio de estado del bit 7 del byte de "status" de la operación seek.
- 4) Inicializar al DMA para mover los datos a memoria.
- 5) Enviar las instrucciones al FDC.
- 6) Leer la información del FDC.
- 7) Apagar el motor.

En páginas anteriores mencionamos que la tarjeta controladora de discos flexibles utiliza la interrupción No.6 (IRQ6) para indicarle al procesador que terminó la operación de búsqueda a través de modificar el estado del bit 7 del byte de "status" de la operación seek en la BIOS DATA AREA localidad 0040:003E.

La IRQ6 es utilizada para evitar que el procesador esté continuamente leyendo el "Status Register" del FDC, ya que la operación de búsqueda es la que más tiempo ocupa en el acceso a disco y además su tiempo varía dependiendo

de donde se encuentre posicionada la cabeza,. Esto le permite al procesador realizar actividades síncronas en paralelo al movimiento de la cabeza del drive.

#### INTERFAZ CON EL USUARIO

La interfaz contemplada para este diseño consta de un "display" alfanumérico de cristal líquido y un teclado estándar de matriz. Estos tienen la función de permitir la comunicación elemental entre el usuario y la tarjeta controladora de tal manera que se pueda realizar las siguientes operaciones:

| 1) | DIR                                       | -Desplegar nombres de archivo en disco- |  |
|----|-------------------------------------------|-----------------------------------------|--|
| 2) | LEE Y EJECUTA                             | -Pasar información de disco a memoria y |  |
|    |                                           | ejecutar a partir de esa localidad-     |  |
| 3) | ESCRIBE                                   | -Pasar información de memoria a disco-  |  |
| 4) | RELOJ -Programar el reloj de tiempo real- |                                         |  |

-Programar el reloj de tiempo real-

Para lograr la máxima flexibilidad en el diseño, la interfaz con el usuario no se limitan al teclado y al "display", sino que abarca la comunicación vía serial con una computadora personal.

Si es que se requiere, se puede sustituir el teclado y "display" local de este controlador por el monitor y el teclado de la PC. Esto nos permite graficar y procesar la información en el lugar y en el momento de la adquisición de la misma.

#### 1.6) DIAGRAMA GENERAL DE BLOQUES

Integrando los elementos presentados en este capítulo, el diagrama general de bloques del controlador digital tiene las siguientes caracterísiticas.

#### CONTROLADOR DIGITAL



FIGURA 1.1

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

26

## **CAPITULO II**

## MANEJO DE ARCHIVOS EN MS-DOS

#### II.1) CONCEPTOS GENERALES DE LA ESTRUCTURA DE UN DISCO

El almacenamiento en disco está basado en dos cosas principalmente: tecnología de grabado y un esquema de rápido acceso.

La tecnología utilizada es el grabado magnético. El grabado digital magnético es hecho en una superficie de material magnéticamente sensible, usualmente de una forma de óxido de cobre, lo cual le da su color característico café. El recubierto magnético es muy delgado y usualmente cubre a un material de soporte plástico de tipo "mylar".

La superficie del disco es tratada como una matriz de puntos. Cada uno de estos puntos son caracterizados como bits y podrán ser puestos a su equivalente magnético "0" ó "1". Debido a que la localización de estos puntos no está precisamente determinada, los esquemas de almacenamiento involucran marcas para reconocer posiciones. Esta es una de las razones por las cuales los discos tienen que ser "formateados" previamente antes de ser usados.

En lo que respecta al esquema de rápido acceso, existe una diferencia entre el concepto de cinta magnética, -que es escencialmente lineal porque la información tiene que ser almacenada en ésta del frente hacia atrás y no hay manera sencilla de saltar al centro de la misma-, y un disco rotatorio.

El disco rotatorio tiene dos características importantes que hacen posible el llegar a cualquier parte de su superficie rápidamente.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingenlería UNAM

28

La primera es la rotación del disco. El disco gira sobre sí mismo a 300 R.P.M., es decir que cada 120 milésimas de segundo se tendrá acceso al mismo lugar en sentido circunferencial.

La segunda es el movimiento de la cabeza grabadora, la cual atraviesa el disco en forma radial de la parte más externa hasta la parte más interna del disco y viceversa. Este movimiento se realiza en un promedio de 100 milisegundos. Utilizando estos dos factores es como se puede llegar a cualquier parte del disco en un tiempo muy corto. Esta es la razón por la cual los discos son llamados unidades de almacenamiento de acceso aleatorio, ya que podemos accesar cualquier dato directamente sin necesidad de pasar a través de toda la información de manera secuencial como lo haríamos en una cinta magnética.

Para el uso en una computadora personal, el disco es dividido en anillos concéntricos, llamados cilindros o "tracks". El número de "tracks" varía dependiendo del tipo de disco.

Independientemente del número de "tracks" que posea un disco, estos son siempre identificados por un número, empezando por el "0" que es el track más alejado del centro del disco.

Al igual que la superficie del disco es dividida en anillos concéntricos, cada anillo concéntrico es dividido a su vez en partes llamadas "sectores" que son de un tamaño fijo.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

29

Todas las lecturas o escrituras a disco son hechas en términos de sectores completos. Los sectores son identificados mediante números asignados a ellos.

Para los propósitos particulares de este proyecto, se utilizarán discos de doble densidad, es decir, el grabado al disco se realiza alternamente en ambas caras. Lo que implica contar con dos cabezas lectoras.

Los discos de doble densidad cuentan con 40 "tracks" por lado, 9 sectores por "track" y cada sector es de 512 bytes (figura II.1)



Figura II.1

#### II.2) Estructura en MS-DOS

Como ya mencionamos anteriormente, el sector en un disco es la unidad fundamental para las operaciones del mismo. Para el sistema operativo MS-DOS, no existen tracks, ni lados, solamente sectores. DOS numera los sectores de un disco de manera secuencial empezando con "0" para el primer sector del track 0 del lado 0 y continuando con el segundo sector del mismo track y del mismo lado, cuando termina un track continua con el mismo track pero del otro lado del disco (figura II.2).



Figura II.2

Para organizar la información en un disco, DOS divide a éste en dos partes: Una parte pequeña, la cual DOS utiliza para mantener registro de información clave acerca del disco, y la zona mayor para los datos en sí. La primera es conocida como área del sistema y a su vez es dividida en tres partes: área de "boot", área de "FAT" y área del directorio Raíz (Root).



Figura II.3

#### H.2.1) AREA DE BOOT

El área de "boot", contenida en el sector lógico "0", contiene toda la información indispensable acerca de las características del medio magnético (ver figura II.4).

El primer byte en el sector es siempre una instrucción de salto, que puede ser dentro del segmento (opcode 0E9H) seguida de un desplazamiento de 16 bits o un salto corto (opcode 0EBH) seguido de un desplazamiento de 8 bits y después por un NOP (opcode 90H). Si ninguno de estos dos saltos está presente implica que el disco no está formateado.



Figura II.4

Después de la instrucción inicial de salto, en el byte 03h, encontramos un campo de 8 bytes reservado para la identificación del programa que formateó el disco.

El tercer componente de esta sección es el Bios Parameter Block (BPB) localizada entre los bytes OBH y el 17H. Esta estructura describe las características físicas del disco y permite al "device driver" calcular las direcciones físicas para un sector lógico dado. También el BPB contiene información que es usada para calcular la dirección y tamaño de cada una de las áreas de control del disco (área de FAT y área del directorio Raíz).

Después de BPB se encuentran tres palabras (offset 18H, 1AH y 1CH) que le especifican al "device driver" el número de secotres por FAT, de cabezas y de sectores ocultos.

El último elemento que compone el sector de boot (offset 1EH) es el programa de "bootstrap" que se encarga primitivamente de transferir el control al Basic Input Output System "BIOS" de máquinas compatibles con MS-DOS.

El sector de boot es parte del área reservada que puede ser de varios sectores. El tamaño de esta área reservada está escrito en el BPB en el desplazamiento 0EH.

#### 11.2.2) AREA DE "FAT"

Esta área debe sus siglas a "File Allocation Table", y es de suma utilidad para que el sistema operativo mantenga información acerca del área de datos. Esta área es simplemente una tabla de números, donde se relacionan para cada archivo, los sectores del área de datos asociados a éste.

Un archivo, al ser creado o modificado, se le asignan o reasignan sectores del disco en potencias de 2 conocidas como "allocation units" o clusters. El número de sectores por cluster está definido en el BPB en el byte ODH.

La FAT está dividida en campos que corresponden directamente a clusters asignados en el disco. Estos campos son de 12 bits o de 16 bits según la versión del sistema operativo y de la capacidad del medio magnético de que se trate (12 bits si es disco flexible y 16 bits para discos duros).

Los primeros dos campos en la FAT son reservados, en el caso de discos flexibles donde la FAT es de campos de 12 bits, serán los tres primeros bytes. Para discos duros cuya FAT es de 16 bits, los dos primeros campos ocupan cuatro bytes. En ambos casos, los primeros 8 bits del primer campo reservado contiene una copla del "media descriptor byte" que también se encuentra en el BPB. El resto de los bits del primer campo y del segundo campo son 1.

Por el número almacenado en cada entrada de la FAT, se determina el estado que tienen cada uno de los clusters, que a su vez corresponden a sectores del disco. En la tabla II.1 se describe el posible contenido de los campos.

| VALOR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | SIGNIFICADO                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | CLUSTER DISPONIBLE            |
| A ALLES ALLES                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CLUSTER RESERVADO             |
| erial) de la                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | CLUSTER DAÑADO                |
| Carlotte and The                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ULTIMO CLUSTER DEL ARCHIVO    |
| CONTRACT CON | SIGUIENTE CLUSTER DEL ARCHIVO |

Tabla II.1

Cada entrada de archivo en el directorio del disco contiene su cluster de inicio. Este cluster inicial nos indica la posición dentro de la tabla de la FAT donde está almacenado el siguiente cluster del archivo. Esto se repite hasta localizar el cluster que señala el fin de archivo.

La forma en como se interpreta el contenido del área de Boot y de la File Allocation Table (FAT) se muestra a continuación.



Figura II.5

Del Bios Parameter Block (BPB) se obtiene:

- 512 Bytes por sector (0200h)
- 2 sectores por cluster (02h)
- 2 sectores por FAT (0002h)
- 2 FAT's (02h)
- 112 entradas de directorio (0070h)

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM De esta información podemos calcular el número del sector de inicio lógico de cada una de las áreas de control del disco y del área de archivos contruyendo una tabla como sigue:

| AREA                  | LONGITUD   | NÚMERO DE SECTOR  |
|-----------------------|------------|-------------------|
| And the second second | 1 sector   | 00                |
|                       | 2 sectores | 01 - 04           |
|                       | 7 sectores | 05 - 0Bh          |
|                       |            | 12 sectores (0Ch) |

Por lo tanto, el primer sector del área de archivos es el 12 (0Ch)

Tabla II.2

Al leer el disco en el sector correspondiente al inicio de la FAT (sector 01) obtenido en la tabla anterior se puede observar la secuencia de los cluster de algunos archivos (Figura II.6)



Figura II.6

Diseño de un Controlador Digital con unidad de disco Facultad de ingeniería UNAM En la figura anterior se observa que los primeros dos clusters (formados por los 3 primeros bytes) son reservados. El primer archivo inicia a partir de ellos en el cluster 2, y siguendo la secuencia "xyz" y "abc" se relacionan los siguientes clusters como se muestra en la siguiente tabla:

| GLUSTER   | 02        | 03        | 04        | 05        | 006       |
|-----------|-----------|-----------|-----------|-----------|-----------|
| CONTENIDO | 003 (xyz) | 004 (abc) | 005 (xyz) | 006 (abc) | FFF (xyz) |

Tabla II.3

#### II.2.3) AREA DEL DIRECTORIO RAIZ

El- directorio raíz puede ser visto como un catálogo que describe el contenido de un disco. Esta área lleva los nombres de los archivos dentro del área de datos, así como el nombre de los archivos especiales llamados subdirectorios.

El tamaño y la posición del directorio raíz es fija y está determinada por el formato del disco. El número de entradas en el directorio raíz y la localización del mismo pueden ser determinados mediante la información del BPB como se mostró con el ejemplo anterior.

Cada disco tiene un único directorio raíz, en el cual puede haber desde ningún subdirectorio hasta tantos como el disco pueda almacenar. Estos

subdirectorios a su vez pueden contener tantos subdirectorios como se deseen (figura II.7)



Figura II.7

Cada entrada del directorio raíz, ya sea nombre de archivo o nombre de subdirectorio, tiene un espacio único de 32 bytes. En la siguiente figura vemos las características de esta entrada.

| BYTE  | DESCRIPCION        | COMENTARIOS |
|-------|--------------------|-------------|
|       | NOMBRE DEL ARCHIVO | NOTA 1      |
|       | EXTENSION          |             |
|       | ATRIBUTOS ARCHIVO  | NOTA 2      |
|       | RESERVADO          |             |
|       | TIEMPO             | NOTA 3      |
|       | FECHA              | NOTA 4      |
|       | CLUSTER INICIAL    | NOTA 5      |
| OOLCH | TAMAÑO ARCHIVO     | 4 BYTES     |

Tabla II.4

#### Notas a la Tabla II.4:

NOTA 1: El primer byte del campo del nombre de archivo puede contener la siguiente información:

| VALOR      | SIGNIFICADO                                                                                                                                                                                                                      |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00H        | LA ENTRADA A ESTE DIRECTORIO NUNCA HA SIDO USADA, FIN DEL DIRECTORIO                                                                                                                                                             |
| <b>06H</b> | EL PRIMER CARACTER DEL NOMBRE DE ARCHIVO ES ACTUALMENTE E5H                                                                                                                                                                      |
| 2EH        | LA ENTRADA ES UN ALIAS PARA EL ACTUAL SUBDIRECTORIO. SI EL SIGUIENTE BYTE ES 2EH, ENTONCES EL CAMPO DEL CLUSTER CONTIENE EL NUMERO DE CLUSTER DEL DIRECTORIO PREDECESOR (CERO SI EL DIRECTORIO PREDECESOR ES EL DIRECTORIO RAIZ) |
| te:        | EL ARCHIVO HA SIDO BORRADO                                                                                                                                                                                                       |

NOTA 2: El byte de atributos es codificado como sigue:

| BIT                                    | SIGNIFICADO                                         |  |  |  |  |
|----------------------------------------|-----------------------------------------------------|--|--|--|--|
|                                        | SOLO LECTURA                                        |  |  |  |  |
|                                        | ARCHIVO OCULTO                                      |  |  |  |  |
|                                        | ARCHIVO DEL SISTEMA                                 |  |  |  |  |
|                                        | ETIQUETA DEL VOLUMEN                                |  |  |  |  |
|                                        | SUBDIRECTORIO                                       |  |  |  |  |
|                                        | ARCHIVO (ENCENDIDO CUANDO EL ARCHIVO ES MODIFICADO) |  |  |  |  |
| ************************************** | RESERVADO                                           |  |  |  |  |
|                                        | RESERVADO                                           |  |  |  |  |

NOTA 3: El campo del tiempo se codifica como sigue:

| BITS     | CONTENIDO '                                                                   |  |  |  |
|----------|-------------------------------------------------------------------------------|--|--|--|
| oon ogh  | NUMERO BINARIO DE MULTIPLOS DE 2 SEGUNDOS (0-29, CORRESPONDE A 0-58 SEGUNDOS) |  |  |  |
| OCEH-CAH | NUMERO BINARIO DE MINUTOS (0-59)                                              |  |  |  |
| dell     | NUMERO BINARIO DE HORAS (0-23)                                                |  |  |  |

NOTA 4: La codificación del campo de la fecha es:

| BITS    | CONTENIDO             | * 2 |
|---------|-----------------------|-----|
| COLOCAL | DIA DEL MES (0-31)    |     |
|         | MES (1-12)            |     |
|         | AÑO (ASOCIADO A 1980) |     |

NOTA 5: El campo del tamaño del archivo es interpretado como un entero de 4 bytes, con los dos bytes menos significativos almacenados primero.

Si el disco es utilizado para cargar el sistema operativo, las dos primeras entradas en el directorio raíz siempre son para los archivos del MS-DOS BIOS y del MS-DOS KERNEL.

También el directorio raíz puede contener una entrada especial llamada etiqueta del volumen, la cual da el nombre a todo el disco.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM En la figura II.8 se muestra el primer sector de un directorio raíz:



Figura II.8

Como mencionamos, los subdirectorios son un tipo de archivo especial que pueden contener descriptores de archivos de datos o apuntadores a otros subdirectorios. Una entrada de este tipo de archivo se caracteriza por tener el bit 4 puesto en 1 del byte de atributos y 0 en el tamaño de archivo. El campo del número de cluster apunta al primer cluster que implementa el subdirectorio.

Los cluster adicionales sólo pueden ser encontrados siguiendo la cadena de clusters a través de la FAT. En la siguiente figura se muestra la entrada a un subdirectorio.



Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM Dentro de un subdirectorio, el formato de entrada para un archivo o para otro subdirectorio es exactamente igual que en el directorio raíz, es decir que las entradas son únicas y de 32 bytes.

Existen dos entradas especiales "." y "..", que todos los subdirectorios tienen y que se generan al momento de su creación y no pueden ser borradas. El punto se refiere al subdirectorio actual con la característica de que el campo de cluster apunta al cluster en el cual el subdirectorio se encuentra. El doble punto se refiere al subdirectorio predecesor donde el campo del cluster apunta al primer cluster del directorio predecesor. Si el directorio predecesor es el raíz, este campo es cero. A continuación se muestra el primer block de un subdirectorio.



Primer archivo del subdirectorio (MYFILE.DAT)

Figura II.10

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

# **CAPITULO III**

# DISEÑO DEL CONTROLADOR

# III.1) DESCRIPCION GENERAL DEL CONTROLADOR

El controlador está compuesto por un procesador 8088, controladores de acceso directo a memoria, controladores de interrupciones y del "driver". Además cuenta con dispositivos de entrada y salida en serie y paralelo, memorias ROM y RAM y un reloj de tiempo real. Así como elementos para interactuar con el usuario: un "display" de cristal líquido y un teclado de matriz.

En la figura III.1 se muestra un diagrama de bloques del controlador:.



Figura III.1

Aunque en la figura III.1 no se muestra una computadora personal, se puede utilizar ésta para sustituir al "display" y al teclado de matriz en la interacción con los usuarios.

El controlador se diseñó usando básicamente integrados de los denominados "LSI" (Integración en gran escala) y complementando con integrados de menor complejidad, encargados de "adaptar" las señales provenientes de integrados de familias distintas.

En contraste con los componentes mayores, que son integrados LSI o VLSI construidos típicamente con tecnología MOS, o alguna pequeña variación de ésta, los integrados que realizan la "adaptación" suelen ser constituidos con tecnología bipolar TTL, con baja o media escala de integración (SSI o MSI).

Gracias a esta tecnología, el sistema puede codificar y decodificar las señales de control y separar y combinar señales de direcciones y de datos provenientes de los chips procesadores y controladores.

En los sistemas actuales se hace imprescindible el poder combinar estas señales (control, datos y direcciones) debido a que, en general, hay más señales necesarias que líneas para transportarlas.

# III.2) PRINCIPALES COMPONENTES DEL CONTROLADOR

#### Microprocesador 8088

El microprocesador que se escogió para desarrollar este sistema fue el 8088 ya que es de bajo costo, está ampliamente disponible en el mercado nacional y reúne las características necesarias para el diseño.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

El 8088 es un microprocesador con atributos tanto de procesadores de 8 como de 16 bits. Está diseñado para operar autogenerando sus señales del bus de control (modo mínimo) o para depender de un controlador de buses externo como el 8288 (modo máximo).

La configuración que se utiliza es la mínima, porque ésta soporta los requerimientos del controlador además de simplificar el diseño.

Entre las principales características de este procesador es que tiene un bus de direcciones de 20 bits, lo que le permite accesar hasta un millón de bytes direccionándolos de 00000(H) a FFFFF(H) divididas en segmentos de 16 bits (64 kbytes).

Todos los accesos a un segmento de memoria están referenciadas a la dirección base donde inicia dicho segmento y a incrementos tomados a partir de la base.

Otra característica es que este procesador comparte el bus de direcciones con el bus de datos (A0-A7 con D0-D7), esto se hace mediante un multiplexado en el tiempo, es decir, se envian señales distintas en tiempos diferentes por las mismas líneas. Por ejemplo, durante el acceso a memoria, la dirección se envia en el primer ciclo de reloj y los datos en los ciclos posteriores.

Sin embargo, como las memorias requieren que la dirección y el dato se presenten simultáneamente, es necesario contar con lógica intermedia que separe y guarde temporalmente tanto el dato como la dirección, y usar

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

determinadas señales del procesador para diferenciar a las direcciones de los datos y si estos se leen o escriben a un puerto o memoria. Estas señales de control que genera el procesador son seis y se agrupan en el bus de control del procesador.

De estas señales: Address Latch Enable (ALE) y Data Enable (DEN) se utilizan para que la lógica intermedia pueda determinar si la información enviada es una dirección o un dato. Gracias a ellas, parte de la circuitería externa al CPU puede trabajar con las direcciones e ignorar los datos, mientras que otra parte de la misma circuitería ignora las direcciones para guardar la información sobre los datos.

Las otras señales que componen el bus de control son: Data Transmition/Reception (DT/R^), Input Output/Memory (IO/M^), Read (RD^) y Write (WR^). Todas ellas utilizadas para controlar el flujo de datos y direcciones de y hacia el procesador.

Las señales que utiliza el procesador para ceder ordenadamente el control del bus del sistema al DMA ante una solicitud de éste son HOLD y HLDA.

El microprocesador reconoce dos tipos de interrupciones, las de software y las de hardware. Esta última, se clasifica en mascarables y no mascarables. La no mascarable está ligada a la señal NMI y tienen una prioridad superior a las mascarables que se reciben a través de la señal Interrup Request (INTR).

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

Las interrupciones por software se reciben a través de código máquina, relacionándolas con una tabla de hasta 256 elementos de 4 bytes cada uno, que contienen el apuntador a la dirección donde se localiza el programa de servicio a esa interrupción. Esta tabla se localiza en las localidades absolutas de 0 a 3FFH que es el primer kbyte de memoria.

### Generador de Pulsos de Reloj 8284

El Generador de Pulsos de Reloj 8284 genera cuatro señales importantes para el controlador.

La primera, CLK, que son los pulsos de reloj que determinan la velocidad de funcionamiento del sistema (los pulsos generados tienen un ciclo de trabajo de 33%). Esta señal es generada a una frecuencia de 4.77 MHz por medio de un cristal de 14.318 MHz conectado al generador.

La de RESET, que inicializa al procesador, y ejecuta las instrucciones empezando con la localidad de memoria predeterminada (FFFF0H). En algunos casos, permite interrumpir un programa que ha entrado en un bucle infinito.

La tercera, READY, que sincroniza al procesador con los dispositivos de más lento acceso.

Y la de PCLK (Reloj Periférifo), cuya frecuencia es la mitad de la de CLK, con un ciclo de trabajo de 50% del período.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

# Controlador Programable de Acceso Directo a Memoria 8257

El 8257 es un controlador programable de cuatro canales de acceso directo a memoria, que permite la tranferencia de bloques de información de hasta 64 kbytes entre la memoria y un dispositivo periférico (un puerto o el controlador del "driver") sin la intervención del procesador.

Este componente recibe las solicitudes del dispositivo periférico a través de las señales de entrada DRQ (0-3). El 8257 solicita el control del bus del sistema al procesador con la señal HRQ, que el procesador recibe vía HOLD, y espera respuesta de éste a través de HLDA.

El dispositivo periférico es avisado de que su solicitud será atendida con las señales DACK (0-3).

El 8257, atiende las solicitudes en base a su programación inicial, que establece la forma en que serán atendidas las solicitudes. Estas pueden ser de una manera cíclica o de modo fijo, es decir, asignando siempre mayor prioridad al canal 0 y menor prioridad al canal 3.

En base a la prioridad predefinida, suministra al sistema la dirección base de la memoria que cada canal tiene asignado y genera las señales de control de escribir o leer tanto a memoria como al periférico para que la transferencia directa de información se lleve a cabo.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

El 8257 mantiene el control del bus del sistema y repite la sequencia de transferencia de información mientras el periférico mantenga su solicitud o hasta que se hallan transmitido un número específico de bytes, que es cuando activa la señal TC (Terminal Count), informándole al periférico que la transferencia ha sido realizada.

Para programar este circuito, primero hay que activar su CS<sup>^</sup>, lo que lo habilita para trabajar en modo programación o "esclavo". Después, hay que inicializar el registro de dirección y de cuenta terminal para el canal que se va a utilizar y por último enviar la palabra de control que establece el modo de operación del canal. Esto se realiza en el programa de inicialización del controlador.

Los tres posibles modos de operación de cada canal son: lectura del DMA (transfiere datos de memoria a un periférico), escritura (transferencia del periférico a memoria), y verificación (validación de cualquiera de las operaciones anteriores). El modo de operación es selecccionado a través de los bits más significativos del registro de cuenta terminal del canal.

Cabe aclarar que para facilitar la programación de la tarjeta, se puede activar el AUTO LOAD a través de la palabra de control. Esto permite que el canal 2 sea utilizado en repetidas operaciones sin necesidad de volver a programar el registro de dirección. Esto lo hace internamente el DMA guardando las referencias del canal dos en el tres.

El 8257 mantiene el control del bus del sistema y repite la sequencia de transferencia de información mientras el periférico mantenga su solicitud o hasta que se hallan transmitido un número específico de bytes, que es cuando activa la señal TC (Terminal Count), informándole al periférico que la transferencia ha sido realizada.

Para programar este circuito, primero hay que activar su CS^, lo que lo habilita para trabajar en modo programación o "esclavo". Después, hay que inicializar el registro de dirección y de cuenta terminal para el canal que se va a utilizar y por último enviar la palabra de control que establece el modo de operación del canal. Esto se realiza en el programa de inicialización del controlador.

Los tres posibles modos de operación de cada canal son: lectura del DMA (transfiere datos de memoria a un periférico), escritura (transferencia del periférico a memoria), y verificación (validación de cualquiera de las operaciones anteriores). El modo de operación es selecccionado a través de los bits más significativos del registro de cuenta terminal del canal.

Cabe aclarar que para facilitar la programación de la tarjeta, se puede activar el AUTO LOAD a través de la palabra de control. Esto permite que el canal 2 sea utilizado en repetidas operaciones sin necesidad de volver a programar el registro de dirección. Esto lo hace internamente el DMA guardando las referencias del canal dos en el tres.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

Este circuito también comparte el bus de direcciones con el bus de datos mediante un multiplexado en el tiempo. A diferencia del procesador, que comparte A0-A7 con D0-D7, el DMA lo hace en A8-A15 con D0-D7. También se utiliza lógica externa y las señales del bus de control del DMA para reconocer el tipo de información que está enviando.

Las señales de control son: Input/Output Read (I/OR), I/O Write (I/OW), Memory Read (MEMR), Memory Write (MEMW), Address Enable (AEN) y Address Strobe (ADSTB).

### Memorias RAM 2016 y HM62256

El controlador utiliza memorias de acceso aleatorio de tipo estático, es decir, que no requieren de un proceso de reescritura (refresco) para asegurar la integridad de la información.

Entre las características de la tarjeta controladora, se consideró el uso de memorias de acceso aleatorio de dos capacidades diferentes. Una de 1 kbyte por 8 bits utilizada para almacenar información propia del funcionamiento de la tarjeta controladora o de los dispositivos de medición. De esta forma el programador del sistema de adquisición, no necesita mezclar datos procedente de los dispositivos de medición, con información necesaria para su control.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

Adicionalmente, se contemplan dos memoria de 32 kbytes por 8 bits para almacenar temporalmente la información proveniente de los sensores o estaciones de muestreo mientras ésta es guardada en el disco flexible.

Ambas memorias son de rápido acceso (100 ns), lo que asegura que no se requieran señales para su sincronización.

#### Memoria EEPROM 27512

La memoria de sólo lectura tiene una capacidad de 64 kbyte por 8 bits, para almacenar el programa de inicialización y control básico de toda la tarjeta, así como el "device driver" para el manejo del controlador de disco. Esta memoria es el único elemento de la tarjeta controladora que debe reprogramarse en el caso de que se cambie el medio magnético de almacenamiento.

# Controlador de Interrupciones 8259

El diseño de este sistema requiere que los dispositivos de entrada salida como el teclado, "display", los puertos serie y paralelo y el controlador del drive sean atendidos eficientemente por el procesador, es decir, que el procesador minimice el tiempo de atención a estos dispositivos.

El método más común para atender este tipo de necesidades es el poleo. En este enfoque el procesador debe recorrer secuencialmente a todos los

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

dispositivos preguntándoles si alguno requiere ser atendido. Es fácil observar que al aumentar el número de dispositivos conectados a la tarjeta aumenta el tiempo que el procesador debe dedicar a barrer todos los dispositivos, disminuyendo, en la misma proporción, la velocidad de ejecución del programa principal.

Un método más deseable es aquel que permite que el procesador esté ejecutando su programa principal y que sólo lo suspenda para ejecutar la rutina de servicio de un dispositivo cuando el mismo dispositivo así lo solicita, volviendo posteriormente, a la rutina principal en el punto donde suspendió su ejecución. De esta manera, el número de dispositivos a atender puede aumentar sin afectar el tiempo de respuesta del sistema y sólo requiere que a todos los dispositivos se les asigne un orden con el cual serán atendidos por el procesador. Este método es llamado interrupción.

En la tarjeta utilizamos el controlador programable de interrupciones 8259 que puede operar y priorizar hasta 8 interrupciones solicitadas al procesador. Internamente esta compuesto de dos registros: el registro de solicitudes de interrupción (IRR) sobre el que se determina la prioridad de las interrupciones y el registro de atención de interrupciones (ISR) que informa al procesador de las interrupciones que están siendo atendidas

Este integrado opera de la siguiente manera: recibe la solicitud de interrupción de uno de los dispositivos activándose su bit del IRR, lo analiza y envia la señal de INTR al procesador, éste, a su vez, al reconocerlo responde con un pulso de INTA^ activando el bit que le corresponde en el registro ISR del

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM dispositivos preguntándoles si alguno requiere ser atendido. Es fácil observar que al aumentar el número de dispositivos conectados a la tarjeta aumenta el tiempo que el procesador debe dedicar a barrer todos los dispositivos, disminuyendo, en la misma proporción, la velocidad de ejecución del programa principal.

Un método más deseable es aquel que permite que el procesador esté ejecutando su programa principal y que sólo lo suspenda para ejecutar la rutina de servicio de un dispositivo cuando el mismo dispositivo así lo solicita, volviendo posteriormente, a la rutina principal en el punto donde suspendió su ejecución. De esta manera, el número de dispositivos a atender puede aumentar sin afectar el tiempo de respuesta del sistema y sólo requiere que a todos los dispositivos se les asigne un orden con el cual serán atendidos por el procesador. Este método es llamado interrupción.

En la tarjeta utilizamos el controlador programable de interrupciones 8259 que puede operar y priorizar hasta 8 interrupciones solicitadas al procesador. Internamente esta compuesto de dos registros: el registro de solicitudes de interrupción (IRR) sobre el que se determina la prioridad de las interrupciones y el registro de atención de interrupciones (ISR) que informa al procesador de las interrupciones que están siendo atendidas

Este integrado opera de la siguiente manera: recibe la solicitud de interrupción de uno de los dispositivos activándose su bit del IRR, lo analiza y envia la señal de INTR al procesador, éste, a su vez, al reconocerlo responde con un pulso de INTA^ activando el bit que le corresponde en el registro ISR del

Diseño de un Controlador Digital con unidad de disco Facultad de Ingenieria UNAM

controlador de interrupciones y borrando el del IRR. Al mismo tiempo el 8259 determina la interrupción con la más alta prioridad.

Cuando el procesador genera el segundo pulso INTA<sup>^</sup>, el 8259 libera una palabra de 8 bit que contiene la dirección de inicio de la rutina de servicio al bus de datos de donde lo lee el procesador. Esto completa el ciclo de interrupción entre el procesador y el controlador de interrupciones, que borra el bit del registro ISR de la interrupción atendida. El procesador, por su parte, guarda la posición del programa que estaba ejecutando e inicia la ejecución del programa de la interrupción solicitada.

Para programar este integrado se debe habilitar la señal de CS^ y enviarle de dos a cuatro bytes con los comandos de inicialización (ICW).

El comando de inicialización uno (ICW1) le informa al controlador la forma de operar al sambio de las señales de solicitud de interrupción (nivel o transición), si operará en cascada con otros 8259's y si requiere identificar al procesador que lo controla. En nuestro caso, operará al cambiar el nivel de la señal de solicitud de interrupción (y no por transición), no se le enviará la palabra ICW3 por no operar en cascada con otros 8259 y que debe esperar el comando ICW4 para identificar al procesador como 8088.

El comando de inicialización dos (ICW2), le indica al controlador la dirección de inicio de las rutinas de servicio de cada interrupción. En cada palabra los 5 bits más significativos son las dirección (A15-A11) y los tres bits menos significativos identifican a la interrupción.

El cuarto comando (ICW4), le informa al controlador que el procesador del sistema es un 8088, que active la terminación automática de interrupciones (AEOI) en vez de esperar que la rutina de servicio genere la señal de interrupción terminada (EOI).

El controlador permite a través del uso de las palabras de control de operación (OCW) que se inhiban determinadas interrupciones, en nuestro caso habilitamos la interrupción 6 que permite que el controlador del "driver" interrumpa al procesador y la interrupción 7 que se efectua cuando el puerto serie recibe la secuencia de cambio de interfaz con el usuario.

# Interfaz programable Serie 8251

En el diseño del sistema se incluyó un interfaz programable para la transmisión en serie, ya que resulta la manera más sencilla de conectarlo con una computadora. Normalmente se utiliza la transmisión en serie pues requiere un menor número de cables, permite transmisiones a grandes velocidades con menos errores debidos al ruido.

El 8251 es un receptor/transmisor con operación síncrona o asíncrona (USART) que acepta los datos en paralelo que le envía el procesador y los convierte en una secuencia de datos para su transmisión en serie o viceversa, recibir en serie para transformarlos a paralelo. Este circuito le avisa al procesador cuándo puede recibir otro dato en paralelo para su transformación y transmisión en serie o cuándo ya convirtió un dato recibido en serie a paralelo.

Puede operar en dos modos: en el modo síncrono, donde una vez iniciada la comunicación continuamente existe intercambio de información protocolaria entre el emisor y el receptor en bloques que se envían como una unidad a una frecuencia de transmisión dada. Cabe aclarar que en el caso de que no haya dato disponible a transmitirse, el 8251 automáticamente genera y transmite caracteres de sincronia.

En el modo asíncrono, se envían unidades de hasta 10 bits (bit de inicio, bits de datos, bit de paridad y bit de fin), únicamente cuando existe información a ser transmitida. La ventaja de este modo de transmisión es que sólo se distrae al procesador para la recepción de información y no para procedimientos de sincronización.

Para simplificar la conexión entre el controlador y la PC, se decidió trabajar con el modo de transmisión asíncrono.

Antes de inciar la recepción o transmisión de información, el 8251 debe ser programado por dos palabras de control generadas por el procesador. Estas dos palabras definen completamente el modo de operación. Las palabras de control están divididas en dos formatos: la de instrucción y la de comando.

El formato de instruccion define las caracterísitcas generales de operación, es decir, si opera en modo síncrono o asincrono, si generará y verificará bits de paridad, la longitud de la palabra y sincronía externa para el modo síncrono y el número de bits de stop para el modo asíncrono.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

En el formato de comando se controla la operación del modo de comunicación seleccionado, a través de las funciones para habilitar la transmisión/recepción, el reset de errores y el control del modem.

Para que este integrado pueda interrumpir al procesador a través del controlador de interrupciones 8259 es necesario conectar la señal de RxD (Receiver Ready) al pin de la interrupción 7 del 8259.

#### Generador de Baud Rate MC14411

Para generar la velocidad de transmisión serial se utiliza un Generador de Baud Rate MC 14411. Este integrado es un generador de bases de tiempo programable. Tiene 16 salidas que nos proporciona una determinada frecuencia dependiendo de la selección del rango deseado. Este circuito tiene cuatro rangos a escoger dependiendo del factor a multiplicar la frecuencia del cristal (1.8432MHz) y hasta 35 diferentes frecuencias. En nuestro caso se optó por tomar el primer rango de frecuencias por ser estas las normalmente utilizadas.

#### Interfaz programable Paralelo 8255

Las transmisiones en paralelo son útiles en todas aquellas aplicaciones que requieren una gran velocidad y utilicen dispositivos no demasiado alejados entre sí (requiere de un mayor número de líneas para la transmisión de información).

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

No hay ninguna sincronización especial en las transmisiones en paralelo. La velocidad máxima de transmisión está limitada por la rapidez con que el sistema pueda operar los datos.

Este integrado consta de tres puertos paralelos (A, B y C), cada uno de 8 bits. El puerto C se puede dividir en dos puertos de 4 bits cada uno.

Existen tres modos de operación que pueden ser seleccionados por software para definir el funcionamiento de los puertos: Modo 0 (Basic Input/Output), Modo 1 (Strobed Input/Output) y Modo 2 (Bi-Directional Bus).

En el Modo 0, los puertos A, B y C pueden funcionar como entradas o salidas donde las salidas son "latched" y las entradas no. Como el puerto C puede ser dividido en dos puertos de cuatro bits, este modo de operación genera 16 posibles combinaciones.

En el Modo 1, se tienen dos grupos de operación 1 o 2. Cada uno de ellos contiene un puerto de 8 bits de datos (A ó B) que puede ser programado como entrada o salida donde ambas son "latched" y otro de 4 (la mitad de C) para la información de control y estatus en forma bidireccional.

El modo 2 se establece al puerto A como un bus bidireccional de 8 bits y ocupa 5 líneas del puerto C para control del mismo.

En el diseño se utiliza el modo de operación 0, donde A y C son puertos de salida y B es un puerto de entrada.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

### Reloj de tiempo real RTC 58321

El reloj de tiempo real proporciona la fecha y la hora para la grabación de los archivos de información proveniente de los dispositivos de medición.

Este reloj tiene la ventaja de contar con un oscilador integrado, por lo que no requiere un cristal externo para su base de tiempo.

Entre sus características primordiales está el poder multiplexar su bus de direcciones con el de datos.

Durante su programación se le habilita como memoria para leer o escribir un dato que puede ser la fecha o la hora y como dispositivo de entrada/salida para identificar el dato a utilizar.

Es posible programar segundos, minutos, horas, dia, semana, mes y año (lleva el control de años bisiestos).

# HI.3) DIAGRAMAS DEL CONTROLADOR

#### III.3.1) Arquitectura básica con 8088 y DMA

En la figura III.2 se muestra el diagrama de conexión entre el procesador 8088, el generador de pulsos de reloj 8284 y el DMA 8257.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM Como ya se mencionó, el 8088 opera en modo mínimo, es decir, autogenera las señales de control del bus de datos y direcciones por lo que el pin 33 es conectado a Vcc.

Existen dos señales para el manejo de interrupciones mascarables, Interrup Request (INTR) e Interrup Acknowledge (INTA). Ambas se conectan al Controlador de Interrupciones (8259) como se muestra en la figura III.5. El diseño de esta tarjeta no contempla el uso de interrupciones no mascarables, por lo que el pin 17 (NMI) está conectado a tierra para deshabilitar su función.

La señal de TEST que normalmente es utilizada en conjunto con la instrucción de WAIT, para detener temporalmente la ejecución de un programa no será utilizada en este diseño, por lo cual se conecta a tierra.

Las señales que recibe del generador de pulsos 8284 son CLK, RESET y READY.

El generador de pulsos de reloj 8284 divide en tres la frecuencia de oscilación tanto de un cristal conectado entre sus pines 16 y 17 o de una señal que se reciba por el pin 14. En este caso, se decidió utilizar un circuito oscilador por lo que la señal Frequency/Cristal select (F/C^) está conectada a Vcc. Las resistencia R1 y R2 se utilizan para darle estabilidad al circuito de oscilación.

La señales para sincronizar al procesador con otros dispositivos más lentos (AEN1^, AEN2^, RDY1, RDY2, ASYNC^, ) no son utilizadas al contar con circuitos integrados de rápido acceso. Las señales de External Frequency (EFI) y de Clock

Synchronization (CSYNC) tampoco son utilizadas. Para deshabilitarlas estas señales, se conectan como se muestra en la figura III.2



Figura III.2

El 8284 genera la señal de RESET para el sistema a través de un circuito RC conectado a un "Schmitt Trigger" interno del 8284 en el pin RES^.

Esta señal junto con la de PCLK son utilizadas por el DMA 8257 (Direct Memory Access).

El DMA al recibir el DRQ2 proveniente del controlador de disco (figura III.5), solicita al procesador el control del bus del sistema. Una vez concedido, el DMA le avisa al controlador del "driver" con DACK2 que puede iniciar la transferencia de información.

#### III.3.2) Control de Buses

Este circuito se diseñó para garantizar que el multiplexado de señales tanto del procesador como del DMA sea eficiente y asegurar que sólo uno de estos dispositivos controlará el bus del sistema.

La lógica externa permite separar las direcciones de los datos. En ella se observa que para el control del bus de datos se utiliza un circuito integrado 74LS245 que permite manejar los datos en forma bidireccional. Se utiliza la señal del microprocesador que controla la dirección de los datos DT/R^ para identificar si es entrada o salida y DEN^ como pulso para activar la "captura" del dato válido. En el caso de que sea el DMA el que tenga control sobre el bus no se requiere circuitería especial para manejar los datos.

Se utilizaron tres circuitos integrados 74LS373 y la combinación de las señales de control ALE del procesador y AEN y ADSTB del DMA para habilitar adecuadamente a estos circuitos e inhibir la posible contención de buses.

En el caso de que sea el microprocesador el que genera la dirección, los bits menos significativos (A0-A7) son capturados en el primer "latch" utilizando la

señal del procesador ALE y AEN del DMA. Los siguientes ocho bits (A8-A15) como no se multiplexan no se tienen que almacenar, y por último, la información de los bits más significativos (A16-A19) vuelven a capturarse usando las mismas señales que para el primer 74LS373.

Si es el DMA el que tiene control sobre el bus de direcciones, los bits menos significativos (A0-A7) que no se multiplexan, no se "latchean". Los siguientes ocho bits (A8-A15) son capturados en el segundo "latch" utilizando las señales del DMA AEN y ADSTB. El DMA no genera señales para accesar más de 64 kbytes, por lo que no requiere del tercer "latch".

El último 74LS373 es utilizado como "page register" para permitir que el DMA pueda accesar el mismo mapa de memoria que accesa el procesador. Como el DMA sólo tiene 16 bits de direcciones, es necesario proveer de manera externa los 4 bits más significativos. El programador debe asegurar que los datos del "page register" correspondan a la sección de memoria que se desea utilizar.

Para generar el pulso que guarde la información de los 4 bits en el "page register", se utiliza una operación lógica NOR de las señales "chip select" del "page register" (P.R.CS^) con WR^ y DEN^. que vienen directamente del control de buses del procesador.

En la figura III.3 se muestra el diagrama de conexiones del control de buses.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingentería UNAM



Figura III.3

# III.3.2) Líneas de Control y Decodificación de Memorias y Puertos.

Como ya se mencionó, las señales del bus de control son generadas por el procesador o por el DMA. Las señales aunque equivalentes no son iguales, el procesador genera las señales de IO/M^, RD^ y WR^ mientras que el DMA genera I/OR^, I/OW^, MEMR^ y MEMW^.



Figura iii.3

# III.3.2) Líneas de Control y Decodificación de Memorias y Puertos.

Como ya se mencionó, las señales del bus de control son generadas por el procesador o por el DMA. Las señales aunque equivalentes no son iguales, el procesador genera las señales de IO/M^, RD^ y WR^ mientras que el DMA genera I/OR^, I/OW^, MEMR^ y MEMW^.

Para facilitar el control del sistema, las tres señales que genera el procesador son reacondicionadas utilizando el integrado 74LS257 para ser iguales a las del DMA. En la figura III.4 se muestra el diagrama de la conexión de este integrado.



Figura III.4

En la misma figura se observa el diagrama de decodificadores para las memorias así como para los dispositivos de entrada y salida. El objetivo de esta decodificación es asegurar que no se activen dos dispositivos simultáneamente.

La decodificación de las memorias está determinada por una característica del procesador, que al encender el sistema o después de un RESET éste apunta a la dirección FFFF0H. En esta dirección debe encontrarse siempre un salto a otra dirección donde realmente se encuentre el programa de inicialización y control de la tarjeta. Este salto y el programa de inicialización y control se encuentran pregrabados en la EEPROM 27512.

Partiendo de esta condición, el mapa de memoria se definió como sigue:

| DIRECCIONES      | DISPOSITIVOS                  | SENAL     |  |
|------------------|-------------------------------|-----------|--|
| Been Britis      | EPROM 27512 de 64K x 8        | ROM CS^   |  |
| COCCUI (STATE)   |                               | Libre     |  |
|                  |                               | Libre     |  |
|                  | Reloj de Tiempo Real          | MECKCS^   |  |
|                  | Controlador de Interrusciones | I. C. CS^ |  |
|                  | RAM2 HM62256 de 32K x 8       | RAM2CS^   |  |
| Access Contracts | RAM1 HM62256 de 32K x 8       | RAM1CS^   |  |
|                  | RAMO 2016 de 8K x 8           | RAMOCS^   |  |

Se utiliza el circuito integrado 74LS138 que decodifica las señales A17, A18, A19 e IO/M^ emitidas por el procesador para habilitar a uno de estos dispositivos.

El mapa de los dispositivos de entrada y salida es controlado por el circuito integrado 74LS139 de la siguiente manera:

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

| DIRECCIONES | DISPOSITIVOS           | SENAL                 |
|-------------|------------------------|-----------------------|
| OOH         | Puerto Paralelo 8255   | P. P. CS^             |
| 40H 7FH     | Puerto Serie 8251      | P. S. CS <sup>^</sup> |
| adel arel   | DMA 8257               | DMACS^                |
| CON CEN     | Page Register          | P. R. CS^             |
| DOH DEN     | Generador de Baud Rate | B. R. CS^             |
| EOH EFH     | Reloj de Tiempo Real   | IOCK CS^              |
| PON FFH     | Libre                  |                       |

La selección de las alternativas se realiza con las señales del bus de direcciones A4-A7 y con la señal negada de IO/M<sup>^</sup> pues el integrado se habilita en bajo.

Para controlar el reloj de tiempo real, se utiliza las señales MECKCS^ del decodificador de memorias así como IOCKCS^ del decodificador de entrada y salida y lógica externa. Lo anterior es necesario pues el reloj para su programación y uso requiere que se le habilite como memoria para leer o escribir un dato, y como dispositivo de entrada y salida para identificar el dato a utilizar. Con las dos señales se genera la de CLOCKCS.

## III.3.4) Memorias, controlador de interrupciones e interfaz para el controlador del "driver".

El diagrama de conexión de las memorias se muestra en la figura III.5. Como se observa, las señales ROMCS^, RAM0CS^, RAM1CS^ y RAM2CS^ generadas por el integrado 74LS138 habilitan a las memorias. Las señales del bus de control que se utilizan al operar con las memorias RAM0, RAM1 y RAM2 son: WRM^ y RDM^.



Figura III.5

La EEPROM 27512 sólo utiliza RDM<sup>^</sup>. En ella reside el programa de inicialización y de control de todo el sistema

El controlador de interrupciones 8259 considerado como un dispositivo de entrada/salida para el procesador, recibe la solicitud de interrupción del controlador del "driver" a través de la línea IRQ6 y del puerto serie por la IRQ7.

La señal "Slave Program Enable Buffer", está conectada a tierra ya que no hay otro controlador de interrupciones en la tarjeta.

También se muestra en la figura III.5 las señales de interfaz con el controlador del "driver".

#### NI.3.6) Puerto Serie 8251

La señal de CLK es usada para generar el tiempo interno de operación del puerto serie. Esta señal es tomada del PCLK del generador de pulsos 8284.

La programación del 8251 se realiza a través de la señal "Control/Data" (C/D^) en conjunto con la señal de WR IO^ y el P.S. CS^. Si C/D^ es igual a 1, el puerto serie espera ser programado, si es 0 el puerto serie está en modo operación.

El control de la señal C/D<sup>\*</sup> se realiza a través del bit menos significativo del bus de direcciones.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingenieria UNAM

El 8251 a través de sus señales TxC y RxC, recibe la frecuencia de transmisión y recepción de datos, ambas señales deben ser de la misma frecuencia y estar en sincronía.

La señal de transmisión TxD se conecta con el circuito integrado 1488 que eleva el voltaje de la señal de 0 y +5 volts a una de +/- 12 volts para cumplir con el estándar RS232C.

Por otra parte, el circuito integrado 1489 se utiliza para la recepción de datos, transforma las señales de +/- 12 volts en voltajes TTL (0 y 5volts), que son enviados al puerto serie a través del pin RxD.

Para generar las frecuencias de transmisión y recepción, se utiliza un generador de Baud Rate que proporciona 16 frecuencias por rango. Para este diseño se optó por tomar el primer rango de frecuencias por lo que se utiliza un factor de 1 a través de conectar a tierra las líneas RSA y RSB.

Dentro de las frecuencias generadas en este rango, se seleccionaron 9600 bps (F1), 4800 bps (F3), 2400 bps (F5) y 1200 bps (F7). Para poder seleccionar por programa una de estas cuatro frecuencias utilizamos el 7475 y el 74153.

El 7475, hace las veces de un Flip Flop seguidor que guarda la información de los bits D0 y D1 con el pulso generado por la señal de B.R. CS^ y WR I/O^. Este valor almacenado lo recibe el 74153 por lo que deja pasar sólo el canal de frecuencia seleccionada.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingenieria UNAM

THE TO MINE

En la siguiente figura se muestra el diagrama de conexión del puerto serie.

Figura III.6

#### M.3.7) Puerto Paralelo y Reloj de Tiempo Real

Et puerto paralelo en la tarjeta realiza básicamente dos operaciones. La primera como elemento de enlace con la interfaz con el usuario donde lee y despliega la selección de la operación a realizar.

La segunda como elemento para controlar el sensor o estación de muestreo así como recibir la información enviada por los mismos

Adicionalmente, este dispositivo puede ser utilizado para detectar y corregir problemas en la tarjeta controladora.

Por otra parte, el reloj de tiempo real es el dispositivo utilizado para generar la fecha y hora que utiliza MS-DOS al crear o actualizar un archivo.

El integrado se habilita con alto en las señales CS1 y CS2. En el diagrama de conexión se ve que CS1 está conectado a Vcc y que CS2 responde a la señal de CLOCKCS. Cabe aclarar que esta señal habilita al integrado para operar tanto como memoria como dispositivo de entrada y salida por lo que acepta los comandos de OUT y movE.

Las señal de TEST se conecta a tierra para evitar un mal funcionamiento debido a ruido y la de STOP a CLOCKCS para detener el funcionamiento del reloj durante las lecturas o escrituras.

Para la programación de este integrado se manda por el bus de datos el identificador de unidades de segundo como si fuera un dato a escribir en un puerto (comando OUT) y después se manda por ese mismo bus el dato con la instrucción de movE. De manera similar se programan el resto de los registros.

En la figura III.7 se observa el diagrama de conexiones tanto del puerto paralelo como del reloj de tiempo real.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM



Figura III.7

## **CAPITULO IV**

# PROGRAMACION DEL CONTROLADOR

#### IV.1) Diagrama General de Flujo

La programación se divide en cuatro módulos, el primero se encarga de inicializar los componentes de la tarjeta controladora, el segundo controla el manejador de disco, el tercero es la interfaz con el usuario final de la tarjeta y por último el módulo de programación para el sensor o estación de muestreo.

La secuencia en que se tienen que ejecutar estos módulos en la tarjeta se muestra en la figura IV.1. Los tres primeros son los programas base y se encuentran almacenados en la ROM de la tarjeta mientras que el último módulo es desarrollado por el programador para el manejo y control del sensor o estación de muestreo y no reside en la ROM de la tarjeta.



Figura IV.1

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

#### IV.2) Rutina de Inicialización

Este módulo del programa se ejecuta cada vez que se enciende o se "resetea" la tarjeta controladora y su función principal es la de programar los elementos de la tarjeta y verificar su correcto funcionamiento. En la figura IV.2 se muestra la secuencia en la que cada uno de los dispositivos es programado y cómo se realiza su verificación.



Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

#### IV.3) Manejador de Disco y Carga de Programa

Como ya se ha mencionado, las características principales de este diseño es poder accesar datos de disco en formato de MS-DOS, manejando las áreas de Fat y Dir de una manera equivalente a como lo hace MS-DOS. Esta situación y el diseño conceptual de la tarjeta permite al usuario final hacer un programa "Ad Hoc" para sensores y estaciones de muestreo, compilarlo y guardarlo en disco y posteriormente leerlo en la tarjeta controladora para ser ejecutado sin necesidad de escribir en la ROM de la tarjeta controladora.

Fundamentalmente, se elaboraron tres rutinas independientes para proveer al programador del sensor o estación de muestreo y al usuario final de comandos de software para poder realizar los accesos a disco y la ejecución de los programas de control y muestreo. Estos tres comandos o interrupciones son: Dir para desplegar el nombre de los archivos que se encuentran en el disco; Lee y ejecuta para leer un archivo del disco, colocarlo en memoria de la tarjeta y transferir el control de la tarjeta a dicho programa; y Escribe para escribir datos de memoria de la tarjeta a disco.

#### IV.3.1) RUTINA DE DESPLIEGUE DE DIRECTORIO

Esta rutina consiste básicamente en leer la zona de directorio del disco y desplegar los datos de cada archivo localizados en el disco. Esto le da la oportunidad al usuario de medir la capacidad de almacenamiento que tiene, verificar que los archivos de datos se hayan grabado en su totalidad, etc.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingenlería UNAM

ESTA TESIS NO PERE SAUR DE LA BIBLIOTECA

A continuación, en la figura IV.3 se muestra el diagrama general de flujo de la rutina para desplegar el directorio del disco.



Figura IV.3

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

#### IV.3.2) RUTINA PARA LEER Y EJECUTAR UN ARCHIVO

Esta rutina que es descrita en la figura IV.4, permite leer el archivo especificado del disco, cargarlo en ciertas localidades de memoria y transferirle el control de ejecución a dicho archivo. La función principal de esta rutina es proveer al usuario de la tarjeta un elemento para poder cargar el programa de manejo y control de sensores o estaciones de adquisición sin tener que grabar la ROM.

#### IV.3.3) RUTINA PARA ESCRIBIR A DISCO

El propósito de esta rutina es permitir el almacenamiento de los datos recolectados por el sensor o estación de muestreo en un medio magnético de alta capacidad (disco flexible) en formato compatible con MS-DOS para permitir su procesamiento posterior en paquetes estándares de mercado. (Excel, Lotus, etc.).

Esto se muestra en la figura IV.5

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM



Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM



Diseño de un Controlador Digital con unidad de disco

Facultad de Ingenieria UNAM

#### IV.4) Interfaz con el Usuario

Se desarrollaron dos versiones de esta interfaz. Una en lenguaje ensamblador para residir en la memoria EEPROM para cuando se utilice el "display" y teclado de la tarjeta controladora y otra en BASIC, para ejecutarlo en la P.C. conectada a través del puerto serie que sustituye al "display" y teclado de la tarjeta.

La diferencia fundamental entre estas dos versiones reside en el puerto que se utiliza durante la interfaz. Si la tarjeta opera autónomamente, las instrucciones del usuario las recibe a través del puerto paralelo. Si la tarjeta utiliza el teclado y "display" de una PC la comunicación se realiza por medio del puerto serie.

Para no entrar en conflicto, sólo una de estas alternativas puede estar habilitada. La del puerto paralelo reside en memoria EEPROM como parte de la configuración inicial del sistema que puede ser deshabilitada al transmitírsele a través del puerto serie la secuencia de cambio.

Ambos programas permiten que el usuario seleccione una de las siguientes opciones: Dir, Escribe, Lee y Ejecuta y Programación del Reloj. En la figura IV.6 se muestra el diagrama de bloques de la interfaz paralelo y en la IV.7 la interfaz serial.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM



. .gata 17.0



Diseño de un Controlador Digital con unidad de disco Facultad de Ingenieria UNAM

#### IV.5) Lineamientos para la programación del sensor

Este subíndice tiene por objeto el proveer de los elementos indispensables, a quien desarrolle el software de control del sensor(es) o estación(es) de muestreo, para manipular la tarjeta y el acceso a disco.

A continuación se muestran los mapas de memoria (Tabla IV.1), de interrupciones (Tabla IV.2) y el mapa de puertos (Tabla IV.3).

| MEMORIA | DIRECCION       | COMENTARIO                                                   |
|---------|-----------------|--------------------------------------------------------------|
| RAN D   | 00000h a 0002Fh | Reservado para 12 vectores de interrusción                   |
|         | 00030h a 001FFh | Espacio reservado para el Stack                              |
|         | 00200h a 01FFFh | Destinada al programa de los sensores.                       |
| RAN 1   | 20000h a 27FFFh | Zona libre • ara almacenamiento de datos                     |
| RAMIA   | 40000h a 47FFFh | Zona libre para almacenamiento de datos                      |
| C200    | 60000h          | 1a. palabra de control ICW1                                  |
| 4.6     | 60001h          | 2a. palabra de control ICW2 (vector y nivel)                 |
|         | 60001h          | 4a. palabra de control ICW4                                  |
| · 70    | 60001h          | 1a. palabra de operación OCW1 (máscara)                      |
|         | 80000           | Lectura o escritura de registros                             |
| ROM     | F0000h a FFFFFh | Programa de inicialización, e interfaces de disco y usuario. |

Tabla IV.1

| INTERRUPCIONES | NUMERO  | COMENTARIO '                    |
|----------------|---------|---------------------------------|
| Boltwere       |         | Son liamadas por el programador |
| DP 1           | INT 01h |                                 |
| Lac y Elegija  | INT 02h |                                 |
|                | INT 03h |                                 |
| Reflection.    |         | Son ejecutadas por el circuito  |
| Access a Disco | 06h     |                                 |
| Pueto Bato     | 07h     |                                 |

Tabla IV.2

| PUERTO      | DIRECCION | COMENTARIO                       |
|-------------|-----------|----------------------------------|
|             | 00h       | Puerto de Salida                 |
| 17.         | 01h       | Puerto de Entrada                |
|             | 02h       | Puerto de Salida                 |
|             | 03h       | Pregramación.                    |
| La La Maria | 40h       | Lectura y/o escritura de datos.  |
|             | 41h       | Pregramación.                    |
|             | 84h       | Canal 2 (dirección)              |
|             | 85h       | Canal 2 (Terminal Count)         |
|             | CO        | Habilitador del Pase Resister    |
|             | D0 a D3   | Frecuencia 1 a 4 respectivamente |
| -           | EO        | Selección de registros           |

Tabla IV.3

Diseño de un Controlador Digital con unidad de disco Facultad de Ingenieria UNAM

## CONCLUSIONES

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM Consideramos que los objetivos de flexibilidad y capacidad de almacenamiento del proyecto se cumplieron satisfactoriamente. Desarrollamos un controlador que se adecua a las necesidades de los proyectos de medición de perfiles de distribución de agua así como a estaciones de muestreo sísmicas y climatológicas sin tener la limitante de esclavizar una PC y con la ventaja de poder manejar la información obtenida en diskettes que pueden ser facilmente transportables.

Por otra parte se simplificó el uso de la tarjeta al permitir que el desarrollador del programa de control de los sensores accese a disco en forma similar a como se realiza en un ambiente de MS-DOS.

El acceso a las rutinas básicas de disco, video, teclado, etc. en MS-DOS se realizan invocando vía código máquina (INT xx) una interrupción para el propósito específico. Por lo tanto, las rutinas creadas por nosotros para el acceso a disco están grabadas en la EEPROM de la tarjeta para ser llamadas como interrupciones simulando el BIOS de cualquier PC.

Aunque inicialmente el alcance contemplado para este proyecto fue solamente el diseño conceptual de la tarjeta controladora, se desarrollaron programas que se probaron sustituyendo en una PC las rutinas de MS-DOS para el manejo de disco. Se pudo constatar que estas efectivamente simulan lo que el sistema operativo realiza, ya que los archivos grabados a disco pudieron ser leídos en otras PC's y exportados a algunas aplicaciones como Lotus o Excel.

Estos programas tuvieron que ser adecuados minímamente para poder ser operados en la tarjeta controladora, pero las rutinas principales para accesar el

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

"drive", leer el directorio del disco, leer un archivo en disco y bajarlo a memoria así como la rutina de escribir a disco conservan integramente su estructura. Las adecuaciones que se realizaron fueron el sustituir algunas rutinas especiales desarrolladas para la interfaz con el usuario.

Adicionalmente, se implementó el prototipo llegando hasta las fases de prueba de la rutina de inicialización.

Estamos conscientes de que el diseño de esta tarjeta controladora puede ser mejorado. En hardware, se le puede aumentar su capacidad de almacenamiento tanto en memoria como en disco.

En caso de que se desee crecer la memoria, en el diseño se deja la posibilidad de subsegmentar el mapa de memoria. En el caso de almacenamiento a disco, puede incluirse una tarjeta controladora de alta densidad para discos de 1.44 Mb de 3.5 in. o disco duro, debiéndo hacer los cambios necesarios en el programa del "Device Driver".

Se pueden incluir elementos adicionales de entrada/salida dependiendo de las necesidades de los sensores.

Debemos mencionar que se optó por utilizar un drive de baja densidad (360 kbytes), ya que la PC donde se efectuaron las pruebas de las rutinas contaba con este tipo de dispositivo, sin embargo, como fue tratado en el capítulo correspondiente, el utilizar un drive de mayor densidad no implica ni representa

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

diferencias sustanciales con el programa diseñado salvo por un punto en el cual los bytes por sector pueden ser de 1024 en lugar de 512.

Aunque actualmente existen en el mercado procesadores de la misma familia pero de mayor capacidad y rapidez consideramos que esto no es una limitante para el sistema, debido a que el 8088 cumple sobradamente con los requerimientos del diseño. Comparando este procesador con el Z80 que originalmente fue una alternativa, el 8088 tiene la capacidad de direccionar hasta 1Mb de memoria y existe toda una familia de dispositivos que facilitan el diseño como los son el controlador de interrupciones, el reloj y el DMA.

En el aspecto de software, en especial en la interfaz con el usuario, se pueden adicionar comandos para el formateo de discos, para el borrado de archivos y para el copiado de los mismos, así como rutinas especiales para el manejo de la información.

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

### **ANEXOS**

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

#### PROGRAMA DE INICIALIZACION

```
; Programa principal
                        Proc
                                      FAR
MAIN
                        PUSH
                                      DS
                                      AX,0
                        mov
                        PUSH
                                      AX,DATA
                        mov
                               DS,AX
                        mov
                                      ES,AX
                        mov
; Inicio
                                      AX,0000H
                        mov
                               DS,AX
                        mov
                                      AX,07FFH
SS,AX
                        mov
                        mov
                        mov
                                      AX,0F000H
                                      CS,AX
                        mov
; Inicializacion del Puerto Paralelo, la palabra de control es 82
; Puertos A(00) y C(02) salidas, puerto B(01) es entrada
; Mandarlo por el 03 para quese guarde como palabra de control
                                      AL,082h
03,AL
AL,7Fh
                        mov
                        OUT
                        mov
                                      BX,0FFFFH
02,AL
INICIO:
                        mov
LOOP:
                        OUT
                                      BX
OTRO
                        DEC
                        JΖ
                        JMP
                                      LOOP
OTRO:
                        CMP
                                      AL,00H
                                      FIN1
                        JE
                        SHR
                                      AL,1
                                      INICIO
                        JMP
FIN1:
                        mov
                                      AL, OFFH
                                      02,AL
                        OUT
                        NOP
; Los cuatro primeros switches establecen un estado especial, el puerto C
; despliega el numero leido del puerto B(01)
                                      AL,01
                        IN
                                      AL,00
CERO
                        CMP
                        JE
                        CMP
                                      AL,01
                                      UNO
                        JE
                        CMP
                                      AL,02
                                      DOS
                        JE
                        CMP
                                      AL,04
                                      TRES
                        JE
                        CMP
                                      AL,08
```

```
CUATRO
                       JE
                              AL,086H
                       mov
                       OUT
                                     02,AL
                       JMP
                                     FIN2
                                     AL,0C0H
CERO:
                       mov
                       OUT
                                     02,AL
                       JMP
                                    FIN2
UNO:
                                     AL,0F9H
                       mov
                                    02,AL
                       OUT
                                    FIN2
                       JMP
DOS:
                       mov
                                     AL,0A4H
                       OUT
                                     02,AL
                       JMP
                                    FIN2
TRES:
                                     AL,0B0H
                       mov
                       OUT
                                    02,AL
                       JMP
                                    FIN2
                                    AL,099H
02,AL
CUATRO:
                       mov
                       OUT
FIN2:
; Verificacion de las tres RAM. Se graba "00" en toda la memoria validando ; su contenido, despues se graba "FF" revisando que todas las localidades
; de memoria tengan este dato. Se despliega mensaje numerico si la memoria
; opera correctamente y alfabetico en el caso contrario
; RAMO
                              AX,0000H
                       mov
;DS en 0000h para esta memoria
                                    DS,AX
                       mov
                                    AL,00H
                       mov
                                    BX,00H
                       mov
                              [BX],AL
SIGUE:
                       mov
                                    BX
                       INC
                       CMP
                                     BX,0800H
                       JE
                                    VALIDA
                                    SIGUE
                       JMP
VALIDA:
                       mov
                              BX,00H
VALIDA1:
                       CMP
                                    AL,[BX]
                       JNE
                                    ERROR
                                    BX
                       INC
                       CMP
                                    BX,0800H
                       JNE
                                    VALIDA1
                              AL,0FFH
                       mov
                                    BX,00H
                       mov
SIGUE1:
                       mov
                                    [BX],AL
                       INC
                                    BX
```

BX,0800H VALIDA2

SIGUE1

BX,00H

**CMP** 

JE JMP

mov

VALIDA2:

```
AL,[BX]
ERROR
                      CMP
VALIDA3:
                      JNE
                      INC
                                  BX
                                  BX,0800H
VALIDA3
                      CMP
                      JNE
                      mov
                                  AL,0F9H
                      OUT
                                  02,AL
;Mensaje "1" RAMO OKI
                      JMP
                                  RAM1
ERROR:
                                  AL,088H
                     mov
;ERROR "A" problemas con la RAMO
                     OUT
                                  02,AL
; RAM1
RAM1:
                                  AX,02000H
                     mov
;DS en 2000h para la memoria RAM1
                                  DS,AX
                     mov
                                  AL,00H
BX,00H
                      mov
                      mov
                                  [BX],AL
BX
SIGUE2:
                      mov
                      INC
                                  BX,08000H
                      CMP
                                  VALIDA4
                      JE
                      JMP
                                  SIGUE2
VALIDA4:
                      mov
                                  BX,00H
                                  AL,[BX]
ERROR1
                      CMP
VALIDA5:
                      JNE
                      INC
                                  BX
                                  BX,08000H
                      CMP
                                  VALIDA5
                      JNE
                                  AL,OFFH
                      mov
                                  BX,00H
                      mov
SIGUE3:
                                  [BX],AL
                      mov
                      INC
                                  BX
                                  BX,08000H
VALIDA6
                      CMP
                      JE
                      JMP
                                  SIGUE3
                                  BX,00H
AL,[BX]
ERROR1
VALIDA6:
                      mov
                      CMP
VALIDA7:
                      JNE
                      INC
                                  BX
                      CMP
                                  BX,08000H
                      JNE
                                  VALIDA7
                                  AL, 0A4H
                      mov
;Mensaje "2" RAM1 OK!
                      OUT
                                  02,AL
                      JMP
                                  RAM2
ERROR1:
                                  AL,083H
                      mov
;ERROR "b" problemas con la RAM1
                      OUT
                                  02,AL
```

```
; RAM2
                              AX,4000H
RAM2:
                       mov
;DS en 4000H para la RAM2
                                    DS,AX
                       mov
                                    AL,00H
BX,00H
                       mov
                       mov
SIGUE4:
                       mov
                                    [BX],AL
                       INC
                                    BX
                       CMP
                                    BX,08000H
                                    VALIDA8
                       JE
                       JMP
                                    SIGUE4
VALIDA8:
                       mov
                                    BX,00H
VALIDA9:
                       CMP
                                    AL,[BX]
                                    ERROR2
                       JNE
                       INC
                                    BX
                       CMP
                                    BX,08000H
                       JNE
                                    VALIDA9
                                    AL,OFFH
                       mov
                                    BX,00H
                       mov
SIGUE5:
                       mov
                                    [BX],AL
                       INC
                                    BX
                                    BX,08000H
VALIDA10
                       CMP
                       JE
                       JMP
                                    SIGUE5
VALIDA10:
                       mov
                                    BX,00H
VALIDA11: .
                                    AL,[BX]
ERROR2
                       CMP
                       JNE
                       INC
                                    BX
                                    BX,08000H
                       CMP
                                    VALIDA11
                       JNE
                                    AL,0B0H
                       mov
;Mensaje "3" RAM2 OKI
                       OUT
                                    02,AL
                       JMP
                                    FINRAM
ERROR2:
                                    AL,0C6H
                       mov
;ERROR "C" problemas con la RAM2
                       OUT
                                    02,AL
                                    CX,0FFFFH
FINRAM:
                       mov
SIGUE6:
                       NOP
                       LOOP
                                    SIGUE6
; Inicializacion de la palabra de control del DMA
; Para habilitar el DMA e indicarle que es la palabra de control
; la direccion es "88".
; La palabra de control es "66" habilitando solo el canal 2
; DMA
                                    AL,066H
                       mov
                       OUT
                                    88,AL
                       mov
                             AL,099H
```

;Mensaje "4" DMA OK!

OUT 02,AL

mov

CX,0FFFFH

SIGUE7:

NOP

LOOP

SIGUE7

; Para habilitar el canal dos la salida debe mandarse a la "84" ; la direccion y a la "85" el tama¤o indicando la operacion en

; b14 para escribir y en b15 para leer.

; Inicializacion del Controlador de Interrupciones

; Prueba de la tarjeta. Prender el Motor del Drive

DX,3F2H AL,28 DX,AL mov mov OUT

; Inicializacion del Reloj de Tiempo Real

AX,8000H mov

;Habilitamos el clock por memoria

mov

mov

DS,AX BX,00H

AL,01H mov

:Mandar activar "STOP"

OUT 00,AL **CX,00H** 

mov mov

AL,00H OUT OEOH,AL

;Selecciona UNIDADES de seg

CX,09H

[BX],CX

mov ;Cargamos con 09 las unidades de seg.

INC

OUT

mov

mov

OEOH,AL

;Selecciona DECENAS de seg.

CX,05H

[BX],CX mov ;Cargamos con 05 las decenas de seg.

INC

OUT

OEOH,AL

;Selecciona UNIDADES de min. mov

mov

CX,08H [BX],CX

;Cargamos con 08 las unidades de min.

INC

AL

OUT

OEOH,AL

;Selecciona DECENAS de min. CX,04H mov [BX],CX ;Cargamos con 04 las decenas de min. INC OEOH,AL OUT ;Selecciona UNIDADES de hora. mov CX,02H [BX],CX mov ;Cargamos con 02 las unidades de hora. INC OUT OEOH,AL ¡Selecciona DECENAS de hora. CX,01H mov [BX],CX mov ;Cargamos con 01 las decenas de hora. AL,00H mov ;Desactivamos el "STOP" OUT 00,AL mov AL,092H ;Mensaje "5" REAL CLOCK OKI 02,AL CX,0FFFFH OUT mov ;SIGUE8: NOP LOOP SIGUE8 ; Validar la correcta opecación del Reloj de Tiempo Real mov BX,00H AL,01H mov ;Activamos el "STOP" OUT 00,AL DL,00h mov ;OTRO1: OUT OEOH,AX ;Seleccionamos AL,[BX] 02,AL mov OUT CX,OFFFFH mov ;SIGUE9: NOP LOOP SIGUE9 CX,0FFFFH mov ;SIGUE10: NOP SIGUE10 LOOP AX OTRO1 INC **JMP** ; Inicializacion del Puerto Serie

#### PROGRAMA DE DIR

```
data segment para public 'data'
;Cadenas a desp. (DEPURACION) con INT de soft. 21H func. 9 de MS-DOS.
string0 db
            'error al leer sect. boot',13,10,'$'
string1 db
            'disco no formateado',13,10,'$'
string2 db
            'no tiene 512 bytes por sector',13,10,'$'
            '1. DIR, 2. LEE, 3. ESCRIBE: ?',13,10,'$'
string3 db
            'Dame el archivo :',13,10,'$',
string4 db
string5 db
            'Archivo no encontrado',13,10,'$'
            'error al leer sect. dir.',13,10,'$'
string6 db
string7 db
            'error al leer sect. fats', 13, 10, '$'
            'error al leer SECTOR',13,10,'$'
string8 db
string9 db
            'No hay espacio en disco',13,10,'$'
string10 db 'Dame la long. del arch.:',13,10,'$'
string11 db 'Aqui voy...',13,10,'$'
string12 db 'error al esc SECTOR',13,10,'$'
string13 db 'error al esc sect. dir.',13,10,'$'
string14 db 'error al esc sect. fats', 13, 10, '$'
¡Vars. globales en DS para almacenar inf. de disco o para referencia:
;area de Xferencia de disk. a mem. (INT 25H) por sec. log. 0 (pag 388 Adv.) bufzero db 512 dup ('a')
;area de Xferencia de disk. a mem. (INT 25H) por 1 sec. log. (pag 388 Adv.)
     buffsec db 512 dup ('a')
;area de Xferencia de disk. a mem. (INT 25H) por n sec. de dir.
     buffdir db 7168 dup ('0')
area de Xferencia de disk. a mem. (INT 25H) por n sec. de fats
     buffat db 5120 dup ('0')
;buffer para escritura de nombre de archivo.
     buffnom db 11 dup ('20H')
;buffer para escritura de fecha hora start_clus, y tame¤o de la zona de
directorio
     datosdir db 10 dup ('20H')
;varible con datos a escribir a un archivo de disco
     archivo db 512 dup ('00112233445566778899,AEIOU')
;bandera de error entre rutinas
     banderr db 1 dup ('1')
;bandera para determinar si se encontro un arch.
     arch_endb 1 dup ('0')
;var. para el sec. de inic. de directorio
     secdir dw 1 dup ('0')
;var. para el INICIO de area de datos, es decir EL 1er SECTOR
     secdat dw 1 dup ('0')
;var. para num. de sect. por cluster
     seclus dw 1 dup ('0')
```

;var. para total de sectores logicos en disco totsec dw 1 dup ('0') ;var. para sector logico pag. 170 adv. msdos sector dw 1 dup (0) var. para num. de sec. en dir. numsecdir dw 1 dup ;var. para num. de sec. de fats numsecfat dw 1 dup ('0') var. para num. de ent. en dir numentdir dw 1 dup ('0') ;var. para num. de sec. de inic. de fats secfat dw 1 dup ('0') var. para guardar cluster cluster dw 1 dup ;variable para lectura de tecla opcion db 1 dup ('1') ;var. para guardar ultimo offset en fat last\_clus dw 1 dup ('0') ;var. para guardar offset de entry libre entry dw 1 dup ('0') ;var. para guardar offset de arch enc. off\_endir\_enc dw 1 dup ;bandera arch borrado. arch\_borr db 1 dup (0) ;bandera entry en directorio llenos entry\_full db 1 dup (0) ;var. para guardar offset de arch borrado off\_borr dw 1 dup ('0') ;var. para guardar isw del tamano de arch. fsize\_isw dw 1 dup ('0') var. para guardar msw del tamano de arch. fsize\_msw dw 1 dup ('0') ;variable para cta. de clusters ctaclus dw 1 dup (0) ; var. para apuntar a la fat pointer dw 1 dup (0) ;variable para denotar cluster par o impar par db 1 dup (0) tabla para guardar los clusters libres al recorrer fat clus\_libre dw 100 dup (0) ; variable para guardar direcciones tabla dw 1 dup (0) ;variable clusterslibres dw 1 dup (0) ;variable resul dw 1 dup (0) ;variable para saber si se trata del 1er cluster primcluster db 1 dup (0)

```
;variable para dimension de arch.
     necesito
                 dw
                       1
                                    (0)
;variable
     last_off_fat dw
                              dup
                                    (0)
;clusters de un arch. nvo.
     clus_a_esc dw 1
                               dup (0)
;clusters de un arch. viejo
     realsize dw
                             dup (0)
;variable para definir a la hora de escribir arch. si:
;0=off_borr, 1=off_endir_enc, 2=entry
                             dup (0)
     entryclas dw 1
;variable
     posicion
                dw
                       1
                            dup
                                   (0)
;tabla para guardar clusters de un arch. encontrado
     clus_de_arch dw 100 dup (0)
  offsetfat
                dw
                            dup
  suficiente
                db
                                   (0)
                            dup
   data ends
code segment para public 'code'
         assume cs:code,DS:DATA,ES:DATA
; Programa principal
MAIN
            Proc FAR
; inicio
                       PUSH
                                     DS
                                     AX,0
                       mov
                       PUSH
                                     AX
                                     AX,DATA
                       mov
                                     DS,AX
                       mov
                                     ES,AX
                       mov
; si no error, y segun la opcion seleccionada, es decir, ; obtener DIR, LEER archivo o ESCRIBIR archivo se hace:
                                     dx,offset string3; dame opcion
                       mov
                       call
                                     desp_mje
                       call
                                     lee_tecla
                                     [opcion],al
                       mov
; para ver que caracter se lee, se desplegara en pantalla
; despues del echo, usando chrout
                       cmp
                                     [opcion],49
                                                  ;dir
                                     directorio
                       je
                       cmp
                                     [opcion],50
                                                  ;lec
                       je
                                     leo
                                     [opcion],51 ;ESC
                       cmp
                                     escribo
                       jе
```

```
directorio:
                            call
                                             desp_dir
                                             fin_main
                            jmp
leo:
                            call
                                             iee_arch
                            jmp
                                             fin_main
escribo:
                                             esc_arch
                            call
fin_main:
                            nop
                            ret
MAIN
                            endp
; Esta rutina lee y guarda en 'bufzero' la inf. del sec. log. 0,
; da valor a las variables SECDIR, NUMSECDIR, SECDAT,
; SECLUS, NUMSECFAT, y SECFAT, si hay error, BANDERR
; se queda con 1 . Antes se llamaba basis
lee_seczero proc
                            mov
                                             [banderr],1
                            mov
                                             al,1 ;drive b=1 drive a=0
                                             cx,1
                            mov
                                             dx,0
                            mov
                            mov
                                             bx,offset bufzero
                            int
                                             25h
                            jc
                                             errbios
                            popf
; se despliega la inf. leida con desp
                                             cx,512
                            mov
                            mov
                                             bx,00h
                                             si,offset bufzero
                            mov
                            call
                                             desp
                            jmp
                                             cont
embios:
                            mov
                                             dx,offset string0 ;error
                                             desp_mje
fin_zero
                            call
                            jmp
                                             si, offset bufzero
cont:
                            mov
                            mov
                                             bx,0
                                            al,[si+bx]
al,0e9h
siformat
                            mov
                            cmp
                            je
                            cmp
                                             al,0ebh
                                             siformat
                            je
                                             dx,offset string1; no format
                            mov
                            call
                                             desp_mje
                            jmp
                                             fin_zero
siformat:
                                             bx,16h
                            mov
                                             dx,[si+bx] ;sectors/fat
                            mov
                            mov
                                             [numsecfat],dx
unum, sec. ocup, por 1 fat
                                             al,[si+10h] ;number of fats ;se hace WORD
                            mov
                            cbw
```

```
mul
;en AX sect. ocup. por fats = sectors/fat*fats
                                       bx,[si+0eh]; sectores reservados
                         mov
                         mov
                                       [secfat],bx ;inicio de fats
                         add
                                       ax,bx
;en AX suma de sect. de fats y sect. res.
                                       [secdir],ax ;inicio de directorio
                         mov
                         mov
                                        ax,[si+11h]; num. de ent. en dir.
                                       [numentdir],ax
                         mov
                                       cx,32
                         mov
                         mul
;en AX hay 32 por num. ent. en dir.
                                       cl,[si+Och]; bytes/sector
                         mov
                         cmp
                                       cl,02h
                                                   ; si 512b/sec salta a b512
                                       b512
                         jz
                         mov
                                        dx,offset string2; no 512b/sec
                         call
                                        desp_mje
                         jmp
                                       fin_zero
                                       cx,512
b512:
                         mov
                         div
                                       [numsecdir],ax
;num de sec en directorio
                                       ax,[secdir]
[secdat],ax ;inicio area datos
                         add
                         mov
                         mov
                                        al,[si+Odh]
                         cbw
                                       [seclus],ax; sectores por cluster
                         mov
                                        ax [si+13h]
                         mov
                         mov
                                        [totsec],ax
; si hasta aqui no hubo error, entonces banderr se hace cero
                                       [bandert],0
                         mov
fin_zero:
                         nop
                         ret
                         endp
lee_seczero
; Se determina la cap. libre del disco cuando se accesa desde
; la opcion de dir, o bien si se quiere esc. un archivo, se
; van determinando los clusters libres, y se va llenando tabla ; CLUS_LIBRE con CLUSTERS.
; Se llama desde lee_fat
buscacluster proc
                                       [ctaclus],0
                         mov
                                        si,offset buffat
                         mov
                         mov
                                        bx,0003h
```

cmp

Ja

bx,[last\_off\_fat]

salida

denuevo:

```
ax,[si+bx]
con_busq_libre:
                          mov
                                         ax,0fffh
                          and
                                         inc1
                          inz
                                         [clusterslibres]
                          inc
no_libre:
                                         [opcion],49
                          cmp
                                         inc1
                         je
                                         [par],1
                          mov
                          call
                                         esc_clus
                                         [necesito],0
                          cmp
                                         EOF
                          je
inc1:
                                         bx
                         inc
                                         bx,[last_off_fat]
                         cmp
                          Ja
                                         salida
                                         ax,[si+bx]
ax,Offf0h
                          mov
                          and
                                         inc2
                         jnz
                                         [clusterslibres]
                         inc
                                         [opcion],49
no_libre2:
                          cmp
                         je
                                         inc2
                                         [par],0
                         mov
                                         esc_clus
                         call
                                         [necesito],0
                         cmp
                                         EOF
                         je
inc2:
                         inc
                                         bx
                                         bx
                         inc
                                         denuevo
                         jmp
EOF:
                         mov
                                         di,[ctaclus]
                         mov
                                        [clus_libre+di],0fffh ;genera el EOF
salida:
                         nop
                         ret
buscacluster
                         endp
; Rutina para lectura de los NUMSECFAT sec. de las fats en 'buffat' ; a partir del sector logico SECFAT, con INT 25H
; Se determina ademas el espacio libre o el que se ocupara al esc. arch.
lee_fat
             proc
                         mov
                                         [banderr],1
                                        al,1 ;drive b=1 drive a=0
                         mov
                         mov
                                         cx,[numsecfat]
                                         dx,[secfat]
                         mov
                                        bx,offset buffat
                         mov
                                        25h
                         int
                         c
                                         errorlecfat
                         popf
; se previene crecimiento incontrolado del stack
                                        [opcion],50
                         cmp
                         je
                                         saltabusca
```

```
[suficiente],1
                          cmp
;se va a esc. un arch. que cabe
                                         saltabusca
; se hace calculo de ESPACIO LIBRE en disco:
                                         ax,[totsec] ;2880
                          mov
                          sub
                                         ax,[secdat] ;ax-secdat 2847
                                         dx,0h
                         mov
                          div
                                         [seclus]
en ax quedan clusters tot en datos 2847
                          add
                                         ax,2
                                                   ;por el inicio de cluster con 2
                          sub
                                         ax,1
;porque el offset empieza en 0
                                         [last_clus],ax;2849
                         mov
                         mov
                                         cx,03
;se mult. por 1.5 para obt. bytes
                                                  :8541
                                         CX
                         mul
                                         ax,1
                                                  ; divide entre 2
                         shr
                         jnc
                                         sumpar
                         add
                                         ax,1
                                         [last_off_fat],ax ;4272
sumpar:
                         mov
                                        buscacluster
                         call
; Segun opcion se determina espacio o clusters a usar para esc. arch.
saltabusca:
                                         [banderr],0
                         mov
                         jmp
                                         fin_secfat
                                         dx,offset string7 ;error at leer buff. fat
erroriecfat:
                         mov
                         call
                                         desp_mje
fin_secfat:
                         qon
                         ret
lee_fat
                         endp
; Rutina para escritura de ios NUMSECFAT sec. de 'buffat' en la FAT ; del disco a partir del sector logico SECFAT, con INT 26H
esc_fat
             proc
                         mov
                                         [banderr],1
                                         al,1;drive b=1 drive a=0
                         mov
                                        cx,[numsecfat]
                         mov
                         mov
                                         dx,[secfat]
                         mov
                                         bx,offset buffat
                                         26h
                         int
                                         errorescfat
                         jc
; se previene crecimiento incontrolado del stack
                         popf
                         mov
                                         [banderr],0
                                         finesc_fat
                         jmp
errorescfat:
                         mov
                                         dx,offset string14 ;error al esc. buff. fat
                         call
                                         desp_mje
finesc_fat:
                         пор
```

```
ret
esc_fat
                        endp
RUTINA PARA GUARDAR EL NUMERO DE CLUSTER LIBRES PARA
ESCRIBIR ARCHIVO
ESC_CLUS
                PROC
                                      ax,0000h; incializacion de ax
                        mov
                        mov
                                      ax,bx; en bx se tiene offset
                        mov
                                      cx,2
                                              ; ax=ax*2
                        mul
                                      CX
                                      cx,3
                        mov
                                              ; ax=ax/3 1er. clust libre
                        div
                                      [par],0
                        cmp
                                      nosedonde
                        jnz
                        add
                                      ax,1
nosedonde:
                        push
                                      bx
                                      bx,[ctaclus]
                        mov
                                      [clus_libre+bx],ax
                        mov
                        ADD
                                      [ctaclus],2
                                                    ;tiene que ir de 2 en 21
                        pop
dec
                                      bx
                                      [necesito]
ESC_CLUS
                        ENDP
; Rutina para lectura de los NUMSECDIR sec. del directorio en 'buffdir'
; a partir del sector logico SECDIR, con INT 25H
lee_dir
           proc
                        mov
                                      [banderr],1
                                      al,1; drive b=1 drive a=0
                        mov
                                      cx,[numsecdir]
dx,[secdir]
                        mov
                        mov
                        mov
                                      bx,offset buffdir
                        int
                                      errorlecdir
; se previene crecimiento incontrolado del stack
                        popf
                                      [banderr],0
                        mov
                                     fin_secdir
dx,offset string6 ;error al leer buff. dir
                        jmp
```

; Rutina para escritura de los NUMSECDIR sec. en 'buffdir' al directorio ; de disco a partir del sector logico SECDIR, con INT 26H

desp\_mje

mov call

nop ret

endp

errorlecdir:

fin\_secdir:

lee\_dir

```
proc
esc_dir
                                       [banderr],1
                         mov
                                       al,1 ;drive b=1 drive a=0
                         mov
                         mov
                                       cx,[numsecdir]
                                       dx,[secdir]
                        mov
                                       bx,offset buffdir
                         mov
                                       26h
                        int
                        jc
                                       errorescdir
; se previene crecimiento incontrolado del stack
                        popf
                                       [banderr],0
                         mov
                                       fin_escdir
                        jmp
errorescdir:
                         CALL
                                       VIDEO_WORD
; SE REGRESA ERROR EN AX
                        mov
                                       dx,offset string13 ;error al esc. buff. dir
                        call
                                       desp_mje
fin_escdir:
                        nop
                        ret
esc_dir
                        endp
; se lee el sec. log. cero o BOOT SECTOR ; se lee la zona de fat y la de directorio
inicializacion proc
                        call
                                       lee_seczero
                        call
                                       lee_fat; se llena buffat y espacio disp.
                                       lee_dir
                        call
                        ret
inicializacion endp
; Rutina que despliega el dir., usando la inf.
; depositada en buffdir por lee_dir.
             proc
desp_dir
                        CALL
                                       INICIALIZACION
;funciona a medias,
                        call
                                       scan_dir
;hay riesgo de overflow
                                       ex,[clusterslibres]
                        mov
                                       cx,512
                        mov
                        mul
                        mov
                                       cx,[seclus]
                        mul
                                       CX
                                       bh,al
                        mov
                        mov
                                       bl,ah
                        mov
                                       ax,bx
```

mov

cx,2

```
[resul],ax
                          mov
                                          si, offset resul
                          mov
                          call
                          ret
desp_dir
                          endp
; Rutina para barrer la zona de dir en disco y tomar acciones
; segun la opcion que siga el usuario. Se llama desde todas las ; opciones (Desp. dir. leer o escribir arch.)
scan_dir
              proc
                          mov
                                          [arch_borr],0
                                          [entry_full],0
si,offset buffdir
                          mov
                          mov
                                          bx,00h
                          mov
                          mov
                                          cx,[numentdir]
                                          al,[si+bx]
                          mov
otroarch:
                          cmp
                                          al,00h
                          je
                                          entry_zero
                          cmp
                                          al,0e5h
                                          borrados
                          je
                                          al,02eh
                          cmp
                                          buscaotro ; especial (ja) [opcion],49 ;dir
                          je
                          cmp
                                          ve_si_esc ;para no desp. archivo
                          jne
                                          nomarch ;se apunta con BX en SI
                          call
                                          [opcion],51 ;esc
ve_si_esc:
                          cmp
                                          comparanom
                                          [opcion],50
                          cmp
                                          buscaotro
                          jne
comparanom:
                          call
                                          compa_nom
                          cmp
                                          [arch_en],1
                          jne
                                          buscaotro
                                          [off_endir_enc],bx
                          mov
; bx en var. p' luego ai' meterlo
; traer 4 bytes del filesize en los regs. DX Y AX y llenar var [fsize]
                          add
                                          bx,1ch
                                          ax,[si+bx];LSW
bx,2
                          mov
                          add
                          mov
                                          dx,[si+bx];MSW
                                          [fsize_lsw],ax
[fsize_msw],dx
                          mov
                          mov
                          mp
                                          fin_scan_dir
buscaotro:
                          loop
                                          aviso
                          mov
                                          [entry_fuli],1
                          jmp
                                          fin_scan_dir
                                          [opcion],51 ;esc
borrados:
                          cmp
```

```
jne
                                        buscaotro
                         cmp
                                        [arch_borr],1
                                        buscaotro
                         je
                                        [arch_borr],1
                                                           ;falta declarar
                         mov
                                        [off_borr],bx
                         mov
                         jmp
                                        buscaotro
                                        dx,32
aviso:
                         mov
                                        bx,dx
                         add
                                        otroarch
                         jmp
entry_zero:
                         cmp
                                        [opcion],51
                         ine
                                        fin_scan_dir
                                        [entry],bx
                         mov
fin_scan_dir:
                         nop
                         ret
scan_dir
                         endp
; Rutina que obtiene un cluster, el cual se guarda en [cluster]
obten_clusters proc
                         cmp
                                        [primcluster],1
; si no es el 1er. cluster salta
                         jne
                                        clu_sig
                                        si, offset buffdir
                         mov
                         mov
                                        bx,[off_endir_enc]
                                        cx,1ah
                         mov
                         add
                                        bx,cx
; se suma a lo que llevaba bx 1ah
                                       cx,[si+bx]
[cluster],cx
[primcluster],0
                         mov
                         mov
                         mov
                         jmp
                                        fin_obt
; se puede usar SI para manejar buffat
                                        si,offset buffat
clu_sig:
                         mov
                         mov
                                        ax,[cluster]
                         mov
                                        cx,3
                                                  ; mult. por 1.5
                         mul
                                        СХ
                                                 ; ax=ax*3
                         clc
                                               ; clear carry flag
                                                  ; corr. a la der. (div/2)
                         shr
                                        ax,1
                         mov
                                        bx, ax
; usar parte entera como offset en FAT
                                        ax,[si+bx]
                         mov
; guardar la palab, en ese offset en reg. AX
                                        op_and
; si el prod. fue ent. (no carry) salt. a op_and
                                        cl,4
                         mov
                                        ax,cl
                         shr
                                        limites
                         jmp
op_and:
                         and
                                        ax,Offfh
```

```
[cluster],ax
limites:
                          mov
;guardo 12 bits como CLUSTER
fin_obt:
                          nop
                          ret
obten_clusters
                          endp
; Esta rutina lee y guarda en 'buffsec' la inf. del SECTOR,
; se despliega y si hay error, B
lee_sector proc
                                         ANDERR es dejada en 1
                          PUSH
                                         SI
                          push
                                         ax
                          push
                                         bx
                         push
                                         CX
                                         dx.
                          push
                          mov
                                         [banderr],1
                          mov
                                         al,1 ;drive b=1 drive a=0
                                         cx,1; numero de sec. a leer
dx,[sector]; sector logico a leer
                          mov
                          mov
                          mov
                                         bx,offset buffsec
                          int
                                         25h
                         jc
                                         er_bios
                          popf
; se despliega la inf. leida con desp
                          mov
                                         cx,512
                                         bx,00h
                          mov
                                         si,offset buffsec
                          mov
                          call
                                         desp
                          jmp
                                         no_error
                                        dx,offset string8 ;error desp_mje
err_bios:
                          mov
                          call
                                        fin_sector
                         jmp
; si hasta aqui no hubo error, entonces banderr se hace cero
no_error:
                                        [banderr],0
                         mov
fin_sector:
                          nop
                          pop
                                         dх
                         pop
                                        CX
                         pop
                                        bx
                         POP
                                        ax
                                        SI
                          ret
lee_sector
                          endp
; Esta rutina escribe en SECTOR inf. mantenida en memoria,
; como puede ser cualquier buffer. esc_sector proc
                          push
                                        ax
```

```
push
                                        bx
                         push
                                        CX
                         push
                                        dx
                         mov
                                        [banderr],1
                                        al,1;drive b=1 drive a=0
cx,1; numero de sec. a escrbir
                         mov
                         mov
                                        dx,[sector]; sector logico a leer
                         mov
                         mov
                                        bx, offset archivo
                         int
                                        26h
                                        error_bios
                         jc
                         popf
                         jmp
                                        finescsector
error_bios:
                         call
                                        video_word
                                        dx,offset string 12 ;error
                         mov
                         call
                                        desp_mje
finescsector:
                         nop
                         pop
                                        ďχ
                         pop
                                        CX
                         pop
                                        bx
                         pop
                                        ax
                         ret
esc_sector
                         endp
; Rutina para lectura de un archivo a partir de sus CLUSTERS
; (es la inf. que maneja la FAT) y obtener SECTORES (es lo que
reconoce la cabeza del drive). El archivo se lee con lee_nomarch.
lee_arch
                         mov
                                        dx,offset string4 ;dame arch.
                         call
                                        desp_mje
                                       lee_nomarch
INICIALIZACION
                         call
                         CALL
; se hace barrido de dir para buscar el arch.
                         call
                                       scan_dir
                                       [arch_en],0
                         cmp
                                       fin_busqda
                         mov
                                       [primcluster],1
; se entra a loop que sigue los clusters para DESPLEGAR el arch.
otro_cluster:
                                       obten_clusters ; da valor a [cluster]
                        call
                                       [cluster], Off8h
                        cmp
; p' no desplegar la eof mark
                                        fin_leearch
                        call
                                       obt_sect
; con CLUSTER se obt. SECTOR
                        call
                                       lee_sector
; se obt. y desp. el 1er sec./clu.
                        cmp
                                       [seclus],1
```

je

otro\_cluster

```
add
                                       [sector],1
                                       lee_sector
                         call
; se obt. y desp. el 2o. sec./clu.
                        jmp
                                       otro_cluster
fin_busqda:
                                       dx, offset string5 ; arch. no enc.
                         mov
                         call
                                       desp_mje
fin_leearch:
                         nop
                         ret
lee_arch
                         endp
; rutina para escribir en la zona de datos del disco,
; dados los clusters -en clus_libre- y esc. en sectores físicos
escribedatos proc
                                       bx,0
                         mov
                                       ax,[clus_libre+bx]
otrolibre:
                         mov
                                       [cluster],ax
                         mov
                         call
                                       video_word
                                       ax,Offfh
                         cmp
                                       finescdat
obt_sect
                        jΖ
                         call
                         call
                                       esc_sector
                         add
                                       [sector],1
                                       esc_sector
                        call
                         add
                        jmp
                                       otrolibre
                        nop
finescdat:
                        ret
escribedatos
                        endp
; Rutina para escritura de un archivo .-
esc_arch
              proc
                                       [clus_a_esc],1
                        mov
                                       dx,offset string4 ;dame arch.
                        call
                                       desp_m
                                                            je
                        call
                                       lee_nomarch
                         CALL
                                       lee_seczero
                        call
                                       lee_dir
                                       scan_dir
                        call
                                       [entry_full],1; ya no hay entries?
                         cmp
                        je
                                       intenta_borr
                        cmp
                                       [arch_en],1 ; se encontro arch ?
                                       bypass1
[arch_borr],0
                        je
                        cmp
                         je
                                       dos
                        jmp
                                       uno
dos:
                        mov
                                       [entryclas],2
                        jmp
                                       tres
```

```
intenta_borr:
                          cmp
                                         [arch_borr],0
                          je
                                         bypass
                          mov
                                         [entryclas],0
uno:
                                        ax,[clus_a_esc]
[necesito],ax
tres:
                          mov
                          mov
cuatro:
                          call
                                         lee_fat
                         cmp
                                        [necesito],0
                                         bypass
                         jne
                                        [entryclas],1
                         cmp
                                         sihayarch
                          je
                          cmp
                                        [entryclas],0
                                        erased
                         je
                                        ax,[entry]
                         mov
                                        [posicion],ax
                         mov
                                        escribe_dir
                         jmp
bypass1:
                         imp
                                        sigue_arch
erased:
                                        ax,[off_borr]
                         mov
                                        [posicion],ax
                         mov
escribe_dir:
                                        escribedir
                         call
                         call
                                        escribefat
                         call
                                        escribedatos
                                        fin_escarch
                         jmp
                                        lee_fat
ax,[off_endir_enc]
sihayarch:
                         call
                         mov
                         mov
                                        [posicion],ax
                                        [primcluster], 1
                         mov
                                        di,0
                         mov
                                        obten_clusters; da valor a [cluster] [cluster], Off8h
other_cluster:
                         call
                         cmp
                                        terminador
                         jae
                                        ax,[ciuster]
                         mov
                                        [clus_de_arch+di],ax
                         mov
                         add
                                        di,2
;se ha de mover de 2 en 2
                                        other_cluster [suficiente],1
                         imp
terminador:
                         cmp
                         jne
                                        escribe_dir
                         mov
                                        [clus_de_arch+di],Offfh
;EOF mark en clus_de_arch
                                        escribe_dir
                         jmp
bypass:
                         jmp
                                        noti_nohay
backpass:
                         jmp
                                        cuatro
                                        ax,[fsize_lsw]
sigue_arch:
                         mov
                                        dx,[fsize_msw]
                         mov
; en AX se tiene el tama¤o del arch. viejo
                         mov
                                        cx,400h
                         div
                                        CX
                                        dx.0
                         cmp
```

```
unalinea
                         je
                         inc
                                        ax
unalinea:
                         mov
                                        [realsize],ax
;tama¤o real en clusters del arch. viejo
                         sub
                                        [clus_a_esc],ax
; clus_a_esc tiene el tama¤o del nvo.
                                        ax,[clus_a_esc]
                         mov
                         mov
                                        [necesito],ax
                                       video_word
[entryclas],1
[necesito],0
                         call
                         mov
                         cmp
                         ja
                                        backpass
                         mov
                                       [suficiente],1
; el arch. es menor o igual
                                        sihayarch
                         jmp
; si no cabe el archivo se dep. mje.
noti_nohay:
                         mov
                                       dx,offset string9 ;no cabe el arch.
                         cail
                                       desp_mje
fin_escarch:
                         nop
                         ret
esc_arch
                         endp
; Rutina para meter inf. del nvo. arch. en la zona de dir del disco
escribedir
             proc
                                       si,offset buffdir
                         mov
                                       bx,[posicion]
si, offset buffnom
                         mov
                         mov
                         mov
                                       di, offset buffdir
                         add
                                       di,bx
                                       cx,11
                         mov
                                       movsb
                         rep
                         call
                                       tiempo
;se simulan las 17:51:26 -> 1000,1 110,011 0,1101
                        mov
                                       bx,0
                                       [datosdir+bx],6Dh
                         mov
                         inc
                                       [datosdir+bx],8Eh
                         mov
                         cail
                                       fecha
;se simula el 20/11/92
                        -> 0001,100
                                      1,011 1,0100
                         inc
                                       bx
                                       [datosdir+bx],74h
                         mov
                        inc
                                       bx
                        mov
                                       [datosdir+bx], 19h
                         inc
                                       bx
                                       [entryclas],1
                         cmp
```

```
jne
                                       jump_one
                         mov
                                       ax,[clus_de_arch+0]
                                       jump_two
ax,[clus_libre+0] ; cluster inic.
                         jmp
jump_one:
                         mov
jump_two:
                         mov
                                       [datosdir+bx],al
                         inc
                                       [datosdir+bx],ah
                        mov
                         inc
                                       bx
                        mov
                                       [datosdir+bx],00H
                         inc
                                       [datosdir+bx],04h
                        mov
                        inc
                                       bx
                         mov
                                       [datosdir+bx],00
                        inc
                                       [datosdir+bx],00
                        mov
; se simulan 400h bytes
                        mov
                                       bx,[posicion]
                         mov
                                       si, offset datosdir
                                       di, offset buffdir
                        mov
                        add
                                       di,bx
                        add
                                       di, 16h
                        mov
                                       cx, 10
                                       movsb
                        rep
                                       si, offset buffdir
                        mov
                        add
                                       bx,0bh
                        mov
                                       [buffdir+bx],32; para el atributo
                        call
                                       esc_dir
                        ret
escribedir
                        endp
; Rutina para meter inf. del nvo. arch. -clus_libre y clus_de_arch-
; en la zona de fat del disco
escribefat proc
                                       si, offset buffat
;inicializacion
                                       di,0
                        mov
                                       [pointer],0
                        mov
                                       [arch_en],1
                        cmp
                        je
                                       con_clus_arch
;se usan clusters libres:
fat_sig:
                                       ax,[clus_libre+di]
                        mov
                                               ; mult. por 1.5
                        mov
                                       cx,3
                        mul
                                                ; ax=ax*3
                        clc
                                              ; clear carry flag
                                                ; corr. a la der. (div/2)
                        shr
                                       ax,1
                                       [offsetfat]
                        mov
```

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

```
entero ; (no carry) salt. a entero [pointer],2
, ax; usar parte entera como offset en FAT
                          jnc
                          add
                                          di,[pointer]
                          mov
                          mov
                                          ax,[clus_libre+di]
                          mov
                                         cl,4
                          shl
                                         ax,cl
                                         bx,[offsetfat]
                          mov
                                         [si+bx],ax
                          or
                                         ax,0fff0h
                          cmp
                                         fat_sig
finescfat ; interfin
[pointer],2
                          ine
                          jmp
entero:
                          add
                          mov
                                         di,[pointer]
                                         ax,[clus_libre+di]
                          mov
                                         bx,[offsetfat]
                          mov
                          or
                                         [si+bx],ax
                          cmp
                                         ax,0fffh
                          ine
                                         fat_sig
                          jmp
                                         finesclat
; se tienen clusters de archivo:
con_clus_arch:
                          cmp
                                         [suficiente],1
                          ine
                                         liga
; si es suficiente, trabajo solo con clus_de_arch
                          mov
                                         ax,[realsize]
                          cmp
                                         [clus_a_esc],ax
                                         bigtrouble
                          jne
fat_sig1:
                                         ax,[clus_de_arch+di]
                          mov
                          mov
                                         cx,3
                                                   ; mult. por 1.5
                          mul
                                                   ax=ax*3
                          clc
                                                 ; clear carry flag
                          shr
                                         ax, 1
                                                   ; corr. a la der. (div/2)
                          mov
                                         [offsetfat], ax
                                         entero1 ; (no carry) salt. a entero
[pointer],2
; usar parte entera como offset en FAT
                         jnc
                          add
                                         di,[pointer]
                          mov
                          mov
                                         ax,[clus_de_arch+di]
                          mov
                                         cl,4
                                         ax.cl
bx.[offsetfat]
                          shi
                          mov
                          or
                                         [si+bx],ax
                          cmp
                                         ax, Offf Oh
                          ine
                                         fat_sig1
                                         finesciat
                          jmp
entero1:
                          add
                                         [pointer],2
                          mov
                                         di,[pointer]
                          mov.
                                         ax,[clus_de_arch+di]
```

```
bx,[offsetfat]
[si+bx],ax
ax,0fffh
                            mov
                            or
                            cmp
                            jne
                                            fat_sig1
                           jmp
                                            finescfat
; el arch. nvo. es mas pequeño que el original bigtrouble:
; el arch. nvo. es mas grande que el original y han de usarse las 2 estructuras
liga:
                            lea
                                            ax,clus_libre
                                           cx,[ax+di]
esc_fat
                           mov
finescfat:
                           call
                            ret
escribefat
                            endp
; Rutina para desplegar cadenas con INT 21H func. 09H,
; la cadena es puesta antes del llamado en DS:DX
desp_mje
                           push
                                            ah,9
                            mov
                           int
                                            21h
                           pop
                                            ax
                           ret
desp_mje
                           endp
; Rutina obtiene sector dada la var. CLUSTER y el valor ; obtenido se guarda en SECTOR
obt_sect proc
; si se usa bx, guardarlo en stackl
                           push
                                            [cluster]
                           dec
                                            [cluster]
                            dec
                                            [cluster] ;restar 2 al cluster
                           mov
                                            ax,[cluster]
                           mul
                                            [seclus]
;mult. por num.sec/cluster, res. en AX
                                            ax,[secdat]
                           add
;sumar no de sec. antes. de arch.
                                            [sector],ax
                           mov
                                            [cluster]
                           pop
                           ret
obt_sect
                           endp
; Rutina para leer cararcteres de teclado con INT 21H func. 01H,
; la tecia regresa en AL, y ha de ser tomada por la inst. sig.
              proc
lee_tecla
                           mov
                                            ah,1
```

```
21h
                        int
                        ret
lee_tecla
                        endp
; Rutina para leer la long. de un archivo con lee_tecla, la long
; se guarda en clus_a_esc. y solo ha de ser de hasta 99
lee_longarch proc
                        mov
                                      [clus_a_esc],0
                                      ax,0
                        mov
                                      bx,1; peso o posicion en la cifra
                        mov
leeotro:
                        call
                                      lee_tecla
                                      al, 13
                        cmp
; se compara con RET
                                      fin_leelong
                        je
                        cmp
                                      bx,1
                                      nounit
; el valor en AL ha de estar entre 48(0) y 57(9) y se hace word
                        sub
                                      ax,48
; se le resta 48 para obtener el VALOR
                        add
                                      [clus_a_esc],ax
; se suma a [clus_a_esc]
                                      fin_leelong
ax,48
                        jmp
nounit:
                        sub
                        push
                                      CX
                                      cx,0ah
                        mov
                        mul
                                      CX
                        pop
                                      CX
                        add
                                      [clus_a_esc],ax
; se suma a [clus_a_esc]
                        dec
                                      bx
                        jmp
                                      leeotro
fin_leelong:
                        nop
                        ret
lee_longarch
                        endp
; Rutina para leer el nombre de un archivo con lee_tecla, el nombre
; se guarda en buffnom, el cual es una variable que acepta 8 carac.
; para el nombre, 3 para la ext.
lee_nomarch proc
                                      [banderr],1
                        mov
                                      bx,0
cx,11
                        mov
                        mov
                                      buffnom+bx],20h
limpiabx:
                        mov
                        inc
                                      bx
                                      limpiabx
                        loop
                                      bx,0
                        mov
```

```
call
                                     iee_tecla
; el carac. es pto. y bx < 7 entonces dejar con 20H desde la pos. bx a la 7
                                     al,2eH
                       cmp
                                     guarda2; si car <> pto.
                       jne
                                     bx,8
                       mov
                       jmp
                                     leeotra
guarda2:
                                     al,13
                       cmp
; se compara con RET
                       je
                                     fin_leenom
                       mov
                                     [buffnom+bx],al
                                     bx
                       inc
                                     ieeotra
                       jmp
fin_leenom:
                       nop
                       ret
lee_nomarch
                       endp
; Escribe, usando la rutina chrout, el nombre con ext. de un arch.
; el nombre se tiene con lo apuntado por SI+BX
nomarch
             proc
                       push
                                     bх
; se guarda, pues es apuntador
; se escribe nombre
                                     cx,8
al,[si+bx]
                       mov
otrocamom:
                       mov
                       call
                                     chrout
                       inc
                                     bx
                       loop
                                     otrocamom
; se escribe ext
                       mov
                                     al,46
                       call
                                     chrout
                                     cx,3
                       mov
                                     al,[si+bx]
otrocarext:
                       mov
                       call
                                     chrout
                       inc
                                     bx
                       ioop
                                     otrocarext
                                     al,13
                       mov
                                     chrout
                       call
                       mov
                                     al,10
                       call
                                     chrout
                       pop
                                     bx
                       ret
nomarch
                       endp
; Compara el nombre del archivo actualmente leido (SI+BX) con el
; que se busca leer o escribir, y de ser igual, prende la bandera
```

; de arch\_en.

```
compa_nom
                   proc
                            push
                                             СХ
                            push
                                             bx
                                             di,0
                            mov
                                            al,0
[arch_en],0
cx,11;nombre+ext
al,[si+bx]
al,[buffnom+di]
diferente
                            mov
                            mov
otrocar:
                            mov
                            cmp
                            jne
                                            bx
                            inc
                            inc
                                             di
                            loop
                                             otrocar
                            mov
                                            [arch_en],1
diferente:
                            nop
                            pop
                                            bx
                            pop
ret
                                            СХ
                            endp
compa_nom
```

;Usando el proc. VIDEO va desplegando, previa conversion a HEX, ;los CX bytes que llegan apuntados por SI desp proc

| desp     | proc |      |            |
|----------|------|------|------------|
|          |      | push | ax         |
|          |      | push | bx         |
|          |      | push | dx         |
|          |      | mov  | bx,0       |
| otronum: |      | mov  | al,[si+bx] |
|          |      | push | CX         |
|          |      | push | ax         |
|          |      | mov  | dx,2       |
|          |      | and  | al,0f0h    |
|          |      | dec  | dx         |
|          |      | mov  | cl,4       |
|          |      | ror  | al,cl      |
| compara: |      | cmp  | al,0ah     |
|          |      | jae  | letra      |
|          |      | add  | al,30h     |
|          |      | cali | video      |
|          |      | jmp  | nibble     |
| letra;   |      | add  | al,37h     |
|          |      | cali | video      |
| nibble:  |      | cmp  | dx,0h      |
|          |      | jz   | ultimo     |
|          |      | pop  | ax         |
|          |      | and  | al,0fh     |
|          |      | dec  | dx         |
|          |      | jmp  | compara    |
|          |      |      |            |

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM

```
ultimo:
                        pop
                                       СХ
                        inc
                                       bx
                        loop
                                       ctronum
                        pop
                                       dχ
                        pop
                                       bx
                        pop
                                       ax
                        ret
desp
                        endp
; Escribe caracter ASCII que ESTA en AL a video, usando INT 10H ; la usa el proc. DESP
video
            proc
                                       AX
ah,14
10h
AX
                        PUSH
                        mov
                        int
                        POP
                        ret
video
                        endp
; Escribe UN carac. ubicado en AL en video, usando INT 21H func. 02
chrout
                        push
                                       ax
di,ai
ah,02h
                        mov
                        mov
                        int
                                       21h
                        рор
                                       ax
                        ret
chrout
                        endp
VIDEO_WORD
                   PROC
                        PUSH
PUSH
PUSH
                                       AX
BX
CX
DX
                        PUSH
                        mov
                                       BX,2
otronumv:
                        push
                                       ax
                        push
                                       ax
                                       dx,2
                        mov
                                       al,OfOh
                        and
se analiza el byte bajo nibble x nibble
                        dec
                                       dx
                        mov
                                       cl,4
                                       al,cl
                        ror
comparav:
                                       al,0ah
                        cmp
                                       letrav
                        jae
                                       al,30h
                        add
```

call video nibblev al,37h jmp add letrav: video call dx,0h ultimov nibblev: cmp jz pop and ax al,0fh dec dx comparav jmp ultimov: pop al,ah ;se analiza el byte alto usando al mov dec bx otronumy DX CX BX AX jnz POP POP POP POP ret ENDP VIDEO\_WORD code ends end MAIN

# **BIBLIOGRAFIA**

Diseño de un Controlador Digital con unidad de disco Facultad de Ingeniería UNAM **Advanced MS DOS** 

Duncan, Ray

Microsoft Press

U.S.A. 1986

Assembly Language Book for the IBM PC

Norton, Peter

Ed. Brady

U.S.A. 1986

Desinging with the 8088 Microprocesor

Zarrella, John

Ed. Microcomputer Application

Suisun City Catifornia U.S.A. 1984

**IBM PC Assambler Language** 

Tabler, Donna

Ed. Willey Press Book

U.S.A. 1985

IBM Personal System / 1 Hardware

Interface Technical Reference

IBM

U.S.A. 1992

Inside de IBM PC

Norton, Peter

Ed. Brady

U.S.A. 1986

## **Memory Component Handbook**

Intel

U.S.A. 1988

#### Microprocessor and Peripheral Handbook

Intel Corporation, Vol. 1

U.S.A. 1988

#### Microsoft Macro Assembler for the MS DOS

**Operating System User's Guide** 

Ed. Microsoft Corporation

U.S.A. 1985

# **Peripheral Desing Handbook**

Intel

U.S.A. 1981

## Programmer's Guide to the IBM PC

Norton, Peter

Microsoft Press

U.S.A. 1985

Programmer's Problem Solver for the IBM

Jourdain, Robert

PC, XT & AT

Ed. Brady

U.S.A. 1986

The TTL Data Book for Desing Engineers

Ed. Texas Instuments

U.S.A. 1976

400 Ideas for Desing Volume IV

Editado por Grossman, Morris

Hayden Book Company, Inc.

U.S.A. 1988

8088 Assembler Language Programming

the IBM PC

Ed. Howard W. Sams

U.S.A. 1983