Instruction set
COMF | Complement f |
Form |
[label] COMF f, d
( label is omitable, shows SPACE code ) |
Operands |
f : Register file addesss ( 00(00h) to 127(7Fh) )
d : Destination select ( 0 or 1 ) |
Operation |
It executes the complementary operation of the contents of the f register.(Not 2's Complement)
d = 0 : store result in W
d = 1 : store result in f
(EX) data:image/s3,"s3://crabby-images/0b64a/0b64a6a115c32c1bee7a5b8446b043d1b14b36af" alt="" | data:image/s3,"s3://crabby-images/58623/58623e340cfdb0b0e0b28a616b051760a5b2c054" alt="" |
Flag |
When the result is 0, it sets 1 to the Z flag.
When the result is not 0, it sets 0 to the Z flag. |
Instruction
cycles | 1 cycle |
DECF | Decrement f |
Form |
[label] DECF f, d
( label is omitable, shows SPACE code ) |
Operands |
f : Register file addesss ( 00(00h) to 127(7Fh) )
d : Destination select ( 0 or 1 ) |
Operation |
It subtracts 1 from the contents of the f register.
d = 0 : store result in W
d = 1 : store result in f
(EX) data:image/s3,"s3://crabby-images/bb32b/bb32b9400547bcc2def909c435b51f8022a83224" alt="" | data:image/s3,"s3://crabby-images/87b96/87b96df5691b04b2fcaa34dc2a03cdadaf68965a" alt="" |
Flag |
When the result is 0, it sets 1 to the Z flag.
When the result is not 0, it sets 0 to the Z flag. |
Instruction
cycles | 1 cycle |
DECFSZ | Decrement f, Skip if 0 |
Form |
[label] DECFSZ f, d
( label is omitable, shows SPACE code ) |
Operands |
f : Register file addesss ( 00(00h) to 127(7Fh) )
d : Destination select ( 0 or 1 ) |
Operation |
It subtracts 1 from the contents of the f register.
d = 0 : store result in W
d = 1 : store result in f
In case of the result of the subtraction is 0, it changes the following instruction into the NOP and executes it. (It executes the instruction of the present address +2.) | data:image/s3,"s3://crabby-images/5615d/5615d2fc6371682f5ad7f9f747959bf5da027012" alt="" |
Flag | No change |
Instruction
cycles |
1 cycle
When skipping, it is 2 cycles. |
GOTO | Go to address |
Form |
[label] GOTO k
( label is omitable, shows SPACE code ) |
Operands | k : literal field ( 000(000h) to 2047(7FFh) ) |
Operation |
It jumps unconditionally to the address which the literal field shows.
It sets the literal value to 11 bits of lower part of program counter (PC) and it sets the bit 3 and 4 of the PCLATH register to 2 bits of higher part. | data:image/s3,"s3://crabby-images/8f64b/8f64bed43b7e8eb22d1dac45e22626d625e470b0" alt="" |
Flag | No change |
Instruction
cycles | 2 cycles |
Next instructions
data:image/s3,"s3://crabby-images/5c58b/5c58b6dd643779043c885ecf049d9c213b2b9680" alt="" |