Sistem Tertanam - Instruksi

Alur program berjalan secara berurutan, dari satu instruksi ke instruksi berikutnya, kecuali instruksi transfer kontrol dijalankan. Berbagai jenis instruksi transfer kontrol dalam bahasa assembly termasuk lompatan bersyarat atau tidak bersyarat dan instruksi panggilan.

Instruksi Loop dan Lompat

Looping di 8051

Mengulangi urutan instruksi beberapa kali disebut a loop. Sebuah instruksiDJNZ reg, labeldigunakan untuk melakukan operasi Loop. Dalam instruksi ini, register dikurangi dengan 1; jika bukan nol, maka 8051 melompat ke alamat target yang dirujuk oleh label.

Register diisi dengan penghitung untuk jumlah pengulangan sebelum dimulainya loop. Dalam instruksi ini, baik penurunan register dan keputusan untuk melompat digabungkan menjadi satu instruksi. Register dapat berupa salah satu dari R0 – R7. Penghitung juga bisa menjadi lokasi RAM.

Contoh

Multiply 25 by 10 using the technique of repeated addition.

Solution- Perkalian dapat dicapai dengan menjumlahkan perkalian dan berulang kali, sebanyak pengali. Sebagai contoh,

25 * 10 = 250 (FAH)

25 + 25 + 25 + 25 + 25 + 25 + 25 + 25 + 25 + 25 = 250

MOV A,#0             ;A = 0,clean ACC 
   MOV R2,#10           ; the multiplier is replaced in R2 
   Add A,#25            ;add the multiplicand to the ACC 
	
AGAIN:DJNZ R2, 
AGAIN:repeat  until R2 = 0 (10 times) 

   MOV R5 , A           ;save A in R5 ;R5 (FAH)

Drawback in 8051 - Tindakan mengulang dengan instruksi DJNZ Reg labeldibatasi hingga 256 iterasi saja. Jika lompatan bersyarat tidak dilakukan, maka instruksi yang mengikuti lompatan tersebut dijalankan.

Looping di dalam Loop

Saat kita menggunakan perulangan di dalam perulangan lain, ini disebut a nested loop. Dua register digunakan untuk menahan hitungan ketika jumlah maksimum dibatasi hingga 256. Jadi kami menggunakan metode ini untuk mengulangi tindakan lebih dari 256.

Example

Tulis program untuk -

  • Muat akumulator dengan nilai 55H.
  • Lengkapi ACC 700 kali.

Solution- Karena 700 lebih besar dari 255 (kapasitas maksimum register manapun), dua register digunakan untuk menampung hitungan. Kode berikut menunjukkan bagaimana menggunakan dua register, R2 dan R3, untuk menghitung.

MOV A,#55H            ;A = 55H 
	
NEXT: MOV R3,#10         ;R3 the outer loop counter 
AGAIN:MOV R2,#70         ;R2 the inner loop counter 

   CPL A                 ;complement

Lompatan Bersyarat Lainnya

Tabel berikut mencantumkan lompatan bersyarat yang digunakan di 8051 -

Petunjuk Tindakan
JZ Lompat jika A = 0
JNZ Lompat jika A ≠ 0
DJNZ Penurunan dan Lompat jika mendaftar ≠ 0
CJNE A, data Langsung jika A ≠ data
CJNE reg, #data Langsung jika byte ≠ data
JC Lompat jika CY = 1
JNC Langsung jika CY ≠ 1
JB Lompat jika bit = 1
JNB Lompat jika bit = 0
JBC Lompat jika bit = 1 dan hapus bit
  • JZ (jump if A = 0)- Dalam instruksi ini, konten akumulator diperiksa. Jika nol, maka 8051 akan melompat ke alamat target. Instruksi JZ hanya dapat digunakan untuk akumulator, tidak berlaku untuk register lain.

  • JNZ (jump if A is not equal to 0)- Dalam instruksi ini, konten akumulator diperiksa menjadi bukan nol. Jika bukan nol, maka 8051 akan melompat ke alamat target.

  • JNC (Jump if no carry, jumps if CY = 0)- Bit bendera Carry dalam register flag (atau PSW) digunakan untuk membuat keputusan apakah akan melompati "label JNC" atau tidak. CPU melihat flag carry untuk melihat apakah itu dinaikkan (CY = 1). Jika tidak dimunculkan, maka CPU mulai mengambil dan menjalankan instruksi dari alamat label. Jika CY = 1, itu tidak akan melompat tetapi akan mengeksekusi instruksi berikutnya di bawah JNC.

  • JC (Jump if carry, jumps if CY = 1) - Jika CY = 1, ini melompat ke alamat target.

  • JB (jump if bit is high)

  • JNB (jump if bit is low)

