EEM 437 MİKROİŞLEMCİLER DERS NOTLARI



Benzer belgeler
BÖLÜM Mikrodenetleyicisine Giriş

x86 Ailesi Mikroişlemciler ve Mikrobilgisayarlar

EEM 437 MİKROİŞLEMCİLER DERS NOTLARI

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

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

Çalışma Açısından Bilgisayarlar

Adres Yolu (Address Bus) Bellek Birimi. Veri Yolu (Databus) Kontrol Yolu (Control bus) Şekil xxx. Mikrodenetleyici genel blok şeması

BÖLÜM MİKROİŞLEMCİSİ

MİKROBİLGİSAYAR SİSTEMLERİ VE ASSEMBLER

EEM 419-Mikroişlemciler Güz 2017

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

Mikroişlemcili Sistemler ve Laboratuvarı 6.Hafta

EEM 419-Mikroişlemciler Güz 2016

HAFTA 1 KALICI OLMAYAN HAFIZA RAM SRAM DRAM DDRAM KALICI HAFIZA ROM PROM EPROM EEPROM FLASH HARDDISK

Mikroişlemcili Sistemler ve Laboratuvarı 5.HAFTA:BÖLÜM-1

BM-311 Bilgisayar Mimarisi

MIKRODENETLEYICILER. Ege Üniversitesi Ege MYO Mekatronik Programı

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

Embedded(Gömülü)Sistem Nedir?

8. MİKROİŞLEMCİ MİMARİSİ

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

BM-311 Bilgisayar Mimarisi

Mikrobilgisayarlar. Mikroişlemciler ve. Mikrobilgisayarlar

Von Neumann Mimarisi. Mikroişlemciler ve Mikrobilgisayarlar 1

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

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

DERS 5 PIC 16F84 PROGRAMLAMA İÇERİK. PIC 16F84 bacak bağlantıları PIC 16F84 bellek yapısı Program belleği RAM bellek Değişken kullanımı Komutlar

Bilgisayarların Gelişimi

İşletim Sistemleri (Operating Systems)

İŞLEMCİLER (CPU) İşlemciler bir cihazdaki tüm girdilerin tabii tutulduğu ve çıkış bilgilerinin üretildiği bölümdür.

ESM-361 Mikroişlemciler. 1. Hafta Ders Öğretim Üyesi Dr.Öğr.Üyesi Ayşe DEMİRHAN

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ı

Mikroişlemciler ve Assembler Programlama. Teknoloji Fakültesi / Bilgisayar Mühendisliği Öğr.Gör. Günay TEMÜR

BÖLÜM in Bellek Organizasyonu

MİKROİŞLEMCİLER. Mikroişlemcilerin Tarihsel Gelişimi

BÖLÜM 2 SAYI SİSTEMLERİ

MEB YÖK MESLEK YÜKSEKOKULLARI PROGRAM GELİŞTİRME PROJESİ. 1. Tipik bir mikrobilgisayar sistemin yapısı ve çalışması hakkında bilgi sahibi olabilme

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

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

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

Mikroişlemcili Sistemler ve Laboratuvarı

BİLGİSAYAR MİMARİSİ. Bilgisayar Bileşenleri Ve Programların Yürütülmesi. Özer Çelik Matematik-Bilgisayar Bölümü

İçİndekİler. 1. Bölüm - Mİkro Denetleyİcİ Nedİr? 2. Bölüm - MİkroDenetleyİcİlerİ Anlamak

Mikrobilgisayar Mimarisi ve Programlama

Bilgisayar Mühendisliğine Giriş. Yrd.Doç.Dr.Hacer KARACAN

Mikrobilgisayar Sistemleri ve Assembler

NEDEN & ADuC8xx EĞİTİM NOTLARI Bölüm-2 Selim Dilmaç Neden 8051

İÇİNDEKİLER. 1-1 Lojik ve Anahtara Giriş Lojik Kapı Devreleri... 9

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

80C51 Mikrodenetleyicilerinde Timer-Counter Yapılarının FPGA Mimarileri Kullanılarak Geliştirilmesi. Özdemir ÇETİN 1. Bölümü, Adapazarı

Mikrobilgisayar Mimarisi ve Programlama

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

MİKROİŞLEMCİLER 1 Ders 1

Mimari Esaslar. Mikroişlemcinin mimari esasları; Kaydediciler Veriyolları İş hatları dır.

Mikroişlemcili Sistemler ve Laboratuvarı

Bellekler. Mikroişlemciler ve Mikrobilgisayarlar

Donanımlar Hafta 1 Donanım

Komutların Yürütülmesi

Haftalık Ders Saati Okul Eğitimi Süresi

MİKROİŞLEMCİLER. Mikroişlemcilerde Kullanılan Yeni Teknolojiler ve Mikroişlemcilerin Rakipleri

Ad Soyad: Öğrenci No:

BİLGİSAYAR MİMARİSİ. << Bus Yapısı >> Özer Çelik Matematik-Bilgisayar Bölümü

MİKROİŞLEMCİ MİMARİLERİ

İşletim Sistemlerine Giriş

Hacettepe Robot Topluluğu

Giriş MİKROİŞLEMCİ SİSTEMLERİ. Elektronik Öncesi Kuşak. Bilgisayar Tarihi. Elektronik Kuşak. Elektronik Kuşak. Bilgisayar teknolojisindeki gelişme

Eğitim - Öğretim Yöntemleri Başlıca öğrenme faaliyetleri Kullanılan Araçlar Dinleme ve anlamlandırma

Mikroişlemciler ve Mikrokontrolörlere Giriş (CMPE236) Ders Detayları

A.Ü. GAMA MYO. Elektrik ve Enerji Bölümü ALGORİTMA VE PROGRAMLAMA 1.HAFTA

Dr. Feza BUZLUCA İstanbul Teknik Üniversitesi Bilgisayar Mühendisliği Bölümü

Bilgisayar Donanım 2010 BİLGİSAYAR

Merkezi İşlem Birimi MİKROİŞLEMCİ SİSTEMLERİ. MİB Yapısı. MİB in İç Yapısı. MİB Altbirimleri. MİB in İç Yapısı

MİLLİ SAVUNMA ÜNİVERSİTESİ KARA HARP OKULU DEKANLIĞI BİLGİSAYAR MÜHENDİSLİĞİ BÖLÜMÜ DERS TANITIM BİLGİLERİ

Bölüm 4 Aritmetik Devreler

Bir mikroişlemci temel olarak üç kısımdan oluşur. Bunlar merkezi işlem birimi (CPU), giriş çıkış birimi (G/Ç) ve bellektir.

Giris {\} /\ Suhap SAHIN

1 GİRİŞ 1 Bu Kitap Kimlere Hitap Eder 1 Kitabın İşleyişi 2 Kitabın Konuları 3 Kitabı Takip Etmek İçin Gerekenler 6 Kaynak Kodu ve Simülasyonlar 6

