Mikroprosesor - Panduan Cepat

Mikroprosesor adalah unit pengontrol mikro-komputer, dibuat pada chip kecil yang mampu melakukan operasi ALU (Arithmetic Logical Unit) dan berkomunikasi dengan perangkat lain yang terhubung dengannya.

Mikroprosesor terdiri dari ALU, array register, dan unit kontrol. ALU melakukan operasi aritmatika dan logis pada data yang diterima dari memori atau perangkat input. Register array terdiri dari register yang diidentifikasikan dengan huruf seperti B, C, D, E, H, L dan akumulator. Unit kontrol mengontrol aliran data dan instruksi di dalam komputer.

Diagram Blok dari Komputer Mikro Dasar

Bagaimana Cara Kerja Mikroprosesor?

Mikroprosesor mengikuti urutan: Fetch, Decode, dan Execute.

Awalnya, instruksi disimpan dalam memori secara berurutan. Mikroprosesor mengambil instruksi tersebut dari memori, kemudian mendekodekannya dan menjalankan instruksi tersebut sampai instruksi STOP tercapai. Kemudian, ia mengirimkan hasilnya dalam biner ke port keluaran. Di antara proses-proses ini, register menyimpan data sementara dan ALU melakukan fungsi komputasi.

Daftar Istilah yang Digunakan dalam Mikroprosesor

Berikut adalah daftar dari beberapa istilah yang sering digunakan dalam mikroprosesor -

  • Instruction Set - Ini adalah sekumpulan instruksi yang dapat dipahami oleh mikroprosesor.

  • Bandwidth - Ini adalah jumlah bit yang diproses dalam satu instruksi.

  • Clock Speed- Ini menentukan jumlah operasi per detik yang dapat dilakukan prosesor. Ini dinyatakan dalam megahertz (MHz) atau gigahertz (GHz). Ini juga dikenal sebagai Clock Rate.

  • Word Length- Tergantung pada lebar bus data internal, register, ALU, dll. Mikroprosesor 8-bit dapat memproses data 8-bit dalam satu waktu. Panjang kata berkisar dari 4 bit hingga 64 bit tergantung pada jenis komputer mikro.

  • Data Types - Mikroprosesor memiliki beberapa format tipe data seperti biner, BCD, ASCII, angka bertanda dan tidak bertanda.

Fitur Mikroprosesor

Berikut adalah daftar dari beberapa fitur yang paling menonjol dari setiap mikroprosesor -

  • Cost-effective - Chip mikroprosesor tersedia dengan harga rendah dan menghasilkan biaya rendah.

  • Size - Mikroprosesor adalah chip ukuran kecil, oleh karena itu portabel.

  • Low Power Consumption - Mikroprosesor diproduksi dengan menggunakan teknologi semikonduktor metaloksida, yang memiliki konsumsi daya rendah.

  • Versatility - Mikroprosesor serba guna karena kita dapat menggunakan chip yang sama di sejumlah aplikasi dengan mengkonfigurasi program perangkat lunak.

  • Reliability - Tingkat kegagalan sebuah IC pada mikroprosesor sangat rendah, sehingga dapat diandalkan.

Mikroprosesor dapat diklasifikasikan menjadi tiga kategori -

Prosesor RISC

RISC adalah singkatan dari Reduced Instruction Set Computer. Ini dirancang untuk mengurangi waktu eksekusi dengan menyederhanakan set instruksi komputer. Menggunakan prosesor RISC, setiap instruksi hanya membutuhkan satu siklus clock untuk mengeksekusi hasil dalam waktu eksekusi yang seragam. Ini mengurangi efisiensi karena ada lebih banyak baris kode, maka lebih banyak RAM diperlukan untuk menyimpan instruksi. Kompilator juga harus bekerja lebih keras untuk mengubah instruksi bahasa tingkat tinggi menjadi kode mesin.

Beberapa prosesor RISC adalah -

  • Power PC: 601, 604, 615, 620
  • DEC Alpha: 210642, 211066, 21068, 21164
  • MIPS: TS (R10000) Prosesor RISC
  • PA-RISC: HP 7100LC

Arsitektur RISC

Arsitektur mikroprosesor RISC menggunakan serangkaian instruksi yang sangat dioptimalkan. Ini digunakan pada perangkat portabel seperti Apple iPod karena efisiensi daya.

Karakteristik RISC

Karakteristik utama dari prosesor RISC adalah sebagai berikut -

  • Ini terdiri dari instruksi sederhana.

  • Ini mendukung berbagai format tipe data.

  • Ini menggunakan mode pengalamatan sederhana dan instruksi panjang tetap untuk pemipaan.

  • Ini mendukung register untuk digunakan dalam konteks apa pun.

  • Waktu eksekusi satu siklus.

  • Instruksi "LOAD" dan "STORE" digunakan untuk mengakses lokasi memori.

  • Ini terdiri dari jumlah register yang lebih besar.

  • Ini terdiri dari jumlah transistor yang lebih sedikit.

Prosesor CISC

CISC adalah singkatan dari Complex Instruction Set Computer. Ini dirancang untuk meminimalkan jumlah instruksi per program, mengabaikan jumlah siklus per instruksi. Penekanannya adalah membangun instruksi kompleks langsung ke perangkat keras.

Kompilator harus melakukan pekerjaan yang sangat sedikit untuk menerjemahkan bahasa tingkat tinggi ke bahasa tingkat perakitan / kode mesin karena panjang kode relatif pendek, sehingga sangat sedikit RAM yang diperlukan untuk menyimpan instruksi.

Beberapa Prosesor CISC adalah -

  • IBM 370/168
  • VAX 11/780
  • Intel 80486

Arsitektur CISC

Arsitekturnya dirancang untuk mengurangi biaya memori karena lebih banyak penyimpanan diperlukan dalam program yang lebih besar sehingga menghasilkan biaya memori yang lebih tinggi. Untuk mengatasi ini, jumlah instruksi per program dapat dikurangi dengan menanamkan jumlah operasi dalam satu instruksi.

Karakteristik CISC

  • Berbagai mode pengalamatan.
  • Jumlah instruksi yang lebih banyak.
  • Panjang variabel format instruksi.
  • Beberapa siklus mungkin diperlukan untuk menjalankan satu instruksi.
  • Logika instruksi-decoding itu rumit.
  • Satu instruksi diperlukan untuk mendukung beberapa mode pengalamatan.

Prosesor Khusus

Ini adalah prosesor yang dirancang untuk beberapa tujuan khusus. Beberapa prosesor khusus dibahas secara singkat -

Koprosesor

Koprosesor adalah mikroprosesor yang dirancang khusus, yang dapat menangani fungsi khususnya berkali-kali lebih cepat daripada mikroprosesor biasa.

For example - Math Coprocessor.

Beberapa prosesor matematika Intel adalah -

  • 8087-digunakan dengan 8086
  • 80287-digunakan dengan 80286
  • 80387-digunakan dengan 80386

Prosesor Input / Output

Ini adalah mikroprosesor yang dirancang khusus yang memiliki memori lokal sendiri, yang digunakan untuk mengontrol perangkat I / O dengan keterlibatan CPU minimum.

For example -

  • Pengontrol DMA (Direct Memory Access)
  • Pengontrol keyboard / mouse
  • Pengontrol tampilan grafis
  • Pengontrol port SCSI

Transputer (Komputer Transistor)

Transputer adalah mikroprosesor yang dirancang khusus dengan memori lokalnya sendiri dan memiliki tautan untuk menghubungkan satu transputer ke transputer lain untuk komunikasi antar prosesor. Ini pertama kali dirancang pada tahun 1980 oleh Inmos dan ditargetkan untuk pemanfaatan teknologi VLSI.

Transputer dapat digunakan sebagai sistem prosesor tunggal atau dapat dihubungkan ke tautan eksternal, yang mengurangi biaya konstruksi dan meningkatkan kinerja.

For example - 16-bit T212, 32-bit T425, prosesor floating point (T800, T805 & T9000).

DSP (Prosesor Sinyal Digital)

Prosesor ini dirancang khusus untuk mengolah sinyal analog menjadi bentuk digital. Ini dilakukan dengan mengambil sampel level tegangan pada interval waktu yang teratur dan mengubah tegangan pada saat itu juga ke dalam bentuk digital. Proses ini dilakukan oleh rangkaian yang disebut konverter analog ke digital, konverter A ke D atau ADC.

DSP berisi komponen berikut -

  • Program Memory - Ini menyimpan program yang akan digunakan DSP untuk memproses data.

  • Data Memory - Ini menyimpan informasi untuk diproses.

  • Compute Engine - Ia melakukan pemrosesan matematika, mengakses program dari memori program dan data dari memori data.

  • Input/Output - Terhubung ke dunia luar.

Aplikasinya adalah -

  • Sintesis suara dan musik
  • Kompresi audio dan video
  • Pemrosesan sinyal video
  • Akselerasi grafis 2D dan 3D.

For example - Seri TMS 320 Texas Instrument, misalnya, TMS 320C40, TMS320C50.

8085 diucapkan sebagai mikroprosesor "delapan puluh delapan puluh lima". Ini adalah mikroprosesor 8-bit yang dirancang oleh Intel pada tahun 1977 menggunakan teknologi NMOS.

Ini memiliki konfigurasi berikut -

  • Bus data 8-bit
  • Bus alamat 16-bit, yang dapat menangani hingga 64KB
  • Penghitung program 16-bit
  • Penunjuk tumpukan 16-bit
  • Enam register 8-bit disusun berpasangan: BC, DE, HL
  • Membutuhkan suplai + 5V untuk beroperasi pada clock fase tunggal 3,2 MHZ

Ini digunakan dalam mesin cuci, oven microwave, ponsel, dll.

8085 Mikroprosesor - Unit Fungsional

8085 terdiri dari unit fungsional berikut -

Aki

Ini adalah register 8-bit yang digunakan untuk melakukan operasi aritmatika, logika, I / O & LOAD / STORE. Terhubung ke bus data internal & ALU.

Aritmatika dan unit logika

Seperti namanya, ia melakukan operasi aritmatika dan logika seperti Penambahan, Pengurangan, DAN, OR, dll. Pada data 8-bit.

Register tujuan umum

Ada 6 register serba guna pada prosesor 8085, yaitu B, C, D, E, H & L. Setiap register dapat menampung data 8-bit.

Register ini dapat bekerja berpasangan untuk menyimpan data 16-bit dan kombinasi penyandingannya seperti BC, DE & HL.

Penghitung program

Ini adalah register 16-bit yang digunakan untuk menyimpan lokasi alamat memori dari instruksi berikutnya yang akan dieksekusi. Mikroprosesor menaikkan program setiap kali instruksi dijalankan, sehingga penghitung program menunjuk ke alamat memori dari instruksi berikutnya yang akan dieksekusi.

Penunjuk tumpukan

Ini juga merupakan register 16-bit yang berfungsi seperti tumpukan, yang selalu bertambah / berkurang 2 selama operasi push & pop.

Daftar sementara

Ini adalah register 8-bit, yang menyimpan data sementara dari operasi aritmatika dan logika.

Flag register

Ini adalah register 8-bit yang memiliki lima flip-flop 1-bit, yang menampung 0 atau 1 tergantung pada hasil yang disimpan dalam akumulator.

Ini adalah set 5 sandal jepit -

  • Tanda-tanda)
  • Nol (Z)
  • Auxiliary Carry (AC)
  • Paritas (P)
  • Bawa (C)

Posisi bitnya ditunjukkan pada tabel berikut -

D7 D6 D5 D4 D3 D2 D1 D0
S Z AC P. CY

Register instruksi dan decoder

Ini adalah register 8-bit. Ketika sebuah instruksi diambil dari memori maka itu disimpan dalam register Instruksi. Dekoder instruksi menerjemahkan informasi yang ada di register instruksi.

Pengaturan waktu dan unit kontrol

Ini memberikan sinyal waktu dan kontrol ke mikroprosesor untuk melakukan operasi. Berikut adalah sinyal waktu dan kontrol, yang mengontrol sirkuit eksternal dan internal -

  • Sinyal Kontrol: READY, RD ', WR', ALE
  • Sinyal Status: S0, S1, IO / M '
  • Sinyal DMA: HOLD, HLDA
  • RESET Sinyal: RESET IN, RESET OUT

Kontrol interupsi

Seperti namanya, ia mengontrol interupsi selama proses. Ketika mikroprosesor menjalankan program utama dan setiap kali terjadi interupsi, mikroprosesor menggeser kontrol dari program utama untuk memproses permintaan yang masuk. Setelah permintaan selesai, kontrol kembali ke program utama.

Ada 5 sinyal interupsi dalam 8085 mikroprosesor: INTR, RST 7.5, RST 6.5, RST 5.5, TRAP.

Kontrol Input / output Serial

Ini mengontrol komunikasi data serial dengan menggunakan dua instruksi berikut: SID (Serial input data) dan SOD (Serial output data).

Buffer alamat dan buffer alamat-data

Konten yang disimpan dalam penunjuk tumpukan dan penghitung program dimuat ke dalam buffer alamat dan buffer alamat-data untuk berkomunikasi dengan CPU. Memori dan chip I / O terhubung ke bus ini; CPU dapat menukar data yang diinginkan dengan memori dan chip I / O.

Bus alamat dan bus data

Bus data membawa data untuk disimpan. Ini dua arah, sedangkan bus alamat membawa lokasi ke tempat itu harus disimpan dan itu searah. Ini digunakan untuk mentransfer data & Address I / O perangkat.

8085 Arsitektur

Kami telah mencoba menggambarkan arsitektur 8085 dengan gambar berikut -

Gambar berikut menggambarkan diagram pin Mikroprosesor 8085 -

Pin mikroprosesor 8085 dapat diklasifikasikan menjadi tujuh kelompok -

Bus alamat

A15-A8, ini membawa alamat memori / IO 8-bit yang paling signifikan.

Bus data

AD7-AD0, ini membawa alamat 8-bit dan bus data yang paling tidak signifikan.

Kontrol dan sinyal status

Sinyal ini digunakan untuk mengidentifikasi sifat operasi. Ada 3 sinyal kontrol dan 3 sinyal status.

