Mistivia 3 months ago
parent
commit
8be90132c8
1 changed files with 111 additions and 1 deletions
  1. 111 1
      README.md

+ 111 - 1
README.md

@@ -1,3 +1,113 @@
 # Fantasy Virtual Machine
 
-A 64-bit stack-based virtual machine and its assembler, created for fun. The design principles are simplicity, clarity, portability, and ease of understanding. Future plans include programming language-related experiments based on this as foundation.
+A 64-bit stack-based virtual machine and its assembler, created for fun.
+
+## Build
+
+FVM includes two parts: the virtual machine and the assembler.
+
+The build the assembler, you need to intall CHICKEN Scheme first. For example, on Arch Linux:
+
+    sudo pacman -S chicken
+
+Then install CHICKEN Scheme dependencies:
+
+    sudo chicken-install matchable srfi-69 srfi-4
+
+Then run make, which will build both components:
+
+    make
+
+If successful, you will see two executables, the virtual machine `fvm` and the assembler`fvm-as`.
+
+## Run
+
+After writing the assembly code (examples can be found in the `examples` directory), first run the assembler:
+
+    ./fvm-as input.asm bytecode.bin
+
+This will generate the bytecode file `output.bin`. Then run the virtual machine:
+
+    ./fvm bytecode.bin
+
+## Registers
+
+FVM contains 4 registers:
+
+- SP: stack pointer
+- BP:base pointer
+- PC:program counter
+- RV: returned value
+
+There are no general-purpose registers; all operations happen on the stack.
+
+## Opcodes
+
+All opcodes are single-byte, except for immediate value instructions.
+
+The instructions supported by FVM are as follows:
+
+### Register Instructions
+
+**sp**
+<br>0x00
+<br>push stack pointer to stack
+
+**ssp**
+<br>0x01
+<br>pop a 64-bit number from stack and set stack pointer to it.
+
+**bp**
+
+**sbp**
+
+**pc**
+
+**rv**
+
+**srv**
+
+### Immediate Number
+
+**imm**
+<br>
+<br>
+
+### Memory
+
+**ld**
+
+**ld8**
+
+**ld16**
+
+**ld32**
+
+
+**st**
+
+**st8**
+
+**st16**
+
+**st32**
+
+### Stack Operations
+
+**dup**
+
+**pop**
+
+**swap**
+
+**over**
+
+**rot**
+
+
+## Call Frame
+
+
+## Pseudo-Opcodes
+
+