Note - Harus dicatat bahwa semua lompatan bersyarat adalah lompatan pendek, yaitu, alamat target harus berada dalam –128 hingga +127 byte dari konten penghitung program.

Instruksi Lompat Tanpa Syarat

Ada dua lompatan tanpa syarat di 8051 -

  • LJMP (long jump)- LJMP adalah instruksi 3-byte di mana byte pertama mewakili opcode, dan byte kedua dan ketiga mewakili alamat 16-bit dari lokasi target. Alamat target 2-byte memungkinkan lompatan ke lokasi memori manapun dari 0000 ke FFFFH.

  • SJMP (short jump)- Ini adalah instruksi 2-byte di mana byte pertama adalah opcode dan byte kedua adalah alamat relatif dari lokasi target. Rentang alamat relatif dari 00H hingga FFH yang dibagi menjadi lompatan maju dan mundur; yaitu, dalam –128 hingga +127 byte memori relatif terhadap alamat PC saat ini (penghitung program). Jika terjadi lompatan maju, alamat target dapat berada dalam jarak 127 byte dari PC saat ini. Jika terjadi lompatan mundur, alamat target dapat berada dalam –128 byte dari PC saat ini.

Menghitung Alamat Lompat Pendek

Semua lompatan bersyarat (JNC, JZ, dan DJNZ) adalah lompatan pendek karena merupakan instruksi 2-byte. Dalam instruksi ini, byte pertama mewakili opcode dan byte kedua mewakili alamat relatif. Alamat target selalu relatif terhadap nilai penghitung program. Untuk menghitung alamat target, byte kedua ditambahkan ke PC instruksi tepat di bawah lompatan. Lihatlah program yang diberikan di bawah ini -

Line   PC    Op-code   Mnemonic   Operand 
1      0000               ORG       0000 
2      0000  7800         MOV       R0,#003  
3      0002  7455         MOV       A,#55H0 
4      0004  6003         JZ        NEXT 
5      0006  08           INC       R0 
6      0007  04   AGAIN:  INC       A 
7      0008  04           INC       A 
8      0009  2477 NEXT:   ADD       A, #77h 
9      000B  5005         JNC       OVER 
10     000D  E4           CLR       A
11     000E  F8           MOV       R0, A 
12     000F  F9           MOV       R1, A 
13     0010  FA          MOV       R2, A 
14     0011  FB           MOV       R3, A 
15     0012  2B   OVER:   ADD       A, R3 
16     0013  50F2         JNC       AGAIN 
17     0015  80FE HERE:   SJMP      HERE 
18     0017             END

Perhitungan Alamat Target Lompat Mundur

Dalam kasus lompatan maju, nilai perpindahan adalah bilangan positif antara 0 hingga 127 (00 hingga 7F dalam hex). Namun, untuk lompatan mundur, perpindahannya adalah nilai negatif dari 0 sampai –128.

Instruksi CALL

CALL digunakan untuk memanggil subrutin atau metode. Subrutin digunakan untuk melakukan operasi atau tugas yang perlu sering dilakukan. Ini membuat program lebih terstruktur dan menghemat ruang memori. Ada dua instruksi - LCALL dan ACALL.

LCALL (Panggilan Panjang)

LCALL adalah instruksi 3-byte dimana byte pertama mewakili opcode dan byte kedua dan ketiga digunakan untuk memberikan alamat subrutin target. LCALL dapat digunakan untuk memanggil subrutin yang tersedia dalam ruang alamat 64K-byte dari 8051.

Agar berhasil kembali ke titik setelah eksekusi subrutin yang dipanggil, CPU menyimpan alamat instruksi tepat di bawah LCALL pada stack. Jadi, ketika subrutin dipanggil, kontrol dipindahkan ke subrutin tersebut, dan prosesor menyimpan PC (penghitung program) pada stack dan mulai mengambil instruksi dari lokasi baru. Instruksi RET (return) mentransfer kontrol kembali ke pemanggil setelah menyelesaikan eksekusi subrutin. Setiap subrutin menggunakan RET sebagai instruksi terakhir.

ACALL (Panggilan Mutlak)

ACALL adalah instruksi 2-byte, berbeda dengan LCALL yang 3 byte. Alamat target subrutin harus dalam 2K byte karena hanya 11 bit dari 2 byte yang digunakan untuk alamat. Perbedaan antara ACALL dan LCALL adalah bahwa alamat target untuk LCALL dapat berada di mana saja dalam ruang alamat 64K-byte dari 8051, sedangkan alamat target CALL berada dalam kisaran 2K-byte.