Instruksi Aritmatika Instruksi Logika dan Manipulasi Bit Instruksi Transfer Kendali

XCHD : Pertukaran nibble orde rendah antara RAM internal lokasinya ditunjukkan oleh R0 dan R1

2.7.1 Instruksi Aritmatika

Operasi dasar aritmatik seperti penjumlahan, pengurangan, perkalian dan pembagian dimiliki oleh AT89S52 dengan mnemonic : INC, ADD, SUBB, DEC, MUL dan DIV. Penjelasan dari operasi mnemonic tersebut dijelaskan sebagai berikut : INC : Menambah satu isi sumber operand dan menyimpan hasilnya ke operand tersebut ADD : Penjumlahan antara akumulator dengan sumber operand dan hasilnya disimpan di akumulator SUBB : Pengurangan akumulator dengan sumber operand, hasilnya disimpan dalam operand tersebut. DEC : Mengurangi sumber operand dengan 1. dan hasilnya disimpan pada operand tersebut. MUL : Perkalian antara akumulator dengan Register B. DIV : Pembagian antara akumulator dengan Register B dan hasilnya disimpan dalam akumulator, sisanya di Register B.

2.7.2 Instruksi Logika dan Manipulasi Bit

Mikrokontroller AT89S52 dapat melakukan operasi logika bit maupun operasi logika byte. Operasi logika tersebut dibagi atas dua bagian yaitu : Universitas Sumatera Utara • Operasi logika operand tunggal, yang terdiri dari CLR, SETB, CPL, RL, RR, dan SWAP. • Operasi logika dua operand seperti : ANL, ORL, dan XRL. Operasi yang dilkukan oleh AT89S52 dengan pembacaan instruksi logika tersebut dijelaskan dibawah ini : CLR : Menghapus byte atau bit menjadi nol. SETB : Menggeser bit atau byte menjadi satu. CPL : Mengkomplemenkan akumulator. RL : Rotasi akumulator 1 bit ke kiri. RR : Rotasi akumulator ke kanan. SWAP : Pertukaran nibble orde tinggi.

2.7.3 Instruksi Transfer Kendali

Instruksi transfer kendali control transfer terdiri dari 3 tiga kelas operasi yaitu : • Lompatan tidak bersyarat Unconditional Jump seperti : ACALL, AJMP, LJMP,SJMP • Lompatan bersyarat Conditional Jump seperti : JZ, JNZ, JB, CJNE, dan DJNZ Universitas Sumatera Utara • Insterupsi seperti : RET dan RET1. Penjelasan dari instruksi diatas sebagai berikut : ACALL : Instruksi pemanggilan subroutine bila alamat subroutine tidak lebih dari 2 Kbyte. LCALL : Pemanggilan subroutine yang mempunyai alamat antara 2 Kbyte – 64 Kbyte. AJMP : Lompatan untuk percabangan maksimum 2 Kbyte. LJMP : Lompatan untuk percabangan maksimum 64 Kbyte. JNB : Percabangan bila bit tidak diset. JZ : Percabangan akan dilakukan jika akumulator adalah nol. JNZ : Percabangan akan dilakukan jika akumulator adalah tidak nol. JC : Percabangan terjadi jika CY diset “1”. CJNE : Operasi perbandingan operand pertama dengan operand kedua, jika tidak sama akan dilakukan percabangan. DJNZ : Mengurangi nilai operand sumber dan percabangan akan dilakukan apabila isi operand tersebut tidak nol. RET : Kembali ke subroutine. RET1 : Kembali ke program interupsi utama Universitas Sumatera Utara BAB III PERANCANGAN DAN CARA KERJA ALAT

3.1 Diagram Blok