diff options
Diffstat (limited to '')
-rw-r--r-- | cpu/instructions/execution_control/call.txt | 11 | ||||
-rw-r--r-- | cpu/instructions/execution_control/call_conditional.txt | 22 | ||||
-rw-r--r-- | cpu/instructions/execution_control/jump.txt | 10 | ||||
-rw-r--r-- | cpu/instructions/execution_control/jump_conditional.txt | 21 | ||||
-rw-r--r-- | cpu/instructions/instruction_definition_template.txt | 7 | ||||
-rw-r--r-- | cpu/instructions/overview.txt | 4 |
6 files changed, 73 insertions, 2 deletions
diff --git a/cpu/instructions/execution_control/call.txt b/cpu/instructions/execution_control/call.txt new file mode 100644 index 0000000..edec5f1 --- /dev/null +++ b/cpu/instructions/execution_control/call.txt @@ -0,0 +1,11 @@ +Number of parameters: 1 + +Usage: + call <target> + +Effect: + IP pushed to stack + IP moved to <target> + +Exceptions: + None diff --git a/cpu/instructions/execution_control/call_conditional.txt b/cpu/instructions/execution_control/call_conditional.txt new file mode 100644 index 0000000..7663e54 --- /dev/null +++ b/cpu/instructions/execution_control/call_conditional.txt @@ -0,0 +1,22 @@ +Number of parameters: 2 + +Usage: call_conditional <type_and_index> <target> + type_and_index: + Lowest 3 bits: flags for each of the following checked, from lowest to highest: + Zero + Overflow + Carry + Next 3 bits: + Value for each of the above that it should match + Remaining bits: + Index into instruction queue for which result is to be compared + +Effect: + If all of the checked flags match the value to compare to: + IP pushed to stack + IP moved to <target> + + If no flags are to be checked, it will always set IP + +Exceptions: + Instruction reference nonexistent diff --git a/cpu/instructions/execution_control/jump.txt b/cpu/instructions/execution_control/jump.txt new file mode 100644 index 0000000..6675f03 --- /dev/null +++ b/cpu/instructions/execution_control/jump.txt @@ -0,0 +1,10 @@ +Number of parameters: 1 + +Usage: + jump <target> + +Effect: + Sets IP to <target> + +Exceptions: + None diff --git a/cpu/instructions/execution_control/jump_conditional.txt b/cpu/instructions/execution_control/jump_conditional.txt new file mode 100644 index 0000000..52f323b --- /dev/null +++ b/cpu/instructions/execution_control/jump_conditional.txt @@ -0,0 +1,21 @@ +Number of parameters: 2 + +Usage: jump_conditional <type_and_index> <target> + type_and_index: + Lowest 3 bits: flags for each of the following checked, from lowest to highest: + Zero + Overflow + Carry + Next 3 bits: + Value for each of the above that it should match + Remaining bits: + Index into instruction queue for which result is to be compared + +Effect: + If all of the checked flags match the value to compare to: + IP moved to <target> + + If no flags are to be checked, it will always set IP + +Exceptions: + Instruction reference nonexistent diff --git a/cpu/instructions/instruction_definition_template.txt b/cpu/instructions/instruction_definition_template.txt new file mode 100644 index 0000000..328ec16 --- /dev/null +++ b/cpu/instructions/instruction_definition_template.txt @@ -0,0 +1,7 @@ +Number of parameters: + +Usage: + +Effect: + +Exceptions: diff --git a/cpu/instructions/overview.txt b/cpu/instructions/overview.txt index 3cfe266..5545697 100644 --- a/cpu/instructions/overview.txt +++ b/cpu/instructions/overview.txt @@ -25,9 +25,9 @@ Dynamic VLIW num_opcodes for each: opcode - num_instructions + num_parameters for each: - parameters + value size_of_immediate_references for each: value |