Tiga sinyal kontrol adalah RD, WR & ALE.

  • RD - Sinyal ini menunjukkan bahwa IO atau perangkat memori yang dipilih akan dibaca dan siap untuk menerima data yang tersedia pada bus data.

  • WR - Sinyal ini menunjukkan bahwa data pada bus data akan ditulis ke dalam memori atau lokasi IO yang dipilih.

  • ALE- Ini adalah pulsa positif yang dihasilkan ketika operasi baru dimulai oleh mikroprosesor. Ketika denyut nadi tinggi, itu menunjukkan alamat. Ketika denyut nadi turun itu menunjukkan data.

Tiga sinyal status adalah IO / M, S0 & S1.

IO / M

Sinyal ini digunakan untuk membedakan antara operasi IO dan Memori, yaitu ketika tinggi menunjukkan operasi IO dan ketika rendah maka itu menunjukkan operasi memori.

S1 & S0

Sinyal ini digunakan untuk mengidentifikasi jenis operasi saat ini.

Sumber Daya listrik

Ada 2 sinyal catu daya - VCC & VSS. VCC menunjukkan catu daya + 5v dan VSS menunjukkan sinyal ground.

Sinyal jam

Ada 3 sinyal clock, yaitu X1, X2, CLK OUT.

  • X1, X2- Kristal (RC, LC N / W) dihubungkan pada dua pin ini dan digunakan untuk mengatur frekuensi generator jam internal. Frekuensi ini secara internal dibagi 2.

  • CLK OUT - Sinyal ini digunakan sebagai jam sistem untuk perangkat yang terhubung dengan mikroprosesor.

Mengganggu & sinyal yang dimulai secara eksternal

Interupsi adalah sinyal yang dihasilkan oleh perangkat eksternal untuk meminta mikroprosesor melakukan suatu tugas. Ada 5 sinyal interupsi yaitu TRAP, RST 7.5, RST 6.5, RST 5.5, dan INTR. Kami akan membahas interupsi secara rinci di bagian interupsi.

  • INTA - Ini adalah sinyal pengakuan interupsi.

  • RESET IN - Sinyal ini digunakan untuk mengatur ulang mikroprosesor dengan mengatur penghitung program ke nol.

  • RESET OUT - Sinyal ini digunakan untuk mengatur ulang semua perangkat yang terhubung saat mikroprosesor diatur ulang.

  • READY- Sinyal ini menunjukkan bahwa perangkat siap mengirim atau menerima data. Jika READY rendah, maka CPU harus menunggu READY menjadi tinggi.

  • HOLD - Sinyal ini menunjukkan bahwa master lain sedang meminta penggunaan alamat dan bus data.

  • HLDA (HOLD Acknowledge)- Ini menunjukkan bahwa CPU telah menerima permintaan HOLD dan akan melepaskan bus pada siklus jam berikutnya. HLDA diset ke low setelah sinyal HOLD dihilangkan.

Sinyal I / O serial

Ada 2 sinyal serial yaitu SID dan SOD dan sinyal ini digunakan untuk komunikasi serial.

  • SOD (Jalur data keluaran serial) - SOD keluaran diatur / diatur ulang seperti yang ditentukan oleh instruksi SIM.

  • SID (Baris data input serial) - Data pada baris ini dimuat ke akumulator setiap kali instruksi RIM dijalankan.

Sekarang mari kita bahas mode pengalamatan di 8085 Mikroprosesor.

Mengatasi Mode di 8085

Ini adalah instruksi yang digunakan untuk mentransfer data dari satu register ke register lain, dari memori ke register, dan dari register ke memori tanpa perubahan apa pun pada konten. Mode pengalamatan di 8085 diklasifikasikan menjadi 5 kelompok -

Mode pengalamatan langsung

Dalam mode ini, data 8/16-bit ditentukan dalam instruksi itu sendiri sebagai salah satu operannya. For example: MVI K, 20F: berarti 20F disalin ke register K.

Daftarkan mode pengalamatan

Dalam mode ini, data disalin dari satu register ke register lainnya. For example: MOV K, B: berarti data pada register B disalin ke register K.

Mode pengalamatan langsung

Dalam mode ini, data langsung disalin dari alamat yang diberikan ke register. For example: LDB 5000K: berarti data di alamat 5000K disalin ke register B.

Mode pengalamatan tidak langsung

Dalam mode ini, data ditransfer dari satu register ke register lain dengan menggunakan alamat yang ditunjuk oleh register. For example: MOV K, B: berarti data ditransfer dari alamat memori yang ditunjukkan oleh register ke register K.

Mode pengalamatan tersirat

Mode ini tidak membutuhkan operan apa pun; data ditentukan oleh opcode itu sendiri.For example: CMP.

Menyela di 8085

Interupsi adalah sinyal yang dihasilkan oleh perangkat eksternal untuk meminta mikroprosesor melakukan suatu tugas. Ada 5 sinyal interupsi yaitu TRAP, RST 7.5, RST 6.5, RST 5.5, dan INTR.

Interupsi diklasifikasikan ke dalam grup berikut berdasarkan parameternya -

  • Vector interrupt - Dalam jenis interupsi ini, alamat interupsi diketahui oleh prosesor. For example: RST7.5, RST6.5, RST5.5, TRAP.

  • Non-Vector interrupt - Dalam jenis interupsi ini, alamat interupsi tidak diketahui oleh prosesor, sehingga alamat interupsi perlu dikirim secara eksternal oleh perangkat untuk melakukan interupsi. For example: INTR.

  • Maskable interrupt - Dalam jenis interupsi, kita dapat menonaktifkan interupsi dengan menulis beberapa instruksi ke dalam program. For example: RST7.5, RST6.5, RST5.5.

  • Non-Maskable interrupt - Dalam jenis interupsi, kita tidak dapat menonaktifkan interupsi dengan menulis beberapa instruksi ke dalam program. For example: PERANGKAP.

  • Software interrupt- Dalam jenis interupsi, pemrogram harus menambahkan instruksi ke dalam program untuk menjalankan interupsi. Ada 8 interupsi software di 8085, yaitu RST0, RST1, RST2, RST3, RST4, RST5, RST6, dan RST7.

  • Hardware interrupt - Terdapat 5 pin interupsi pada 8085 yang digunakan sebagai interupsi hardware, yaitu TRAP, RST7.5, RST6.5, RST5.5, INTA.

Note- NTA bukan interupsi, ini digunakan oleh mikroprosesor untuk mengirimkan pengakuan. TRAP memiliki prioritas tertinggi, kemudian RST7.5 dan seterusnya.

Interrupt Service Routine (ISR)

Program kecil atau rutinitas yang ketika dijalankan, melayani sumber interupsi yang sesuai disebut ISR.

PERANGKAP

Ini adalah interupsi yang tidak dapat ditutup-tutupi, memiliki prioritas tertinggi di antara semua interupsi. Secara default, ini diaktifkan sampai diakui. Jika terjadi kegagalan, ini dijalankan sebagai ISR ​​dan mengirim data ke memori cadangan. Interupsi ini mentransfer kontrol ke lokasi 0024H.

RST7.5

Ini adalah interupsi yang dapat ditutup-tutupi, memiliki prioritas tertinggi kedua di antara semua interupsi. Ketika interupsi ini dijalankan, prosesor menyimpan konten register PC ke dalam stack dan bercabang ke alamat 003CH.

RST 6.5

Ini adalah interupsi yang dapat ditutup-tutupi, memiliki prioritas tertinggi ketiga di antara semua interupsi. Ketika interupsi ini dijalankan, prosesor menyimpan konten register PC ke dalam stack dan bercabang ke alamat 0034H.

RST 5.5

Ini adalah interupsi yang dapat ditutup-tutupi. Ketika interupsi ini dijalankan, prosesor menyimpan konten register PC ke dalam stack dan bercabang ke alamat 002CH.

INTR

Ini adalah interupsi yang dapat ditutup-tutupi, memiliki prioritas terendah di antara semua interupsi. Ini dapat dinonaktifkan dengan mengatur ulang mikroprosesor.

Kapan INTR signal goes high, peristiwa berikut dapat terjadi -

  • Mikroprosesor memeriksa status sinyal INTR selama pelaksanaan setiap instruksi.

  • Ketika sinyal INTR tinggi, maka mikroprosesor menyelesaikan instruksi saat ini dan mengirimkan sinyal pengakuan interupsi rendah yang aktif.

  • Ketika instruksi diterima, maka mikroprosesor menyimpan alamat instruksi berikutnya pada stack dan menjalankan instruksi yang diterima.

Mari kita lihat pemrograman Mikroprosesor 8085.

Set instruksi adalah kode instruksi untuk melakukan beberapa tugas. Itu diklasifikasikan ke dalam lima kategori.

S.No. Instruksi & Deskripsi
1 Instruksi Kontrol

Berikut adalah tabel yang menunjukkan daftar instruksi Kontrol beserta artinya.

2 Instruksi Logis

Berikut adalah tabel yang menunjukkan daftar instruksi Logis beserta artinya.

3 Instruksi Percabangan

Berikut adalah tabel yang menunjukkan daftar instruksi Percabangan beserta artinya.

4 Instruksi Aritmatika

Berikut adalah tabel yang menunjukkan daftar instruksi Aritmatika beserta artinya.

5 Instruksi Transfer Data

Berikut adalah tabel yang menunjukkan daftar instruksi transfer data beserta artinya.

8085 - Program Demo

Sekarang, mari kita lihat beberapa demonstrasi program menggunakan petunjuk di atas -

Menambahkan Dua Angka 8-bit

Tulis program untuk menambahkan data di lokasi memori 3005H & 3006H dan simpan hasilnya di lokasi memori 3007H.

Problem demo -

(3005H) = 14H 
   (3006H) = 89H

Result -

14H + 89H = 9DH

Kode program dapat ditulis seperti ini -

LXI H 3005H   : "HL points 3005H" 
MOV A, M      : "Getting first operand" 
INX H         : "HL points 3006H" 
ADD M         : "Add second operand" 
INX H         : "HL points 3007H" 
MOV M, A      : "Store result at 3007H" 
HLT           : "Exit program"

Bertukar Lokasi Memori

Tulis program untuk menukar data pada lokasi memori 5000M & 6000M.

LDA 5000M   : "Getting the contents at5000M location into accumulator" 
MOV B, A    : "Save the contents into B register" 
LDA 6000M   : "Getting the contents at 6000M location into accumulator" 
STA 5000M   : "Store the contents of accumulator at address 5000M" 
MOV A, B    : "Get the saved contents back into A register" 
STA 6000M   : "Store the contents of accumulator at address 6000M"

Atur Angka dalam Urutan Naik

Tulis program untuk menyusun 10 angka pertama dari alamat memori 3000H dalam urutan menaik.

MVI B, 09         :"Initialize counter"      
START             :"LXI H, 3000H: Initialize memory pointer" 
MVI C, 09H        :"Initialize counter 2" 
BACK: MOV A, M    :"Get the number" 
INX H             :"Increment memory pointer" 
CMP M             :"Compare number with next number" 
JC SKIP           :"If less, don’t interchange" 
JZ SKIP           :"If equal, don’t interchange" 
MOV D, M 
MOV M, A 
DCX H 
MOV M, D 
INX H             :"Interchange two numbers" 
SKIP:DCR C        :"Decrement counter 2" 
JNZ BACK          :"If not zero, repeat" 
DCR B             :"Decrement counter 1" 
JNZ START 
HLT               :"Terminate program execution"

8086 Mikroprosesor adalah versi yang disempurnakan dari 8085Mikroprosesor yang dirancang oleh Intel pada tahun 1976. Ini adalah Mikroprosesor 16-bit yang memiliki 20 jalur alamat dan 16 jalur data yang menyediakan penyimpanan hingga 1MB. Ini terdiri dari set instruksi yang kuat, yang menyediakan operasi seperti perkalian dan pembagian dengan mudah.

Ini mendukung dua mode operasi, yaitu mode Maksimum dan mode Minimum. Mode maksimum cocok untuk sistem yang memiliki banyak prosesor dan mode Minimum cocok untuk sistem yang memiliki prosesor tunggal.

Fitur 8086

Fitur yang paling menonjol dari mikroprosesor 8086 adalah sebagai berikut -

  • Ini memiliki antrian instruksi, yang mampu menyimpan enam byte instruksi dari memori yang menghasilkan pemrosesan yang lebih cepat.

  • Itu adalah prosesor 16-bit pertama yang memiliki ALU 16-bit, register 16-bit, bus data internal, dan bus data eksternal 16-bit yang menghasilkan pemrosesan lebih cepat.

  • Ini tersedia dalam 3 versi berdasarkan frekuensi operasi -

    • 8086 → 5MHz

    • 8086-2 → 8MHz

    • (c) 8086-1 → 10 MHz

  • Ini menggunakan dua tahap pipelining, yaitu Tahap Ambil dan Tahap Eksekusi, yang meningkatkan kinerja.

  • Tahap pengambilan dapat mengambil lebih dulu hingga 6 byte instruksi dan menyimpannya dalam antrian.

  • Jalankan tahap menjalankan instruksi ini.

  • Ini memiliki 256 interupsi vektor.

  • Ini terdiri dari 29.000 transistor.

Perbandingan antara 8085 & 8086 Mikroprosesor

  • Size - 8085 adalah mikroprosesor 8-bit, sedangkan 8086 adalah mikroprosesor 16-bit.

  • Address Bus - 8085 memiliki bus alamat 16-bit sedangkan 8086 memiliki bus alamat 20-bit.

  • Memory - 8085 dapat mengakses hingga 64Kb, sedangkan 8086 dapat mengakses memori hingga 1 Mb.

  • Instruction - 8085 tidak memiliki antrian instruksi, sedangkan 8086 memiliki antrian instruksi.

  • Pipelining - 8085 tidak mendukung arsitektur pipelined sedangkan 8086 mendukung arsitektur pipelined.

  • I/O - 8085 dapat menangani 2 ^ 8 = 256 I / O, sedangkan 8086 dapat mengakses 2 ^ 16 = 65.536 I / O.

  • Cost - Biaya 8085 rendah sedangkan 8086 mahal.

Arsitektur 8086

Diagram berikut menggambarkan arsitektur Mikroprosesor 8086 -

Mikroprosesor 8086 dibagi menjadi dua unit fungsional, yaitu, EU (Unit Eksekusi) dan BIU (Unit Antarmuka Bus).