Bilgisayar Temel kavramlar - Donanım -Yazılım Ufuk ÇAKIOĞLU

MEKATRONİĞİN TEMELLERİ

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

BM-311 Bilgisayar Mimarisi

Quiz:8086 Mikroişlemcisi Mimarisi ve Emirleri

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

PIC Mikrodenetleyicileri

Yrd.Doç.Dr. Celal Murat KANDEMİR

Konular MİKROİŞLEMCİ SİSTEMLERİ. Giriş. Bilgisayar Tarihi. Elektronik Kuşak. Elektronik Öncesi Kuşak

İÇİNDEKİLER. 3 STM32F4 MIKRO-DENETLEYICISI 23 STM32 Ailesi ve STM32F STM32 Ailesi 23 STM32 Mikrodenetleyicileri 30 Numaralandırılması 30

GAZİANTEP ÜNİVERSİTESİ

Yrd. Doç. Dr. Bülent ÇOBANOĞLU

Ders Adı Kodu Yarıyılı T+U Saati Ulusal Kredisi AKTS. Microprocessors EEE

Günümüz. Intel Core i nm teknolojisi 1.86 Milyar tranzistör. Intel Core i nm teknolojisi 1.4 Milyar tranzistör

1969 yılında, klasik (Elektrik) kumandanın. Elektronik karşılığı olan ilk PLC yapıldı yılında ise dört yıllık bir çalımanın ürünü

Merkezi İşlem Birimi MİKROİŞLEMCİ SİSTEMLERİ. MİB Yapısı. MİB Altbirimleri. Durum Kütüğü. Yardımcı Kütükler

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

Deney 10: Analog - Dijital Dönüştürücüler (Analog to Digital Converters - ADC) Giriş

ADUC841 MİKRODENETLEYİCİ TABANLI GELİŞTİRME KARTININ TANITIMI:

Mikrobilgisayar Donanımı

4-Deney seti modüler yapıya sahiptir ve kabin içerisine tek bir board halinde monte edilmiştir.

Assembly Dili Nedir? Assembly dili biliyorum derken hangi işlemci ve hangi işletim sistemi için olduğunu da ifade etmek gerekir.

PIC 16F877 nin kullanılması

Transkript:

T.C. SAKARYA ÜNİVERSİTESİ MÜHENDİSLİK FAKÜLTESİ ELEKTRİK-ELEKTRONİK MÜHENDİSLİĞİ BÖLÜMÜ EEM 437 MİKROİŞLEMCİLER DERS NOTLARI Prof. Dr. Ayhan ÖZDEMİR Yrd. Doç. Dr. Zekiye ERDEM (25)

Dersin amacı: Temel mikroişlemci ve mikrodenetleyici mimari yapısının, sayısal ölçme/kontrol/kumanda işlemlerinin gerçekleştirilmesi için gerekli olan çevre birimlerine (ADC, DAC, PWM, EEPROM, SPI, vb.) sahip gelişmiş bir mikrodenetleyici mimarisinin öğrenilmesi. Mimariye dayalı adresleme yöntemlerini kullanarak makine dilinde programlama yeteneğinin geliştirilmesi, kesme kaynaklarının kullanılabilmesi, problem çözüm algoritmalarının geliştirilmesi yeteneklerinin kazandırılması, disiplinler arası ilişki içeren ilgili senaryoya göre karmaşık mühendislik problemlerin çözümünde donanımsal ve yazılımsal tasarımların/çözümlerin üretilmesidir. Ders sonunda hedeflenen öğrenme çıktıları:. Mikroişlemci/Mikrodenetleyici (intel-85) mimarisinin öğrenilmesi 2. Dahili/Harici Hafıza ve RAM yapılarının öğrenilmesi 3. Adresleme modları ve makine dilinin öğrenilmesi 4. Gelişmiş mikrodenetleyici mimarisi ve çevre birimlerinin öğrenilmesi(aduc84) 5. Kesme kaynaklarının öğrenilmesi ve kullanabilme yeteneğinin geliştirilmesi 6. Disiplinler arası ilişki içeren karmaşık mühendislik problemleri için çözüm algoritmalarını geliştirme ve makine dilinde programlama yeteneğinin elde edilmesi 7. Asenkron/Senkron seri ve SPI haberleşme yeteneklerinin geliştirilmesi 8. Yazılım ve Donanım güvenliği sağlayabilme yeteneğinin geliştirilmesi DEĞERLENDİRME SİSTEMİ: YARIYIL İÇİ ÇALIŞMALARI SIRA KATKI YÜZDESİ Ara Sınav 5 Kısa Sınav 2 Ödev 3 4 Toplam Finalin Başarıya Oranı 5 Yıliçinin Başarıya Oranı 5 Toplam NOT: Ders boyunca toplamda 5 adet proje verilmesi ve bu projelerin ağırlıklı ortalaması alınarak Ödev katkısı olarak değerlendirme sistemine eklenmesi hedeflenmektedir. Kaynaklar:. The 85 microcontroller : architecture, programming, and applications, Kenneth J Ayala 2. C and the 85, Thomas W. Schultz 2

İÇİNDEKİLER: BÖLÜM : Mikroişlemci ve Mİkrodenetleyici tarihçesi BÖLÜM 2: Mikroişlemciler ve Merkezi İşlem Birim (CPU) Mimarisi BÖLÜM 3: Özel Fonksiyon Kaydedicileri ve dahili RAM ve Yığın (Stack Pointer) BÖLÜM 4: 85 mimarisi, Adresleme modları ve Fonksiyonlarına göre Assembly Komut Kümeleri BÖLÜM 5: Alt program ve Yığın (Stack Pointer) işleyişi BÖLÜM 6: 85 ve ADUC84 mimarisinde Port Yapıları ve fonksiyonları BÖLÜM 7: Kesme kaynakları ve kesme hizmet programı BÖLÜM 8: Zamanlayıcı/Sayıcılar BÖLÜM 9: Darbe-genişlik modülasyon çevre birimi ve modları (PWM) BÖLÜM : Analog-Dijital (ADC) /Dijital-Analog (DAC) çevre birimleri ve modları BÖLÜM : Çift veri göstergesi (Dual-DPTR), Harici Hafızaların ( dahili RAM/EEPROM) kullanımı BÖLÜM 2: Asenkron/Senkron seri, SPI haberleşme ve modları (UART ve SPI yapısı ) BÖLÜM 3: Yazılım ve Donanım Güvenliği 3

