İSTANBUL TİCARET ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ MİKROİŞLEMCİLİ SİSTEM LABORATUVARI OLAYLARI ZAMANLAMA



Benzer belgeler
İSTANBUL TİCARET ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ MİKROİŞLEMCİLİ SİSTEM LABORATUVARI OLAYLARI ZAMANLAMA

İSTANBUL TİCARET ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ MİKROİŞLEMCİLİ SİSTEM LABORATUVARI OLAYLARI ZAMANLAMA

İSTANBUL TİCARET ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ MİKROİŞLEMCİLİ SİSTEM LABORATUVARI KESMELİ GİRİŞ/ÇIKIŞ

İSTANBUL TİCARET ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ MİKROİŞLEMCİLİ SİSTEM LABORATUARI MİKROİŞLEMCİLİ A/D DÖNÜŞTÜRÜCÜ

İSTANBUL TİCARET ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ MİKROİŞLEMCİLİ SİSTEM LABORATUARI İKİLİ TABANDA ÇOK BAYTLI ÇARPMA

Bahar Dönemi BIL382 Mikroişlemcili Sistem Lab. Vize Sınavı,

MTM 305 MİKROİŞLEMCİLER

İSTANBUL TİCARET ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ MİKROİŞLEMCİLİ SİSTEM LABORATUVARI SERİ GİRİŞ ÇIKIŞ

İSTANBUL TİCARET ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ MİKROİŞLEMCİLİ SİSTEM LABORATUVARI SERİ GİRİŞ/ÇIKIŞ

DENEY III RAPORU MİKROİŞLEMCİ UYGULAMALARI LABORATUVARI

(5 soru seçerek cevaplandırınız. Seçilen soru numaralarını yukarıdaki çizelgede işaretleyiniz) Sınav süresi 100 dakikadır. Başarılar dileriz.

JZ TEST3 (7/3) 1 makine çevrimi süresi

DENEY II RAPORU MİKROİŞLEMCİ UYGULAMALARI LABORATUVARI

SAYISAL MANTIK LAB. PROJELERİ

Program Kontrol Komutları. Mikroişlemciler ve Mikrobilgisayarlar 1

x86 Ailesi Mikroişlemciler ve Mikrobilgisayarlar

Quiz:8086 Mikroişlemcisi Mimarisi ve Emirleri

Mikrobilgisayar Donanımı

MTM 305 MĠKROĠġLEMCĠLER

MTM 305 MİKROİŞLEMCİLER

Bahar Dönemi. Öğr.Gör. Vedat MARTTİN

C-Serisi PLC İleri Seviye Eğitim

BIL 362 Mikroilemciler Dersi Arasınav Cevapları 3 Temmuz 2007

BM-311 Bilgisayar Mimarisi

Adresleme Modları. Mikroişlemciler ve Mikrobilgisayarlar

Ders 3 ADRESLEME MODLARI ve TEMEL KOMUTLAR

MİKROBİLGİSAYAR SİSTEMLERİ. Teknik Bilimler Meslek Yüksekokulu

Mikroişlemcili Sistemler ve Laboratuvarı 6.Hafta

Mikroişlemcili Sistemler ve Laboratuvarı

8086 nın Bacak Bağlantısı ve İşlevleri. 8086, 16-bit veri yoluna (data bus) 8088 ise 8- bit veri yoluna sahip16-bit mikroişlemcilerdir.

Bölüm 3: Adresleme Modları. Chapter 3: Addressing Modes

SAYICILAR. Tetikleme işaretlerinin Sayma yönüne göre Sayma kodlanmasına göre uygulanışına göre. Şekil 52. Sayıcıların Sınıflandırılması

DIGIAC 2000 Deney Seti PAT İŞLEMCİ KARTI :

MC6800. Veri yolu D3 A11. Adres yolu A7 A6 NMI HALT DBE +5V 1 2. adres onaltılık onluk bit 07FF kullanıcının program alanı

BM-311 Bilgisayar Mimarisi. Hazırlayan: M.Ali Akcayol Gazi Üniversitesi Bilgisayar Mühendisliği Bölümü

TEKNOLOJİ FAKÜLTESİ ELEKTRİK ELEKTRONİK MÜHENDİSLİĞİ EET-206 SAYISAL ELEKTRONİK - II LABORATUVARI

Araş. Gör. Abdulkerim ŞENOĞLU Araş. Gör. Mehmet AYAN Araş. Gör İbrahim Kök. BM 310 Mikroişlemciler Dersi Laboratuvarı (LAB2)

