Mikroilemciler Intel 8086 Mimarisi Adresleme Modlar 1 erik

  • Slides: 43
Download presentation
Mikroişlemciler Intel 8086 Mimarisi Adresleme Modları 1

Mikroişlemciler Intel 8086 Mimarisi Adresleme Modları 1

İçerik 8086 Mikroişlemcinin iç tasarımı Adresleme modları 2

İçerik 8086 Mikroişlemcinin iç tasarımı Adresleme modları 2

8086 Mimarisi 3

8086 Mimarisi 3

8086 Mimarisi 8086’da bulunan tüm iç register’lar ve veri yolları 16 bitlik genişliktedir. 8086:

8086 Mimarisi 8086’da bulunan tüm iç register’lar ve veri yolları 16 bitlik genişliktedir. 8086: little endian mikroişlemcidir. Hafıza bloğuna 16 bitlik veri yazıldığı zaman, hafızanın ilk 8 bitlik satırında verinin küçük kısmı bulunur. Big Endian İlk baytta, verinin büyük kısmı bulunur Small Endian İlk baytta, verinin küçük kısmı bulunur 4

Adresleme Veri yolu 16 -bit genişliğindedir. Adres yolu ise 20 -bit genişliğindedir 8086, 1

Adresleme Veri yolu 16 -bit genişliğindedir. Adres yolu ise 20 -bit genişliğindedir 8086, 1 MB’lık hafıza bloğunu adresleyebilir (1 M = 220) Ancak, en fazla adreslenebilir hafıza uzayı 64 KB büyüklüğündedir. Çünkü tüm dahili register’lar 16 -bit büyüklüğündedir. 64 KB’lık sınırların dışında programlama yapabilmek için extra operasyonlar kullanmak gerekir 5

8086 Bileşenleri 6

8086 Bileşenleri 6

Register’lar Register’lar, CPU içerisinde bulunduklarından dolayı, 7 hafıza bloğuna göre oldukça hızlıdırlar. Hafıza bloğuna

Register’lar Register’lar, CPU içerisinde bulunduklarından dolayı, 7 hafıza bloğuna göre oldukça hızlıdırlar. Hafıza bloğuna erişim için sistem veri yollarının kullanılması gereklidir. Register’daki verilerin ulaşılması için çok küçük bir zaman dilimi yeterli olur. Bu sebeple, değişkenlerin, register’larda tutulmasına çalışılmalıdır. Register grupları genellikle oldukça kısıtlıdır ve çoğu register’ın önceden tanımlanmış görevleri bulunur. Bu nedende, kullanımları çok sınırlıdır. Ancak, yine de hesaplamalar için geçici hafıza birimi olarak kullanılmak için en ideal birimlerdir.

Register Tipleri Genel Amaçlı Register’lar 2. İndis Register’ları 3. Özel Amaçlı Register’lar 1. 8

Register Tipleri Genel Amaçlı Register’lar 2. İndis Register’ları 3. Özel Amaçlı Register’lar 1. 8

1. Genel Amaçlı Register’lar 8086 CPU’da, 8 genel amaçlı register bulunur. Her register’ın ayrı

1. Genel Amaçlı Register’lar 8086 CPU’da, 8 genel amaçlı register bulunur. Her register’ın ayrı bir ismi bulunur: AX - accumulator register – akümülatör (AH / AL). BX - the base address register – adres başlangıcı (BH / BL). CX - the count register – sayma (CH / CL). DX - the data register – veri (DH / DL). SI - source index register – kaynak indisi. DI - destination index register – hedef indisi. BP - base pointer – temel gösterici. SP - stack pointer – yığıt gösterici. 9

Genel Amaçlı Register’lar (devam) Bu register’lar, isminin belirttiği amaçlar için kullanılmak zorunda değildir. Programcı,

Genel Amaçlı Register’lar (devam) Bu register’lar, isminin belirttiği amaçlar için kullanılmak zorunda değildir. Programcı, genel amaçlı register’ları istediği gibi kullanabilir. Register’ların ana amacı, bir değişkeni tutmaktır. Yukarıdaki register’ların tamamı 16 -bitliktir. 4 geneş amaçlı register (AX, BX, CX, DX), iki 8 -bitlik register olarak kullanılabilir. Örneğin eğer AX=3 A 39 h ise, bu durumda AH=3 Ah ve AL=39 h olur. 8 -bitlik register’ları değiştirdiğiniz zaman, 16 -bitlik register’lar da değişmiş olur. 10