EU (Unit Eksekusi)

Unit eksekusi memberikan instruksi kepada BIU yang menyatakan dari mana mengambil data dan kemudian mendekode dan menjalankan instruksi tersebut. Fungsinya untuk mengontrol operasi pada data menggunakan instruksi decoder & ALU. EU tidak memiliki koneksi langsung dengan bus sistem seperti yang ditunjukkan pada gambar di atas, EU menjalankan operasi melalui data melalui BIU.

Sekarang mari kita bahas bagian fungsional dari mikroprosesor 8086.

ALU

Ini menangani semua operasi aritmatika dan logika, seperti operasi +, -, ×, /, OR, AND, NOT.

Tandai Register

Ini adalah register 16-bit yang berperilaku seperti flip-flop, yaitu mengubah statusnya sesuai dengan hasil yang disimpan di akumulator. Ini memiliki 9 bendera dan mereka dibagi menjadi 2 kelompok - Bendera Bersyarat dan Bendera Kontrol.

Bendera Bersyarat

Ini mewakili hasil aritmatika terakhir atau instruksi logis yang dieksekusi. Berikut adalah daftar bendera bersyarat -

  • Carry flag - Bendera ini menunjukkan kondisi luapan untuk operasi aritmatika.

  • Auxiliary flag- Ketika operasi dilakukan di ALU, itu menghasilkan carry / barrow dari nibble bawah (yaitu D0 - D3) ke nibble atas (yaitu D4 - D7), maka flag ini diset, yaitu carry yang diberikan oleh bit D3 ke D4 adalah Bendera AF. Prosesor menggunakan tanda ini untuk melakukan konversi biner ke BCD.

  • Parity flag- Bendera ini digunakan untuk menunjukkan paritas hasil, yaitu ketika urutan 8-bit hasil yang lebih rendah berisi angka genap 1, maka Bendera Paritas ditetapkan. Untuk angka ganjil 1, Bendera Paritas disetel ulang.

  • Zero flag - Bendera ini disetel ke 1 jika hasil operasi aritmatika atau logika adalah nol, jika tidak disetel ke 0.

  • Sign flag - Flag ini menyimpan tanda hasil, yaitu jika hasil operasi negatif, maka tanda tanda diset ke 1 dan setel ke 0.

  • Overflow flag - Bendera ini mewakili hasil ketika kapasitas sistem terlampaui.

Bendera Kontrol

Bendera kontrol mengontrol operasi unit eksekusi. Berikut ini adalah daftar bendera kontrol -

  • Trap flag- Digunakan untuk kontrol satu langkah dan memungkinkan pengguna untuk menjalankan satu instruksi pada satu waktu untuk debugging. Jika sudah diatur, maka program dapat dijalankan dalam mode satu langkah.

  • Interrupt flag- Ini adalah tanda aktifkan / nonaktifkan interupsi, yaitu digunakan untuk mengizinkan / melarang interupsi program. Ini diatur ke 1 untuk kondisi aktifkan interupsi dan ke 0 untuk kondisi nonaktif interupsi.

  • Direction flag- Ini digunakan dalam operasi string. Seperti namanya ketika diset maka byte string diakses dari alamat memori yang lebih tinggi ke alamat memori yang lebih rendah dan sebaliknya.

Register tujuan umum

Ada 8 register serba guna yaitu AH, AL, BH, BL, CH, CL, DH, dan DL. Register ini dapat digunakan secara individual untuk menyimpan data 8-bit dan dapat digunakan berpasangan untuk menyimpan data 16bit. Pasangan register yang valid adalah AH dan AL, BH dan BL, CH dan CL, serta DH dan DL. Ini dirujuk ke AX, BX, CX, dan DX masing-masing.

  • AX register- Ini juga dikenal sebagai register akumulator. Ini digunakan untuk menyimpan operan untuk operasi aritmatika.

  • BX register- Ini digunakan sebagai register dasar. Ini digunakan untuk menyimpan alamat dasar awal dari area memori di dalam segmen data.

  • CX register- Ini disebut sebagai counter. Ini digunakan dalam instruksi loop untuk menyimpan penghitung loop.

  • DX register - Register ini digunakan untuk menyimpan alamat port I / O untuk instruksi I / O.

Register penunjuk tumpukan

Ini adalah register 16-bit, yang menyimpan alamat dari awal segmen ke lokasi memori, di mana sebuah kata terakhir disimpan di stack.

BIU (Unit Antarmuka Bus)

BIU menangani semua data dan transfer alamat di bus untuk UE seperti alamat pengiriman, mengambil instruksi dari memori, membaca data dari port dan memori serta menulis data ke port dan memori. UE tidak memiliki koneksi penunjuk arah dengan Bus Sistem sehingga hal ini dimungkinkan dengan BIU. EU dan BIU terhubung dengan Bus Internal.

Ini memiliki bagian fungsional berikut -

  • Instruction queue- BIU berisi antrian instruksi. BIU mendapatkan hingga 6 byte dari instruksi berikutnya dan menyimpannya dalam antrian instruksi. Ketika EU menjalankan instruksi dan siap untuk instruksi berikutnya, maka EU hanya membaca instruksi dari antrian instruksi ini sehingga kecepatan eksekusi meningkat.

  • Mengambil instruksi berikutnya saat instruksi saat ini dijalankan dipanggil pipelining.

  • Segment register- BIU memiliki 4 bus segmen yaitu CS, DS, SS & ES. Ini menyimpan alamat instruksi dan data dalam memori, yang digunakan oleh prosesor untuk mengakses lokasi memori. Ini juga berisi 1 register penunjuk IP, yang menyimpan alamat dari instruksi selanjutnya untuk dieksekusi oleh UE.

    • CS- Itu singkatan dari Code Segment. Ini digunakan untuk menangani lokasi memori di segmen kode memori, di mana program yang dapat dieksekusi disimpan.

    • DS- Itu singkatan dari Data Segment. Ini terdiri dari data yang digunakan oleh program dan diakses di segmen data dengan alamat offset atau isi register lain yang menyimpan alamat offset.

    • SS- Itu singkatan dari Stack Segment. Ini menangani memori untuk menyimpan data dan alamat selama eksekusi.

    • ES- Itu singkatan dari Segmen Ekstra. ES adalah segmen data tambahan, yang digunakan oleh string untuk menampung data tujuan tambahan.

  • Instruction pointer - Ini adalah register 16-bit yang digunakan untuk menyimpan alamat dari instruksi selanjutnya yang akan dieksekusi.

8086 adalah mikroprosesor 16-bit pertama yang tersedia dalam chip DIP (Dual Inline Package) 40-pin. Sekarang mari kita bahas secara rinci konfigurasi pin dari Mikroprosesor 8086.

Diagram Pin 8086

Berikut adalah diagram pin mikroprosesor 8086 -

Sekarang mari kita bahas sinyal secara rinci -

Power supply and frequency signals

Ini menggunakan suplai 5V DC pada V CC pin 40, dan menggunakan ground pada V SS pin 1 dan 20 untuk operasinya.

Clock signal

Sinyal jam disediakan melalui Pin-19. Ini memberikan waktu ke prosesor untuk operasi. Frekuensinya berbeda untuk versi yang berbeda, yaitu 5MHz, 8MHz dan 10MHz.

Address/data bus

AD0-AD15. Ini adalah 16 bus alamat / data. AD0-AD7 membawa data byte orde rendah dan AD8AD15 membawa data byte orde tinggi. Selama siklus clock pertama, ia membawa alamat 16-bit dan setelah itu ia membawa data 16-bit.

Address/status bus

A16-A19 / S3-S6. Ini adalah 4 bus alamat / status. Selama siklus clock pertama, ia membawa alamat 4-bit dan kemudian membawa sinyal status.

S7/BHE

BHE adalah singkatan dari Bus High Enable. Ini tersedia di pin 34 dan digunakan untuk menunjukkan transfer data menggunakan bus data D8-D15. Sinyal ini rendah selama siklus jam pertama, setelah itu aktif.

Read($\overline{RD}$)

Ini tersedia di pin 32 dan digunakan untuk membaca sinyal untuk operasi Baca.

Ready

Ini tersedia di pin 22. Ini adalah sinyal pengakuan dari perangkat I / O bahwa data ditransfer. Ini adalah sinyal tinggi aktif. Jika tinggi, ini menunjukkan bahwa perangkat siap mentransfer data. Ketika rendah, ini menunjukkan status tunggu.

RESET

Ini tersedia di pin 21 dan digunakan untuk memulai kembali eksekusi. Ini menyebabkan prosesor segera menghentikan aktivitasnya saat ini. Sinyal ini aktif tinggi selama 4 siklus jam pertama untuk RESET mikroprosesor.

INTR

Ini tersedia di pin 18. Ini adalah sinyal permintaan interupsi, yang diambil sampelnya selama siklus clock terakhir dari setiap instruksi untuk menentukan apakah prosesor menganggap ini sebagai interupsi atau tidak.

NMI

Ini adalah singkatan dari non-maskable interrupt dan tersedia di pin 17. Ini adalah input edge triggered, yang menyebabkan permintaan interupsi ke mikroprosesor.

$\overline{TEST}$

Sinyal ini seperti status menunggu dan tersedia di pin 23. Ketika sinyal ini tinggi, maka prosesor harus menunggu status IDLE, jika tidak eksekusi dilanjutkan.

MN/$\overline{MX}$

Ini singkatan dari Minimum / Maximum dan tersedia di pin 33. Ini menunjukkan mode prosesor untuk beroperasi; bila tinggi, ia bekerja dalam mode minimum dan sebaliknya.

INTA

Ini adalah sinyal pengakuan interupsi dan id tersedia di pin 24. Ketika mikroprosesor menerima sinyal ini, ia mengakui interupsi.

ALE

Ini singkatan dari address enable latch dan tersedia di pin 25. Pulsa positif dihasilkan setiap kali prosesor memulai operasi apa pun. Sinyal ini menunjukkan ketersediaan alamat yang valid pada alamat / jalur data.

DEN

Itu singkatan dari Data Enable dan tersedia di pin 26. Ini digunakan untuk mengaktifkan Transreceiver 8286. Transreceiver adalah perangkat yang digunakan untuk memisahkan data dari alamat / bus data.

DT/R

Ini adalah singkatan dari Data Transmit / Receive signal dan tersedia di pin 27. Ini menentukan arah aliran data melalui transreceiver. Ketika tinggi, data ditransmisikan keluar dan sebaliknya.

M/IO

Sinyal ini digunakan untuk membedakan antara memori dan operasi I / O. Ketika tinggi, ini menunjukkan operasi I / O dan ketika rendah menunjukkan operasi memori. Ini tersedia di pin 28.

WR

Ini singkatan dari sinyal tulis dan tersedia di pin 29. Ini digunakan untuk menulis data ke dalam memori atau perangkat keluaran tergantung pada status sinyal M / IO.

HLDA

Ini adalah singkatan dari sinyal Hold Acknowledgement dan tersedia di pin 30. Sinyal ini mengakui sinyal HOLD.

HOLD

Sinyal ini menunjukkan kepada prosesor bahwa perangkat eksternal meminta untuk mengakses bus alamat / data. Ini tersedia di pin 31.

QS1 and QS0

Ini adalah sinyal status antrian dan tersedia di pin 24 dan 25. Sinyal ini memberikan status antrian instruksi. Kondisinya ditunjukkan pada tabel berikut -

QS 0 QS 1 Status
0 0 Tidak ada operasi
0 1 Byte pertama opcode dari antrian
1 0 Kosongkan antrian
1 1 Byte berikutnya dari antrian

S0, S1, S2

Ini adalah sinyal status yang memberikan status operasi, yang digunakan oleh Pengontrol Bus 8288 untuk menghasilkan sinyal kontrol memori & I / O. Ini tersedia di pin 26, 27, dan 28. Berikut adalah tabel yang menunjukkan statusnya -

S 2 S 1 S 0 Status
0 0 0 Interupsi pengakuan
0 0 1 I / O Read
0 1 0 I / O Write
0 1 1 Berhenti
1 0 0 Pengambilan opcode
1 0 1 Memori dibaca
1 1 0 Menulis memori
1 1 1 Pasif

LOCK

Ketika sinyal ini aktif, ini menunjukkan kepada prosesor lain untuk tidak meminta CPU meninggalkan bus sistem. Ini diaktifkan menggunakan awalan LOCK pada instruksi apa pun dan tersedia di pin 29.

RQ/GT1 and RQ/GT0

Ini adalah sinyal Request / Grant yang digunakan oleh prosesor lain yang meminta CPU untuk melepaskan bus sistem. Ketika sinyal diterima oleh CPU, kemudian mengirimkan pengakuan. RQ / GT 0 memiliki prioritas lebih tinggi daripada RQ / GT 1 .

Mikroprosesor 8086 mendukung 8 jenis instruksi -

  • Instruksi Transfer Data
  • Instruksi Aritmatika
  • Instruksi Manipulasi Bit
  • Instruksi String
  • Instruksi Transfer Eksekusi Program (Instruksi Cabang & Loop)
  • Instruksi Kontrol Prosesor
  • Instruksi Kontrol Iterasi
  • Instruksi Interupsi

Mari kita sekarang membahas set instruksi ini secara rinci.

Instruksi Transfer Data

Instruksi ini digunakan untuk mentransfer data dari operan sumber ke operan tujuan. Berikut adalah daftar instruksi di bawah grup ini -

Instruksi untuk mentransfer kata

  • MOV - Digunakan untuk menyalin byte atau kata dari sumber yang disediakan ke tujuan yang diberikan.

  • PPUSH - Digunakan untuk meletakkan kata di bagian atas tumpukan.

  • POP - Digunakan untuk mendapatkan kata dari atas tumpukan ke lokasi yang disediakan.

  • PUSHA - Digunakan untuk meletakkan semua register ke dalam stack.

  • POPA - Digunakan untuk mendapatkan kata-kata dari tumpukan ke semua register.

  • XCHG - Digunakan untuk bertukar data dari dua lokasi.

  • XLAT - Digunakan untuk menerjemahkan byte dalam AL menggunakan tabel di memori.

