Documente Academic
Documente Profesional
Documente Cultură
LUCRAREA DE LABORATOR 3
PROGRAME LINIARE
1. SCOPUL LUCRARII
Lucrarea prezinta instructiunile pentru transferuri de date, instructiuni in aritmetica binara si in
aritmetica BCD.
2. NOTIUNI TEORETICE
Instructiunile de transfer permit copierea unui octet sau cuvant de la sursa la destinatie. Destinatia
poate fi un registru, locatie de memorie sau un port de iesire, iar sursa poate fi un registru, o locatie de
memorie, constante sau port de intrare. Ca regula generala destinatia si sursa nu pot fi ambele locatii
de memorie. In specificarea sursei si destinatiei se vor folosi notatiile:
segment: offset pentru adrese fizice;
[x] paranteze patrate pentru a desemna continutul lui x.
OBS. Instructiunea de transfer nu modifica indicatori de conditie (flagurile) cu exceptia instructiunilor
SAHF si POPF.
2.1. Instructiuni de transfer.
2.1.1. Instruciunea MOV (Move Data).
Forma general a instruciunii MOV este:
mov dest, sursa ;
[dest] [sursa]
realizeaz transferul informaiei de la adresa efectiva data de sursa la dest.
Restricii:
Este necesar ca ambii operanzi s fie de aceiai mrime;
Ambii operanzi nu pot fi locaii de memorie (este necesar utilizarea unui registru);
Registrele IP, EIP, sau RIP nu pot fi ca operanzi destinaie.
Structura instruciunii MOV poate fi urmtoarea:
MOV reg,reg
MOV mem,reg
MOV reg,mem
MOV mem,imm
MOV reg,imm
Exemple:
.data
var1 WORD ?
var2 WORD ?
.code
mov ax,var1
mov var2,ax
.data
oneByte BYTE 78h
oneWord WORD 1234h
oneDword DWORD 12345678h
.code
mov eax,0 ; EAX = 00000000h
mov al,oneByte ; EAX = 00000078h
mov ax,oneWord ; EAX = 00001234h
mov eax,oneDword ; EAX = 12345678h
.data
byte1 BYTE 9Bh
word1 WORD 0A69Bh
.code
movzx eax,word1 ; EAX = 0000A69Bh
movzx edx,byte1 ; EDX = 0000009Bh
movzx cx,byte1 ; CX = 009Bh
Instruciunea MOVSX (move with sign-extend)
Copie coninutul sursei n destinaie cu extinderea valorii ntroducnd uniti. Aceast instruciune este
utilizat numai petru valori cu semn. Sunt trei variante:
MOVZX reg32,reg/mem8
MOVZX reg32,reg/mem16
MOVZX reg16,reg/mem8
Exemplu:
mov bx,0A69Bh
movsx eax,bx ; EAX = FFFFA69Bh
movsx edx,bl ; EDX = FFFFFF9Bh
movsx cx,bl ; CX = FF9Bh
Exemplu de program:
.data
val1 WORD 1000h
val2 WORD 2000h
arrayB BYTE 10h,20h,30h,40h,50h
arrayW WORD 100h,200h,300h
arrayD DWORD 10000h,20000h
.code
main PROC
; Demonstrating MOVZX instruction:
mov bx,0A69Bh
movzx eax,bx ; EAX = 0000A69Bh
movzx edx,bl ; EDX = 0000009Bh
movzx cx,bl ; CX = 009Bh
; Demonstrating MOVSX instruction:
mov bx,0A69Bh
movsx eax,bx ; EAX = FFFFA69Bh
movsx edx,bl ; EDX = FFFFFF9Bh
mov bl,7Bh
movsx cx,bl ; CX = 007Bh
; Memory-to-memory exchange:
mov ax,val1 ; AX = 1000h
xchg ax,val2 ; AX=2000h, val2=1000h
mov val1,ax ; val1 = 2000h
; Direct-Offset Addressing (byte array):
mov al,arrayB ; AL = 10h
mov al,[arrayB+1] ; AL = 20h
mov al,[arrayB+2] ; AL = 30h
; Direct-Offset Addressing (word array):
mov ax,arrayW ; AX = 100h
mov ax,[arrayW+2] ; AX = 200h
; Direct-Offset Addressing (doubleword array):
mov eax,arrayD ; EAX = 10000h
mov eax,[arrayD+4] ; EAX = 20000h
mov eax,[arrayD+4] ; EAX = 20000h
Instruciunea XCHG ( Exchange Data )
Interschimb sursa cu destinaia. Forma general:
XCHG dest, sursa
Restricii:
registrele de segment nu pot aprea ca operanzi;
cel puin un operand trebuie sa fie un registru general.
Sunt trei variante:
XCHG reg,reg
XCHG reg,mem
XCHG mem,reg
Exemple:
xchg
al, ah
xchg
alfa, ax
xchg
sir [si], bx
xchg eax,ebx ; exchange 32-bit regs
Interschimbarea coninutului a doi operanzi din memorie op1 i op2 se poate face prin secvena de
instruciuni:
mov
reg, op1
xchg
reg, op2
mov
op2, reg
Instruciunea XLAT (Translate)
Forma general:
XLAT
Instruciunea nu are operanzi, semnificaia fiind:
[al] ds: [[bx]+[al]]
adic se transfera n al coninutul octetului de la adresa efectiva : [bx]+[al].
Instruciunea se folosete la conversia unor tipuri de date, folosind tabele de conversie, adresa
acestor tabele se introduce n bx, iar n al se introduce poziia elementului din tabel. De exemplu:
conversia unei valori numerice cuprins intre 0 i 15 n cifrele hexazecimale corespunztoare, se poate
face prin:
tabel
BYTE '0123456789abcdef''
..........
lea bx, tabel
mov
al,11
xlat
n al se va depune cifra hexazecimala b.
2.1.2 Instruciunile IN (Input Data) i OUT (Output Data)
Instruciunea IN execut o citire de 8, 16, 32 bii de la portul de intrare. i invers, instruciunea OUT
execut o scriere de 8, 16, 32 bii ntr-un port. Sintaxa este urmtoarea:
IN accumulator,port
OUT port,accumulator
Port poate fi o constant cu plaja 0 - FFh, sau poate fi o valoare ncrcat n registrul DX cu plaja
0 - FFFFh. Ca Accumulator va fi registrul AL pentru transferuri pe 8-bii, AX pentru transferuri pe 16bii i EAX pentru transferuri pe 32-bii.
Exemple:
in al,3Ch
; input byte from port 3Ch
out 3Ch,al
; output byte to port 3Ch
mov dx, portNumber ; DX can contain a port number
in ax,dx
; input word from port named in DX
out dx,ax
; output word to the same port
in eax,dx
; input doubleword from port
out dx,eax
; output doubleword to same port
unde dest este un registru general, un operand din memorie. Semnificaia fiind operandul dest este
incrementat cu unu. Indicatorii afectai sunt AF, PF, SF, ZF, OF.
Exemple:
inc alfa
inc bl
inc eax
inc rbx
inc word ptr [bx] [si]
Instruciunea DEC (decrement)
Forma general:
DEC
dest ;
[dest] [dest] 1
unde dest are aceeai semnificaie ca dest de la Instruciunea INC. Aceeai indicatori ca la INC sunt
afectai.
Instruciunea NEG (Negate)
Forma general:
NEG
dest : [dest] 0 [dest] schimbare de semn
unde dest este un operand pe 8, 16, 32 sau 64 bii ce poate fi un registru general sau o locaie de
memorie. Instruciunea afecteaz indicatorii AF, CF, PF, SF, OF i ZF.
Exemplu:
alfa byte 75
............
mov al, alfa
neg al
mov alfa, al ; la adresa alfa avem - 75
sau
neg alfa
Instruciunea CMP (Compare)
Forma general:
CMP
dest, sursa
; [dest] [sursa]
Instruciunea realizeaz o operaie de scdere intre cei doi operanzi, fr a modifica operandul
dest sau sursa cu poziionarea indicatorilor de condiie. Indicatorii afectai sunt: AF, CF, PF, SF, ZF i
OF.
Aceasta instruciune se folosete mpreuna cu instruciunea de salt condiionat.
Cnd comparm doi operanzi fr semn indicatoarele Zero i Carry indic urmtoarea relaie ntre
operanzi:
Exemple:
cmp
ax, alfa[bx][si]
cmp [si], 0
2.2 Instruciuni de salt i ciclare
a)Instruciunea de salt necondiionat JMP
Forma generala :
JMP operand
unde, operand este adresa de salt necondiionat. Exist urmtoarele tipuri de instruciuni JMP:
de tip SHORT - cnd operandul specifica o adres n domeniul -128 +127 fa de (IP)
actualizat
de tip NEAR - operandul specific o adres din acelai segment de cod;
de tip FAR - operandul specific o adres din alt segment de cod.
b)Instruciuni de salt condiionat
Aceste instruciuni implementeaz salturile condiionate de indicatorii de condiie.
Forma generala:
Jcond operand
unde:
- cond este condiia de salt i este reprezentat de una sau dou litere (vezi tabelul de mai jos);
- operand este un offset cuprins ntre -128 si 128.
Dac condiia este ndeplinit are loc saltul la adresa dat de operand, dac nu - se continu n
secven.
Se observ c exist 2 categorii de instruciuni pentru mai mic si mai mare, cele care conin
cuvintele above sau bellow i cele care conin cuvintele less sau greater. Primele se folosesc n
situaia comparrii a dou valori fr semn, iar ultimele n situaia comparrii a dou valori cu semn.
Fie secvenele de program:
mov ax,0FFFEh
mov bx, 2
cmp ax, bx
ja alfa
i
mov ax, 0FFFEh
mov bx, 2
cmp ax, bx
jg alfa
n care se compar pe cuvnt 0FFFEh i 2.
Se observ c (AX) > (BX) dac cele dou valori se consider reprezentate fr semn i c (AX) <
(BX) dac cele dou valori se consider cu semn. (-2 este mai mic decat 2). Ca atare n primul caz
saltul la eticheta alfa are loc, pe cand n cel de-al doilea caz nu are loc.
Fiecare mnemonic din tabel se refer la iniialele cuvintelor urmtoare, ce indic condiia n
limba englez: Above (peste, mai mare), Below (sub, mai mic), Equal (egal), Not (nu), Greater (mai
mare), Less (mai mic), Carry (transport), Zero, Overflow (depire de capacitate), Parity (PEven paritate par, POdd - paritate impar), Sign (semn).
Instruciune
Condiie de salt
Interpretare
(mnemonica)
JE, JZ
ZF = 1
Zero, Equal
JL, JNGE
Less, Not Greater or Equal
SF OF
JLE,JNG
SF OF sau ZF = 1 Less or Equal, Not Greater
JB, JNAE, JC
CF = 1
Below, Not Above or Equal, Carry
JBE, JNA
CF = 1 sau ZF = 1
Below or Equal, Not Above
JP, JPE
PF = 1
Parity, Parity Even
JO
OF = 1
Overflow
JS
SF = 1
Sign
JNE, JNZ
ZF = 0
Not Zero, Not Equal
JNL, JGE
SF = OF
Not Less, Greater or Equal
JNLE, JG
SF = OF si ZF = 0
Not Less or Equal, Greater
JNB, JAE, JNC CF = 0
Not Below, Above or Equal, Not Carry
JNBE, JA
CF = 0 si ZF = 0
Not Below or Equal, Above
JNP, JPO
PF = 0
Not Parity, Parity Odd
JNO
OF = 0
Not Overflow
JNS
SF = 0
Not Sign
(Exemplu de citire: JNBE = jump if not below or equal, salt (J) dac nu (N) e mai mic (B) sau egal
(E)).
movbx,+32
cmpbx,35
jngL5;jumpnottaken(+32<=35isfalse)
jngeL5;jumpnottaken(+32<35isfalse)
jgeL1;jumpistaken(+32>=35istrue)
movecx,0
cmpecx,0
jgL5;jumpnottaken(0>0isfalse)
jnlL1;jumpistaken(0>=0istrue)
movecx,0
cmpecx,0
jlL5;jumpnottaken(0<0isfalse)
jngL1;jumpistaken(0<=0istrue)
Exemplu, salt la etichet dac toi biii (2, 3 i 7) sunt setai n 1:
moval,status
andal,10001100b;maskbits2,3,7
cmpal,10001100b;allbitsset?
jeResetMachine;yes:jumptolabel
2.3 Aritmetica BCD
2.3.1 Instruciunea AAA (ASCII Adjust for Addition)
Instruciunea nu are operanzi i execut corecia acumulatorului AX, dup operaii de adunare cu
numere n format BCD despachetat. Semnificaia este:
daca [AL0:3] > 9 sau [AF] = 1, atunci {
[AL] [AL] + 6
[AH] [AH]+1
[AF] 1
[CF] 1
[AL] [AL] AND 0FH
}
Indicatorii afectai : AF, CF, restul nedefinii.
Exemplu:
mov ax, 408h
mov dx, 209h
add ax, dx ; [ax]=0611h
AAA
; [ax]=0707h
2.3.2 Instruciunea AAS (ASCII Adjust for Subtraction)
Instruciunea nu are operanzi i execut corecia acumulatorului AX, dup operaii de scdere cu
numere in format BCD despachetat. Semnificaia este:
daca [AL0:3] > 9 sau [AF] = 1, atunci {
[AL] [AL] - 6
[AH] [AH] - 1
[AF] 1
[CF] 1
[AL] [AL] AND 0FH
}
Indicatorii afectai : AF, CF, restul nedefinii.
10
Exemplu:
mov ax, 408h
mov dx, 209h
sub ax, dx ; [ax]=01ffh
AAS
; [ax]=0109h
2.3.3 Instruciunea DAS (Decimal Adjust for Substraction)
Instruciunea nu are operanzi i execut corecia zecimala a acumulatorului AL, dup operaii de
scdere cu numere n format BCD mpachetat. Semnificaia este:
daca [AL0:3] > 9 sau [AF] = 1, atunci {
[AL] [AL] - 6
[AF] 1
}
daca acum [AL4:7] > 9 sau CF = 1, atunci {
[AL] [AL] - 60H
[CF] 1
}
Indicatorii afectai : AF, CF, PF, SF, ZF. Indicatorul OF este nedefinit.
De exemplu, n urma secvenei:
MOV AL, 52H
SUB AL, 24H ; AL = 2EH
DAS
; AL = 28H
se obine n AL rezultatul corect 28H.
2.3.5 Instruciunea AAM (ASCII Adjunct for Multiply)
Instruciunea nu are operanzi i efectueaz o corecie a acumulatorului AX, dup o nmul ire pe 8
bii cu operanzi n format BCD despachetat.
Semnificaia este urmtoarea:
[AH] [AL] / 10
[AL] [AL] MOD 10
Indicatori afectai: PF, SF, ZF, restul nedefinite.
De exemplu
mov al, 7
mov bl, 9
mul bl ; 003Fh
AAM ; 0603h
2.3.6 Instruciunea AAD (ASCII Adjunct for Division)
Instruciunea nu are operanzi i efectueaz o corecie a
mpriri a doi operanzi n format BCD despachetat.
Semnificaia este urmtoarea:
[AL] [AH] * 10 + [AL]
[AH] 0
Indicatori afectai: PF, SF, ZF, restul nedefinite.
De exemplu
mov ax, 305h
mov bl, 2
AAD
; [ax]=35h
div bl ; [al]=12h [ah]=1
3 EXEMPLE REZOLVATE SI COMENTATE
11
Se cere obinerea fiierului executabil si rularea apoi pas cu pas. Datele se introduce de la tastatur si
rezultatele se afieaz pe ecran
INCLUDE Irvine32.inc
.data
mes1 byte "Introduceti valoarea X:",0
mes2 byte "Introduceti valoarea Y:",0
mes3 byte "Rezutatul este:",0
vrx dword 0
vry dword 0
rez dd 0
.code
main PROC
mov edx,OFFSET mes1
call WriteString ; afisarea mes1
call ReadDec ; introducerea de la tastatura
mov vrx,eax ; salvarea valorii in variabila vrx
mov edx,OFFSET mes2
call WriteString ; afisarea mes2
call ReadDec ; introducerea de la tastatura
mov vry,eax ; salvarea valorii in variabila vry
;controlam conditiile
xor eax,eax
mov edx,0
mov eax,vry
mov bx,2
mul bx ; calcul Y*2
cmp vrx,eax ;compararea X cu 2Y
jb con1 ; salt la con1, daca X<2Y
mov eax,vry ;realizam expresia 2Y-60
mov bx,2
mul bx
sub eax,60
mov rez,eax
jmp ex ; salt neconditionat la ex
con1: mov eax,vrx ; realizam expresia X/8+32-Y
mov bx,8
div bx
add eax,32
sub eax,vry
mov rez,eax
ex: mov edx,OFFSET mes3
12
.DATA
WORD 100h,200h,300h
.CODE
main PROC
mov
Exemplul 3. Se consider un vector de trei componente cuvinte. S se introduc valoarea 55h n octeii
superiori ai elementelor vectorului.
.DATA
val
EQU
55h
vect DW
111h,222h,333h
.CODE
mov
mov
mov
mov
Exemplul 4. S se genereze 2 numere a cte 4 cifre zecimale reprezentate n format BCD mpachetat
(adic fiecare grup de doua cifre zecimale este memorat ntr-un octet) i s se scrie o secven de
program pentru calculul sumei i diferenei lor.
.data
bcd1 DB
bcd2 DB
13
; impachetat
sum DB 2 DUP(?)
dif DB 2 DUP(?)
.code
mov
add
daa
mov
mov
adc
daa
mov
mov
sub
das
mov
mov
sbb
das
mov
al,bcd1
al,bcd2
sum,al
al,bcd1+1
al,bcd2+1
sum+1,al
al,bcd1
al,bcd2
dif,al
al,bcd1+1
al,bcd2+1
sum+1,al
Exemplul 5. S se scrie un program pentru adunarea i scderea a doua numere a cte dou cifre
zecimale reprezentate n format BCD nempachetat (adic fiecare cifra zecimal se memoreaz n
tetrada inferioara a unui octet):
.data
upk1 DB
al,upk1
al,upk2
sum,al
al,upk1+1
al,upk2+1
dif+1,al
al,upk1
al,upk2
dif,al
al,upk1+1
al,upk2+1
dif+1,al
14
Rulai exemplele pas cu pas, programele ce folosesc instruciuni aritmetice pentru a urmri evolu ia
rezultatelor pariale.
5 PROBLEME PROPUSE
Conform variantei elaborai 2 variante de program :
1) cu introducerea datelor de la tastatur i afiarea rezultatelor pe ecran.
2) cu generarea datelor de intrare, utiliznd procedurile Random32, RandomRange.
Nr
1
Expresia
Nr
9
10
11
12
13
14
15
6 CONTINUTUL REFERATULUI
Referatul va conine urmtoarele elemente:
enunul problemelor de rezolvat;
exemplele de programe comentate;
listingul programului comentat conform variantei.
Expresia