projects:archevo:asia16
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
projects:archevo:asia16 [2021/04/26 18:12] – Owen Mellema | projects:archevo:asia16 [2021/05/02 04:30] (current) – Owen Mellema | ||
---|---|---|---|
Line 2: | Line 2: | ||
ASIA-16 is an [[projects: | ASIA-16 is an [[projects: | ||
- | ^ GB ^ OpCode ^ Mnemonic | + | This added flexibility leads to some new, more powerful concepts: |
- | | 0 | 0000 | INC C | Increment C. C = C + 1 | | + | * Three-register operations. In ASIA, the only way to add two numbers was to overwrite one of them with the answer. (For example, A = A+B). Now, both registers A and B can be preserved. |
- | | 0 | 0001 | DEC C | Decrement C. C = C - 1 | | + | * Working with constants. We can load constants, and also increment and decrement by the constant. |
- | | 0 | 0010 | ICC x C | Increment C by x. C = C + x | | + | * Compare-and-jump. ASIA-16 does away with booleans. All comparisons are done inside of the jump. This saves register space and cycles. |
- | | 0 | 0011 | DCC x C | Decrement C by x. C = C - x | | + | * Compare-and-execute. Cell operations have options for inlining comparisons. For example, in ASIA, RNE would take at least three cycles. Now, it takes one. |
- | | 0 | 0100 | ADD A B C | Add. C = A + B | | + | |
- | | 0 | 0101 | SUB A B C | Subtract. C = A - B | | + | An instruction looks like this: |
- | | 0 | 0110 | MUL A B C | Multiply. C = A*B | | + | < |
- | | 0 | 0111 | DIV A B C | Divide (Round down). C = A/B| | + | OOOOAAAABBBBCCCC |
- | | 0 | 1000 | AND A B C | And. C = A and B | | + | O - Opcode |
- | | 0 | 1001 | OR A B C | Or. C = A or B | | + | A - Register A |
- | | 0 | 1010 | INV A C | Invert. C = not A | | + | B - Register B |
- | | 0 | 1011 | XOR A B C | Exclusive Or. C = B xor A | | + | C - Register C |
- | | 0 | 1100 | SRL C | + | </ |
- | | 0 | 1101 | SLL C | + | or, like this: |
- | | 0 | 1110 | MOV A C | Move A to C. C = A | | + | < |
- | | 0 | 1111 | LOD x C | Loads a value. C = x | | + | OOOOxxxxxxxxCCCC |
+ | O - Opcode | ||
+ | x - Constant | ||
+ | C - Register C | ||
+ | </ | ||
+ | |||
+ | Of the possible 65335 instructions, | ||
+ | |||
+ | ^ GB ^ OpCode ^ Mnemonic | ||
+ | | 0 | 0000 | INC C | Increment C. C = C + 1 | ||
+ | | 0 | 0001 | DEC C | Decrement C. C = C - 1 | ||
+ | | 0 | 0010 | ICC x C | Increment C by x. C = C + x | 1792 | ||
+ | | 0 | 0011 | DCC x C | Decrement C by x. C = C - x | 1792 | ||
+ | | 0 | 0100 | ADD A B C | Add. C = A + B | ||
+ | | 0 | 0101 | SUB A B C | Subtract. C = A - B | 1792 | ||
+ | | 0 | 0110 | MUL A B C | Multiply. C = A*B | 1792 | ||
+ | | 0 | 0111 | DIV A B C | Divide (Round down). C = A/B| 1792 | ||
+ | | 0 | 1000 | AND A B C | And. C = A and B | ||
+ | | 0 | 1001 | OR A B C | Or. C = A or B | ||
+ | | 0 | 1010 | INV A C | Invert. C = not A | 112 | | ||
+ | | 0 | 1011 | XOR A B C | Exclusive Or. C = B xor A | 1792 | ||
+ | | 0 | 1100 | SRL A C | ||
+ | | 0 | 1101 | SLL A C | ||
+ | | 0 | 1110 | MOV A C | Move A to C. C = A | ||
+ | | 0 | 1111 | LOD x C | Loads a value. C = x | ||
+ | | 1 | 0000 | REP | Reproduce. | ||
+ | | 1 | 0001 | ATK | Attack. | ||
+ | | 1 | 0010 | MOV | Move. | 1 | | ||
+ | | 1 | 0011 | JMP | Jump. | 1 | | ||
+ | | 1 | 0100 | JLT A B | Jump if A < B. | 256 | | ||
+ | | 1 | 0101 | JGT A B | Jump if A > B. | 256 | | ||
+ | | 1 | 0110 | JET A B | Jump if A == B. | 256 | | ||
+ | | 1 | 0111 | JNE A B | Jump if A != B. | 256 | | ||
+ | | 1 | 1000 | RET A B | Reproduce if A == B. | 256 | | ||
+ | | 1 | 1001 | RNE A B | Reproduce if A != B. | 256 | | ||
+ | | 1 | 1010 | AET A B | Attack if A == B. | 256 | | ||
+ | | 1 | 1011 | ANE A B | Attack if A != B. | 256 | | ||
+ | | 1 | 1100 | MET A B | Move if A == B. | 256 | | ||
+ | | 1 | 1101 | MNE A B | Move if A != B. | 256 | | ||
+ | | 1 | 1110 | NPA | NOP A. | 1 | | ||
+ | | 1 | 1111 | NPB | NOP B. | 1 | |
projects/archevo/asia16.1619460741.txt.gz · Last modified: 2021/04/26 18:12 by Owen Mellema