Petunjuk untuk transfer port input dan output

  • IN - Digunakan untuk membaca byte atau word dari port yang disediakan ke akumulator.

  • OUT - Digunakan untuk mengirimkan byte atau word dari akumulator ke port yang disediakan.

Instruksi untuk mentransfer alamat

  • LEA - Digunakan untuk memuat alamat operan ke register yang disediakan.

  • LDS - Digunakan untuk memuat register DS dan register lain yang disediakan dari memori

  • LES - Digunakan untuk memuat register ES dan register lain yang disediakan dari memori.

Instruksi untuk mentransfer register bendera

  • LAHF - Digunakan untuk memuat AH dengan byte rendah dari register flag.

  • SAHF - Digunakan untuk menyimpan register AH ke byte rendah dari register flag.

  • PUSHF - Digunakan untuk menyalin register bendera di bagian atas tumpukan.

  • POPF - Digunakan untuk menyalin kata di bagian atas tumpukan ke register bendera.

Instruksi Aritmatika

Instruksi ini digunakan untuk melakukan operasi aritmatika seperti penjumlahan, pengurangan, perkalian, pembagian, dll.

Berikut adalah daftar instruksi di bawah grup ini -

Instruksi untuk melakukan penjumlahan

  • ADD - Digunakan untuk menambahkan byte ke byte / kata ke kata yang disediakan.

  • ADC - Digunakan untuk menambahkan barang bawaan.

  • INC - Digunakan untuk menambah byte / kata yang disediakan sebesar 1.

  • AAA - Digunakan untuk mengatur ASCII setelah penambahan.

  • DAA - Digunakan untuk mengatur desimal setelah operasi penambahan / pengurangan.

Instruksi untuk melakukan pengurangan

  • SUB - Digunakan untuk mengurangi byte dari byte / kata dari kata.

  • SBB - Digunakan untuk melakukan pengurangan dengan meminjam.

  • DEC - Digunakan untuk mengurangi byte / kata yang disediakan sebesar 1.

  • NPG - Digunakan untuk meniadakan setiap bit dari byte / kata yang disediakan dan menambahkan komplemen 1/2.

  • CMP - Digunakan untuk membandingkan 2 byte / kata yang disediakan.

  • AAS - Digunakan untuk menyesuaikan kode ASCII setelah pengurangan.

  • DAS - Digunakan untuk mengatur desimal setelah pengurangan.

Instruksi untuk melakukan perkalian

  • MUL - Digunakan untuk mengalikan byte unsigned dengan byte / kata demi kata.

  • IMUL - Digunakan untuk mengalikan byte yang ditandatangani dengan byte / kata demi kata.

  • AAM - Digunakan untuk menyesuaikan kode ASCII setelah perkalian.

Instruksi untuk melakukan divisi

  • DIV - Digunakan untuk membagi kata unsigned dengan byte atau unsigned double kata demi kata.

  • IDIV - Digunakan untuk membagi kata yang ditandatangani dengan byte atau ditandatangani kata ganda demi kata.

  • AAD - Digunakan untuk menyesuaikan kode ASCII setelah pembagian.

  • CBW - Digunakan untuk mengisi byte atas kata dengan salinan bit tanda dari byte bawah.

  • CWD - Digunakan untuk mengisi kata atas dari kata ganda dengan tanda bit pada kata bagian bawah.

Instruksi Manipulasi Bit

Instruksi ini digunakan untuk melakukan operasi di mana bit data terlibat, yaitu operasi seperti logika, shift, dll.

Berikut adalah daftar instruksi di bawah grup ini -

Instruksi untuk melakukan operasi logis

  • NOT - Digunakan untuk membalikkan setiap bit atau kata.

  • AND - Digunakan untuk menambahkan setiap bit dalam byte / kata dengan bit terkait dalam byte / kata lain.

  • OR - Digunakan untuk mengalikan setiap bit dalam satu byte / kata dengan bit yang sesuai dalam byte / kata lain.

  • XOR - Digunakan untuk melakukan operasi Exclusive-OR pada setiap bit dalam satu byte / kata dengan bit yang sesuai dalam byte / kata lain.

  • TEST - Digunakan untuk menambahkan operan untuk mengupdate flag, tanpa mempengaruhi operand.

Instruksi untuk melakukan operasi shift

  • SHL/SAL - Digunakan untuk menggeser bit dari byte / word ke kiri dan meletakkan nol (S) di LSB.

  • SHR - Digunakan untuk menggeser bit dari byte / word ke arah kanan dan menempatkan nol (S) di MSB.

  • SAR - Digunakan untuk menggeser bit byte / word ke arah kanan dan menyalin MSB lama ke MSB baru.

Instruksi untuk melakukan operasi rotasi

  • ROL - Digunakan untuk memutar bit byte / word ke arah kiri, yaitu MSB ke LSB dan untuk Membawa Bendera [CF].

  • ROR - Digunakan untuk memutar bit byte / word ke arah kanan, yaitu LSB ke MSB dan untuk Membawa Bendera [CF].

  • RCR - Digunakan untuk memutar bit byte / word ke arah kanan, yaitu LSB ke CF dan CF ke MSB.

  • RCL - Digunakan untuk memutar bit byte / word ke arah kiri, yaitu MSB ke CF dan CF ke LSB.

Instruksi String

String adalah sekelompok byte / kata dan memorinya selalu dialokasikan dalam urutan yang berurutan.

Berikut adalah daftar instruksi di bawah grup ini -

  • REP - Digunakan untuk mengulang instruksi yang diberikan sampai CX ≠ 0.

  • REPE/REPZ - Digunakan untuk mengulang instruksi yang diberikan sampai CX = 0 atau bendera nol ZF = 1.

  • REPNE/REPNZ - Digunakan untuk mengulang instruksi yang diberikan sampai CX = 0 atau bendera nol ZF = 1.

  • MOVS/MOVSB/MOVSW - Digunakan untuk memindahkan byte / kata dari satu string ke string lainnya.

  • COMS/COMPSB/COMPSW - Digunakan untuk membandingkan dua string byte / kata.

  • INS/INSB/INSW - Digunakan sebagai string input / byte / kata dari port I / O ke lokasi memori yang disediakan.

  • OUTS/OUTSB/OUTSW - Digunakan sebagai string / byte / kata keluaran dari lokasi memori yang disediakan ke port I / O.

  • SCAS/SCASB/SCASW - Digunakan untuk memindai string dan membandingkan byte-nya dengan byte di AL atau kata string dengan kata di AX.

  • LODS/LODSB/LODSW - Digunakan untuk menyimpan string byte ke AL ​​atau kata string ke AX.

Instruksi Transfer Eksekusi Program (Instruksi Cabang dan Loop)

Instruksi ini digunakan untuk mentransfer / mencabangkan instruksi selama eksekusi. Ini termasuk instruksi berikut -

Instruksi untuk mentransfer instruksi selama eksekusi tanpa syarat apapun -

  • CALL - Digunakan untuk memanggil prosedur dan menyimpan alamat pengirimnya ke stack.

  • RET - Digunakan untuk kembali dari prosedur ke program utama.

  • JMP - Digunakan untuk melompat ke alamat yang diberikan untuk melanjutkan ke instruksi berikutnya.

Instruksi untuk mentransfer instruksi selama eksekusi dengan beberapa kondisi -

  • JA/JNBE - Digunakan untuk melompat jika instruksi di atas / tidak di bawah / sama memuaskan.

  • JAE/JNB - Digunakan untuk melompat jika instruksi di atas / tidak di bawah memuaskan.

  • JBE/JNA - Digunakan untuk melompat jika instruksi di bawah / sama / tidak di atas memuaskan.

  • JC - Digunakan untuk melompat jika membawa bendera CF = 1

  • JE/JZ - Digunakan untuk melompat jika sama dengan / nol bendera ZF = 1

  • JG/JNLE - Digunakan untuk melompat jika instruksi lebih besar / tidak kurang dari / sama memuaskan.

  • JGE/JNL - Digunakan untuk melompat jika lebih besar dari / sama / tidak kurang dari instruksi yang memuaskan.

  • JL/JNGE - Digunakan untuk melompat jika instruksi kurang dari / tidak lebih dari / sama memuaskan.

  • JLE/JNG - Digunakan untuk melompat jika kurang dari / sama / jika tidak lebih besar dari instruksi yang memuaskan.

  • JNC - Digunakan untuk melompat jika tidak ada bendera carry (CF = 0)

  • JNE/JNZ - Digunakan untuk melompat jika tidak sama / bendera nol ZF = 0

  • JNO - Digunakan untuk melompat jika tidak ada flag overflow OF = 0

  • JNP/JPO - Digunakan untuk melompat jika tidak paritas / paritas ganjil PF = 0

  • JNS - Digunakan untuk melompat jika tidak masuk SF = 0

  • JO - Digunakan untuk melompat jika bendera meluap OF = 1

  • JP/JPE - Digunakan untuk melompat jika paritas / paritas genap PF = 1

  • JS - Digunakan untuk melompat jika tanda bendera SF = 1

Instruksi Kontrol Prosesor

Instruksi ini digunakan untuk mengontrol tindakan prosesor dengan mengatur / mengatur ulang nilai bendera.

Berikut adalah instruksi di bawah grup ini -

  • STC - Digunakan untuk mengatur carry flag CF ke 1

  • CLC - Digunakan untuk menghapus / mengatur ulang bendera pembawa CF ke 0

  • CMC - Digunakan untuk menempatkan komplemen di negara bagian carry flag CF.

  • STD - Digunakan untuk mengatur arah flag DF ke 1

  • CLD - Digunakan untuk menghapus / mereset flag arah DF ke 0

  • STI - Digunakan untuk menyetel flag pengaktifan interupsi ke 1, yakni mengaktifkan input INTR.

  • CLI - Digunakan untuk menghapus flag pengaktifan interupsi ke 0, yaitu menonaktifkan input INTR.

Instruksi Kontrol Iterasi

Instruksi ini digunakan untuk menjalankan instruksi yang diberikan beberapa kali. Berikut adalah daftar instruksi di bawah grup ini -

  • LOOP - Digunakan untuk mengulang sekelompok instruksi sampai kondisi terpenuhi, yaitu CX = 0

  • LOOPE/LOOPZ - Digunakan untuk mengulang sekelompok instruksi sampai memenuhi ZF = 1 & CX = 0

  • LOOPNE/LOOPNZ - Digunakan untuk mengulang sekelompok instruksi sampai memenuhi ZF = 0 & CX = 0

  • JCXZ - Digunakan untuk melompat ke alamat yang diberikan jika CX = 0

Instruksi Interupsi

Instruksi ini digunakan untuk memanggil interupsi selama eksekusi program.

  • INT - Digunakan untuk menginterupsi program selama eksekusi dan layanan panggilan yang ditentukan.

  • INTO - Digunakan untuk menginterupsi program selama eksekusi jika OF = 1

  • IRET - Digunakan untuk kembali dari layanan interupsi ke program utama

Interruptadalah metode untuk membuat penghentian sementara selama eksekusi program dan memungkinkan perangkat periferal mengakses mikroprosesor. Mikroprosesor menanggapi interupsi itu denganISR (Interrupt Service Routine), yaitu program singkat untuk menginstruksikan mikroprosesor tentang cara menangani interupsi.

Gambar berikut menunjukkan jenis interupsi yang kami miliki di mikroprosesor 8086 -

Interupsi Perangkat Keras

Interupsi perangkat keras disebabkan oleh perangkat periferal apa pun dengan mengirimkan sinyal melalui pin tertentu ke mikroprosesor.

8086 memiliki dua pin interupsi perangkat keras, yaitu NMI dan INTR. NMI adalah interupsi non-maskable dan INTR adalah interupsi maskable yang memiliki prioritas lebih rendah. Satu lagi pin interupsi yang terkait adalah INTA yang disebut interrupt confirm.

NMI

Ini adalah pin interupsi non-maskable tunggal (NMI) yang memiliki prioritas lebih tinggi daripada pin permintaan interupsi maskable (INTR) dan merupakan interupsi tipe 2.

Saat interupsi ini diaktifkan, tindakan ini terjadi -

  • Menyelesaikan instruksi saat ini yang sedang berlangsung.

  • Mendorong nilai register Flag ke stack.

  • Mendorong nilai CS (segmen kode) dan nilai IP (penunjuk instruksi) dari alamat pengirim ke stack.

  • IP diambil dari isi lokasi kata 00008H.

  • CS diambil dari isi lokasi kata berikutnya 0000AH.

  • Bendera interupsi dan bendera perangkap disetel ulang ke 0.

INTR

INTR adalah interupsi yang dapat ditutup karena mikroprosesor akan diinterupsi hanya jika interupsi diaktifkan menggunakan instruksi set interrupt flag. Ini tidak boleh diaktifkan menggunakan instruksi Clear interrupt Flag.

Interupsi INTR diaktifkan oleh port I / O. Jika interupsi diaktifkan dan NMI dinonaktifkan, maka mikroprosesor pertama-tama menyelesaikan eksekusi saat ini dan mengirim '0' pada pin INTA dua kali. '0' pertama berarti INTA memberi tahu perangkat eksternal untuk bersiap-siap dan selama '0' kedua mikroprosesor menerima 8 bit, katakanlah X, dari pengontrol interupsi yang dapat diprogram.

Tindakan ini dilakukan oleh mikroprosesor -

  • Pertama, selesaikan instruksi saat ini.

  • Mengaktifkan keluaran INTA dan menerima jenis interupsi, misalnya X.

  • Nilai register bendera, nilai CS dari alamat pengirim dan nilai IP dari alamat pengirim didorong ke tumpukan.

  • Nilai IP diambil dari isi lokasi kata X × 4

  • CS diambil dari isi lokasi kata berikutnya.

  • Bendera interupsi dan bendera perangkap disetel ulang ke 0

Interupsi Perangkat Lunak

Beberapa instruksi disisipkan pada posisi yang diinginkan ke dalam program untuk membuat interupsi. Instruksi interupsi ini dapat digunakan untuk menguji kerja berbagai penangan interupsi. Ini termasuk -

INT- Instruksi interupsi dengan nomor tipe

Ini adalah instruksi 2-byte. Byte pertama memberikan kode op dan byte kedua memberikan nomor tipe interupsi. Ada 256 jenis interupsi di bawah grup ini.