2. Segment Register’ları CS – (Code Segment) Mevcut programın bulunduğu bölümü işaretler. DS –

2. Segment Register’ları CS – (Code Segment) Mevcut programın bulunduğu bölümü işaretler. DS – (Data Segment) Genellikle programda bulunan değişkenlerin bulunduğu bölümü işaretler. ES – (Extra Segment) Bu register’ın kullanımı, kullanıcıya bırakılmıştır. SS – (Stack Segment) yığının bulunduğu bölümü işaretler. 11

Segment Register’ları (devam) Segment register’larında herhangi bir veriyi depolamak mümkündür. Ancak bu, güzel bir

Segment Register’ları (devam) Segment register’larında herhangi bir veriyi depolamak mümkündür. Ancak bu, güzel bir fikir değildir. Segment register’larının özel amaçları vardır. Hafızada ulaşılabilir bazı bölümleri işaretler. 12

Segment Register’ları (devam) Segment register’ları, genel amaçlı register’ları ile birlikte çalışarak hafızada herhangi bir

Segment Register’ları (devam) Segment register’ları, genel amaçlı register’ları ile birlikte çalışarak hafızada herhangi bir bölgeyi işaretleyebilir. Örneğin, fiziksel adres 12345 h (heksadesimal) işaretlenmesi isteniyor ise, DS = 1230 h ve SI = 0045 h olmalıdır. CPU, segment register’ı 10 h ile çarpar ve genel amaçlı register’da bulunan değeri de ilave eder (1230 h× 10 h + 45 h = 12345 h). 13

Segment Register’ları (devam) 2 register tarafından oluşturulmuş olan adrese, effective address (efektif adres) ismi

Segment Register’ları (devam) 2 register tarafından oluşturulmuş olan adrese, effective address (efektif adres) ismi verilir. BX, SI ve DI register’ları, DS ile birlikte çalışır; BP ve SP register’ları ise SS ile birlikte çalışır. Diğer genel amaçlı register’lar, efektif adres oluşturmak için kullanılmazlar. Ayrıca, BX efektif adres oluşturulmasında kullanılırken, BH ve BL kullanılmaz. 14

Segment ve Offset Tüm hafıza adresleri segment adresine offset adresi ilave edilmesi ile bulunur.

Segment ve Offset Tüm hafıza adresleri segment adresine offset adresi ilave edilmesi ile bulunur. segment adresi: Herhangi bir 64 KB’lık hafıza bölümünün başlangıcını gösterir. offset adresi: 64 KB’lık hafıza bölümünde herhangi bir satırı belirtir. 15

Segment ve Offset (devam) Segment register’ı 1000 h değerine sahip ise, 10000 h ile

Segment ve Offset (devam) Segment register’ı 1000 h değerine sahip ise, 10000 h ile 1 FFFFh aralığında bir hafıza adresine karşılık gelir. 64 KB’lık bir aralıktır Offset değeri F 000 h ise 1 F 000 h adresindeki hafıza satırına karşılık gelir. 16

Segment ve Offset (devam) Başlandıç adresi belli ise, bitiş adresi FFFFh ilave edilerek bulunur.

Segment ve Offset (devam) Başlandıç adresi belli ise, bitiş adresi FFFFh ilave edilerek bulunur. Çünkü segment register’ı 64 KB’lık bir bölümü işaretler. Offset adresi, segment adresine ilave edilir. Segment ve offset adresleri 1000: 2000 biçiminde de yazılarbilir. Bu durumda segment adresi 1000 H ve offset’te 2000 H’dir. 17

Öntanımlı Segment ve Offset Register’ları CS: IP CS, kod bölümünün başlangıcına işaret eder. IP,

Öntanımlı Segment ve Offset Register’ları CS: IP CS, kod bölümünün başlangıcına işaret eder. IP, kod bölümü içerisinde bir sonraki komutun bulunduğu hafıza adresine işaret eder. Eğer CS=1400 H ve IP=1200 H, mikroişlemci, bir sonraki komutu 14000 H + 1200 H = 15200 H adresinden okur. 18

