Clase 15 macros y procedimientos
Download
1 / 51

CLASE 15 MACROS Y PROCEDIMIENTOS - PowerPoint PPT Presentation


  • 87 Views
  • Uploaded on

CLASE 15 MACROS Y PROCEDIMIENTOS. Una de las claves para poder solucionar un problema complejo está en la capacidad de fragmentarlo en subproblemas . En la medida en que los subproblemas sean correctamente identificados, la solución será mejor que otras posibles. .

loader
I am the owner, or an agent authorized to act on behalf of the owner, of the copyrighted work described.
capcha
Download Presentation

PowerPoint Slideshow about ' CLASE 15 MACROS Y PROCEDIMIENTOS' - rob


An Image/Link below is provided (as is) to download presentation

Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author.While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server.


- - - - - - - - - - - - - - - - - - - - - - - - - - E N D - - - - - - - - - - - - - - - - - - - - - - - - - -
Presentation Transcript
Clase 15 macros y procedimientos

CLASE 15MACROS Y PROCEDIMIENTOS


Una de las claves para poder solucionar un problema complejo está en la capacidad de fragmentarlo en subproblemas.

En la medida en que los subproblemas sean correctamente identificados, la solución será mejor que otras posibles.


En programación hay disponibles, en primera instancia, dos herramientas para ayudar a hacer esta fragmentación:

una es provista por el microprocesador (los procedimientos)

otra por el ensamblador (las macros).


MACROS: herramientas para ayudar a hacer esta fragmentación:

Al familiarizarse con las interrupciones se descubre que la interacción con ellas se realiza normalmente siguiendo tres labores:

Paso de parámetros

Llamado

Recepción de resultados


1) Ubicar en ciertos registros la información requerida por la interrupción (paso de parámetros)

2) Invocar a la interrupción (llamada)

3) Tomar los resultados entregados de los registros correspondientes (valores retornados)

Sería deseable disponer de un mecanismo para automatizar esta labor y eso es precisamente lo que hace una macro.