Eksekusinya meliputi langkah-langkah berikut -

  • Nilai register bendera didorong ke tumpukan.

  • Nilai CS dari alamat pengirim dan nilai IP dari alamat pengirim didorong ke tumpukan.

  • IP diambil dari isi lokasi kata 'jenis nomor' × 4

  • CS diambil dari isi lokasi kata berikutnya.

  • Interrupt Flag dan Trap Flag di-reset ke 0

Alamat awal untuk interupsi tipe0 adalah 000000H, untuk interupsi tipe1 adalah 00004H demikian pula untuk tipe2 adalah 00008H dan …… seterusnya. Lima petunjuk pertama adalah petunjuk interupsi khusus. yaitu -

  • TYPE 0 interupsi merupakan pembagian dengan situasi nol.

  • TYPE 1 interrupt merupakan eksekusi satu langkah selama debugging program.

  • TYPE 2 interrupt merupakan interupsi NMI yang tidak dapat ditutup-tutupi.

  • TYPE 3 interrupt merupakan interupsi break-point.

  • TYPE 4 interrupt merupakan interupsi overflow.

Interupsi dari Tipe 5 hingga Tipe 31 disediakan untuk mikroprosesor tingkat lanjut lainnya, dan interupsi dari 32 hingga Tipe 255 tersedia untuk interupsi perangkat keras dan perangkat lunak.

Instruksi Interupsi Titik Istirahat INT 3

Ini adalah instruksi 1-byte yang memiliki op-code CCH. Instruksi ini dimasukkan ke dalam program sehingga ketika prosesor sampai di sana, kemudian menghentikan eksekusi normal program dan mengikuti prosedur break-point.

Eksekusinya meliputi langkah-langkah berikut -

  • Nilai register bendera didorong ke tumpukan.

  • Nilai CS dari alamat pengirim dan nilai IP dari alamat pengirim didorong ke tumpukan.

  • IP diambil dari isi lokasi kata 3 × 4 = 0000CH

  • CS diambil dari isi lokasi kata berikutnya.

  • Interrupt Flag dan Trap Flag di-reset ke 0

INTO - Interupsi pada instruksi overflow

Ini adalah instruksi 1-byte dan mnemonik mereka INTO. Kode op untuk instruksi ini adalah CEH. Seperti namanya, ini adalah instruksi interupsi bersyarat, yaitu hanya aktif ketika flag overflow disetel ke 1 dan bercabang ke penangan interupsi yang nomor tipe interupsi 4. Jika flag overflow di-reset kemudian, eksekusi dilanjutkan ke instruksi selanjutnya.

Eksekusinya meliputi langkah-langkah berikut -

  • Nilai register bendera didorong ke tumpukan.

  • Nilai CS dari alamat pengirim dan nilai IP dari alamat pengirim didorong ke tumpukan.

  • IP diambil dari isi lokasi kata 4 × 4 = 00010H

  • CS diambil dari isi lokasi kata berikutnya.

  • Bendera interupsi dan bendera Perangkap disetel ulang ke 0

Cara berbeda di mana operan sumber dilambangkan dalam instruksi yang dikenal sebagai addressing modes. Ada 8 mode pengalamatan berbeda dalam pemrograman 8086 -

Mode pengalamatan langsung

Mode pengalamatan di mana operan data adalah bagian dari instruksi itu sendiri yang dikenal sebagai mode pengalamatan langsung.

Contoh

MOV CX, 4929 H, ADD AX, 2387 H,  MOV AL, FFH

Daftarkan mode pengalamatan

Artinya register adalah sumber operan untuk sebuah instruksi.

Contoh

MOV CX, AX   ; copies the contents of the 16-bit AX register into  
             ; the 16-bit CX register),  
ADD BX, AX

Mode pengalamatan langsung

Modus pengalamatan di mana alamat efektif dari lokasi memori ditulis langsung dalam instruksi.

Contoh

MOV AX, [1592H], MOV AL, [0300H]

Daftarkan mode pengalamatan tidak langsung

Mode pengalamatan ini memungkinkan data untuk dialamatkan di setiap lokasi memori melalui alamat offset yang disimpan di salah satu register berikut: BP, BX, DI & SI.

Contoh

MOV AX, [BX]  ; Suppose the register BX contains 4895H, then the contents  
              ; 4895H are moved to AX 
ADD CX, {BX}

Modus pengalamatan berbasis

Dalam mode pengalamatan ini, alamat offset dari operan diberikan oleh jumlah konten register BX / BP dan perpindahan 8-bit / 16-bit.

Contoh

MOV DX, [BX+04], ADD CL, [BX+08]

Mode pengalamatan yang diindeks

Dalam mode pengalamatan ini, alamat offset operan ditemukan dengan menambahkan konten register SI atau DI dan perpindahan 8-bit / 16-bit.

Contoh

MOV BX, [SI+16], ADD AL, [DI+16]

Mode pengalamatan berbasis indeks

Dalam mode pengalamatan ini, alamat offset dari operan dihitung dengan menjumlahkan register dasar ke isi register Indeks.

Contoh

ADD CX, [AX+SI], MOV AX, [AX+DI]

Berbasis diindeks dengan mode perpindahan

Dalam mode pengalamatan ini, offset operan dihitung dengan menambahkan konten register dasar. Indeks mendaftarkan konten dan perpindahan 8 atau 16-bit.

Contoh

MOV AX, [BX+DI+08], ADD CX, [BX+SI+16]

Multiprosesor berarti sekumpulan prosesor yang menjalankan instruksi secara bersamaan. Ada tiga konfigurasi multiprosesor dasar.

  • Konfigurasi koprosesor
  • Konfigurasi yang sangat erat
  • Konfigurasi yang digabungkan secara longgar

Konfigurasi Coprocessor

Coprocessor adalah sirkuit yang dirancang khusus pada chip mikroprosesor yang dapat melakukan tugas yang sama dengan sangat cepat, yang dilakukan oleh mikroprosesor. Ini mengurangi beban kerja prosesor utama. Koprosesor berbagi memori yang sama, sistem IO, bus, logika kontrol, dan generator jam. Coprocessor menangani tugas-tugas khusus seperti kalkulasi matematika, tampilan grafis di layar, dll.

8086 dan 8088 dapat melakukan sebagian besar operasi tetapi set instruksinya tidak dapat melakukan operasi matematika yang kompleks, sehingga dalam kasus ini mikroprosesor memerlukan koprosesor matematika seperti koprosesor matematika Intel 8087, yang dapat dengan mudah melakukan operasi ini dengan sangat cepat.

Diagram Blok dari Konfigurasi Koprosesor

Bagaimana koprosesor dan prosesor terhubung?

  • Koprosesor dan prosesor dihubungkan melalui sinyal TEST, RQ- / GT- dan QS 0 & QS 1 .

  • Sinyal TEST dihubungkan ke pin BUSY koprosesor dan 3 pin sisanya dihubungkan ke 3 pin koprosesor dengan nama yang sama.

  • Sinyal TEST menangani aktivitas koprosesor, yaitu koprosesor sedang sibuk atau idle.

  • RT- / GT-digunakan untuk arbitrase bus.

  • Coprocessor menggunakan QS 0 & QS 1 untuk melacak status antrian prosesor host.

Konfigurasi yang Digabungkan Secara Dekat

Konfigurasi yang digabungkan secara erat mirip dengan konfigurasi koprosesor, yaitu keduanya berbagi memori yang sama, bus sistem I / O, logika kontrol, dan generator kontrol dengan prosesor host. Namun, koprosesor dan prosesor host mengambil dan menjalankan instruksinya sendiri. Bus sistem dikendalikan oleh koprosesor dan prosesor host secara independen.

Diagram Blok dari Konfigurasi yang Digabungkan Secara Dekat

Bagaimana prosesor dan prosesor independen terhubung?

  • Komunikasi antara host dan prosesor independen dilakukan melalui ruang memori.

  • Tidak ada instruksi yang digunakan untuk komunikasi, seperti WAIT, ESC, dll.

  • Prosesor host mengelola memori dan membangunkan prosesor independen dengan mengirimkan perintah ke salah satu portnya.

  • Kemudian prosesor independen mengakses memori untuk menjalankan tugas.

  • Setelah menyelesaikan tugas, ia mengirimkan pengakuan ke prosesor host dengan menggunakan sinyal status atau permintaan interupsi.

Konfigurasi yang Digabungkan Secara Longgar

Konfigurasi yang digabungkan secara longgar terdiri dari jumlah modul sistem berbasis mikroprosesor, yang dihubungkan melalui bus sistem umum. Setiap modul terdiri dari generator jam, memori, perangkat I / O mereka sendiri dan terhubung melalui bus lokal.

Diagram Blok dari Konfigurasi yang Digabungkan Secara Longgar

Keuntungan

  • Memiliki lebih dari satu prosesor menghasilkan peningkatan efisiensi.

  • Setiap prosesor memiliki bus lokalnya sendiri untuk mengakses memori / perangkat I / O lokal. Ini membuatnya mudah untuk mencapai pemrosesan paralel.

  • Struktur sistem bersifat fleksibel, yaitu kegagalan satu modul tidak mempengaruhi kegagalan sistem secara keseluruhan; modul yang rusak dapat diganti nanti.

8087 prosesor data numerik juga dikenal sebagai Math co-processor, Numeric processor extension dan Floating point unit. Itu adalah koprosesor matematika pertama yang dirancang oleh Intel untuk dipasangkan dengan 8086/8088 sehingga menghasilkan perhitungan yang lebih mudah dan lebih cepat.

Setelah instruksi diidentifikasi oleh prosesor 8086/8088, maka itu dialokasikan ke prosesor bersama 8087 untuk eksekusi lebih lanjut.

Tipe data yang didukung oleh 8087 adalah -

  • Integer Biner
  • Bilangan desimal yang dikemas
  • Bilangan real
  • Format nyata sementara

Fitur yang paling menonjol dari prosesor data numerik 8087 adalah sebagai berikut -

  • Ini mendukung data tipe integer, float, dan tipe real mulai dari 2-10 byte.

  • Kecepatan pemrosesan sangat tinggi sehingga dapat menghitung perkalian dua bilangan real 64-bit dalam ~ 27 µs dan juga dapat menghitung akar kuadrat dalam ~ 35 µs.

  • Ini mengikuti standar titik mengambang IEEE.

8087 Arsitektur

8087 Arsitektur dibagi menjadi dua kelompok, yaitu Control Unit (CU) dan Numeric Extension Unit (NEU).

  • Itu control unit menangani semua komunikasi antara prosesor dan memori seperti menerima dan mendekode instruksi, membaca dan menulis operan memori, memelihara antrian paralel, dll. Semua instruksi koprosesor adalah instruksi ESC, yaitu, dimulai dengan 'F', hanya koprosesor menjalankan instruksi ESC sementara instruksi lain dijalankan oleh mikroprosesor.

  • Itu numeric extension unitmenangani semua instruksi prosesor numerik seperti aritmatika, logika, transendental, dan instruksi transfer data. Ini memiliki 8 tumpukan register, yang menyimpan operan untuk instruksi dan hasilnya.

Arsitektur koprosesor 8087 adalah sebagai berikut -

8087 Deskripsi Pin

Mari kita lihat diagram pin 8087 -

Daftar berikut menyediakan Deskripsi Pin 8087 -

  • AD0 – AD15 - Ini adalah jalur alamat / data multipleks waktu, yang membawa alamat selama siklus jam pertama dan data dari siklus jam kedua dan seterusnya.

  • A19 / S6 – A16/S- Baris ini adalah baris alamat / status multiplexing waktu. Ini berfungsi dengan cara yang mirip dengan pin yang sesuai pada 8086. S 6 , S 4 dan S3 secara permanen tinggi, sedangkan S 5 secara permanen rendah.

  • $\overline{BHE}$/S7 - Selama siklus jam pertama, file $\overline{BHE}$/ S 7 digunakan untuk mengaktifkan data ke byte yang lebih tinggi dari bus data 8086 dan setelah itu berfungsi sebagai baris status S 7 .

  • QS1, QS0 - Ini adalah sinyal input status antrian yang memberikan status antrian instruksi, kondisinya seperti yang ditunjukkan pada tabel berikut -

QS 0 QS 1 Status
0 0 Tidak ada operasi
0 1 Byte pertama opcode dari antrian
1 0 Kosongkan antrian
1 1 Byte berikutnya dari antrian
  • INT - Ini adalah sinyal interupsi, yang berubah menjadi tinggi ketika pengecualian tanpa kedok telah diterima selama eksekusi.

  • BUSY - Ini adalah sinyal keluaran, ketika tinggi itu menunjukkan status sibuk ke CPU.

  • READY - Ini adalah sinyal input yang digunakan untuk menginformasikan koprosesor apakah bus siap menerima data atau tidak.

  • RESET - Ini adalah sinyal input yang digunakan untuk menolak aktivitas internal koprosesor dan mempersiapkannya untuk eksekusi lebih lanjut kapan pun diperlukan oleh CPU.

  • CLK - Input CLK memberikan pengaturan waktu dasar untuk operasi prosesor.

  • VCC - Ini adalah sinyal catu daya, yang membutuhkan pasokan + 5V untuk pengoperasian rangkaian.

  • S0, S1, S2- Ini adalah sinyal status yang memberikan status operasi yang digunakan oleh Pengontrol Bus 8087 untuk menghasilkan memori dan sinyal kontrol I / O. Sinyal-sinyal ini aktif selama siklus clock keempat.

S 2 S 1 S 0 Status Antrian
0 X X Tidak terpakai
1 0 0 Tidak terpakai
1 0 1 Memori dibaca
1 1 0 Menulis memori
1 1 1 Pasif
  • RQ/GT1 & RQ/GT0 - Ini adalah Request/Grant sinyal yang digunakan oleh prosesor 8087 untuk mendapatkan kendali bus dari prosesor host 8086/8088 untuk transfer operan.

Pada bab ini, kita akan membahas Memory Interfacing dan IO Interfacing dengan 8085.

Interfaceadalah jalur komunikasi antara dua komponen. Antarmuka terdiri dari dua jenis, antarmuka memori dan antarmuka I / O.

Antarmuka Memori