BÖLÜM MİKROİŞLEMCİ VE MİKRODENETLEYİCİ TARİHÇESİ. Genel Tarihçe: 94 lı yıllarda ilk transistor ün keşfi ile elektronik endüstrisinde yeni bir çağ başlamıştır. Bu keşiften birkaç yıl sonra transistor ün ticarileşmesi ile elektronik devreler yarı iletkenler ile üretilmeye başlanmış ve devre üzerinden geçen akımın düşük miktardaki başka bir akım geçişi ile kontrol edilebildiği tümdevreler ortaya çıkmıştır. Buna ek olarak, bilgisayar mimarisinde paralel gelişimlerin doğması ve tümdevrelerin seri üretime geçmesini sağlayacak olan mikroişlemci (microprocessor) veya chip işlemci (Computer- on- a Chip) teknolojisi ilk defa 97 yılında bilinmeyen küçük bir firma olan Intel tarafından 4-bitlik 44 adlı mikroişlemcisi ile hayat bulmuştur. Şekil İlk defa patenti alınan tüm devre Şekil 2 Intelin piyasaya çıkardığı ilk işlemci 44 4

Aynı anda yürütebildiği bit sayısına bakılarak güçlü olup olmadığı anlaşılan işlemcilere daha sonra kısa bir süreç için sınırlı sayıda işlem yapabilen 8 bitlik 88 işlemcisi eklenmiştir. 974 yılında Intel 88 adlı işlemcisini, hemen ardından da önceki işlemci ile pek farkı olamayan Motorola 68 adlı işlemcisini piyasaya sürmüşlerdir. Birbirleri arasında küçük farklılıklar olan iki işlemci daha piyasaya sürülmüştür. Bunlar, MOS Technology firması tarafından üretilen 652 ve Zilog firması tarafından üretilen Z-8 işlemcileridir. Şekil 3 8 bitlik popüler mikroişlemcilerin teknik özellikleri 8 bitlik 88 ve Z 8 mikroişlemcilerinde hesaplama yapmak maksadıyla bol miktarda kaydedici vardır. Bundan dolayı bu işlemcilere kaydediciye dayalı işlemciler denilmekledir. Diğer 8 bitlik işlemciler 68 ve 652, anlaşılır komutlar ve daha fazla adresleme modu kullanmaları, kaydedicilerinin fazla olmamasından dolayı veri manevrasında sık sık belleği kullanmalarından dolayı belleğe dayalı işlemciler olarak anılırlar. Bu gruplar birbirlerinin bellek ve G/Ç (Girş/Çıkış) yongalarını kullanabilmektedirler. Bulunduğu sistemin belirli bir düzen içerisinde çalışmasını sağlayan, aritmetik ve lojik işlem yapabilme yeteneğine sahip olan mikroişlemciler geçen zaman içerisinde sahip oldukları özellikler açısından olağanüstü bir geliştirme göstererek modern yaşamın vazgeçilmez bir parçası haline gelmiştir []. Başlangıçta endüstriyel uygulamalarda da kullanılan mikroişlemciler, en basit gerçek zaman uygulamalarında bile ihtiyaç duyulan hafıza, giriş/çıkış birimleri, vb. yapıları mimarilerinde dahili olarak sahip değildirler. Bu gibi çevre birimleri harici olarak ilave edilerek mikroişlemci tabanlı uygulamalar gerçekleştirilebilir. Ancak gerçek zaman endüstriyel uygulamalarda gerekli olan çevre birimlerinin karmaşıklılığı ve sayısı zamanla artmıştır. Sonuç olarak mikroişlemci tabanlı sistemlerin tasarımı ve 5

gerçekleştirilmesi oldukça karmaşık, zor ve maliyetli olduğundan günümüzde endüstriyel uygulamalarda Mikrodenetleyici ler kullanılır []. Mikrodenetleyiciler; mimarisinde bir mikroişlemciye ilave olarak bir çok çevre birimini de dahili olarak bulunduran, tek bir tümdevre üzerinde üretilen, endüstriyel uygulamalar için geliştirilmiş özel bir mikro-bilgisayar olarak değerlendirilebilir. Ölçme, kumanda, kontrol, vb. endüstriyel uygulamalarda ihtiyaç duyulan bir çok çevre birimini tek bir tümdevre üzerinde bulunduran mikrodenetleyiciler mikroişlemcilere oranla çok daha basit, ucuz ve kolay çözümler sunar. Günümüzde farklı mimari özelliklere sahip mikrodenetleyiciler çok sayıda firma tarafından üretilmektedir. 85 ailesinin yeni nesil üyeleri endüstriyel uygulamalarda karşılaşılan ihtiyaçlara cevap verebilmek amacı ile temel mimari özelliklere ilave olarak, analog-sayısal dönüştürücü (ADC), sayısal-analog dönüştürücü (DAC), darbe genişlik modülasyonu (PWM), ilave hafıza birimleri, yüksek çalışma frekansları, kısır-döngü zamanlayıcısı (Watchdog Timer) gibi çok çeşitli özelliklere sahip olarak üretilmektedir. Aduc84 mikrodenetleyicisi Analog Device firması tarafından üretilen ve günümüzde bir çok endüstriyel uygulamada tercih edilen, ADC, DAC, PWM, I2C ve SPI haberleşme birimleri, besleme gerilimi izleme, vb. bir çok gelişmiş özelliğe sahip, 85 tabanlı, 8-bit lik bir mikrodenetleyicidir. Günümüzde 85 ailesi dışında çeşitli firmalar tarafından üretilen farklı mimari yapıya sahip mikrodenetleyici aileleri (PIC, Motorola,..) mevcuttur. Ancak bu mikrodenetleyiciler tek bir firma tarafından üretildiğinden, ürün çeşitliliği ve teknik destek açısından dezavantaj oluşturabilmektedir. Diğer yandan başta Intel olmak üzere çok sayıda firma 85 tabanlı mikrodenetleyiciler üretmektedir. Bunun neticesinde ürün çeşitliliği çok olduğundan yapılacak olan uygulamaya yönelik 85 tabanlı mikrodenetleyici temini daha kolay olacaktır. Ayrıca, yine bir çok firma 85 ailesi için teknik doküman, yazılım ve donanım desteği sunmaktadır []. Bu bölümün amacı mikroişlemci ve mikrodenetleyici kavramını açıklamak ve bir mikrodenetleyicinin karakteristik özelliklerini incelemektir. Ders notlarının geri kalan 85 işlemcisi ve ADUC84 mikrodenetleyici mimarileri ve çevre birimleri hakkında detaylı bilgiler verilecektir. 6

2. MİKROİŞLEMCİ VE MİKRODENETLEYİCİ: Mikroişlemci (Microprocessor) Tanım: Mikroişlemci, (Microprocessor, bazen kısaltma olarak µp kullanılır) ana işlem biriminin (CPU) fonksiyonlarını tek bir yarı iletken tümleşik devrede (IC) veya CPU-ona-single-chip (CPU-tek-çip) birleştiren programlanabilir bir sayısal elektronik bileşendir. Mikrodenetleyici (Microcontroller) Tanım: Mikrodenetleyiciler (Microcontrollers), mimarisinde bir CPU ya ilave olarak bir çok çevre birimini (ROM, RAM, girişçıkış birimleri (pin/port), vb.) de dahili olarak bulunduran, tek bir tümdevre üzerinde üretilen, özel bir mikro-bilgisayar olarak değerlendirilebilir. CPU- Merkezi İşlem Birimi Mikrodenetleyici Kaydediciler (Registers) FLASH RAM EEPROM PWMs SPI Aritmetik-Lojik Birim CPU (Arithmetic Logic Unit, ALU) UART (RS232) TIMERS Kontrol Birimi (Control Unit) ADCs DACs TEMP SENSOR 7

