I'm having trouble just making clear EQU directive in assembler (8086).
abc EQU xyz
Does EQU literally swaps abc when found in code with xyz, whatever xyz represents, value etc?
i.e. Can i write?
varA EQU [bp+4]
mov ax, varA
And one more question is EQU globally accessed, i.e. can I define EQU out of procedure, and in procedure to use it?
The EQU directive gives a symbolic name to a numeric constant, a register-relative value or a PC-relative value.
* EQU - The equate directive is used to substitute values for symbols or labels. The format is 'label: EQU value', so whenever the assembler encounters 'label', it replaces this with 'value'.
Reserve space in memory for uninitialized variables. Control the appearance of listings. Initialize memory. Assemble conditional blocks.
By the use of EQU, the programmer can change it once and the assembler will change all of its occurrences throughout the program, rather than search the entire program trying to find every occurrence. This directive is used to define a constant value or a fixed address.
Assembler Directives of 8085 and 8086 - Electronics Desk Definition: Assembler directives are the instructions used by the assembler at the time of assembling a source program. More specifically, we can say, assembler directives are the commands or instructions that control the operation of the assembler.
The EQU directive is used to give name to some value or symbol. Each time the assembler finds the given names in the program, it will replace the name with the value or a symbol.
Keywords: assembler directives 8086, directives in 8086 Assembly languages are low-level languages for programming computers, microprocessors, microcontrollers, and other IC. They implement a symbolic representation of the numeric machine Codes and other constants needed to program a particular CPU architecture.
Equate (EQU) Directive EQU - This EQU directive is used to give a name to some value or to a symbol. Each time the assembler finds the name in the program, it will replace the name with the value or symbol you given to that name.
EQU
items are not variables, they don't take any memory space :
EQU
referes to a constant value, it becomes a synonym for that value. This value can't be overwritten, even if you try it won't change.EQU
referes to another variable, it becomes a synonym for that variable, so everything that happens to the synonym will happen to the variable.Copy-paste next code in EMU8086 and run :
.model small
.stack 100h
.data
xyz DW 2016 ;◄■■■ ABC IS NOT A VARIABLE, IT IS
abc EQU xyz ; JUST A SYNONYM FOR XYZ.
pqr EQU 10 ;◄■■■ PQR IS NOT A VARIABLE, IT IS
; JUST A SNYNONYM FOR NUMBER 10.
varA EQU [bp+2] ;◄■■■ BP POINTS TO GARBAGE.
.code
mov ax, @data
mov ds, ax
mov abc, 25 ;◄■■■ XYZ BECOMES 25!!!!
mov pqr, 999 ;◄■■■ NO ERROR, BUT THE VALUE WILL NOT CHANGE.
mov ax, pqr ;◄■■■ AX IS NOT 999, AX=10.
mov si, varA ;◄■■■ GARBAGE.
mov bp, sp
mov si, varA ;◄■■■ DIFFERENT GARBAGE.
push ax ;◄■■■ PUSH 10.
call my_proc
mov ax, NUMBER ;◄■■■ YES, EQUS ARE GLOBAL!!! (AX=0B9H).
mov ax, 4c00h
int 21h
;-----------------------------------------
my_proc proc
mov bp, sp
mov si, varA ;◄■■■ WRONG VALUE (ANOTHER GARBAGE).
mov si, [bp+2] ;◄■■■ PROPER VALUE (10).
varB EQU [bp+2]
mov si, varB ;◄■■■ WRONG AGAIN.
NUMBER EQU 0b9h ;◄■■■ DEFINE EQU INSIDE PROCEDURE.
ret
my_proc endp
In the case of [bp+2]
it just doesn't seem to work, probably because the compiler can't get a fixed value.
EQU simply denotes equality, therefore abc EQU xyz
, xyz must have been defined previously.
In your second example, it would need to be like
%define varA [bp+4]
mov ax, varA
Then after your code is assembled, an object dump would yield
mov ax, [bp+4]
then you could do something like
Bubble equ varA
mov bx, Bubble
and you'd get
mov bx, [bp+4]
Generally, all assemblers work the same way, although syntactically there are subtle nuances such as NASM requires %
, others may not.
Some assemblers have reasonable macro support, that usually works internally as preprocessor, or very close to it.
Otherwise as I already wrote in comment, why don't you use C preprocessor? (it's standalone tool, you can preprocess any text file with it, just using #define
and other to extend your asm source, the rest of the content doesn't have to look like C source, preprocessor doesn't care, it's processing the file as [any] text file).
Would you need it? I wouldn't. I did huge code in ASM only due to my lack of experience and macros/preprocessor wouldn't save me from that huge mistake (they would probably just make it less obvious and somewhat more bearable for longer period of time).
While you do in ASM only small pieces of code for educational reasons, or performance/low-level things, macros/preprocessor would IMHO add layer of abstraction shadowing the produced instructions, so during debugging you may then find yourself asking "where did this one come from?". I prefer to write every ASM instruction rather by hand, knowing why I put it there, I don't want any surprises in ASM code, it's already quite tough to write bug free code in ASM.
Then again most of my late work in ASM were 256B intros, so I really had to know about each byte produced... :)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With