Ketika kita menjalankan instruksi apa pun, kita membutuhkan mikroprosesor untuk mengakses memori untuk membaca kode instruksi dan data yang disimpan dalam memori. Untuk ini, baik memori dan mikroprosesor membutuhkan beberapa sinyal untuk membaca dan menulis ke register.

Proses interfacing mencakup beberapa faktor kunci untuk menyesuaikan dengan kebutuhan memori dan sinyal mikroprosesor. Oleh karena itu, rangkaian antarmuka harus dirancang sedemikian rupa sehingga sesuai dengan persyaratan sinyal memori dengan sinyal mikroprosesor.

Antarmuka IO

Ada berbagai perangkat komunikasi seperti keyboard, mouse, printer, dll. Jadi, kita perlu menghubungkan keyboard dan perangkat lain dengan mikroprosesor dengan menggunakan latch dan buffer. Jenis antarmuka ini dikenal sebagai antarmuka I / O.

Diagram Blok Memori dan Antarmuka I / O

8085 Pin Antarmuka

Berikut ini adalah daftar 8085 pin yang digunakan untuk berinteraksi dengan perangkat lain -

  • A 15 - A 8 (Bus Alamat Lebih Tinggi)
  • AD 7 - AD 0 (Alamat Bawah / Bus Data)
  • ALE
  • RD
  • WR
  • READY

Cara Komunikasi - Mikroprosesor dengan Dunia Luar?

Ada dua cara komunikasi di mana mikroprosesor dapat terhubung dengan dunia luar.

  • Antarmuka Komunikasi Serial
  • Antarmuka Komunikasi Paralel

Serial Communication Interface - Dalam jenis komunikasi ini, antarmuka mendapatkan satu byte data dari mikroprosesor dan mengirimkannya sedikit demi sedikit ke sistem lain secara serial dan sebaliknya.

Parallel Communication Interface - Dalam jenis komunikasi ini, antarmuka mendapatkan satu byte data dari mikroprosesor dan mengirimkannya sedikit demi sedikit ke sistem lain secara simultan (atau) paralel dan sebaliknya.

8279 keyboard yang dapat diprogram / pengontrol tampilan dirancang oleh Intel yang menghubungkan keyboard dengan CPU. Pertama-tama, keyboard memindai keyboard dan mengidentifikasi apakah ada tombol yang telah ditekan. Kemudian mengirimkan respons relatif mereka dari tombol yang ditekan ke CPU dan sebaliknya.

Berapa Banyak Cara Antarmuka Keyboard dengan CPU?

Keyboard dapat dihubungkan baik dalam mode interupsi atau polling. DalamInterrupt mode, prosesor diminta diservis hanya jika ada tombol yang ditekan, jika tidak, CPU akan melanjutkan tugas utamanya.

Dalam Polled mode, CPU secara berkala membaca tanda internal 8279 untuk memeriksa apakah ada tombol yang ditekan atau tidak dengan tekanan tombol.

Bagaimana Cara Kerja Keyboard 8279?

Keyboard terdiri dari maksimal 64 tombol, yang dihubungkan dengan CPU dengan menggunakan kode kunci. Kode-kode kunci ini dipantulkan dan disimpan dalam FIFORAM 8-byte, yang dapat diakses oleh CPU. Jika FIFO lebih dari 8 karakter, berarti lebih dari delapan tombol yang ditekan dalam satu waktu. Ini adalah saat status overrun ditetapkan.

Jika FIFO berisi entri kunci yang valid, maka CPU diinterupsi dalam mode interupsi, jika tidak CPU memeriksa status dalam polling untuk membaca entri. Setelah CPU membaca entri kunci, lalu FIFO diperbarui, dan entri kunci didorong keluar dari FIFO untuk menghasilkan ruang untuk entri baru.

Arsitektur dan Deskripsi

Kontrol I / O dan Buffer Data

Unit ini mengontrol aliran data melalui mikroprosesor. Ini diaktifkan hanya ketika D rendah. Penyangga datanya menghubungkan bus eksternal sistem dengan bus internal mikroprosesor. Pin A0, RD, dan WR digunakan untuk perintah, status, atau operasi baca / tulis data.

Kontrol dan Pendaftaran Waktu dan Kontrol Waktu

Unit ini berisi register untuk menyimpan keyboard, mode tampilan, dan operasi lain seperti yang diprogram oleh CPU. Unit pengaturan waktu dan kontrol menangani pengaturan waktu untuk pengoperasian sirkuit.

Penghitung Pindai

Ini memiliki dua mode yaitu Encoded modedan mode Decoded. Dalam mode enkode, penghitung menyediakan jumlah biner yang akan didekodekan secara eksternal untuk menyediakan garis pemindaian untuk keyboard dan tampilan.

Dalam decoded scan mode, penghitung secara internal mendekode 2 bit paling tidak signifikan dan menyediakan pemindaian 1 dari 4 yang diterjemahkan pada SL 0 -SL 3 .

Kembali Buffer, Keyboard Debounce, dan Kontrol

Unit ini pertama-tama memindai penutupan kunci baris, jika ditemukan maka unit pantulan keyboard menghapus entri kunci. Jika kunci yang sama terdeteksi, maka kode kunci tersebut langsung ditransfer ke RAM sensor bersama dengan status tombol SHIFT & CONTROL.

FIFO / Sensor RAM dan Status Logic

Unit ini bertindak sebagai RAM 8-byte first-in-first-out (FIFO) di mana kode kunci dari setiap tombol yang ditekan dimasukkan ke dalam RAM sesuai urutannya. Logika status menghasilkan permintaan interupsi setelah setiap operasi pembacaan FIFO sampai FIFO kosong.

Dalam mode scan sensor matrix, unit ini bertindak sebagai RAM sensor dimana setiap barisnya dimuat dengan status baris sensor yang sesuai ke dalam matriks. Ketika sensor mengubah statusnya, garis IRQ berubah menjadi tinggi dan mengganggu CPU.

Register Alamat Tampilan dan RAM Tampilan

Unit ini terdiri dari register alamat tampilan yang menyimpan alamat kata yang saat ini dibaca / ditulis oleh CPU ke / dari RAM tampilan.

8279 - Deskripsi Pin

Gambar berikut menunjukkan diagram pin 8279 -

Jalur Bus Data, DB 0 - DB 7

Ini adalah 8 jalur bus data dua arah yang digunakan untuk mentransfer data ke / dari CPU.

CLK

Input jam digunakan untuk menghasilkan pengaturan waktu internal yang dibutuhkan oleh mikroprosesor.

SETEL ULANG

Seperti namanya pin ini digunakan untuk mereset mikroprosesor.

Pilih Chip CS

Saat pin ini disetel ke rendah, ini memungkinkan operasi baca / tulis, jika tidak pin ini harus disetel ke tinggi.

A 0

Pin ini menunjukkan transfer informasi perintah / status. Ketika rendah, ini menunjukkan transfer data.

RD, WR

Pin Baca / Tulis ini memungkinkan buffer data untuk mengirim / menerima data melalui bus data.

IRQ

Jalur keluaran interupsi ini menjadi tinggi ketika ada data dalam RAM sensor FIFO. Garis interupsi menjadi rendah dengan setiap operasi pembacaan RAM FIFO. Namun, jika FIFO RAM lebih lanjut berisi entri kode kunci apa pun untuk dibaca oleh CPU, pin ini lagi-lagi menjadi tinggi untuk menghasilkan interupsi ke CPU.

V ss , V cc

Ini adalah jalur ground dan power supply dari mikroprosesor.

SL 0 - SL 3

Ini adalah garis pindai yang digunakan untuk memindai matriks keyboard dan menampilkan digitnya. Baris-baris ini dapat diprogram sebagai dikodekan atau didekodekan, menggunakan register kontrol mode.

RL 0 - RL 7

Ini adalah Garis Kembali yang terhubung ke satu terminal kunci, sedangkan terminal kunci lainnya terhubung ke jalur pindai yang diterjemahkan. Garis-garis ini diset ke 0 bila ada tombol yang ditekan.

BERGESER

Status baris input Shift disimpan bersama dengan setiap kode kunci dalam FIFO dalam mode keyboard yang dipindai. Sampai itu ditarik rendah dengan penutup kunci, itu ditarik ke atas secara internal agar tetap tinggi

CNTL / STB - CONTROL / STROBED I / P Mode

Dalam mode keyboard, baris ini digunakan sebagai input kontrol dan disimpan dalam FIFO pada penutupan tombol. Garis adalah garis strobo yang memasukkan data ke dalam FIFO RAM, dalam mode input strobed. Ini memiliki tarikan internal. Garis ditarik ke bawah dengan penutup kunci.

BD

Itu singkatan dari tampilan kosong. Ini digunakan untuk mengosongkan tampilan selama perpindahan digit.

OUTA 0 - OUTA 3 dan OUTB 0 - OUTB 3

Ini adalah port keluaran untuk dua register penyegaran tampilan internal 16x4 atau satu 16x8. Data dari garis-garis ini disinkronkan dengan garis pindai untuk memindai tampilan dan keyboard.

Mode Operasional 8279

Ada dua mode operasi pada 8279 - Input Mode dan Output Mode.

Mode Masukan

Mode ini berkaitan dengan input yang diberikan oleh keyboard dan mode ini selanjutnya diklasifikasikan menjadi 3 mode.

  • Scanned Keyboard Mode- Dalam mode ini, matriks kunci dapat dihubungkan menggunakan pemindaian yang dikodekan atau didekodekan. Dalam pemindaian yang disandikan, keyboard 8 × 8 atau dalam pemindaian yang diterjemahkan, keyboard 4 × 8 dapat dihubungkan. Kode kunci yang ditekan dengan status SHIFT dan CONTROL disimpan ke dalam FIFO RAM.

  • Scanned Sensor Matrix- Dalam mode ini, larik sensor dapat dihubungkan dengan prosesor menggunakan pemindaian encoder atau decoder. Dalam pemindaian encoder, matriks sensor 8 × 8 atau dengan pemindaian decoder matriks sensor 4 × 8 dapat dihubungkan.

  • Strobed Input - Dalam mode ini, ketika garis kontrol diatur ke 0, data pada garis kembali disimpan dalam FIFO byte demi byte.

Mode Keluaran

Mode ini berhubungan dengan operasi yang berhubungan dengan tampilan. Mode ini selanjutnya diklasifikasikan menjadi dua mode keluaran.

  • Display Scan - Mode ini memungkinkan tampilan multipleks 8/16 karakter untuk diatur sebagai unit tampilan ganda 4-bit / tunggal 8-bit.

  • Display Entry - Mode ini memungkinkan data dimasukkan untuk ditampilkan baik dari sisi kanan / kiri.

DMA adalah singkatan dari Direct Memory Access. Ini dirancang oleh Intel untuk mentransfer data dengan kecepatan tercepat. Ini memungkinkan perangkat untuk mentransfer data secara langsung ke / dari memori tanpa gangguan apa pun dari CPU.

Dengan menggunakan pengontrol DMA, perangkat meminta CPU untuk menyimpan data, alamat, dan bus kontrolnya, sehingga perangkat bebas untuk mentransfer data secara langsung ke / dari memori. Transfer data DMA dimulai hanya setelah menerima sinyal HLDA dari CPU.

Bagaimana Operasi DMA Dilakukan?

Berikut adalah urutan operasi yang dilakukan oleh DMA -

  • Awalnya, ketika perangkat harus mengirim data antara perangkat dan memori, perangkat harus mengirim permintaan DMA (DRQ) ke pengontrol DMA.

  • Pengontrol DMA mengirimkan permintaan Hold (HRQ) ke CPU dan menunggu CPU untuk menegaskan HLDA.

  • Kemudian mikroprosesor melakukan tri-state semua bus data, bus alamat, dan bus kontrol. CPU meninggalkan kendali atas bus dan menerima permintaan HOLD melalui sinyal HLDA.

  • Sekarang CPU dalam status HOLD dan pengontrol DMA harus mengelola operasi melalui bus antara CPU, memori, dan perangkat I / O.

Fitur 8257

Berikut adalah daftar dari beberapa fitur utama dari 8257 -

  • Ini memiliki empat saluran yang dapat digunakan lebih dari empat perangkat I / O.

  • Setiap saluran memiliki alamat 16-bit dan penghitung 14-bit.

  • Setiap saluran dapat mentransfer data hingga 64kb.

  • Setiap saluran dapat diprogram secara mandiri.

  • Setiap saluran dapat melakukan transfer baca, transfer tulis, dan verifikasi operasi transfer.

  • Ini menghasilkan sinyal MARK ke perangkat periferal bahwa 128 byte telah ditransfer.

  • Ini membutuhkan jam fase tunggal.

  • Frekuensinya berkisar dari 250Hz hingga 3MHz.

  • Ini beroperasi dalam 2 mode, yaitu, Master mode dan Slave mode.

8257 Arsitektur

Gambar berikut menunjukkan arsitektur 8257 -

8257 Deskripsi Pin

Gambar berikut menunjukkan diagram pin dari pengontrol 8257 DMA -

DRQ 0 −DRQ3

Ini adalah empat input permintaan DMA saluran individu, yang digunakan oleh perangkat periferal untuk menggunakan layanan DMA. Ketika mode prioritas tetap dipilih, maka DRQ 0 memiliki prioritas tertinggi dan DRQ 3 memiliki prioritas terendah di antara keduanya.

DACK o - DACK 3

Ini adalah garis pengakuan DMA rendah aktif, yang memperbarui perangkat yang meminta tentang status permintaan mereka oleh CPU. Garis ini juga dapat bertindak sebagai garis strobo untuk perangkat yang meminta.

D o - D 7

Ini adalah jalur data dua arah yang digunakan untuk menghubungkan bus sistem dengan bus data internal pengontrol DMA. Dalam mode Slave, ia membawa kata-kata perintah ke 8257 dan kata status dari 8257. Dalam mode master, baris-baris ini digunakan untuk mengirim byte yang lebih tinggi dari alamat yang dihasilkan ke latch. Alamat ini selanjutnya dikunci menggunakan sinyal ADSTB.

IOR

Ini adalah jalur input tri-state dua arah aktif-rendah, yang digunakan oleh CPU untuk membaca register internal 8257 dalam mode Slave. Dalam mode master, digunakan untuk membaca data dari perangkat periferal selama siklus penulisan memori.

IOW

