NASM as 6 1 16 bitni registri opte
NASM Čas 6 1
16 -bitni registri opšte namene n n n AX – akumulator za aritmetečke i logičke operacije. Neke instrukcije imaju kraće kodiranje u slučaju njegovog korišćenja, a takođe mogu biti i brže. BX – base registar za čuvanje adresa. CX – brojač DX – registar za aritmetičke i I/O operacije Postoje AH, AL, BH, BL, CH, CL, DH, DL. 2
16 -bitni registri opšte namene n n SI – source index za indeksiranje nizova i pristup memoriji. DI – destination index za indeksiranje nizova i pristup memoriji. BP – base pointer sličan BX registru, ali za pristup argumentima i lokalnim promenljivim funkcija. SP – stack pointer pokazivač na stek. 3
Segmentni registri n n n Segment je količina memorije koja se može adresirati pomoću jednog registra. CS – code segment sadrži adresu segmenta koda. DS – data segmetn sadrži adresu segmenta podataka. ES – extra segment dodatni segmentni registar. SS – stack segment sadrži adresu segmenta koji sadrži stek. U ove segmente je moguće smeštati i podatke, ali to ne treba raditi! 4
Specijalni registri n n IP – instruction pointer sadrži adresu instrukcije koja se trenutno izvršava. FLAGS registar se sastoji od sledećih bitova • • • XXXXODITSZXAXPXC X – ne koristi se O – Overflow D – Direction I – Interrupt T – Trace S – Sign Z – Zero A – Auxilary carry P – Parity C - Carry 5
Segmentacija n n n Pošto je 8086 imao 16 -bitne registre, bilo je moguće adresirati najviše 65536 bajtova. Ovo je veličina jednog segmenta. Da bi se ovo prevazišlo, koriste se tzv. segmentni registri koji određuju koji se segment koristi. Adrese se navode u obliku segment: offset. Npr. 1000: 1 F 00. Ove adrese se nazivaju logičkim. Fizička adresa se, u slučaju da računar radi u real modu, dobija tako što se segment množi sa 16 i dodaje se offset. Npr. 10000 h+1 F 00 h=11 F 00 h Očigledno, različite logičke adrese mogu odgovarati istoj fizičkoj adresi. U slučaju protected moda postupak je komplikovaniji. 6
Načini adresiranja memorije za 8086 n Validni načini adresiranja memorije se mogu dobiti tako što se iz svake kolone donje tabele izabere najviše jedan element, pri čemu je ukupno potrebno izabrati bar jedan i formira se izraz [E 1+E 2+E 3]. Npr. mov ax, [50 h+bp+si] DISP BX SI BP DI 7
Načini adresiranja za 8086 n n n Prvi registar koji se pojavljuje u uglastim zagradama određuje podrazumevani segmentni registar. On se može navesti i eksplicitno. Za BX, SI i DI podrazumeva se DS, a za BP - SS. Registri se adresiraju navođenjem imena. 8
Adresiranje memorije za 80386 n Adresa se formira kao [base+index*scale+disp] Npr. mov ax, [bx+si*2+30] 9
NASM n Pokretanje: • nasm –f <format> <filename> [-o <output>] • <format> predstavlja jedan od formata u kojima se generiše izlaz. Najvažniji su bin i obj. • <filename> predstavlja ulazni fajl sa kodom. • <output> predstavlja naziv izlaznog fajla. n Naravno, postoje i druge opcije. 10
NASM n Izgled komandne linije • oznaka: instrukcija operandi n n n n ; komentar Bilo koji deo može nedostajati. Prisustvo operanada je uslovljeno prirodom instrukcije. Ako na kraju linije stoji , sledeća linija se smatra nastavkom tekuće. Oznake ne moraju imati : na kraju. Validna imena oznaka su sastavljena od slova, brojeva, _, $, #, @, ~, . i ? . Ime počinje slovom, . , _ i ? . Ako ime počinje znakom $, niska se ne tumači kao rezervisana reč, već kao identifikator. Npr. $ax. Ako se znak $ javi sam, označava trenutnu poziciju prilikom asembliranja. 11
NASM n U slučaju bin formata postoje tri istaknute sekcije: • . text za kod, • . data za inicijalizovane podatke i • . bss za neinicijalizovane podatke. 12
Pseudo instrukcije – d* n DB, DW, DD, DQ, DT • • • n db 0 x 55 – bajt 0 x 55 db 0 x 55, 0 x 56, 0 x 57 – tri uzastopna bajta db ‘a’, 0 x 55 – bajtovi 0 x 61 i 0 x 55 db ‘hello’, 13, 10, ‘$’ dw 0 x 1234 – 0 x 34, 0 x 12 dw ‘a’ – 0 x 61, 0 x 00 dw ‘ab’ – 0 x 61, 0 x 61 dw ‘abc’ – 0 x 61, 0 x 62, 0 x 63, 0 x 00 dd 0 x 12345678 – 0 x 78, 0 x 56, 0 x 34, 0 x 12 dd 1. 234567 e 20 dq 1. 234567 e 20 dt 1. 234567 e 20 dq i dt ne prihvataju numeričke konstante ili niske za operande (? ). 13
Pseudo instrukcije – RES* n RESB, RESW, RESD, RESQ i REST rezervišu memoriju za neinicijalizovane podatke. Predviđeno je da se koristi u bss sekciji. Npr. • buffer: resb 64 14
Pseudo instrukcije – EQU n EQU služi da definiše konstantu. Npr. • msglen equ 12 15
Pseudo instrukcije - TIMES n Čini da instrukcija bude asemblirana više puta. Npr. • zerobuff: times 64 db 0 • buffer: db ‘hello, world’ times 64+buffer-$ db ‘ ’ • times 100 movsb 16
Promenljive n Promenljive u punom smislu nisu podržane. Sve što se pamti uz simbol je početna adresa u memoriji. Dužina se mora naknadno zadati u instrukciji. Npr. • var dw 5 • mov word [var], 2 • mov bx, var 17
Pristup memoriji n Za sva pristupanja memoriji moraju biti koripšćene uglaste zagrade. • var • mov • mov dw 5 ax, [var] ax, [var+1] ax, [ds: var+bx] ax, [bp+di+8] ax, [byte bx+6] 18
Numeričke konstante n n n n mov mov ax, ax, 100 ; dekadna 0 a 2 h ; hex $0 a 2 ; hex 0 xa 2 ; hex 777 q ; oktalna 777 o ; oktalna 10010011 b ; binarna 19
Karakterske konstante n Do 4 karaktera ograničena jednostrukim ili dvostrukim navodnicima. Npr. ‘abcd’ se prevodi kao 0 x 64636261. S obzirom da se radi o little-endian arhitekturi, zapisuje se kao 0 x 61626364 što je i željeno. 20
Stringovi n n n Izgledaju kao karakterske konstante, samo što su duže. Dozvoljene su samo u nekim pseudo instrukcijama. db ‘hello’ ; string db ‘h’, ’e’, ’l’, ’o’ ; karakterske konstanta dd ‘ninechars’ dd ‘nine’, ‘char’, ‘s’ Db ‘ninechars’, 0, 0, 0 21
SEG i WRT n SEG operator vraća adresu podrazumevanog segmenta za neki simbol. Npr sledeći kod smešta pokazivač na promenljivu simbol u ES: BX • mov ax, seg simbol • mov es, ax • mov bx, simbol n Ukoliko želimo da izračunamo adresu neke promenljive u odnosu na neki segment koji nije podrazumevani koristimo WRT operator. Npr. • • • mov mov ax, adresa_segmenta es, ax bx, simbol wrt adresa_segmenta 22
Kritični izrazi n n n Kritični izrazi su izrazi čija vrednost mora biti poznata u prvom prolazu asembliranja. Argumenti pseudo instrukcija TIMES, RES* i ЕQU su kritični izrazi. Primer: label: times (label-$) db 0 db ‘tekst’ label: times (label-$+1) db 0 db ‘tekst’ 23
Lokalne oznake n Lokalnim se smatraju oznake koje počinju tačkom. Vezuju se za prvu prethodnu oznaku. Npr. label 1 ; neki kod. lokalna ; neki kod label 2 ; neki kod. lokalna ; neki kod n Prilikom korišćenja oznake. lokalna nema konflikta imena jer se prva interno vodi kao label 1. lokalna, a druga kao label 2. lokalna, a mogu se i tako referencirati. Npr. • jmp label 1. lokalna 24
Direktive n BITS određuje da li će se kod izvršavati na 16 -bitnom ili 32 bitnom procesoru. Npr. • BITS 16 n n SECTION (ili SEGMENT) definiše sekcije. Npr. . text, . data i. bss. EXTERN deklariše simbole iz drugih fajlova sa kojima eventualno vršimo povezivanje. GLOBAL čini simbole vidljivim izvan fajla prilikom povezivanja. CPU određuje skup instrukcija koje se koriste. Npr. • • CPU CPU 8086 186 PENTIUM IA 64 25
Izlazni formati n n bin – čist mašinski kod. Podrazumeva se BITS 16 Koristi se za pisanje kernela, bootloadera, malih programa za DOS, drajvera. . . ORG direktiva određuje adresu na kojoj se očekuje da počne izvršavanje programa. Npr. • ORG 0 x 100 ; očekivano kod. com programa 26
Izlazni formati n n obj – Microsoft-ov objektni format Izlazni kod se mora povezati pomoću linkera. Nema privilegovanih sekcija. Program uvek počinje od oznake. . start 27
Prekidi n Prekidi se dele na: • Hardverske • Softverske • Izuzetke n BIOS obezbeđuje veći broj softverskih prekida koji nam omogućavaju da radimo sa ulazom i izlazom. 28
- Slides: 28