. Mikrodenetleyicilerin Kullanım alanları: Mikrodenetleyiciler otomotiv, tıp, endüstri, askeri ve uzay teknolojileri gibi birçok alanda yoğun bir şekilde kullanılmaktadır. Aşağıda farklı endüstriyel alanlar için mikrodenetleyici tabanlı bazı örnek ürünler-cihazlar gösterilmiştir. Savunma sanayi, Uzaktan kontrol edilebilen atış sistemi İnsansız kara aracı(aselsan) İnsansız deniz aracı (Aselsan) Medikal ürünler, İnsansız hava aracı, ANKA (TAİ) Sayısal tansiyon ölçme aleti Protez Sayısal ateş ölçer 8

Otomotiv sanayi, Endüstriyel uygulamalar, AC-DC Motor sürücüleri Endüstriyel kontrolörler Reaktif güç kontrol rölesi 9

Beyaz eşya, Çamaşır makinesi Buzdolabı Mikrodenetleyici tabanlı diğer uygulamalar, OGS (Otomatik Geçiş Sistemi) Otomat Otomatik kapı-bariyer sistemleri Şekil 4 Mikroidenetleyicilerin günümüzdeki uygulama alnlarından örnekler

Mikrodenetleyicilerin günümüzde kullanılan uygulama alanları aşağıda sıralanmıştır: Buzdolabı, çamaşır makinesi, bulaşık makinesi vb. beyaz eşyalarda değişik parametrelerin ölçülmesi ve süreç denetiminde, Otomobillerde ve diğer araçlarda algılama, denetim ve göstergelerde, Elektrik motoru içeren sistemlerde, motor hızı, açı kontrol uygulamalarda, Fare, klavye, oyun denetçileri vb. Bilgisayar çevre birimlerinde, monitörlerde Elektronik ajanda, cep bilgisayarları (PDA) Endüstriyel ağlarda düşük maliyetli denetleyicili bölgesi ağı (CAN), Genel amaçlı seri yol (USB) algılayıcı-güncelleyici arabirimi, Güvenlik Çevre Birimleri: Kızılötesi uzaktan (IR) algılama ve iletişimi, Elektronik Lamba Balastı Anahtarsız uzaktan Kapı açılması: RKE Televizyonlarda uzaktan kumanda, ekran üzerinde ayar ve gösterge birimlerinde Elektronik saatlerde, Cep telefonları içinde ses, görüntü giriş birimlerinde Elektronik Sistemlerde Kullanılan Mikrodenetleyici Uygulamaları: Paralel veri giriş/çıkış birimlerinde Seri veri giriş/çıkış birimlerinde Sayıcı/ zamanlayıcı denetim ve ölçümünde Endüstriyel ölçme ve kontrol birimlerinde gösterge, çıkış birimi veya klavye, giriş birimi Algılayıcıların çıkış işaretinin dönüştürülmesinde Akım, gerilim, direnç ölçü aletlerinde Sıcaklık ölçümü ve denetiminde Sayısal PID denetleyici uygulamalarında Bir internet denetleyicisine bağlantı (TCP/IP) Yerleşik internet uygulamaları Genel amaçlı seri yol (USB) Denetleyicili bölgesi ağı (CAN) Darbe genişliği modülasyonu (PWM) Bölgesel iç bağlantı ağı (LIN) Radyo frekans, telli ve telsiz çalışma (RKE)

3. SAYI GÖSTERİMLERİ (NUMBER REPRESENTATION) Sayıları gösterirken onların boyutlarını (hane sayısı bakımından) göz önünde bulundururuz. Bit: Tek bir binary digit (hane) 7. bit 6. bit 5. bit 4. bit 3. bit 2. bit. bit. bit Byte: 8 tane binary digit Byte (8-bit) Word: 6 binary digit Byte (8-bit) Byte (8-bit) Word (6-bit) Double Word: 32 binary digit Byte (8-bit) Byte (8-bit) Byte (8-bit) Byte (8-bit) Word (6-bit) Double Word (32-bit) Word (6-bit) Heksadesimal (Hexadecimal): Heksadesimal, 6 tabanlı sayı sistemidir. Hex bilgisayar belleğindeki 8-bit'lik byte'ları göstermek için kullanılan bir kestirme yoldur. Bu sayı sistemine "6 tabanlı sayı sistemi" denilmesinin nedeni, 6 tane sembolden oluşmasıdır. Sembollerden tanesi rakamlarla (,, 2, 3, 4, 5, 6, 7, 8, 9), geri kalan 6 tanesi harflerle (A, B, C, D, E, F) temsil edilir. 2

Heksadesimal Dönüşüm Tablosu Sayıları gösterirken boyutları ihmal etmemeliyiz. 8 bit yani byte ile -255 e kadar olan sayıları gösterebiliriz. ( 2 ya da FF 6 ) 6 bit yani word gösterimi ile -65535 e kadar olan sayıları gösterebiliriz. (veya - 2 ya da FFFF6) Bu sınırlar kullanabileceğimiz sayıları belirler. 3. İşaretli Sayı Kavramı: Mikrodenetleyicilerde dolayısıyla mikroişlemcilerde işaretli sayıların da kullanılması gerekmektedir. Mesela tasarlamak istediğimiz pratik bir devre sırasında (- 5 o C) gibi bir sıcaklık değeri karşımıza çıkabilir. Bu nedenle mikroişlemcide negatif sayıların da temsil edilmesi ve işlenebilmesi gerekir. Bu da aslında sadece ve lerle işlem yapan mikroişlemcilerde negatifliğin bir şekilde temsil edilmesi ihtiyacı olduğu anlamına gelir. Mikroişlemcilerde programlama yapılırken öncelikle işaretli sayılar (negatif işaretli) veya işaretsiz sayılar ile çalışılacağı belirlenmelidir ve program bu mantık kabul edilerek yazılmalıdır. Mikroişlemci hesap yaparken bunu bilmez. Çünkü bu sayıya bir bakış açısıdır. Yoksa mikroişlemci için işaretli sayılarla yapılan işlemin işaretsiz sayılarla yapılan işlemlerden farkı yoktur. Bazı mikroişlemcilerde işaret bitinin değeri bir başka özel bitle belirtilmektedir. 3