Ini adalah jalur tri-state dua arah rendah aktif, yang digunakan untuk memuat konten bus data ke register mode 8-bit atau byte atas / bawah dari register alamat DMA 16-bit atau register jumlah terminal. Dalam mode master, ini digunakan untuk memuat data ke perangkat periferal selama siklus baca memori DMA.

CLK

Ini adalah sinyal frekuensi clock yang diperlukan untuk operasi internal 8257.

SETEL ULANG

Sinyal ini digunakan untuk RESET pengontrol DMA dengan menonaktifkan semua saluran DMA.

A o - A 3

Ini adalah empat baris alamat yang paling tidak signifikan. Dalam mode slave, mereka bertindak sebagai input, yang memilih salah satu register untuk dibaca atau ditulis. Dalam mode master, mereka adalah empat baris keluaran alamat memori yang paling tidak signifikan yang dihasilkan oleh 8257.

CS

Ini adalah jalur pilih chip aktif-rendah. Dalam mode Slave, ini memungkinkan operasi baca / tulis ke / dari 8257. Dalam mode master, ini menonaktifkan operasi baca / tulis ke / dari 8257.

A 4 - A 7

Ini adalah gigitan yang lebih tinggi dari alamat byte bawah yang dihasilkan oleh DMA dalam mode master.

SIAP

Ini adalah sinyal input asinkron tinggi aktif, yang membuat DMA siap dengan memasukkan status tunggu.

HRQ

Sinyal ini digunakan untuk menerima sinyal permintaan tunggu dari perangkat keluaran. Dalam mode slave, ini terhubung dengan jalur input DRQ 8257. Dalam mode Master, ini terhubung dengan input HOLD dari CPU.

HLDA

Ini adalah sinyal pengakuan tahan yang menunjukkan pengontrol DMA bahwa bus telah diberikan ke periferal yang meminta oleh CPU ketika diatur ke 1.

MEMR

Ini adalah sinyal baca memori rendah, yang digunakan untuk membaca data dari lokasi memori yang dialamatkan selama siklus baca DMA.

MEMW

Ini adalah sinyal tiga status aktif-rendah yang digunakan untuk menulis data ke lokasi memori yang dialamatkan selama operasi tulis DMA.

ADST

Sinyal ini digunakan untuk mengubah byte yang lebih tinggi dari alamat memori yang dihasilkan oleh pengontrol DMA menjadi latch.

AEN

Sinyal ini digunakan untuk menonaktifkan bus alamat / bus data.

TC

Ini adalah singkatan dari 'Terminal Count', yang menunjukkan siklus DMA saat ini ke perangkat periferal saat ini.

MENANDAI

Tanda tersebut akan diaktifkan setelah setiap 128 siklus atau kelipatan integral dari awal. Ini menunjukkan siklus DMA saat ini adalah siklus ke-128 sejak output MARK sebelumnya ke perangkat periferal yang dipilih.

V cc

Ini adalah sinyal daya yang diperlukan untuk pengoperasian rangkaian.

SEBUAH microcontroller adalah komputer mikro kecil dan berbiaya rendah, yang dirancang untuk melakukan tugas-tugas spesifik dari sistem tertanam seperti menampilkan informasi gelombang mikro, menerima sinyal jarak jauh, dll.

Mikrokontroler umum terdiri dari prosesor, memori (RAM, ROM, EPROM), port serial, peripheral (timer, counter), dll.

Perbedaan antara Mikroprosesor dan Mikrokontroler

Tabel berikut menyoroti perbedaan antara mikroprosesor dan mikrokontroler -

Mikrokontroler Mikroprosesor
Mikrokontroler digunakan untuk menjalankan satu tugas dalam aplikasi. Mikroprosesor digunakan untuk aplikasi besar.
Biaya perancangan dan perangkat kerasnya rendah. Biaya perancangan dan perangkat kerasnya tinggi.
Mudah diganti. Tidak begitu mudah untuk diganti.
Itu dibangun dengan teknologi CMOS, yang membutuhkan lebih sedikit daya untuk beroperasi. Konsumsi dayanya tinggi karena harus mengontrol seluruh sistem.
Ini terdiri dari CPU, RAM, ROM, port I / O. Itu tidak terdiri dari RAM, ROM, port I / O. Ini menggunakan pinnya untuk terhubung ke perangkat periferal.

Jenis Mikrokontroler

Mikrokontroler dibagi menjadi berbagai kategori berdasarkan memori, arsitektur, bit dan set instruksi. Berikut adalah daftar tipenya -

Sedikit

Berdasarkan konfigurasi bit, mikrokontroler dibagi lagi menjadi tiga kategori.

  • 8-bit microcontroller - Mikrokontroler jenis ini digunakan untuk menjalankan operasi aritmatika dan logika seperti penjumlahan, pengurangan, pembagian perkalian, dll. Sebagai contoh, Intel 8031 ​​dan 8051 adalah mikrokontroler 8 bit.

  • 16-bit microcontroller- Jenis mikrokontroler ini digunakan untuk melakukan operasi aritmatika dan logika di mana diperlukan akurasi dan kinerja yang lebih tinggi. Misalnya, Intel 8096 adalah mikrokontroler 16 bit.

  • 32-bit microcontroller - Mikrokontroler jenis ini umumnya digunakan pada peralatan yang dikontrol secara otomatis seperti mesin operasional otomatis, peralatan medis, dll.

Penyimpanan

Berdasarkan konfigurasi memori, mikrokontroler dibagi lagi menjadi dua kategori.

  • External memory microcontroller- Mikrokontroler jenis ini didesain sedemikian rupa sehingga tidak memiliki memori program pada chipnya. Oleh karena itu dinamai mikrokontroler memori eksternal. Misalnya: mikrokontroler Intel 8031.

  • Embedded memory microcontroller- Mikrokontroler jenis ini didesain sedemikian rupa sehingga mikrokontroler memiliki semua program dan memori data, counter dan timer, interupsi, port I / O yang tertanam pada chip. Misalnya: mikrokontroler Intel 8051.

Set Instruksi

Berdasarkan konfigurasi set instruksi, mikrokontroler dibagi lagi menjadi dua kategori.

  • CISC- CISC adalah singkatan dari komputer set instruksi kompleks. Ini memungkinkan pengguna untuk memasukkan satu instruksi sebagai alternatif dari banyak instruksi sederhana.

  • RISC- RISC adalah singkatan dari Reduced Instruction Set Computers. Ini mengurangi waktu operasional dengan memperpendek siklus jam per instruksi.

Aplikasi Mikrokontroler

Mikrokontroler banyak digunakan di berbagai perangkat seperti -

  • Perangkat penginderaan dan pengontrol cahaya seperti LED.

  • Perangkat penginderaan dan pengontrol suhu seperti oven microwave, cerobong asap.

  • Deteksi kebakaran dan perangkat keamanan seperti Alarm kebakaran.

  • Alat pengukur seperti Volt Meter.

Mikrokontroler 8.051 dirancang oleh Intel pada tahun 1981. Ini adalah mikrokontroler 8-bit. Itu dibangun dengan 40 pin DIP (paket inline ganda), 4kb penyimpanan ROM dan 128 byte penyimpanan RAM, 2 pengatur waktu 16-bit. Ini terdiri dari empat port paralel 8-bit, yang dapat diprogram serta dapat dialamatkan sesuai kebutuhan. Osilator kristal on-chip terintegrasi dalam mikrokontroler yang memiliki frekuensi kristal 12 MHz.

Sekarang mari kita bahas arsitektur Mikrokontroler 8051.

Dalam diagram berikut, bus sistem menghubungkan semua perangkat pendukung ke CPU. Bus sistem terdiri dari bus data 8-bit, bus alamat 16-bit, dan sinyal kontrol bus. Semua perangkat lain seperti memori program, port, memori data, antarmuka serial, kontrol interupsi, pengatur waktu, dan CPU semuanya dihubungkan bersama melalui bus sistem.

Diagram pin mikrokontroler 8.051 terlihat sebagai berikut -

  • Pins 1 to 8- Pin ini dikenal sebagai Port 1. Port ini tidak memiliki fungsi lain. Itu ditarik secara internal, port I / O dua arah.

  • Pin 9 - Ini adalah pin RESET, yang digunakan untuk mengatur ulang mikrokontroler ke nilai awalnya.

  • Pins 10 to 17 - Pin ini dikenal sebagai Port 3. Port ini melayani beberapa fungsi seperti interupsi, input timer, sinyal kontrol, sinyal komunikasi serial RxD dan TxD, dll.

  • Pins 18 & 19 - Pin ini digunakan untuk menghubungkan kristal eksternal untuk mendapatkan jam sistem.

  • Pin 20 - Pin ini menyediakan catu daya ke sirkuit.

  • Pins 21 to 28- Pin ini dikenal sebagai Port 2. Ini berfungsi sebagai port I / O. Sinyal bus alamat tingkat tinggi juga digandakan menggunakan port ini.

  • Pin 29- Ini adalah pin PSEN yang merupakan singkatan dari Program Store Enable. Ini digunakan untuk membaca sinyal dari memori program eksternal.

  • Pin 30- Ini adalah pin EA yang merupakan singkatan dari input Akses Eksternal. Ini digunakan untuk mengaktifkan / menonaktifkan antarmuka memori eksternal.

  • Pin 31- Ini adalah pin ALE yang merupakan singkatan dari Address Latch Enable. Ini digunakan untuk mendemultiplex sinyal alamat-data dari port.

  • Pins 32 to 39- Pin ini dikenal sebagai Port 0. Ini berfungsi sebagai port I / O. Alamat urutan bawah dan sinyal bus data digandakan menggunakan port ini.

  • Pin 40 - Pin ini digunakan untuk menyediakan catu daya ke sirkuit.

Mikrokontroler 8051 memiliki 4 port I / O masing-masing 8-bit, yang dapat dikonfigurasi sebagai input atau output. Oleh karena itu, total 32 pin input / output memungkinkan mikrokontroler untuk dihubungkan dengan perangkat periferal.

  • Pin configuration, yaitu pin dapat dikonfigurasi sebagai 1 untuk input dan 0 untuk output sesuai dengan status logika.

    • Input/Output (I/O) pin - Semua rangkaian di dalam mikrokontroler harus terhubung ke salah satu pinnya kecuali port P0 karena tidak memiliki resistor pull-up built-in.

    • Input pin- Logika 1 diterapkan pada sedikit register P. Transistor FE keluaran dimatikan dan pin lainnya tetap terhubung ke tegangan catu daya melalui resistor pull-up dengan resistansi tinggi.

  • Port 0 - Port P0 (nol) dicirikan oleh dua fungsi -

    • Ketika memori eksternal digunakan maka byte alamat yang lebih rendah (alamat A0A7) diterapkan padanya, jika tidak semua bit dari port ini dikonfigurasi sebagai input / output.

    • Ketika port P0 dikonfigurasi sebagai output maka port lain yang terdiri dari pin dengan resistor pull-up built-in dihubungkan dengan ujungnya ke catu daya 5V, pin port ini memiliki resistor ini tertinggal.

Konfigurasi Input

Jika ada pin dari port ini yang dikonfigurasi sebagai input, maka ia bertindak seolah-olah "mengapung", yaitu input memiliki resistansi input yang tidak terbatas dan potensi yang ditentukan.

Konfigurasi Output

Ketika pin dikonfigurasi sebagai output, maka ini bertindak sebagai "saluran terbuka". Dengan menerapkan logika 0 ke bit port, pin yang sesuai akan dihubungkan ke ground (0V), dan menerapkan logika 1, output eksternal akan tetap "mengambang".

Untuk menerapkan logika 1 (5V) pada pin keluaran ini, perlu untuk membangun resistor pullup eksternal.

Port 1

P1 adalah port I / O yang sebenarnya karena tidak memiliki fungsi alternatif seperti pada P0, tetapi port ini hanya dapat dikonfigurasi sebagai I / O umum. Ini memiliki resistor pull-up built-in dan sepenuhnya kompatibel dengan sirkuit TTL.

Port 2

P2 mirip dengan P0 saat memori eksternal digunakan. Pin port ini menempati alamat yang ditujukan untuk chip memori eksternal. Porta ini dapat digunakan untuk byte alamat yang lebih tinggi dengan alamat A8-A15. Jika tidak ada memori yang ditambahkan maka port ini dapat digunakan sebagai port input / output umum yang mirip dengan Port 1.

Port 3

Di port ini, fungsinya mirip dengan port lain kecuali bahwa logika 1 harus diterapkan ke bit yang sesuai dari register P3.

Pin Batasan Saat Ini

  • Ketika pin dikonfigurasi sebagai output (yaitu logika 0), maka pin port tunggal dapat menerima arus 10mA.

  • Ketika pin ini dikonfigurasi sebagai input (yaitu logika 1), maka resistor pull-up built-in memberikan arus yang sangat lemah, tetapi dapat mengaktifkan hingga 4 input TTL dari seri LS.

  • Jika semua 8 bit port aktif, maka arus total harus dibatasi hingga 15mA (port P0: 26mA).

  • Jika semua port (32 bit) aktif, maka arus maksimum total harus dibatasi hingga 71mA.

Interupsi adalah peristiwa yang menghentikan sementara program utama, meneruskan kontrol ke sumber eksternal dan menjalankan tugasnya. Kemudian meneruskan kontrol ke program utama yang telah ditinggalkannya.

8051 memiliki 5 sinyal interupsi yaitu INT0, TFO, INT1, TF1, RI / TI. Setiap interupsi dapat diaktifkan atau dinonaktifkan dengan mengatur bit dari register IE dan seluruh sistem interupsi dapat dinonaktifkan dengan membersihkan bit EA dari register yang sama.

IE (Interrupt Enable) Daftar

Register ini bertanggung jawab untuk mengaktifkan dan menonaktifkan interupsi. Register EA diatur ke satu untuk mengaktifkan interupsi dan diatur ke 0 untuk menonaktifkan interupsi. Urutan bit dan artinya ditunjukkan pada gambar berikut.

