Chapter 4: Relative Branching/Skips/Subroutines Flashcards
What are relative Branches?
Relative Branches use an offset to adjust the PC. Most branches are local so that only small offsets are required, thus making the operand smaller. This offset can be negative so that they can be used to create loops.
In this case the offset reduces the programme counter to allow a set of instructions to be repeated.
The advantages of relative branches?
The advantage of relative branches is that the code can then be relocatable, i.e. it can be moved to a different part of the memory and still work. This is important when the absolute address is not known at the time when the assembly code is compiled, e.g. an app running under an Operating System
What are skips used for?
Another way of avoiding using large target addresses in a branch instruction is to use skips.
What occurs during a skip?
, the programme counter increments in the usual way, one instruction at a time. However, the skip instruction forces the next operation to not be executed depending on whether a condition is met. Whilst this can be described as jumping over the next instruction, in fact the programme counter is not affected. It actually just overwrites the next fetched instruction with a NOP (No Operation).
Examples of skip operations?
Example: In the PIC16F84A instruction set the BTFSC (Bit Test F, Skip if Clear) and BTFSS (Bit Test F, Skip if Set) are conditional skip operations.
What are subroutines?
High level languages make extensive use of subroutines (or functions). The same can be done in assembly code by using jumps which remember where they have come from, with the idea that once the subroutine has finished, the programme would return to the instruction following the subroutine.
commands used to control subroutines?
PIC16F84A example:
CALL – Branch and put the return address on the stack
RETURN – restore the return address from the stack