Diferencia entre revisiones de «ETC-II 2008/09»
(→Descarga de archivos) |
(→Librerías) |
||
Línea 99: | Línea 99: | ||
* '''tasm /zi teclado.asm''' para generar el fichero '''teclado.obj''' (suponiendo que el archivo que contiene la libreria se llame ''teclado.asm'') | * '''tasm /zi teclado.asm''' para generar el fichero '''teclado.obj''' (suponiendo que el archivo que contiene la libreria se llame ''teclado.asm'') | ||
* '''tlib teclado.lib -+teclado.obj''' para generar el fichero '''teclado.lib''' que es la librería encapsulada. El '''-+''' indica re-emplazo, es decir, si dentro del archivo teclado.lib ya existe una función GetKey procede a su reemplazo por la nueva versión. En caso de que no exista la añade directamente. | * '''tlib teclado.lib -+teclado.obj''' para generar el fichero '''teclado.lib''' que es la librería encapsulada. El '''-+''' indica re-emplazo, es decir, si dentro del archivo teclado.lib ya existe una función GetKey procede a su reemplazo por la nueva versión. En caso de que no exista la añade directamente. | ||
− | * Una vez que se tiene el archivo '''teclado.lib''' se podrá compilar cualquier programa que use funciones de la librería con el comando: '''tlink /v | + | * Una vez que se tiene el archivo '''teclado.lib''' se podrá compilar cualquier programa que use funciones de la librería con el comando: '''tlink /v program.obj teclado.lib''' |
− | + | <br> | |
+ | Veamos ahora un programa que usa esa librería (archivo program.asm)<br> | ||
+ | <pre> | ||
+ | </pre> | ||
=== Fichero Makefile === | === Fichero Makefile === |
Revisión del 21:59 26 oct 2008
Contenido
Ultima hora
- En el driver hay un error. Solo devuelve 128 posiciones de memoria. En la zona de descargas podeis encontrar una version que corrige el error (EEPROM.COM) y pronto estará en la web. (Por cierto el uninstall tampoco funciona por ahora)
- En la zona de descargas teneis un programa que se llama TEST.ASM que permite probar el driver. Para ello crea un fichero que se llama MEM2.BIN, lo rellena de datos y luego comprueba que se leen bien. Además los representa en ASCII en la pantalla.
Resumen Objetivos Entrega
- Realización del programa Lector/Editor Hexadecimal
- Creación de librerias (teclado)
- Uso de los servicios de la BIOS y del DOS
- Detectar la correcta instalación de un driver en memoria
- Compilación usando Makefiles
Consejos
Pasos para la programación del Editor
1. Hacer la estructura del programa partiendo en uno de los ejemplos de la práctica 0
2. Comprobar que existe el driver: Tabla INT, 0CAFEH y STATUS
3. Leer toda la memoria y dejar los valores en un ARRAY en el programa principal.
4. Pinta esos datos en pantalla de forma ordenada: Necesaria función conversion de binario a representación hexadecimal en ASCII
5. Funciones de teclado (Por ejemplo usando Libreria) e implementación del cursor.
6. Meter inteligencia al cursor, de forma que sepa en que byte está en cada momento.
7. Meter funcionalidad de edición de valores.
8. Añadir resto de funciones. Scroll, CTRL-G, ...
Conviene usar Makefile desde el principio.
Librerías
Una librería mantiene una estructura muy parecida a la de un programa, pero con algunas características especiales:
1. Es un archivo fuente .ASM que generalmente sólo lleva la definición del segmento de código, ya que comparte pila y segmento de datos con el programa principal que llama a las funciones de la misma.
2. Las funciones que queramos exportar o hacer visibles se declaran como PUBLIC en el archivo fuente de la librería.
3. Los programas que quieran llamar a esas funciones las tendrán que declarar como EXTERN
4. Una librería se compila con el TASM primero y una vez obtenido el .OBJ se encapsula en un fichero .LIB mediante el comando TLIB.
Veamos un ejemplo de librería (archivo teclado.asm):
;================================== ;= Ejemplo de libreria = ;================================== ;DEFINICION DEL SEGMENTO DE CODIGO TECLADOLIB SEGMENT BYTE PUBLIC 'CODE' ASSUME CS:TECLADOLIB ; Funcion que mira si hay tecla pulsada ; Es equivalente a kbhit(); ; devuelve en AL 0 si no hay tecla ; devuelve en AL 1 si hay tecla IsKey PROC FAR MOV AH,0BH MOV AL,0H INT 21H RET IsKey ENDP ; Funcion que devuelve la tecla pulsada en AL ; Accede al buffer del teclado y devuelve la tecla pulsada ; Si se pulsa una tecla extendida se devuelve 0x00, y luego ; habra que volver a llamar a la funcion para saber cual ha ; sido la tecla pulsada ReadKey PROC FAR PUSH DX MOV AH,06H MOV DL,0FFH INT 21H POP DX RET ReadKey ENDP ; Funcion que espera a que se pulse una tecla ; momento en la que la devuelve en AL GetKey PROC FAR CALL IsKey CMP AL,0 JE GetKey CALL ReadKey RET GetKey ENDP TECLADOLIB ENDS PUBLIC GetKey END
Vemos que se trata de un archivo teclado.asm que tiene una declaración de un solo segmento (el de código). En ese segmento lo único que encontramos son procedimientos (funciones) y no hay programa principal, ni procedimiento principal. En la etiqueta END no se indica por donde se empieza a ejecutar ese código, de hecho, nunca se ejecutará ya que no llegará a ser un programa .EXE.
Podemos poner todos los procemientos que queramos o que sean necesarios, en el ejemplo hay tres:
- IsKey
- ReadKey
- GetKey
Pero de los tres sólo será visible desde el exterior el GetKey dado que es el único que se ha hecho público con la directiva PUBLIC. Por lo tanto, los procedimientos que queramos que sean públicos tendrán que estar listados abajo con la etiqueta PUBLIC delante.
Lo siguiente es ver como se compila un fichero fuente de librería. Los pasos son los siguientes:
- tasm /zi teclado.asm para generar el fichero teclado.obj (suponiendo que el archivo que contiene la libreria se llame teclado.asm)
- tlib teclado.lib -+teclado.obj para generar el fichero teclado.lib que es la librería encapsulada. El -+ indica re-emplazo, es decir, si dentro del archivo teclado.lib ya existe una función GetKey procede a su reemplazo por la nueva versión. En caso de que no exista la añade directamente.
- Una vez que se tiene el archivo teclado.lib se podrá compilar cualquier programa que use funciones de la librería con el comando: tlink /v program.obj teclado.lib
Veamos ahora un programa que usa esa librería (archivo program.asm)
Fichero Makefile
La herramienta make nos permite simplicar la compilación de un programa, al permitir definir en un fichero una serie de reglas o pasos, para que a partir de una serie de archivos fuente se obtenga el fichero o ficheros ejecutables del proyecto.
Dichas reglas se escribirán en un fichero llamado Makefile que será llamado por defecto al ejecutar el comando make
Un ejemplo sencillo de Makefile es el siguiente:
test.exe: test.obj tlink /v test.obj test.obj: test.asm tasm /zi test.asm clean: del *.obj del test.exe
Se lee de la siguiente forma. Para generar el programa ejecutable test.exe necesitamos el fichero objeto test.obj y para ello se ejecuta el comando tlink /v test.obj.
En caso de que no exista el test.obj se buscará por el fichero la regla para construirlo. En este caso aparece más abajo y se interpreta: Para generar el test.obj se parte del test.asm y crea mediante el comando tasm /zi test.asm.
Por último tenemos una opción para borrar los pasos intermedios de la compilación y el resultado. Esto es útil cuando nos queremos asegurar que el proceso empiece desde el principio y que no use ningún .obj anterior. Se invoca haciendo:
>make clean
Veamos ahora otro ejemplo un poco más avanzado.
# Ejemplo de fichero Makefile avanzado editor.exe: main.obj teclado.lib TLINK /V main.obj teclado.lib .asm.obj: TASM /ZI $< .obj.lib: TLIB $&.lib -+$< clean: del *.obj del *.map del *.exe del *.lib
Se lee de la misma forma que el anterior, pero ahora considera que hay una librería. Para generar el programa editor.exe se necesitan los ficheros main.obj y la librería teclado.lib. El comando para generar el ejecutable es tlink /v main.obj teclado.lib
El cambio viene ahora, en lugar de establecer reglas específicas para cada archivo, ponemos una global .asm.obj: que se traduce: Para generar cualquier ASM se parte de un OBJ y se ejuta el comando: TASM /ZI $< donde $< me indica el nombre del archivo .ASM que estamos intentanto pasar a .OBJ
La siguiente línea es igual, nos viene a decir que para generar una librería se parte del .obj y que el comando produce un archivo .lib con el nombre que estemos tratando en ese momento.
Lo bueno de este Makefile, es que al estar parametrizado, con definir las dependencias del programa principal nos bastará, ya que la herramienta Make sabrá como generar cada una de ellas y sin haber necesitado especificarlas.
Descarga de archivos
eeprom.com
test.asm
makefile simple
makefile avanzado
ejemplo libreria
libreria teclado