DENEY 2- Sayıcılar ve Kaydırmalı Kaydediciler

MTM 305 MĠKROĠġLEMCĠLER

BÖLÜM 7 XTAL2 XTAL1. Vss. Şekil Mikrodenetleyicisi osilatör bağlantı şekli. Bir Makine Çevrimi = 12 Osilatör Periyodu

B.Ç. / E.B. MİKROİŞLEMCİLER

BM-311 Bilgisayar Mimarisi

Ders Özeti. Ders 2. PC nin İç Organizasyonu. Mikroişlemcinin Organizasyonu. Basitçe İşlemciyi Oluşturan Parçalar. Mikroişlemciler

80x86 MICROPROCESSOR Instructions

İŞLETİM SİSTEMİ İşletim sistemi kullanıcıyla bilgisayar donanımı arasında iletişim sağlayan programdır.

Mikroişlemcili Sistemler ve Laboratuvarı

Özet DERS 5. Şu ana kadar bilmeniz gerekenler... İşaretsiz Çarpma. Bayraklardaki Durumlar. İşaretli Çarpma

DENEY 2- Sayıcılar. 1. Sayıcıların prensiplerinin ve sayıcıların JK flip-flopları ile nasıl gerçeklendiklerinin incelenmesi.

Von Neumann Mimarisi. Mikroişlemciler ve Mikrobilgisayarlar 1

# PIC enerjilendiğinde PORTB nin 0. biti 1 olacak #PIC enerjilendiğinde PORTA içeriğinin tersini PORTB de karşılık gelen biti 0 olacak

Teorik Bilgi DENEY 7: ASENKRON VE SENKRON SAYICILAR

8086 Mikroişlemcisi Komut Seti

BÖLÜM 6 Seri Port Đşlemleri

PIC 16F84 VE TEK BUTONLA BĐR LED KONTROLÜ

Assembly Language Programming

8051 Ailesi MCS51 ailesinin orijinal bir üyesidir ve bu ailenin çekirdeğini oluşturur çekirdeğinin temel özellikkleri aşağıda verilmiştir:

İÇİNDEKİLER 1. KLAVYE KLAVYE RB KLAVYE RBHIGH DİSPLAY... 31

Çok sayıda adım motoru tasarımı olmasına rağmen, bu motorlar iki değişik temel tür altında toplanabilir: değişken relüktanslı veya hibrid yapılı.

Mikrobilgisayar Mimarisi ve Programlama

Mikroişlemciler. Microchip PIC

BM-311 Bilgisayar Mimarisi

BM 375 Bilgisayar Organizasyonu Dersi Vize Sınavı Cevapları 10 Nisan 2009

1. Ders Giriş. Mikroişlemcili Sistem Uygulamaları

BIL 362 Mikroilemciler Dersi Final Sınavı Cevapları

EasyPic 6 Deney Seti Tanıtımı

İŞLEMCİ DURUM KAYDEDİCİSİ (PROCESSOR STATUS REGISTER)

Komutların Yürütülmesi

Bölüm 4 Ardışıl Lojik Devre Deneyleri

SAYISAL TASARIM. Ege Üniversitesi Ege MYO Mekatronik Programı

8051 Ailesi MCS51 ailesinin orijinal bir üyesidir ve bu ailenin çekirdeğini oluşturur çekirdeğinin temel özellikkleri aşağıda verilmiştir:

DELTA PLC DE ZAMANLAYICILAR

EEM 306 Mikroişlemciler ve Lab. Doç.Dr. Mehmet SAĞBAŞ

Mikroişlemci Nedir? Mikrodenetleyici Nedir? Mikroişlemci iç yapısı Ders Giriş. Mikroişlemcili Sistem Uygulamaları

ARM Ders Notları. SysCtlClockSet( SYSCTL_SYSDIV_4 SYSCTL_USE_PLL SYSCTL_OSC_MAIN SYSCTL_XTAL_8MHZ);

1. PORTB ye bağlı 8 adet LED i ikili sayı sisteminde yukarı saydıracak programı

Arduino Uno ile Hc-Sr04 ve Lcd Ekran Kullanarak Mesafe Ölçmek

D Duplex : Alıcı + Verici Çalışma Debouching : DMA : Direct Memory Access Data-Bus : Data Veri Yolu Data Flow : Veri Akışı Data Processing : Veri

LCD (Liquid Crystal Display)

Programlamada Kullanılan Temel Parametreler

