Set instruksi 14-bit
Set instruksi 14-bit digunakan dalam mikrokontroler PIC keluarga mid-range. Set instruksi 14-bit terdiri dari 35 buah instruksi single word. Setiap word terdiri dari opcode dan operand yang dipaket dalam string biner 14 bit. Setiap instruksi hanya menggunakan satu siklus instruksi, kecuali instruksi percabangan. Set instruksi 14-bit digunakan dalam mikrokontroler berikut ini:
KlasifikasiBerdasarkan strukturnya, set instruksi 14-bit dapat dikelompokkan menjadi instruksi berorientsi byte, instruksi berorientasi bit serta instruksi literal dan kontrol.
PengkodeanSet Instruksi 14 bit terdiri dari opcode dan operand. operandnya dapat berupa b, d, f dan k. Operand b lebarnya 3 bit, digunakan untuk menotasikan alamat bit (bit 0 hingga bit 7). Operand d lebarnya 1 bit, digunakan untuk menotasikan tujuan operasi, jika "0" maka hasil tersimpan di register w, jika "1" maka hasil tersimpan di register f. Operand f lebarnya 5 bit, digunakan untuk menotasikan alamat register f (0x00 hingga 0x3f). Terakhir, operand k digunakan untuk menotasikan data literal baik 8 bit maupun 9 bit.
RincianADDLW [Add Literal and W] Sintaks: [label] ADDLW k Operasi: W = W + k Status terpengaruh: C, DC, Z Deskripsi: Hasil penjumlahan W dan k disimpan ke W
Sintaks: [label] ADDWF f,d Operasi: d = W + f Status terpengaruh: C, DC, Z Deskripsi: Hasil penjumlahan W dan f disimpan ke d
Sintaks: [label] ANDLW k Operasi: W = W AND k Status terpengaruh: Z Deskripsi: Hasil AND antara W dan f disimpan ke W
Sintaks: [label] ANDWF f,d Operasi: d = W AND f Status terpengaruh: Z Deskripsi: Hasil AND antara W dan f disimpan ke d
Sintaks: [label] BCF f,b Operasi: f = 0 Status terpengaruh: - Deskripsi: Bit b register f direset
Sintaks: [label] BSF f,b Operasi: f = 1 Status terpengaruh: - Deskripsi: Bit b register f diset
Sintaks: [label] BTFSS f,b Operasi: loncat jika f = 1 Status terpengaruh: - Deskripsi: Jika bit b register f = "1", loncati baris selanjutnya
Sintaks: [label] BTFSC f,b Operasi: loncat jika f = 0 Status terpengaruh: - Deskripsi: Jika bit b register f = "1", loncati baris selanjutnya
Sintaks: [ label ] CALL k Operasi: TOS = PC + 1; PC<10:0> = k; PC<12:11> = PCLATH<4:3> Status terpengaruh: - Deskripsi: Pemangilan subrutin
Sintaks: [label] CLRF f Operasi: f = 0x00 Status terpengaruh: Z Deskripsi: Isi register f dengan 0x00
Sintaks: [ label ] CLRW Operasi: W = 0x00 Status terpengaruh: Z Deskripsi: Isi register W dengan 0x00
Sintaks: [ label ] CLRWDT Operands: - Operasi: WDT = 0x00 Status terpengaruh: TO, PD Deskripsi: Reset timer WDT dan preskalarnya
Sintaks: [ label ] COMF f,d Operasi: d = inv (f) Status terpengaruh: Z Deskripsi: simpan komplemen f di d
Sintaks: [label] DECF f,d Operasi: d = f -1 Status terpengaruh: Z Deskripsi: Kurangi f, simpan di d
Sintaks: [ label ] DECFSZ f,d Operasi: d = f - 1 ; loncat jika 0 loncat jika result = 0 Status terpengaruh: - Deskripsi: Jika hasil pengurangan register f = 0 maka loncati instruksi selanjutnya
Sintaks: [ label ] GOTO k Operasi: PC<10:0> = k; PC<12:11> = PCLATH<4:3> Status terpengaruh: - Deskripsi: Percabangan tak bersyarat
Sintaks: [ label ] INCF f,d Operasi: d = f + 1 Status terpengaruh: Z Deskripsi: Tambahkan f, simpan di d
Operasi: d = f + 1; loncat jika 0 loncat jika result = 0 Status terpengaruh: - Deskripsi: Jika hasil penambambahan register f = 0 maka loncati instruksi selanjutmya
Sintaks: [ label ] IORLW k Operasi: W = W OR k Status terpengaruh: Z Deskripsi: Regsiter W di OR-kan dengan k, simpan di W
Sintaks: [ label ] IORWF f,d Operasi: d = W OR f Status terpengaruh: Z Deskripsi: Regsiter W di OR-kan dengan f, simpan di d
Sintaks: [ label ] MOVF f,d Operasi: d = f Status terpengaruh: Z Deskripsi: Salin register f ke d
Sintaks: [ label ] MOVLW k Operasi: W = k Status terpengaruh: - Deskripsi: Salin literal k ke register W
Sintaks: [ label ] MOVWF f Operasi: f = W Status terpengaruh: - Deskripsi: Salin register W ke register f
Sintaks: [ label ] NOP Operasi: No Operasi Status terpengaruh: - Deskripsi: Tidak ada operasi
Sintaks: [ label ] RETFIE Operasi: PC = TOS; GIE = 1 Status terpengaruh: - Deskripsi: Kembali dari rutin interupsi
Sintaks: [ label ] RETLW k Operasi: W = k; PC = TOS Status terpengaruh: - Deskripsi: Kembali dari subrutin dengan membawa nilai literal k pada register W
Sintaks: [ label ] RLF f,d Operasi: d = Geser Kiri (f) Status terpengaruh: C Deskripsi: Geser register f ke kiri melalui Carry, simpan di d
Sintaks: [ label ] RETURN Operasi: PC = TOS Status terpengaruh: - Deskripsi: Kembali dari subrutin
Sintaks: [ label ] RRF f,d Operasi: Geser Kanan (f) Status terpengaruh: C Deskripsi: Geser kanan register f melalaui Carry, simpan di d
Sintaks: [ label ] SLEEP Operasi: WDT = 0; TO = 1; PD = 1 Status terpengaruh: TO, PD Deskripsi: Memasuki modus SLEEP, aktifkan flag PD
Sintaks: [ label ] SUBLW k Operasi: W = k - W Status terpengaruh: C, DC, Z Deskripsi: Kurangi W dari k simpan di W
Sintaks: [ label ] SUBWF f,d Operasi: d = f - W Status Affected: C, DC, Z Deskripsi: Kurangi W dari f, simpan di d
Sintaks: [ label ] SWAPF f,d Operasi: (f<3:0>) -> (destination<7:4>); (f<7:4>) -> (destination<3:0>) Status terpengaruh: - Deskripsi: Tukarkan nibble atas dan nibble bawah, simpan di d
Sintaks: [label] XORLW k Operasi: W = W XOR k Status terpengaruh: Z Deskripsi: Hasil XOR antara register W dan k disimpan di register W
Sintaks: [label] XORWF f,d Operasi: d = W XOR f Status terpengaruh: Z Deskripsi: Hasil XOR antara register W dan k disimpan di register d |