İşaretli sayılarda 7. Bit işaret biti olarak kullanılır. Örnek: 7. Bit ise sayı pozitif 7. Bit, ise negatiftir. 83 = -7 = Şeklinde gösterilir. Negatif sayılar kullanılırken genelde ikinin tümleyenini alma yöntemi kullanılır. İlk bit işaret bitini gösterir, -n sayısını göstermek istediğimizi farz edelim, +n sayısının bitlerinin tersini alıp eklediğimizde n sayısını elde ederiz. Bu yöntem ikiye tümleme olarak adlandırılır. Örnek: (-) 9 sayısı için; 9 = 2 ikiye tümeleyeni alınırsa; (-)9 = elde edilir. Neden ikinin tümleyeni alınır? Bu sayede pozitif ve negatif sayıları üzerinde işlem yapmak daha kolaydır. Negatif sayı ile yapılan işlem aslında mikroişlemci için toplama işlemine dönüştürülmüş olur. İşlemci mimarisi toplama işlemi için uygundur. Örneğin; A-B işlemi için; A+(-B) işlemi yapılmış olur. Bunu bir örnekle açıklayalım; Örnek: 83 = (-) 7 = bu iki sayıyı toplarsak 83+ (-)7 işlemini yapmış oluruz. Ve sonuç = () 2 = 2 elde edilir. 4

BÖLÜM 2: Mikroişlemciler ve Merkezi İşlem Birim (CPU) Mimarisi Bir işlemcinin donanımsal özelliklerini kavrayabilmek için onun mimari yapısına hâkim olmak gereklidir. İyi bir programcı programladığı işlemcinin mimarisini ve özelliklerini bildiği takdirde karşılaştığı hataları yorumlayabilir ve çözüme kavuşturabilir. Bu bölümde ilk olarak CPU-(Central Processing Unit) veya Merkezi İşlem birimi (MİB) mimarisi ve özellikleri hakkında genel bilgiler verilecektir. Merkezi işlem birimine ait genel mimari aşağıda belirtilmiştir. Verilen mimari herhangi bir işlemciye ait olmayıp geneldir. INTR RST5.5 RST6.5 RST7.5 TRAP SID SOD Kesme Kontrol Seri I/O Kontrol 8-bit Dahili Veri Yolu A ALU Geçici Reg. IR Komut Kod Çözücü ID B D H SP PC C E L Saklayıcılar Bayraklar (F) X X2 CLK OUT CLK Üretimi Kontrol Zamanlama ve Kontrol MAR MAR / MBR READY RD WR ALE A 5 -A 8 Adres Yolu Şekil 5 CPU- Merkezi İşlem Birimi Genel Mimarisi AD 7 -AD Adres/Veri Yolu CPU nun içyapısı; aritmetik lojik birim (ALU), program sayacı (program counter-pc), yığın işaretleyicisi (stack pointer-sp ) gibi birimlere ait blok diyagramı Şekil 5 de gösterilmiştir. 5

2. ORTAK YOL (BUS) Ortak yol (Bus) aynı amaç için veri taşıyan paralel bağlantıları tanımlar. Bağlantıların sayısı ortak yolun(hat) genişliğini (4-bit, 8-bit, vb.) başka bir ifade ile aynı anda iletilebilecek bit sayısını belirler. örneğin 8-bit lik bir CPU da veri yolundan bir seferde 8-bit uzunluğunda veriler taşınabilir. Bu durum aynı zamanda işlemcinin hızını da işaret eder, günümüzde 26-bit işlemciler mevcuttur bunun anlamı ortak yoldan aynı anda taşınan bit uzunluğunun 28-bit olduğunu gösterir. CPU mimarisinde; Adres yolu (Address bus), veri yolu (Data bus) ve lojik kontrol işaretlerinin iletildiği kontrol yolu (control bus) olmak üzere üç ayrı ortak yol (hat) vardır. Kontrol Yolu Merkezi İşlem Birimi (CPU) Veri Yolu Adres Yolu Hafıza Kontrol Yolu Giriş / Çıkış (I/O) Birimleri Harici Bağlantılar Şekil 6 CPU Ortak yok üzerinde çevre birimler ile bağlantısı Veri yolu (Data bus): İşlemci, hafıza ve çevre birimleri arasında veri iletişimini sağlamak için kullanılır. Adres yolu (Adress bus): İşlemcinin program komutlarına ve veri saklama alanlarına erişimi sağlayan hafıza adreslerini, ROM ve RAM hafızalarına göndermek için kullanılır. Kontrol yolu (Control Bus): Kontrol biriminin ürettiği sinyalleri ilgili çevre birimlerine ve ilgili çevre biriminden kontrol birimine gelecek sinyalleri iletmek için kullanılır. 6

2.2 CPU BİRİMLERİ VE ÖZELLİKLERİ: KAYDEDİCİ VE SAYICI : Kaydediciler ve sayıcılar gerek mikroişlemci içerisindeki gerekse de mikroişlemci ile diğer devreler arasındaki işlemleri destekleyen devrelerdir. Saklayıcılar CPU nun ufak birer bilgi depolama birimleridir ve diğer bellek birimleri gibi ikili (binary) hücrelerden (filp, floplardan) oluşturulmuşlardır. Bazıları yazılım kontrolü altındadır ve CPU nu her bir bilgi alış verişi için bellek bölümüne başvurmama olanağı sağlarlar. Böylece işlem süresi çok kısa olur. Bazıları ise denetim için gerekli bilgileri saklarlar. Temel yapısı, D ve J K Flip Flop lardan oluşur. Sayıcıların görevi ise işlemi yapılacak olan komut verilerin adresini belirlemektir. Temel yapısı, J-K Flip Flop gruplarıdır. ACCUMULATOR: (ACC, A -Akümülatör) CPU nun ana saklayıcıdır. Özel tanımlanmış kaydedici olup, ALU (Arithmetic-Logic Unit) ile yapılan herhangi bir aritmetik veya lojik işlem sonucunu saklar. Veri Yolu (Data bus) ile aynı bit uzunluğuna sahiptir. Öyle ki; 8 bitlik mikroişlemci deyiminden o mikroişlemcinin 8 bitlik data bus ve akümülatör özelliklerine sahip olduğu anlaşılır. Veri Yolu; 4-8-6-32-64 bitlik olabilir. Mikroişlemcilerde genellikle 8 bitik veri alınır, verilir. D7 D6 D5 D4 D3 D2 D D 8 BIT Örnek Saklama: verisi heksadesimal yani 6 bitlik tabana çevrilir ise, A 6 [A6] hafızada A6 Olarak saklanır ALU: (Arithmetic Logic Unit- Aritmetik- Lojik İşlem Ünitesi) Matematiksel (toplama, çıkarma vb.) ve/veya lojik işlemler gerçekleştirilir. ALU ya doğrudan ulaşılamaz; sadece komutlar ile işlem yaptırılabilir. ALU mikroişlemcinin beyni gibi düşünülebilinir. BUFFER REGİSTER: (Tampon/Önbellek kaydedicisi) Bilginin ALU ya girmeden önce saklandığı birimdir. Mikroişlemci ile eşit bit uzunluğuna sahiptir. 7