KOMUT TABLOSU İLE İLGİLİ AÇIKLAMALAR:

TEKNOLOJİ FAKÜLTESİ ELEKTRİK ELEKTRONİK MÜHENDİSLİĞİ EET-206 SAYISAL ELEKTRONİK - II LABORATUVARI

Bölüm 4 Ardışıl Lojik Devre Deneyleri

EEM122SAYISAL MANTIK SAYICILAR. Elektrik Elektronik Mühendisliği Yrd. Doç. Dr. Hüseyin Sağkol

Erzurum Teknik Üniversitesi RobETÜ Kulübü Robot Eğitimleri. ARDUİNO EĞİTİMLERİ I Arş. Gör. Nurullah Gülmüş

MTM 305 MİKROİŞLEMCİLER

5.Eğitim E205. PIC16F628 ve PIC16F877 Hakkında Genel Bilgi IF THEN ELSE ENDIF HIGH-LOW GOTO-END- PAUSE Komutları Tanıtımı ve Kullanımı PIC16F628:

ROBOT KOL BİTİRME PROJESİ DÖNEM İÇİ RAPORU

Debug Komutları C:\>DEBUG - Çizgi işareti artık debug programının komut kabul etmeye hazır olduğunu belirtmektedir.

ÖNEMLİ AÇIKLAMA: Bu derslerdeki sunumların kısa bir özetini göstermek için hazırlanmıştır. Burada türkçeleştirilmemiş olan kısımlar sorulmayacak

8086 dan core2 ya yazaç yapısını tanımak. Bayrak yazacının içeriğinde yer alan bayrakların görevlerini tanımlamak. Real mod çalışmada bellek

BÖLÜM 7 Kesmeler.

DIGIAC 2000 Deney Seti PAT İŞLEMCİ KARTI :

MIKRODENETLEYICILER. Ege Üniversitesi Ege MYO Mekatronik Programı

BÖLÜM in Bellek Organizasyonu

1. Sayıcıların çalışma prensiplerini ve JK flip-floplarla nasıl gerçekleştirileceğini anlamak. 2. Asenkron ve senkron sayıcıları incelemek.

8255 (3 x 8) PARALEL INPUT/OUTPUT-INTERFACE

Mikroişlemciler-IMikrodenetleyiciler. Alper Bayrak Abant İzzet Baysal Üniversitesi Bolu

PIC16F84A Mikroislemci Denetimli Bir Sayisal Sinyal Üretici Tasarimi

DERS 3 MİKROİŞLEMCİ SİSTEM MİMARİSİ. İçerik

b) Aritmetik İşlem Komutları

Transkript:

İSTANBUL TİCARET ÜNİVERSİTESİ BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ MİKROİŞLEMCİLİ SİSTEM LABORATUVARI OLAYLARI ZAMANLAMA İnsanların işlerini bir takvime ve zamana bağlı olarak yürütmesine benzer şekilde, bilgisayarlar da işlerini bir takvim ve zaman içinde yapar. Örneğin bir program koşulurken klavyeden yapılacak müdahaleleri anlayabilmek için belirli aralıklarla klavyenin yoklanması bir zamanlama işidir. Veya CMOS ta üretilen gerçek-zamanlı saatten bilgisayarın sistem saatinin hangi aralıklarla güncelleneceği de yine bir zamanlama problemidir. Eski bilgisayarlarda dinamik belleklerin tazelenmesi (refresh) bu zamanlamaya verilecek başka bir örnektir. Zamanlama işlemi donanım veya yazılımla yapılabilir. Yazılım yöntemi gecikme programı kullanımına dayanır ve bu yüzden CPU saat frekansının bir fonksiyonudur. Yani aynı gecikme programı farklı bilgisayarlarda farklı zamanlamalar doğurur. Bu farklılıkları ortadan kaldırmak ve bilgisayarın donanımından bağımsız zamanlamalar gerçeklemek için bilgisayarlarda özel donanımlar inşa edilmiştir. Bu özel donanımların başında da 1.193180 MHz lik işaretin üretildiği saat devresi ve bu saatten farklı biçimlere sahip dikdörtgen dalga üretmeyi sağlayan 8254PIT Programlanabilen Aralık Zamanlayıcı (Programmable Interval Timer) gelir. Bu deneyin amacı 8254 PIT yongasını tanıtmak ve onu programlayarak çeşitli uygulamalar gerçeklemektir. 8254 PIT in YAPISI ve ÇALIŞMASI 8254 PIT,CPU dan bağımsız olarak, bir dış saat işaretinden programlanabilen zaman aralıkları üretir. Altı farklı çalışma moduna sahip olan PIT in iç yapısı Şekil 1 de gösterilmiştir. Şekil 1: 8254 PIT in iç yapısı 1