Öntanımlı Segment ve Offset Register’ları (devam) SS: SP veya SS: BP Yığın bölümünü kullanan

Öntanımlı Segment ve Offset Register’ları (devam) SS: SP veya SS: BP Yığın bölümünü kullanan komutlar kullanır. DS register’ı, BX, DI, SI, 8 -bit’lik veya 16 -bit’lik sayı ile birlikte ES: DI (string komutları için) 19

3. Özel Amaçlı Register’lar IP –instruction pointer – komut işaretleyicisi. IP register’ı CS ile

3. Özel Amaçlı Register’lar IP –instruction pointer – komut işaretleyicisi. IP register’ı CS ile birlikte, halihazırdaki çalıştırılan komutu işaretler. Flags (Bayrak) register Flags register, CPU tarafından, matematiksel operasyonlardan sonra otomatik olarak değiştirilir. Bu register sayesinde, elde edilen sonucun çeşidi ve durumu ile ilgili bilgiler, program tarafından kullanılabilir. 20

3. Özel Amaçlı Register’lar Genellikle, bu register’lara doğrudan erişim bulunmaz. Ancak, sistem register’larının değerleri,

3. Özel Amaçlı Register’lar Genellikle, bu register’lara doğrudan erişim bulunmaz. Ancak, sistem register’larının değerleri, daha sonra öğreneceğiniz bazı metotlar sayesinde değiştirilebilir. 21

Flag Bit’leri 15 14 13 12 11 10 9 8 7 6 O D

Flag Bit’leri 15 14 13 12 11 10 9 8 7 6 O D I T S Z 5 4 A 3 2 P 1 0 C C (carry): toplama işleminden oluşan elde ve çıkarma işleminden oluşan ödünçleri tutar. Ayrıca, hata durumlarını gösterir P (parity): bir sayıda bulunan 1’lerin tek sayıda mı yoksa çift sayıda mı olduğunu belirtir. 0 tek parity; 1 çift parity. Eğer bir sayı 3 tane binary 1 bit var ise, sayı tek parity’ye sahiptir. Eğer bir sayıda hiç 1 bit yok ise, sayı çift parity’ye sahiptir. 22

Flag Bit’leri (devam) A (auxiliary carry): 3 ve 4. bit pozisyonları için geçerli olmak

Flag Bit’leri (devam) A (auxiliary carry): 3 ve 4. bit pozisyonları için geçerli olmak üzere, toplama işleminden oluşan elde ve çıkarma işleminden oluşan ödünçleri tutar. Z (zero): aritmetik veya mantık operasyonunun sonucunun sıfır olup olmadığı bilgisini tutar. S (sign): çalıştırılan aritmetik veya mantık operasyonunun sonucunda elde edilen sayının aritmetik yönünü (pozitif veya negatif) belirtir. 23

Flag Bit’leri (devam) T (trap): çip üzeri debug özelliğine olanak tanır. I (interrupt): INTR

Flag Bit’leri (devam) T (trap): çip üzeri debug özelliğine olanak tanır. I (interrupt): INTR (interrupt request – interrupt isteği) girişini kontrol eder. D (direction): DI ve/veya SI register’ları için arttırma veya azaltma modlarından birini seçer. O (overflow): iki yönlü sayının toplamı veya çıkarılması durumlarında kullanılır. overflow olması, sonucun, 16 -bitlik kapasiteyi aştığını gösterir. 24

Adresleme Modları 25

Adresleme Modları 25

Giriş Mikroişlemci için verimli yazılım geliştirme, her bir komut için geçerli adresleme modlarının iyi

Giriş Mikroişlemci için verimli yazılım geliştirme, her bir komut için geçerli adresleme modlarının iyi bilinmesine bağlıdır. 26

Veri Adresleme Modları MOV komutu, çok kullanılan esnek bir komuttur. Veri adresleme modlarının anlatımı

Veri Adresleme Modları MOV komutu, çok kullanılan esnek bir komuttur. Veri adresleme modlarının anlatımı için bir temel oluşturacaktır. Source (kaynak): sağda destination (hedef): solda operand Opcode: MOV. Opcode (operasyon kodu): mikroişlemciye, hangi operasyonun çalıştırılacağını belirtir. 27

28

28

Adresleme Modu Operand’larda belirtilen efektif hafıza adresinin nasıl hesaplanacağını belirtir. Bu adresin hesaplanması için