Una macro es una por la interrupción (paso de utilidad que brinda el ensamblador y que permite insertar un trozo de código en una posición cualquiera de un programa, escribiendo en tal posición una palabra que representa el código mencionado.

Además, la macro permite la recepción de parámetros, lo cual simplifica el llamado a interrupciones y a procedimientos.

DEFINICIÓN DE MACRO:


DECLARACION: por la interrupción (paso de

nombre MACRO [parámetros]

; cuerpo de la macro

ENDM

nombre es el identificador que representa a la macro. Las palabras reservadas MACRO y ENDM marcan los límites de la definición. Se puede colocar, opcionalmente, una lista de parámetros para que la macro reciba y/o entregue información.


Ejemplo: por la interrupción (paso de

Se sabe ya que para escribir un carácter en la pantalla se usa el siguiente esquema:

MOV AH, 02H

MOV DL, carácter

INT 21H


A través de una macro quedaría así: por la interrupción (paso de Putch MACRO CharVar MOV AH, 02H MOV DL, CharVar INT 21HENDM ; fin de la macro Putch

Observe que la “variable” CharVar es en realidad un comodínque se usa para representar lo que debe ir en la segunda línea de la macro, no es una variable que exista físicamente.


Una vez declarada la macro, lo cual debe hacerse al por la interrupción (paso de comienzo del programa, se invoca simplemente colocando su nombre y añadiendo, si es el caso, los parámetros correspondientes.

A continuación se muestra un programa de ejemplo:


MOV AL, A por la interrupción (paso de

Putch AL ; pueden pasarse registros

Putch 5 ; pueden pasarse constantes

Putch var8 ; pueden pasarse variables

LEA SI, var8

Putch [SI] ; pueden pasarse punteros


Es importante aclarar que una macro por la interrupción (paso de NO REDUCE el tamaño del programa, es sólo una utilidad que brinda el ensamblador.

Cuando el ensamblador procesa un programa, usualmente realiza tres pasadas sobre él:


Primera pasada: por la interrupción (paso de cambia las constantes por sus valores reales y expande las macros por el código que representan.

Segunda pasada: traduce cada instrucción por su código binario equivalente y va creando una tabla donde almacena las direcciones que corresponden a cada etiqueta.

Tercera pasada: remplaza las referencias a etiquetas que han quedado pendientes por sus valores, según la tabla creada.


De acuerdo con lo dicho, el siguiente programa es por la interrupción (paso de IDÉNTICO al ejemplo mencionado anteriormente:

MOV AL, A MOV AH, 02H MOV DL, AL INT 21H

MOV AH, 02H MOV DL, 5 INT 21H

... < sigue > ...


... < viene > ... por la interrupción (paso de

MOV AH, 02H MOV DL, var8 INT 21H

LEA SI, var8 MOV AH, 02H MOV DL, [SI] INT 21H


En suma, se establece para los macros que: por la interrupción (paso de

1. Son sólo una utilidad que le ahorra al programador tiempo, al poder remplazar con una sola palabra una secuencia de instrucciones.

2. Permiten que un programa sea más comprensible.

3. Por su propia naturaleza, no deben ser muy grandes. Se sugiere que tengan, máximo, 15 líneas de código.


El uso de los macros se recomienda en estas situaciones: por la interrupción (paso de

1. Para llamar interrupciones y procedimientos, facilitando el paso de parámetros y la recepción de valores retornados

2. Para darle un nombre significativo a un código que, aunque aparezca sólo una vez, realiza algún trabajo importante o poco claro


Ejemplo del segundo caso: por la interrupción (paso de

Empezar MACROMOV AX, DATA MOV DS, AX MOV ES, AX ENDM ; fin de EmpezarEsta macro busca darle sentido a las primeras líneas que usualmente inician un programa típico en ensamblador.


MACROS por la interrupción (paso de NO SON PROCS:

Dado que las macros NO son procedimientos o funciones no deben tener etiquetas ni saltos dentro de ellas, en particular, NUNCA utilice la opción LOCAL que permiten algunos ensambladores.


Debe tenerse un cuidado mínimo con los parámetros que se entregan a una macro.

Las principales causas de problemas al interactuar con una macro tienen que ver con la discrepancia entre los argumentos y los parámetros en cuanto a:

El orden en que se pasan

El tipo que se utiliza

El valor de los argumentos se alteradentro de la macro


Para el ejemplo dado, observe estos casos: entregan a una macro.

MOV AH, ‘L’ Putch AH

MOV BX, 102 Putch BX

El primer caso falla porque al empezar la macro, el valor de AH se cambia por 02H, así que la ‘L’ entregada se pierde. En el segundo caso, el registro BX no se corresponde en tamaño con el registro DL que es quien recibe el parámetro.


Procedimientos

Un procedimiento actúa como un entregan a una macro. servicio de interrupción, pero tiene frente a él dos diferencias importantes:

Usualmente es creado sólo para solucionar un problema particular en el programa de usuario

No se invoca con la orden INT sino con la instrucción CALL.

PROCEDIMIENTOS:


Desde el punto de vista entregan a una macro. físico cuando el uP detecta una orden

CALL Etiqueta

Procede de una forma similar a cuando se encuentra con una orden INT: Guarda en la pila el valor de IP (y CS si es un llamado lejano) y carga en este registro el valor indicado por Etiqueta. Los flags no son guardados en esta operación.


Sintaxis sobre procedimientos

Para invocar un procedimiento, se utiliza la orden Call, que requiere como operando la dirección de inicio del procedimiento, la cual usualmente se da en forma de etiqueta, mediante el propio nombre del procedimiento: CALL NombreProc

SINTAXIS SOBRE PROCEDIMIENTOS:


Para crear un procedimiento, se declara en la forma: requiere como operando la

NombreProc PROC [Opciones]

; cuerpo del procedimiento

RET ; fin del procedimiento

NombreProcENDP


Las opciones pueden ser: NEAR o FAR. Un procedimiento tipo requiere como operando la near sólo puede ser invocado desde dentro del segmento en el cual él existe. Si es de tipo far podrá ser invocado desde cualquier otro procedimiento, esté o no en el mismo segmento.


El fin del procedimiento (y retorno al lugar de llamado) se hace con la orden RET. Aunque puede existir más de una orden RET en un procedimiento, la programación estructurada sugiere colocar uno solo y que sea justamente la última instrucción del procedimiento. Si hay más de un punto de retorno en el código, simplemente se coloca un salto hacia esa última instrucción.


ALCANCE DE LOS SALTOS CONDICIONALES: hace con la orden

  • Cuando se realizan ciclos (del tipo for, while o do) es importante tener en cuenta que los saltos condicionales tienen un alcance MÁXIMO de 128 bytes. Si el ciclo es mayor a este valor es una indicación de mala programación.


ALCANCE DE LOS SALTOS CONDICIONALES: hace con la orden

  • Una solución temporal a este problema consiste en ubicar todo o parte del cuerpo del ciclo en un procedimiento.


Paso de par metros

No existe un mecanismo prefijado por el microprocesador para el paso de parámetros a un procedimiento (tal como decir call nomproc parámetros). Por ello, el programador debe escoger entre las posibilidades que se han desarrollado o una ideada por él mismo.

PASO DE PARÁMETROS:


Las formas tradicionales son: el paso de parámetros a un procedimiento (tal como decir

A través de registros

Mediante la pila

La primera tiene la ventaja de permitir intercambio rápido de información, pero a costa de no ser un mecanismo estandarizado; la segunda si es estandarizada, pero tiene por falencia su lentitud.


Ejemplos de procedimientos

Para visualizar mejor estas ideas se darán por ejemplo de procedimientos aquéllos para lectura y escritura de cadenas, que se utilizan en conjunto con sus macros respectivas, lo cual es usual para sistematizar el paso de parámetros desde el procedimiento llamador hacia el procedimiento llamado.

EJEMPLOS DE PROCEDIMIENTOS:


Lectura de cadena

Se empieza por describir la procedimientos aquéllos para lectura y escritura de cadenas, que se utilizan en conjunto con sus macros respectivas, lo cual es usual para sistematizar el paso de parámetros desde el procedimiento llamador hacia el procedimiento llamado.macro que actúa como parte pública o interfaz con el exterior. En esencia, la macro se encarga se ubicar los parámetros en el sitio en donde el procedimiento supone que estarán (registros o pila). También, se encarga de salvar el valor de los registros que pudiesen ser cambiados por el procedimiento:

LECTURA DE CADENA:


Gets MACRO MaxChar, InString procedimientos aquéllos para lectura y escritura de cadenas, que se utilizan en conjunto con sus macros respectivas, lo cual es usual para sistematizar el paso de parámetros desde el procedimiento llamador hacia el procedimiento llamado.; Primero: preservar registros actuantes PUSH CX PUSH SI; Segundo: cargar parámetros MOV CL, MaxChar LEA SI, InString; Tercero: invocar el procedimiento CALL pGets; Cuarto: restaurar registros usados POP SI POP CX

ENDM ; Gets


Ahora se trabajará con el procedimiento, el cual hace la tarea como tal. El nombre del procedimiento puede ser similar al de la macro, el instructor recomienda esta nomenclatura:

Para la macro: Nombre

Para el procedimiento: pNombre

Es decir, preceder el nombre del procedimiento con una letra ‘p’.


El procedimiento a su vez hace uso de las macros tarea como tal. El nombre del procedimiento puede ser similar al de la macro, el instructor recomienda esta nomenclatura:Getch (Int. 21H, Servicio 08H) y Putch (Int. 21H, Servicio 02H) para leer y escribir caracteres. Se asume, además, que se han declarado las constantes:

CR EQU 13 ; retorno de carro

BS EQU 8 ; retroceso

BEEP EQU 7 ; pitido

NULL EQU 0 ; nulo


Para facilitar la comprensión de un procedimiento se acostumbra colocar al comienzo comentarios que indiquen:

; nombre: < del procedimiento >; propósito: < labor que hace >; prototipo: < declaración equivalente en C >; entrada: < registros que reciben ... ... parámetros >; salida: < registros que entregan ... ... resultados >; registros: < otros registros utilizados >


; nombre: acostumbra colocar al comienzo comentarios que indiquen:pGets; propósito: Leer desde teclado una cadena; ASCIIZ (tamaño máximo de ; 255 caracteres); prototipo: unsinged pGets (unsigned, char *);; entrada: CL = Número máximo de ; caracteres a leer; SI = puntero a la variable ; cadena receptora; salida: BL = número de caracteres leídos; registros: AX, DL


pGets PROC acostumbra colocar al comienzo comentarios que indiquen: PUSH AX PUSH DX MOV BX, 0 ; BX=cuenta cars. DO90: Getch AL ; leer un caracter SWITCH90:CASE91: CMP AL, CR JE ENDSWITCH90


CASE92: acostumbra colocar al comienzo comentarios que indiquen: CMP AL, BS JNE DEFAULT90IF90: CMP BL, 0 JBE ELSE90THEN90: DEC BL Putch BS ; borrar último ... Putch ' ' ; ... carácter ... Putch BS ; ... escrito JMP ENDIF90


ELSE90: acostumbra colocar al comienzo comentarios que indiquen: Putch BEEP ; error de ediciónENDIF90: JMP ENDSWITCH90DEFAULT90:IF91: CMP BL, CL JAE ELSE91


THEN91: acostumbra colocar al comienzo comentarios que indiquen: MOV [SI][BX], AL INC BL Putch AL ; escribir el carácter JMP ENDIF91ELSE91: Putch BEEP ; máximo alcanzadoENDIF91:ENDSWITCH90:


WHILE90: acostumbra colocar al comienzo comentarios que indiquen: CMP AL, CR JNE DO90ENDWHILE90: ; colocar final de cadena MOV BYTE PTR [SI][BX], NULL POP DX POP AX RETpGets ENDP


Escritura de cadena

El proceso aquí es mucho más simple. Simplemente se leen caracteres de una variable existente hasta encontrar el carácter terminador NULO.

Como en el caso anterior, se presenta primero la macro y después el procedimiento respectivo.

ESCRITURA DE CADENA:


Puts MACRO OutString caracteres de una variable existente hasta encontrar el carácter terminador NULO.

PUSH SI LEA SI, OutString CALL pPuts POP SI

ENDM ; Puts


; nombre: caracteres de una variable existente hasta encontrar el carácter terminador NULO.pPuts; propósito: Escribir en pantalla una; cadena ASCIIZ; prototipo: void pPuts ( char * );; entrada: SI = puntero a la cadena; salida: Ninguna; registros: AH, DL


pPuts PROC caracteres de una variable existente hasta encontrar el carácter terminador NULO. PUSH AX PUSH DXWHILE92: CMP BYTE PTR [SI], NULL JE ENDWHILE92 Putch [SI] INC SI JMP WHILE92ENDWHILE92: POP DX POP AX RETpPuts ENDP


Recomendaciones

Es opcional caracteres de una variable existente hasta encontrar el carácter terminador NULO.preservar los registros que se usarán en una macro o procedimiento. Al hacerlo, se tiene la tranquilidad de que no se alterarán inadvertidamente sin que se tenga conocimiento de ello fuera de la macro o del procedimiento. Su desventaja es que aumenta el tamaño del código y el tiempo de ejecución

RECOMENDACIONES:


Por razón similar, caracteres de una variable existente hasta encontrar el carácter terminador NULO.nunca deben usarse variables globalesdentro de una macro o procedimiento, si se requieren, se pasarán como parámetros o mediante un puntero

Usar solamente una instrucción RET por procedimiento y ubicarla como instrucción final


Pregunta 15

¿Cómo funciona el uso de caracteres caracteres de una variable existente hasta encontrar el carácter terminador NULO.comodines dentro de las macros y qué utilidad tienen?.

PREGUNTA 15:


Fin de la clase 15
< FIN DE LA CLASE 15 > caracteres de una variable existente hasta encontrar el carácter terminador NULO.


ad