PIT her biri ayrı programlanabilen 16-bit genişliğinde üç adet (Counteer 0-2) sayıcılarına sahiptir. Her sayıcı zaman tabanı (time base) olarak hizmet veren kendi saat işaretine (CLK0-CLK2) sahiptir. Saymayı tetiklemek veya başlatmak için GATE0-GATE2 kapı işaretlerinden yararlanır. Sayma moduna bağlı olarak alçak-yüksek veya yüksek-alçak geçişlerinde sayıcı aktif yapılır ve OUT0-OUT2 çıkışlarında modun gerektirdiği biçimde bir işaret üretilir. 8254 PIT in PROGRAMLANMASI Programlamak için ilk olarak kontrol kelimesi kontrol kaydediciye yazılır, ve daha sonra bir veya iki veri baytı amaçlanan sayıcının portuna yazılır. Kontrol kaydedici bir kere yüklendikten sonra kontrol kaydediciye erişmeden sayıcılara başka değerler yazılabilir. 8253 PIT in kontrol kaydedicisi sadece yazılan, 8254 ün kaydedicisi ise hem yazılan hem de okunan bir kaydedicidir. Şekil 2: 8253 Kontrol kaydedicisi SAYMA MODLARI 8254 PIT altı farklı sayma moduna sahiptir ve hem ikili hem de onlu moda sayabilir. Çeşitli çalışma modları aşağıdaki şekillerde gösterilmiştir. Tüm modlarda PIT ilk sayma değerinden başlayarak aşağı değerlere kadar sayar. Yeni sayma değerleri herhangi bir anda sayıcılara yazılabilir. Sayıcı 0 değerine eriştiği zaman 0,1,4, 5 periyodik olmayan modlarda sayıcı saymayı durdurmaz, ama FFFFh (BCD=0) veya 9999 (BCD=1) ile devam eder. Mod 0: Nihai değerde kesme üretir. Mod 1: Programlanabilen monoflop Mod 2: Oran üretici Mod 3: Kare-dalga üreteci 2

Mod 4: Yazılım tetiklemeli darbe Mod 5: Donanım tetiklemeli darbe Şekil 3: Mod 0 zamanlama diyagramı Şekil 4: Mod 1 zamanlama diyagramı 3

Şekil 5: Mod 2 zamanlama diyagramı Şekil 6: Mod 3 zamanlama diyagramı 4

DENEYİN YAPILIŞI (Deney 1) Amaç: Programın amacı 8253 PIT ının 2. Zamanlayıcısını mod 3 te çalıştırarak frekansı değiştirilebilen bir kare dalga üreteci yapmaktır. Üretilen kare dalganın frekansını değiştirmek için 8255 in A portuna bağlı butonlar kullanılacaktır. Üretilen kare dalga sinyal 8255 in B Portuna bağlı 8 adet led üzerinden dışarıya yansıtılacaktır. Kaynak Program: Deney 1 devre şeması ;================================karedalga.asm====================================== == COMM1 EQU 0FFC8H ;Define 8259 command address for ; ICW1, OCW2, OCW3 COMM2 EQU 0FFCAH ; Define 8259 command address for ;ICW2, ICW3,ICW3, OCW1 COUNT1 EQU 0FFDAH ; Define 8253 counter#1 port address CNT_CSR EQU 0FFDEH ; Define 8253 control word port address CNT3 EQU 3FD6H ;Define 8255 control word port address APORT3 EQU 3FD0H ;Define 8255 porta address BPORT3 EQU 3FD2H ;Define 8255 portb address CPORT3 EQU 3FD4H ;Define 8255 portc address CODE SEGMENT ASSUME CS:CODE,DS:CODE ORG 0 5