CLOCK: (Saat Darbesi) Kontrol biriminin (control unit) zamanlama darbeleri olarak kullandığı belirli frekansta saat darbeleri üretir. Kontrol birimi X ve X 2 girişlerine bağlanan kristalin frekansı üretilecek saat darbelerinin frekansını belirler. Kristal SAAT DARBELERİ X X2 T Q Q 2 KONTROL BİRİMİ Saat Darbeleri çok önemlidir çünkü bu darbeler olmazsa mikroişlemci lojik mimari gereği çalışmaz. Yani bu darbeler Mikroişlemcinin kalp atışları gibidir. CONTROL UNIT: (Kontrol Birimi) CPU nun dış ortamla ilişki kurabilmesi için gerekli sinyalleri üretir ve ilgili birimleri kontrol eder. Kontrol birimi mikroişlemcinin kalbi gibi düşünülebilir. Kalp insanda nasıl organları canlı tutmak için atıyorsa, kontrol biriminden çıkan sinyallerde mikroişlemci içerisindeki birimleri canlı-aktif olarak çalışmasını sağlar. GİRİŞ SİNYALLERİ KONTROL BİRİMİ ÇIKIŞ SİNYALLERİ SAAT DARBELERİ i. MUX (Multiplexer) ve ALU için kontrol hatalarını düzenler. ii. Kaydediciler, hafızalar ve giriş-çıkış cihazları için okuma-yazma darbeleri üretir. iii. Program sayacısını (PC) artırır veya eksiltir. iv. Tüm işlemleri bu birim kontrol eder ve müdahale yapılamaz! IR: (Instruction Register/Komut Kaydedicisi) CPU nun koşturacağı kodu binary kodunda tutan kaydedicidir. 8

ID: (Instruction Decoder/Komut Kod Çözücü) Komut kaydedicisinde tutulan bilgiyi tanımlayarak kontrol biriminin doğru zamanlama ve kontrol darbelerini üretmelerini sağlar. MAR: (Memory Adress Register/Hafıza Adres Kaydedici ) Hafızada okuma-yazma işlemi yapılacaksa; ulaşmak istenilen bölgenin adresinin tutulduğu yerdir. DATA DATA GİRİŞ/ÇIKIŞ ADRES Hafıza Adresi RD WR (READ) (WRITE) Read/Write (RD, WR) sinyalleri Kontrol birimi tarafından üretilir, adres bilgisi MAR dan alınır. Hem veri hem adres yoluna bağlıdır. MUX: (Multiplexer/Çoğullayıcı) Kaydediciler, adres yolu ve veri yolu arasında bilgi transferi için yol seçimini yapan elektronik anahtarlama elemanıdır. Denetimi kontrol birimi (control unit) tarafından yapılır. PC: (Program Counter/Program Sayacı) Genellikle 6-bit olan PC; programdaki bir sonra gelecek komutun adresini saklar. Yani çalıştırılacak komut buradan yola çıkar. PC da adres değişikleri yapılır, satır atlanalabilir. PC nin gösterdiği adres, son komut kullanıldıktan sonra otomatik olarak artar veya program sayıcısına yüklenen 6 bitlik yeni bir komut adresi ile değiştirilebilir. 6 bitlik adres bilgisi 8 bitlik bir işlemcide aşağıda gösterildiği gibi taşınır; 6 BIT PC (6 BIT/WORD) HIGH BYTE (YÜKSEK ANLAMLI 8-BİT) LOW BYTE (DUSUK ANLAMLI 8-BİT) PCH PCL 8 BIT 8 BIT BYTE BYTE Veri yolu (Data bus) 8-bit (byte) olduğu için 6-bit (word) bir bilgi iki adet 8-bit (byte) veri olarak iki kerede RAM den PC ye taşınır. Bu akış kontrol birimi tarafından yapılır. Örneğin; A6 C verisi A6PCH ve CPCL olmak üzere verinin ilk parçası olan A6 PCH a 8 bitlik data bus tan gelir ve yerleşir. Diğer parça da hemen ardından aynen taşınır ve PCL a yerleşir. 9

Adres yolu (Adress bus) 6 bitlik olduğundan parçalanma olmaz aynen iletim olur. WR: (Working register/ Çalışma Kaydedicisi) Bu kaydediciler çeşitli fonksiyonları gerçekleştirebilirler. Bir kısmı çeşitli hafıza, bir kısmı da özel fonksiyon kaydedicileri olarak kullanılır. Sayıları çok fazla olablir (5-54 civarı) 8 bit veya 2x8 bit olabilir. Örnek olarak bir zamanlayıcı (timer) eklemek istersek bunu WR ile gerçekleştirebiliriz. 2.3 MİKROİŞLEMCİ PROGRAMLAMA: Programlama Dili ve Seviyeleri: Yüksek Seviye Diller Assembly dili Makine Dili Donanım Şekil 7 Programlama Dili seviyeleri Mikroişlemci programlamada program dili seviyesi makine dili seviyesine ne kadar yakınsa program dili o derece karmaşıktır fakat bunun yanında mimariye o derece esnek bir şekilde müdahale edilebilir. Bu ders boyunca makine diline en yakın olan Assembly programlama dili hakkında bilgi verilecektir. Mikro Program Koşturulması: Bir mikro pogram fetch (gidip-getirme periyodu) ve execute (yürütme) olmak üzere iki parçadan oluşur. KOMUT MİKROİŞLEMCİDE KOMUT OKUMA (FETCH) YÜRÜTME (EXECUTE) KOMUT YÜRÜTÜLDÜ DONANIM RESET OLUŞTU DURMA (HALT) DURMA (HALT) KOMUTU DONANIM RESET YOK Şekil 8 Bir mikro programın koşturulması 2

Fetch Cycle: [Gidip-getirme Periyodu] Mikro programın ilk kısmı (işlem kodu/opcode) komutun bulunduğu hafızadan alınması ve CPU da uygun kaydediciye konmasıdır. Komut saklayıcısına gelen komut hangi birime gideceği kod çözücü tarafından belirlenir. Bu ise kontrol biriminin diğer devrelerine uygun ve doğru sinyaller göndermesini sağlar. 2 veya 3 byte lık komutlarda işlem kodu byte alınır alınmaz komutun byte 2 ve byte 3 kısmı hafızadan alınmaktadır. Bu işlemlerin tümü fetch cycle olarak adlandırılır. Execute Cycle: [Yürütme periyodu] Mikroprogramın ikinci kısmı ise CPU ya getirilen komutun koşturulmasıdır. Genel mikro program akış diyagramı Mikro Start Fetch cycle Execute cycle Mikro Stop Örnek uygulama: CPU nun fetch ve execute periyodunu belirlenen bir hafıza bölgesindeki bilginin akümülatöre yüklenmesini inceleyelim; Detay: 3 Byte komut, sırasıyla,,2 (hex) adresleridir. Akümülatöre yüklenecek sayı: 38 (hex) Akümülatöre yüklenecek sayının adresi: AA (hex) Kod hafızası: 2