Adresleme Modu Operand’larda belirtilen efektif hafıza adresinin nasıl hesaplanacağını belirtir. Bu adresin hesaplanması için register’larda bulunan bilgiler ve/veya sabit sayılar kullanılabilir. Sabit sayılar, komutun içerisinde belirtilebileceği gibi, farklı yerlerde de belirtilmiş olabilir. 29

1. Register Adreslemesi Bu modda, kaynak operand’ı, hedef operand’ı veya her ikisi birden 8086

1. Register Adreslemesi Bu modda, kaynak operand’ı, hedef operand’ı veya her ikisi birden 8086 register’ları arasından seçilir. MOV DX, CX MOV CL, DL 8 -bit register’lar: AH, AL, BH, BL, CH, CL, DH, ve DL. 16 -bit register’lar: AX, BX, CX, DX, SP, BP, SI, ve DI. HİÇ BİR ZAMAN 8 -bitlik ve 16 -bitlik register’ları karıştırmayın. 30

2. Immediate (Veri tanımlı) Adresleme Kaynak olarak, komutun içerisinde tanımlanmış olan byte veya word;

2. Immediate (Veri tanımlı) Adresleme Kaynak olarak, komutun içerisinde tanımlanmış olan byte veya word; hedef register’ı veya hafıza satırına yazılır. MOV CL, 03 H MOV DX, 0502 H İmmediate (hemen) kelimesi, heksadesimal opcode’dan hemen sonra gelen hafıza satırındaki verinin kullanılmasını ifade eder. İmmediate veriler, sabit verilerdir. Register’dan veya hafıza satırından okunan veriler, değişken verilerdir. 31

Immediate Addressing (continued) H harfi, heksadesimal veri olduğunu ifade eder. Eğer heksadesimal veri, bir

Immediate Addressing (continued) H harfi, heksadesimal veri olduğunu ifade eder. Eğer heksadesimal veri, bir harf ile başlar ise (A, B, C, D, E), assembler, verinin 0 ile başlamasını gerektirir. Örneğin heksadesimal F 2, assembly dilinde 0 F 2 H şeklinde ifade edilmelidir. Desimal (10’luk sistemdeki) veriler için herhangi bir özel ön veya arka takı gerekmez. Örneğin, desimal 100 rakamı AL register’ına yazılması istenir ise MOV AL, 100 komutu kullanılır. 32

Bir Assembly Programı VERI 1 DB 23 H tanımlı VERI 2 DW 1000 H

Bir Assembly Programı VERI 1 DB 23 H tanımlı VERI 2 DW 1000 H tanımlı BASLA: ; VERI 1 23 H baytı olarak ; VERI 2 1000 H word’u olarak MOV AL, BL ; BL’yi AL’ye kopyala MOV BH, AL ; AL’yi BH’ye kopyala MOV CX, 200 ; 200 desimal rakamını CX’e kopyala 33

Assembly Programları Assembly programlama dilindeki her komut 4 parça/kısımdan oluşur. En soldaki kısma label

Assembly Programları Assembly programlama dilindeki her komut 4 parça/kısımdan oluşur. En soldaki kısma label ismi verilir. Bulunduğu hafıza satırı için sembolik bir isim belirtir. Tüm label’lar, bir harf veya şu özel karakterlerden biri ile başlayabilir: @, $, -, or ? . Bir label, 1 ile 35 karakter arasında olabilir. 34

Assembly Dili (devam) Bir sonraki kısım opcode alanıdır. Komutun ne olduğunu tanımlar. Daha önce

Assembly Dili (devam) Bir sonraki kısım opcode alanıdır. Komutun ne olduğunu tanımlar. Daha önce belirtilen örneklerdeki MOV kısmı, opcode için bir örnektir. Opcode kısmının sağındaki kısım operand kısmıdır. Opcode tarafından kullanılacak olan bilgileri içerir. MOV AL, BL komutundaki AL ve BL kısımları operand kısımlarıdır. En sonda ise, komut ile ilgili eklenebilecek yorumları içeren kısmı comment bulunur. Yorumlar, noktalı virgül (; ) karakteri ile başlar. 35

3. Direct (Doğrudan) Adresleme Hafıza ile bir register arasında byte veya word transferi yapar.