START: CLI ;Disable interrupt MOV DI,0 MOV SI,0 MOV AX,CS MOV DS,AX MOV SP,0F000H ; Register for BPORT3 data ; Register for loop inside the subroutine ;CS=DS ;Code segment=data Segment ;Setup stack pointer ;<Setup IR1 interrupt vector> MOV AX,0 ;İnitialize ES to 0 MOV ES,AX ;Extra Segment =0 MOV BX,41H*4 ;Setup vector address of IR1 to BX=41H*4 MOV ES:WORD PTR[BX],OFFSET INTR1 ;IP of ISR write to vector MOV ES:2[BX],CS ;CS of ISR write to vector ;<İnitialize 8259 Command Words> ;<ICW1> MOV DX,COMM1 MOV AL,00010011B ;<ICW2> MOV DX,COMM2 MOV AL,40H MOV AL,00000101B ;<8259 operation command words> ;<OCW1> MOV AL,11111101B ;Enable command 1 port address ; Setup ICW1 ;Enable command 2 port address ; Setup ICW2 ; Setup ICW4 ;OCW1(Unmask IR1) ;<Setup 8255 control word register> MOV AL,90H MOV DX,CNT3 ;AL=90, porta=input, portb=portc=output ;Enable 8255 control port 6

MOV AL,0FFH ;Setup output to logic High MOV DX,CPORT3 ;Enable 8255 portc ;Output FFh so that Gate1 of 8253 =High ;<setup 8253 control word register> I8253: MOV DX,CNT_CSR ;Enable 8253 control port MOV AL,01110110B ;setup 8253 control word register ;<Output to 8253> MOV DX,COUNT1 ;Enable 8253 count#1 MOV AX,0FFFFH ;Divisor set to FFFFh ;Low Byte of divisor transfer to 8253 MOV AL,AH ;High byte of divisor transfer to AL ; High Byte of divisor transfer to 8253 ;<Main code> STI ;Enable interrupt TEKRAR: MOV DX,APORT3 ; Enable 8255 porta IN AL,DX ;Read button data MOV AH,AL ;Transfer AL to AH MOV AL,0FFH ;Write FFh to AL MOV DX,COUNT1 ;Enable 8253 count#1 ;Low Byte of divisor transfer to 8253 MOV AL,AH ;High byte of divisor transfer to AL ; High Byte of divisor transfer to 8253 JMP TEKRAR ;<IR1 Interrupt Service Routine> INTR1: PUSH AX ;Store Ax PUSH DX ;Store DX INC SI ;Increment SI to count timer interrupt calls CMP SI,0010H ; SI==10H? JNZ INTR1_BITIR ;No, then jump to INTR1_BITIR MOV SI,0 ;Yes, clear SI (for recounting process) NOT DI ; Invert DI (which is the data to be transfered to BPORT3 ) MOV AX,DI ;Transfer DI to AX MOV DX,BPORT3 ;Enable BPORT3 7

INTR1_BITIR: ;Write AL to BPORT3 MOV DX,COMM1 ;Enable 8259 data port address (setup OCW2) MOV AL,20H ;EOI(End of Interrupt) Command write to 8259 ;Output command POP DX ;Restore DX POP AX ;Restore AX IRET ;Return to main routine END CODE START ENDS DENEYİN YAPILIŞI (Deney 2) Amaç: Program çalıştırıldığında, 8 TACT switch ten girilen bilgi LED lerde ve yedi parçalı display de gösterilecek ve hoparlör aracılığıyla ilgili müzik skalasına dönüştürülecektir. Uygulamaya ilişkin devre şeması aşağıdaki gibidir. Deney 2 devre şeması Kaynak Program: ;================================piyano.asm======================================== COUNT1 EQU 0FFDAH ;Define 8253 counter#1 port address CSR EQU 0FFDEH ; Define 8253 control word port address CNT3 EQU 3FD6H ; Define 8255 control word port address APORT3 EQU 3FD0H ; Define 8255 porta address BPORT3 EQU 3FD2H ;Define 8255 portb address 8

CPORT3 EQU 3FD4H ;Define 8255 portc address FND EQU 3FF0H ; Define FND port address ORG 0 CODE SEGMENT ASSUME CS:CODE,DS:CODE START: MOV SP,4000H ;Setup of stack pointer MOV AX,CS ;CS=DS MOV DS,AX ; Code Segment=Data segment MOV AX,0 ;Initialize ES to 0 MOV ES,AX ;Extra segment=0 MOV BX,2*4 ;Setup vector address of NMI to BX=02H*4 MOV ES:WORD PTR[BX],OFFSET NMI MOV ES:2[BX],CS ;IP of ISR write to vector MOV DX,CNT3 ;CS of ISR write to vector MOV AL,90H ;A PORT=Input, BC PORT=Output ;Output 90H to 8255 control port MOV DX,CPORT3 ;Enable 8255 portc MOV AL,0FFH ;Setup output to logic High ;Output FFh so that Gate1 of 8253=High ;<Setup 8253 control word register> I8253: MOV DX,CSR ;Enable 8253 control port MOV AL,01110110B ;Setup 8253 control Word register ;Output data to 8253 control port MOV DX,COUNT1 ;Enable 8253 count#1 ;<Send Input data to LED> PLAY: PUSH DX ;DX=COUNT1, store to stack MOV DX,APORT3 ;Enable 8255 PortA (8 bit TACT Switch) IN AL,DX ;Input data from TACT switch NOT AL ;Reverse the signal from Low to High MOV DX,BPORT3 ;Enable 8255 PortB (8 bit LED) ;Output data to LED POP DX ;DX=COUNT1, load from stack ;<Pressed key changed?> 9