İşlemi yaptıracak Kod LDA addr LDA komutunun karşığı 3A dır. LDA AA hex Önce low byte yüklenir ardından High byte yüklenir. code LB HB 3A AA 2 AA WR -RD HIGH BYTE LOW BYTE Adres okunacağı zaman RD kısmına oku sinyali ( ile veri yoluna çıkartılır. ) gelir okunacak adresteki veri bu sinyal Uygulama: 22

I. ADIM LDA AA KOMUTUNUN MİMARİ ÜZERİNDE FETCH CYCLE AŞAMALARININ GÖSTERİMİ I. Adım ADRES YOLU BAŞLA IR ID KOD HAFIZASI 2 3A AA PC 3A 3A KOD ÇÖZÜLÜR ACC 3A VERİ YOLU MAR HB LB ADIM İŞLEM SONUÇ Reset- Program Counter (PC) Donanımsal PC= 2 PC den adres yoluna transfer Adres Yolu na 3 daki bilgi veri yoluna 3A Veri Yoluna 4 Veri yolundaki bilgi IR ye yüklenir 3A IR 5 IR deki bilgi ID ye yüklenir 3A ID 23

II. ADIM II. Adım ADRES YOLU 2 BAŞLA IR ID KOD HAFIZASI ACC 2 3A AA 2 PC PC+ PC++ 3A 3A KOD ÇÖZÜLÜR AA VERİ YOLU FETCH CYLE BİTER AA MAR HB LB ADIM İŞLEM SONUÇ 6 Kontrol birimi komut zamanlama sinyallerini üretir 7 PC+ Bir sonraki PC 8 PC den adres yoluna transfer Adres Yolu na 9 deki bilgi veri yoluna aktarılır AA Veri yolu Veri yolundaki bilgiyi MAR alır AA MAR PC+ Bir sonraki 2 PC 2 PC den adres yoluna transfer 2 Adres Yolu na 3 daki bilgi veri yoluna Veri Yolu 4 Veri yolundaki bilgi MAR ye yüklenir MAR 5 PC+ Bir sonraki 3 PC FETCH CYCLE BİTER 24

LDA AA KOMUTUNUN MİMARİ ÜZERİNDE EXECUTE CYCLE AŞAMALARININ GÖSTERİMİ ADRES YOLU KOD HAFIZAS I 2 3A AA PC 2 ACC Kontrol birimi 38 A A 38 RD SİNYALİ GELİR 38 VERİ YOLU EXECUTE CYLE BİTER AA HB LB MAR EXECUTE(YÜRÜTME) CYCLE ADIM İŞLEM SONUÇ MAR içeriği adres yoluna AA Adres yoluna 2 AA nın içeriği veri yoluna 38 Veri Yolu 3 Veri yolundaki bilgi ACC ye yüklenir 38 Akümülatör Önemli Özellik: PC mikroişlemci ilk çalıştırılması için enerji verildiği anda kendini resetler ve daima adresinden okumaya başlar. 25

3.. 85 MİKROİŞLEMCİSİ Standart 85: 85 Intel firması tarafından, 98 lerin başında piyasaya sunulan, dünyanın en popüler 8-bit mikroişlemcisidir. Bu mikroişlemci için, başta Intel olmak üzere, pek çok üretici firma (Philips, Dallas, Siemens,Oki ve Matra/Harris gibi) geniş bir donanım ve yazılım desteği sunmuş ve bunun neticesi, 85, 98 lerden bugüne, bir endüstri standardı olmuştur. 85 ailesi bazen MCS-5 ailesi olarak da belirtilir. MCS harfleri, geleneksel olarak, Intel firmasının üretmiş olduğu, bir sistemi veya CPU lar, hafızalar, saat üreteçleri, giriş/ çıkış birimleri ve benzeri birimler içeren, mikrobilgisayar ve uyumlu parçaları (components) belirtmede kullanılmıştır. 85 ve MCS-5 ifadeleri, eş anlamlı olarak aynı aileyi belirtmek için kullanılmıştır ve genelde, bir işlemciyi belirtmeyip ailenin ismi olarak kullanılmaktadır. Bununla beraber, 85, MCS-5 ailesinin ilk üyelerinden olan, 85, 875 ve 83 mikroişlemcilerinden birinin de adıdır. Bugün için değişik mikroişlemci aileleri arasında, 85 ailesi, gelişmiş ürünleriyle beraber yaklaşık % 4 gibi bir piyasa payına sahiptir. Bu Derste 85 ailesinin anlatılmasının sebepleri: Çok kaynaklılık: Günümüzde çok değişik 85 işlemcisi üreten 7 üreticinin üzerinde firma bulunmakta ve sayısız yazılım ve bilgi kaynakları bulunmaktadır. Bazı 85 Ailesi üreticilerinden bazı örnekler: Intel (original) Atmel Philips/Signetics AMD Infineon (formerly Siemens) Matra Dallas Semiconductor/Maxim Popülerlik: Kolay bir şekilde bulunmakta ve desteklenmektedir. 85 geliştiricileri için birçok Internet Web sayfası, kitaplar, teknik dökümanlar, yazılım ve donanım gereçleri bulunmaktadır. Uygun, Hızlı ve güçlü: 85 çekirdek mimarisi hedef kontrol uygulamalar için çok uygun olup hızlı ve güçlüdür. 26

Geniş yelpaze ve uyumluluk: Çok değişik 85 ürünleri olmasına karşın, ikili kod düzeyinde bütün ürünler uyumludur (compatible). Diğer mikroişlemci aileleri, 85 in sunmuş olduklarını, farklı ve uyumsuz işlemcilerle (genellikle tek üretici firma kaynaklı olarak) ancak sağlayabilmektedir. Bu uyumluluk, kolaylık ve esneklik, program geliştirme araçlarında, eğitiminde ve yazılım desteğinde de bulunmaktadır. Sürekli iyileştirme: 98 lerden bugüne silikon ve tasarım olarak sürekli geliştirilen 85 ler hızını ve gücünü arttırmıştır. Günümüzde 6-bit modellerinin de bulunduğu 85 ler değişik kapasite, boyutlarda ve fiyatlarda kolay bir şekilde temin edilebilmektedir. 85 Intel firması tarafından üretilen MCS 5 ailesinin ilk mikroişlemcisi olup MCS 5 ürünlerinin temel çekirdeğidir. 85 mikrodenetleyicisinin temel özellikleri şunlardır: Kontrol uygulamalarına yönelik 8-bit CPU Yoğun Boolean işlemleri yapabilme (tek-bit lojik işlemler) özelliği 64K Program Hafıza (Program Memory) adres alanı 64K Veri Hafıza (Data Memory) adres alanı 4K tümdevre-üzeri (on-chip) Program Hafıza 28 byte tümdevre-üzeri veri RAM 32 tane iki yönlü adreslenebilir I/O hatları 2 tane 6-bit Zamanlayıcı/Sayıcı (Timer/Counter) Full duplex UART (Universal Asynchronous Receiver Transmitter) İki öncelik seviyesine sahip 6-kaynak / 5-vektörlü kesme donanım yapısı Uzun Boolean işlemleri yapılabilir. On-chip saat osilatörü. Şekil 9 da gösterildiği gibi temel 85 mimarisinde tüm devre üzerinde 4-kByte program hafıza ve 28- Byte veri hafıza mevcuttur. Ailenin sonraki üyelerinde hafıza değerleri zamanla artmıştır. Örneğin 852 mimarisinde 8-kByte program hafıza ve 256-Byte veri hafıza bulunur. 852 mikrodenetleyici mimarisinde aşağıda blok diyagramında gösterildiği gibi standart 85 e ilave olarak 28-Byte dahili veri hafıza (Toplam 256-Byte dahili RAM), Zamanlayıcı/Sayıcı-2 (Toplam 3 adet 6-bit Zamanlayıcı/Sayıcı) bulunur. 27

