projects:archevo:asia
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
projects:archevo:asia [2021/04/20 17:43] – Owen Mellema | projects:archevo:asia [2021/04/21 14:55] (current) – [Registers] Owen Mellema | ||
---|---|---|---|
Line 2: | Line 2: | ||
**ASIA**, short for **A**rchEvo **S**tandard **I**nstruction set **A**rchitecture, | **ASIA**, short for **A**rchEvo **S**tandard **I**nstruction set **A**rchitecture, | ||
- | ===== Operations | + | ===== Instructions |
- | ASIA uses the [[https:// | + | |
ASIA instructions are eleven bits long. | ASIA instructions are eleven bits long. | ||
Line 13: | Line 12: | ||
</ | </ | ||
- | ^ GB ^ Opcode ^ Command | + | ===== Operations ===== |
- | | 0 | 000 | INC < | + | ASIA uses the [[projects: |
- | | 0 | 001 | DEC < | + | |
- | | 0 | 010 | SLL < | + | ^ GB ^ Opcode ^ Command |
- | | 0 | 011 | SRL < | + | | 0 | 000 | INC < |
- | | 0 | 100 | MOV < | + | | 0 | 001 | DEC < |
- | | 0 | 101 | SLT < | + | | 0 | 010 | SLL < |
- | | 0 | 110 | SGT < | + | | 0 | 011 | SRL < |
- | | 0 | 111 | SET < | + | | 0 | 100 | MOV < |
- | | 1 | 000 | REP | Reproduce at IPLOC | | + | | 0 | 101 | SLT < |
- | | 1 | 001 | JMP | Jump | | + | | 0 | 110 | SGT < |
- | | 1 | 010 | JMC < | + | | 0 | 111 | SET < |
- | | 1 | 011 | MOV | Move cell in direction of IPLOC | | + | | 1 | 000 | REP | Reproduce at IPLOC |
- | | 1 | 100 | NON | // | + | | 1 | 001 | JMP | Jump* | MoveInstructionPointer |
- | | 1 | 101 | NPA | NOP A, part of jump templating | + | | 1 | 010 | JMC < |
- | | 1 | 110 | NPB | NOP B, part of jump templating | + | | 1 | 011 | MOV | Move cell in direction of IPLOC | Move | |
- | | 1 | 111 | ATK | Attack cell at IPLOC | | + | | 1 | 100 | NON | // |
+ | | 1 | 101 | NPA | NOP A, part of jump templating | ||
+ | | 1 | 110 | NPB | NOP B, part of jump templating | ||
+ | | 1 | 111 | ATK | Attack cell at IPLOC | Attack | ||
+ | *Jumping uses [[ projects: | ||
+ | |||
+ | ===== Registers ===== | ||
+ | There are two types of registers - virtual and physical. Physical registers are the eight registers that actually exist in the Cell. Virtual registers are registers that exist outside of the cell, at the [[projects: | ||
+ | |||
+ | The first bit of the register pointer represents whether or not it is virtual. If the register is physical, the first bit will be 0. If virtual, it will be 1. The last three bits are the register number. | ||
+ | We have R/W access to all physical registers except 0b0000, which is energy. |
projects/archevo/asia.1618940625.txt.gz · Last modified: 2021/04/20 17:43 by Owen Mellema