3. Direct (Doğrudan) Adresleme Hafıza ile bir register arasında byte veya word transferi yapar. Komut seti, hafızadan hafızaya veri transferini içermez (MOVS komutu hariç) Örnekler: MOV CX, START MOV START, BL START assembler tarafından, DB(Define Byte – Byte olarak tanımla) or DW(Define Word – Word olarak tanımla) pseudo komutları ile tanımlanmış bir adrestir. 36

4. Register Indirect (Dolaylı) Adresleme Register ile bir indis veya baz register’ı sayesinde adreslenmiş

4. Register Indirect (Dolaylı) Adresleme Register ile bir indis veya baz register’ı sayesinde adreslenmiş olan bir hafıza bölümü arasında byte veya word transferi. Indis ve baz register’ları BP, BX, DI, ve SI’dır. Örnek: MOV AX, [BX] komutu, (veri bölümünün başlangıcından) BX register’ında belirtilen offset’te bulunan 16 -bitlik veriyi AX register’ına kopyalar. 37

5. Base-plus-index (Baz-artıindis) Adresleme Baz register (BP veya BX)’te bulunan değere indis register’larda (DI

5. Base-plus-index (Baz-artıindis) Adresleme Baz register (BP veya BX)’te bulunan değere indis register’larda (DI veya SI)’da bulunan değer ilave edilerek bulunan değerin işaret ettiği hafıza adresindeki veri ile register’da bulunan veri arasında yapılan byte veya word büyüklüğündeki transferi gerçekleştirir. Örnek: MOV [BX+DI], CL komutu, CL’de bulunan byte büyüklüğündeki veriyi, BX+DI ile işaretlenen hafıza adresine kopyalar. 38

6. Register Relative (Göreceli) Adresleme İndis veya baz register’ındaki değere bir sayı ilave edilmesi

6. Register Relative (Göreceli) Adresleme İndis veya baz register’ındaki değere bir sayı ilave edilmesi ile oluşan değerin işaret ettiği hafıza bölgesi ile register arasında gerçekleştirilen byte veya word büyüklüğündeki transferi gerçekleştirir. Örnekler: MOV AX, [BX+4] MOV AX, ARRAY[BX] 39

7. Base Relative-Plus-Index (Baz Göreceli-artı-indis) Adresleme Baz ve indis register’ına bir değer ilave edilerek

7. Base Relative-Plus-Index (Baz Göreceli-artı-indis) Adresleme Baz ve indis register’ına bir değer ilave edilerek bulunan değerin işaretlediği hafıza bölgesi ile register arasındaki byte veya word büyüklüğündeki veri transferi. Örnekler: MOV AX, ARRAY[BX+DI] MOV AX, [BX+DI+4] 40

8. Relative (Göreceli) Adresleme Bu modda, operand, PC’ye göreceli olarak belirtilmiş olan 8 -bitlik

8. Relative (Göreceli) Adresleme Bu modda, operand, PC’ye göreceli olarak belirtilmiş olan 8 -bitlik yönlü sayı ile ifade edilir. Örnek: JNC START Eğer carry=0 ise, PC’ye START’ın gösterdiği 8 -bitlik yönlü sayı ilave edilerek bulunan değer yüklenir. Aksi durumda, bir sonraki komuta geçilir. 41

9. Implied (İmalı) Adresleme Bu modu kullanan komutların hiç operand’ı bulunmaz. Örnek: CLC Bu

9. Implied (İmalı) Adresleme Bu modu kullanan komutların hiç operand’ı bulunmaz. Örnek: CLC Bu komut, carry bayrağının değerini sıfıra çeker. 42

Örnekler 43 Aşağıdaki komutların MOV [DI], BH adresleme modlarını bulun: MOV AX, 44 H

Örnekler 43 Aşağıdaki komutların MOV [DI], BH adresleme modlarını bulun: MOV AX, 44 H MOV AL, NUMBER DH, [BX+DI+20 H] MOV AL, BL JMP LABEL 1 MOV SP, BP MOV AX, WATER MOV CH, [BP+SI] MOV AX, FILE[BX+DI] MOV AX, [DI+100 H] MOV [BX+SI], SP MOV BL, 44 MOV ARRAY[SI], BL MOV LIST[SI+2], CL MOV CX, [BX] CLI