Harici Kesmeler INT INT Dahili Kesmeler Zamanlayıcı Kesmeleri Kesme Kontrol Seri Port Kesmesi 4-kByte Program Hafıza (ROM) SFR 28 Byte Veri Hafıza (Alt 28) Zamanlayıcı/Sayıcı Zamanlayıcı/Sayıcı 85 CPU OSC ve Zamanlama Ortak Yol Kontrolü Giriş/Çıkış Portları Seri Port XTAL XTAL2 PSEN ALE (a) P P2 P P3 TxD Seri Çıkış RxD Seri Giriş Harici Kesmeler INT INT Dahili Kesmeler Zamanlayıcı Kesmeleri Kesme Kontrol Seri Port Kesmesi 8-kByte Program Hafıza (ROM) SFR 256 Byte Veri Hafıza (Alt28 + Üst28) Zamanlayıcı/Sayıcı 2 Zamanlayıcı/Sayıcı Zamanlayıcı/Sayıcı 85 CPU OSC ve Zamanlama Ortak Yol Kontrolü Giriş/Çıkış Portları Seri Port XTAL XTAL2 PSEN ALE (b) P P2 P P3 TxD Seri Çıkış RxD Seri Giriş Şekil 9 85 (a) ve 852 (b) mikrodenetleyicilerine ait basitleştirilmiş blok diyagramı 28

3.2. Aduc84 Mikrodenetleyicisi Mikrodenetleyici mimarilerinde dahili olarak bulunan çevre birimleri endüstriyel uygulamalarda duyulan ihtiyaçlara ve teknolojik gelişmelere paralel olarak sürekli olarak gelişmekte ve yeni çevre birimleri mikrodenetleyici mimarilerine ilave edilmektedir. İlk olarak Intel firması tarafından 98 yılında üretilmeye başlanan 85 ailesi de sürekli olarak gelişmekte ve standart 85 mimarisinin temel özellikleri korunarak endüstriyel uygulamalardaki ihtiyaçlara cevap verebilecek 85 ailesinin yeni nesil üyeleri birçok firma tarafından üretilmektedir. Bu doğrultuda ADUC84 mimarisinde, yüksek hızlı analog giriş (ADC) analog çıkış (DAC) darbe genişlik modülasyon (Pulse Width Modulation, PWM) ilave hafıza (dahili XRAM, flash veri hafıza) Uzun ömürlü ( yıl) ve büyük kapasiteli Flash Program hafıza ilave kesme kaynakları yüksek hızlı haberleşme birimleri (I 2 C, SPI, CAN) kısır-döngü zamanlayıcısı (Watcdog Timer) besleme gerilimi izleme (Power Supply Monitor, PSM) uyku modu (Power-down) devre üzerinde programlanabilme (In System Programming, ISP) vb. bir çok özeliği barındıran 85 tabanlı mikrodenetleyiciler günümüzde çeşitli firmalar tarafından üretilmektedir. Aşağıda Analog Devices firması tarafından üretilen 852 tabanlı gelişmiş bir mikrodenetleyiciye (Aduc84) ait blok diyagram verilmiştir. 29

ADC ADC ADC6 ADC7 TEMP SENSOR MUX BAND GAP REFERANCE BUF T/H ADUC84/ADUC842/ADUC843 2-BIT ADC 62 kbytes PROGRAM FLASH/EE INCLUDING USER DOWNLOAD MODE 4 kbytes DATA FLASH/EE 2 kbytes USER XRAM 2 X DATA POINTERS -BIT STACK POINTER ADC CONTROL AND CALIBRATION 852 MCU CORE DAC CONTROL PWM CONTROL 2-BIT VOLTAGE OUTPUT DAC 2-BIT VOLTAGE OUTPUT DAC 256 BYTES USER RAM WATCHDOG TIMER POWER SUPPLY MONITOR 6-BIT Ʃ-Δ DAC 6-BIT Ʃ-Δ DAC 6-BIT PWM 6-BIT PWM 6 BIT COUNTER TIMERS MUX DAC DAC PWM PWM T T T2 T2EX INT DOWNLOADER DEBUGGER TIME INTERVAL COUNTER (WAKE-UP CCT) INT CREF POR ASYNCHRONOUS SERIAL PORT (UART) UART TIMER SINGLE-PIN EMULATOR SYNCHRONOUS SERIAL INTERFACE (I 2 C AND SPI) PLL OSC AVDD AGND DVDD DVDD DVDD DGND DGND DGND RESET RxD TxD ALE PSEN EA SCLOCK SDATA/MOSI MISO SS XTAL XTAL2 Şekil. Aduc84 blok diyagramı Ders süresince öncelikle temel 85 mikrodenetleyici çekirdeği, ardından Aduc84 mikrodenetleyicisi mimarisinde bulunan çevre birimleri detaylı olarak incelenecektir. Aduc84 mikrodenetleyicisi temel bazı özellikleri aşağıda belirtilmiştir. Endüstri standardı 85 mikrokontrolör mimari yapısı Tek-çevrim, 2 MIPS işlem hızı 62 kb a varan program belleği, 4 kb a varan Flash/EEPROM Data belleği Program ve veri hafızalarının devre üzerinde ( in-circuit ) programlanabilme özelliği 234 Byte dahili XRAM Yüksek doğrulukta yüksek hızda (42 ksps), 2-bit, 8- kanal ADC ADC için yüksek kararlıklı (5 ppm/ C) dahili gerilim referansı 2 adet 2-bit DAC Çift çıkışlı PWM Tümdevre üzeri sıcaklık izleme 2 öncelik seviyeli 2 kesme kaynağı Çift DPTR ve genişletilmiş (-bit) yığın (SP) I 2 C, SPI haberleşme birimleri 3

Kısır-döngü zamanlayıcısı (Watcdog Timer) Besleme gerilimi izleme (Power Supply Monitor, PSM) Enerji tasarrufu için uyku modu (Power-down) 3