EA YAITU.7 Ini menonaktifkan semua interupsi. Ketika EA = 0 tidak ada interupsi yang akan diakui dan EA = 1 mengaktifkan interupsi secara individual.
- YAITU.6 Dicadangkan untuk penggunaan di masa mendatang.
- YAITU.5 Dicadangkan untuk penggunaan di masa mendatang.
ES YAITU.4 Mengaktifkan / menonaktifkan interupsi port serial.
ET1 IE.3 Mengaktifkan / menonaktifkan interupsi overflow timer1.
EX1 IE.2 Mengaktifkan / menonaktifkan interupsi eksternal1.
ET0 IE.1 Mengaktifkan / menonaktifkan interupsi overflow timer0.
EX0 IE.0 Mengaktifkan / menonaktifkan interupsi eksternal0.

IP (Interrupt Priority) Daftar

Kita dapat mengubah tingkat prioritas interupsi dengan mengubah bit yang sesuai dalam register Interrupt Priority (IP) seperti yang ditunjukkan pada gambar berikut.

  • Interupsi berprioritas rendah hanya dapat diinterupsi oleh interupsi berprioritas tinggi, tetapi tidak dapat diinterupsi oleh interupsi berprioritas rendah lainnya.

  • Jika dua interupsi dari tingkat prioritas yang berbeda diterima secara bersamaan, permintaan tingkat prioritas yang lebih tinggi akan dilayani.

  • Jika permintaan dengan tingkat prioritas yang sama diterima secara bersamaan, maka urutan polling internal menentukan permintaan mana yang akan dilayani.

- IP.6 Dicadangkan untuk penggunaan di masa mendatang.
- IP.5 Dicadangkan untuk penggunaan di masa mendatang.
PS IP.4 Ini mendefinisikan tingkat prioritas interupsi port serial.
PT1 IP.3 Ini mendefinisikan interupsi pengatur waktu dari 1 prioritas.
PX1 IP.2 Ini mendefinisikan tingkat prioritas interupsi eksternal.
PT0 IP.1 Ini mendefinisikan tingkat prioritas interupsi timer0.
PX0 IP.0 Ini mendefinisikan interupsi eksternal dari 0 tingkat prioritas.

TCON Daftar

Register TCON menentukan jenis interupsi eksternal ke mikrokontroler.

8255A adalah perangkat I / O yang dapat diprogram bertujuan umum yang dirancang untuk mentransfer data dari I / O untuk menghentikan I / O dalam kondisi tertentu sesuai kebutuhan. Ini dapat digunakan dengan hampir semua mikroprosesor.

Ini terdiri dari tiga port I / O dua arah 8-bit (jalur 24I / O) yang dapat dikonfigurasi sesuai kebutuhan.

Pelabuhan 8255A

8255A memiliki tiga port, yaitu PORT A, PORT B, dan PORT C.

  • Port A berisi satu kait / penyangga keluaran 8-bit dan satu penyangga masukan 8-bit.

  • Port B mirip dengan PORT A.

  • Port C dapat dibagi menjadi dua bagian, yaitu PORT C bawah (PC0-PC3) dan PORT C atas (PC7-PC4) dengan kata kontrol.

Ketiga port ini dibagi lagi menjadi dua kelompok, yaitu Grup A mencakup PORT A dan PORT atas C. Grup B mencakup PORT B ​​dan PORT bawah C. Kedua grup ini dapat diprogram dalam tiga mode berbeda, yaitu mode pertama dinamai mode 0, mode kedua dinamai Mode 1 dan mode ketiga disebut Mode 2.

Mode Operasi

8255A memiliki tiga mode operasi yang berbeda -

  • Mode 0- Dalam mode ini, Port A dan B digunakan sebagai dua port 8-bit dan Port C sebagai dua port 4-bit. Setiap port dapat diprogram dalam mode input atau mode output di mana output terkunci dan input tidak terkunci. Port tidak memiliki kemampuan interupsi.

  • Mode 1- Dalam mode ini, Port A dan B digunakan sebagai port I / O 8-bit. Mereka dapat dikonfigurasi sebagai port input atau output. Setiap port menggunakan tiga jalur dari port C sebagai sinyal jabat tangan. Input dan output terkunci.

  • Mode 2- Dalam mode ini, Port A dapat dikonfigurasi sebagai port dua arah dan Port B baik dalam Mode 0 atau Mode 1. Port A menggunakan lima sinyal dari Port C sebagai sinyal jabat tangan untuk transfer data. Tiga sinyal lainnya dari Port C dapat digunakan sebagai I / O sederhana atau sebagai jabat tangan untuk port B.

Fitur 8255A

Fitur utama 8255A adalah sebagai berikut -

  • Ini terdiri dari 3 port IO 8-bit yaitu PA, PB, dan PC.

  • Bus alamat / data harus didemux secara eksternal.

  • Ini kompatibel dengan TTL.

  • Ini telah meningkatkan kemampuan mengemudi DC.

8255 Arsitektur

Gambar berikut menunjukkan arsitektur 8255A -

Mari kita lihat diagram pin Intel 8255A -

Sekarang mari kita bahas deskripsi fungsional dari pin di 8255A.

Buffer Bus Data

Ini adalah buffer 8-bit tri-state, yang digunakan untuk menghubungkan mikroprosesor ke bus data sistem. Data ditransmisikan atau diterima oleh buffer sesuai instruksi oleh CPU. Kata kontrol dan informasi status juga ditransfer menggunakan bus ini.

Baca / Tulis Logika Kontrol

Blok ini bertanggung jawab untuk mengendalikan transfer data / kontrol / status internal / eksternal. Ia menerima input dari alamat CPU dan bus kontrol, dan pada gilirannya mengeluarkan perintah ke kedua grup kontrol.

CS

Itu singkatan dari Chip Select. A LOW pada input ini memilih chip dan memungkinkan komunikasi antara 8255A dan CPU. Ini terhubung ke alamat yang diterjemahkan, dan A 0 & A 1 terhubung ke baris alamat mikroprosesor.

Hasilnya tergantung pada kondisi berikut -

CS A 1 A 0 Hasil
0 0 0 PELABUHAN A
0 0 1 PELABUHAN B
0 1 0 PELABUHAN C
0 1 1 Kontrol Register
1 X X Tidak ada pilihan

WR

Itu singkatan dari menulis. Sinyal kontrol ini memungkinkan operasi tulis. Ketika sinyal ini menjadi rendah, mikroprosesor menulis ke port I / O atau register kontrol yang dipilih.

SETEL ULANG

Ini adalah sinyal tinggi aktif. Ini membersihkan register kontrol dan mengatur semua port dalam mode input.

RD

Itu singkatan dari Read. Sinyal kontrol ini memungkinkan operasi Baca. Ketika sinyal rendah, mikroprosesor membaca data dari port I / O yang dipilih dari 8255.

A 0 dan A 1

Sinyal input ini bekerja dengan RD, WR, dan salah satu sinyal kontrol. Berikut adalah tabel yang menunjukkan berbagai sinyal dengan hasilnya.

A 1 A 0 RD WR CS Hasil
0 0 0 1 0

Input Operation

PORT A → Bus Data
0 1 0 1 0 PORT B ​​→ Bus Data
1 0 0 1 0 PORT C → Bus Data
0 0 1 0 0

Output Operation

Bus Data → PELABUHAN A
0 1 1 0 0 Bus Data → PELABUHAN A
1 0 1 0 0 Bus Data → PORT B
1 1 1 0 0 Data Bus → PORT D

Intel 8253 dan 8254 adalah Programmable Interval Timers (PTI) yang dirancang bagi mikroprosesor untuk menjalankan fungsi pengaturan waktu dan penghitungan menggunakan tiga register 16-bit. Setiap counter memiliki 2 pin input, yaitu Clock & Gate, dan 1 pin untuk output “OUT”. Untuk mengoperasikan pencacah, pencacah 16-bit dimuat dalam registernya. Atas perintah, ia mulai mengurangi hitungan hingga mencapai 0, lalu menghasilkan pulsa yang dapat digunakan untuk menghentikan CPU.

Perbedaan antara 8253 dan 8254

Tabel berikut membedakan fitur dari 8253 dan 8254 -

8253 8254
Frekuensi operasinya 0 - 2,6 MHz Frekuensi operasinya adalah 0 - 10 MHz
Ini menggunakan teknologi N-MOS Ini menggunakan teknologi H-MOS
Perintah Baca-Kembali tidak tersedia Perintah Baca-Kembali tersedia
Pembacaan dan penulisan dari penghitung yang sama tidak dapat disisipkan. Pembacaan dan penulisan dari penghitung yang sama dapat disisipkan.

Fitur 8253/54

Fitur yang paling menonjol dari 8253/54 adalah sebagai berikut -

  • Ini memiliki tiga penghitung mundur 16-bit independen.

  • Ini dapat menangani input dari DC hingga 10 MHz.

  • Ketiga pencacah ini dapat diprogram untuk penghitungan biner atau BCD.

  • Ini kompatibel dengan hampir semua mikroprosesor.

  • 8254 memiliki perintah kuat yang disebut perintah READ BACK, yang memungkinkan pengguna untuk memeriksa nilai hitungan, mode terprogram, mode saat ini, dan status penghitung saat ini.

8254 Arsitektur

Arsitektur 8254 terlihat sebagai berikut -

8254 Deskripsi Pin

Berikut adalah diagram pin 8254 -

Pada gambar di atas, ada tiga counter, buffer bus data, logika kontrol Baca / Tulis, dan register kontrol. Setiap penghitung memiliki dua sinyal input - CLOCK & GATE, dan satu sinyal output - OUT.

Buffer Bus Data

Ini adalah buffer 8-bit tri-state, bi-directional, yang digunakan untuk menghubungkan 8253/54 ke bus data sistem. Ini memiliki tiga fungsi dasar -

  • Memprogram mode 8253/54.
  • Memuat register hitungan.
  • Membaca nilai hitungan.

Baca / Tulis Logika

Ini mencakup 5 sinyal, yaitu RD, WR, CS, dan baris alamat A 0 & A 1 . Dalam mode I / O periferal, sinyal RD dan WR masing-masing dihubungkan ke IOR dan IOW. Dalam mode I / O yang dipetakan memori, ini terhubung ke MEMR dan MEMW.

Baris alamat A 0 & A 1 dari CPU terhubung ke baris A 0 dan A 1 dari 8253/54, dan CS terikat ke alamat yang diterjemahkan. Register kata kontrol dan penghitung dipilih sesuai dengan sinyal pada baris A 0 & A 1 .

A 1 A 0 Hasil
0 0 Penghitung 0
0 1 Penghitung 1
1 0 Penghitung 2
1 1 Kontrol Kata Register
X X Tidak ada pilihan

Kontrol Kata Register

Register ini diakses ketika baris A 0 & A 1 berada pada logika 1. Ini digunakan untuk menulis kata perintah, yang menentukan penghitung yang akan digunakan, modenya, dan operasi baca atau tulis. Tabel berikut menunjukkan hasil untuk berbagai input kontrol.

A 1 A 0 RD WR CS Hasil
0 0 1 0 0 Penghitung Tulis 0
0 1 1 0 0 Penghitung Tulis 1
1 0 1 0 0 Penghitung Tulis 2
1 1 1 0 0 Tulis Kata Kontrol
0 0 0 1 0 Baca Penghitung 0
0 1 0 1 0 Baca Penghitung 1
1 0 0 1 0 Baca Penghitung 2
1 1 0 1 0 Tidak ada operasi
X X 1 1 0 Tidak ada operasi
X X X X 1 Tidak ada operasi

Penghitung

Setiap pencacah terdiri dari pencacah tunggal 16 bit-down, yang dapat dioperasikan dalam biner atau BCD. Input dan outputnya dikonfigurasi dengan pemilihan mode yang disimpan di register kata kontrol. Pemrogram dapat membaca konten salah satu dari tiga penghitung tanpa mengganggu penghitungan aktual dalam proses.

8253/54 dapat dioperasikan dalam 6 mode berbeda. Pada bab ini, kita akan membahas mode operasional tersebut.

Mode 0 ─ Interupsi pada Hitungan Terminal

  • Ini digunakan untuk menghasilkan interupsi ke mikroprosesor setelah interval tertentu.

  • Awalnya output rendah setelah mode disetel. Outputnya tetap RENDAH setelah nilai hitungan dimuat ke penghitung.

  • Proses penurunan pencacah berlanjut hingga penghitungan terminal tercapai, yaitu, penghitungan menjadi nol dan output menjadi TINGGI dan akan tetap tinggi hingga memuat ulang penghitungan baru.

  • Sinyal GATE tinggi untuk penghitungan normal. Ketika GATE menjadi rendah, penghitungan dihentikan dan penghitungan saat ini terkunci sampai GATE menjadi tinggi lagi.

Mode 1 - Satu Pemotretan Dapat Diprogram

  • Ini dapat digunakan sebagai multi-vibrator mono stable.

  • Input gerbang digunakan sebagai input pemicu dalam mode ini.

  • Outputnya tetap tinggi sampai hitungan dimuat dan pemicu diterapkan.

Mode 2 - Penghasil Tarif

  • Output biasanya tinggi setelah inisialisasi.

  • Setiap kali hitungan menjadi nol, pulsa rendah lainnya dihasilkan pada output dan penghitung akan dimuat ulang.

Mode 3 - Generator Gelombang Persegi

  • Mode ini mirip dengan Mode 2 kecuali output tetap rendah selama setengah periode timer dan tinggi untuk setengah periode lainnya.

Mode 4 - Mode yang Dipicu Perangkat Lunak

  • Dalam mode ini, output akan tetap tinggi sampai timer menghitung ke nol, di mana output akan berdenyut rendah dan kemudian tinggi lagi.

  • Hitungan terkunci ketika sinyal GATE menjadi RENDAH.

  • Pada hitungan terminal, output menjadi rendah untuk satu siklus clock kemudian menjadi TINGGI. Denyut nadi rendah ini bisa digunakan sebagai strobo.

Mode 5 - Mode yang Dipicu Perangkat Keras

  • Mode ini menghasilkan strobo sebagai respons terhadap sinyal yang dihasilkan secara eksternal.

  • Mode ini mirip dengan mode 4 kecuali bahwa penghitungan dimulai oleh sinyal pada input gerbang, yang berarti dipicu oleh perangkat keras, bukan perangkat lunak yang dipicu.

  • Setelah diinisialisasi, output menjadi tinggi.

  • Ketika jumlah terminal tercapai, output menjadi rendah untuk satu siklus clock.