;< Key pressed?> CMP AL,BL ;When BL=unknown, ZF=0 ;When BL=AL, ZF=1 JZ PLAY ;If ZF=0 key change, go next instruction ;If ZF=1 no key change, jump to PLAY wait ;for next key to be pressed. MOV BL,AL ;Copy AL to BL CMP AL,0 ;When any key pressed ZF=0 ;When no key pressed ZF=1 JZ PLAY ;If ZF=0 key pressed, go to next instruction ; play music and show in FND ;If ZF=1 no key pressed, jump to PLAY wait ; for next key to be pressed ;< Short period of soundless> PUSH AX ;Store input data from TACT switch to stack MOV AX,10 ;Data (Divisor) for soundless ;The divisor=10, the frequency is too high MOV AL,AH ;to be heard MOV CX,1500 ;Time delay LOOP $ POP AX ;Load input data back to AX from stack ;< Determine which key is pressed> PUSH DX MOV DX,FND ;DX=COUNT1, store to stack ;Enable FND port address TEST AL,80H ; 7 key pressed? SW10.7=!7FH=80H JNZ DO ; If pressed, jump to DO. TEST AL,40H ; 6 key pressed? SW10.6=!BFH=40H JNZ RE ; If pressed, jump to RE. TEST AL,20H ; 5 key pressed? SW10.5=!DFH=20H JNZ MI ; If pressed, jump to MI. TEST AL,10H ; 4 key pressed? SW10.4=!EFH=10H JNZ FA ; If pressed, jump to FA. TEST AL,8 ; 3 key pressed? SW10.3=!F7H=08H JNZ SOL ; If pressed, jump to SOL. TEST AL,4 ; 2 key pressed? SW10.2=!FBH=04H 10

JNZ RA ; If pressed, jump to RA. TEST AL,2 ; 1 key pressed? SW10.1=!FDH=02H JNZ SY ; If pressed, jump to SY. TEST AL,1 ; 0 key pressed? SW10.0=!FEH=01H JNZ DO1 ; If pressed, jump to DO1. DO: MOV AL,11011000B ; ;Number 7 for FND ;Output to FND MOV AX,4697 ;Divisor for DO RE: MOV AL,10000010B ; ;Number 6 for FND ;Output to FND MOV AX,4184 ;Divisor for RE MI: MOV AL,10010010B ; ;Number 5 for FND ;Output to FND MOV AX,3728 ;Divisor for MI FA: MOV AL,10011001B ;4 ;Number 4 for FND ;Output to FND MOV AX,3519 ;Divisor for FA SOL: MOV AL,10110000B ;3 ;Output to FND MOV AX,3135 ;Divisor for SOL RA: MOV AL,10100100B ;Number 2 for FND ;Output to FND MOV AX,2793 ;Divisor for RA SY: MOV AL,11111001B ;Number 1 for FND ;Output to FND MOV AX,2491 ;Divisor for SY DO1: MOV AL,11000000B ;Number 0 for FND ;Output to FND MOV AX,2352 ;Divisor for High DO 11

;<Play Sound> SET8253: POP DX ;DX=COUNT1, load from stack ;Low Byte of divisor transfer to 8253 MOV AL,AH ;High Byte of divisor transfer to AL ;High Byte of divisor transfer to 8253 MOV CX,1500 LOOP $ JMP PLAY ;<Interrupt Service Routine for NMI> ;Time delay NMI: PUSH DX ;DX store to stack PUSH AX ;AX store to stack MOV DX,COUNT1 ;Enable 8253 Count1 MOV AX,10 ;Data (Divisor) for soundless ;The divisor= 10, frequency too high to be heard MOV AL,AH POP AX ;AX return from stack POP DX ;DX return from stack IRET CODE ENDS END START 12