/believmr

Simulation of a cluster of virtual machines that runs on a network.

Primary LanguageRustThe UnlicenseUnlicense

BelieVMr Specs

issues repo size code size license

Instruction Set Assembly

Instructions OpCode Operations
print src 0x00 prints a null terminated string
mov integer dest 0x10 dest = binary(unsigned integer)
movm src dest 0x11 dest = src
add src dest 0x12 dest = dest + src
sub src dest 0x13 dest = dest - src
and src dest 0x14 dest = dest & src
or src dest 0x15 dest = dest | src
xor src dest 0x16 dest = dest ^ src
cmp src dest 0x17 dest - src, setting the status bits
sll src dest 0x18 dest = dest << src
srl src dest 0x19 dest = dest >> src
sra src dest 0x1A dest = extended(dest) >> src
mul src dest 0x1B dest = dest * src, xr0 = high(dest * src)
div src dest 0x1C dest = dest / src, xr0 = dest % src
mde dest 0x1D dest = % or high of last mul/div
j offset 0x20 add offset to program counter
jl offset 0x21 jump if status[1] set
jle offset 0x22 jump if status[0] or status[1] set
je offset 0x23 jump if status[0] set

Endianess

By default we assume big endian format for our virtual machine.

Status Register

An 8 bit register where the bits as used as described:

  • bit 0 - Zero flag,
  • bit 1 - Underflow flag,
  • bit 2 - Overflow flag,
  • bits 3..7 - Reserved

Special Registers

  • xr0 (32 bits) - Stores upper part of the multiplication or the remainder of a division

About jumps

The program counter is incremented before decodification, thus, jumps must take into account this information. offset can at max cause the program counter to reach program's size causing it to halt.

Planned Features (for OS project)

  • Memory allocators for processes
  • System calls to allocate chunks of memory
  • Implement threads and make context thread level
  • Dynamic linking / loaded libraries
  • I/O (is maybe related to interrupts)

Cluster Architecture

The following is the current idea of how a user would perceive this system.

The user would access the website and write her assembly program and submit for execution. If I ever decide to write my own programming language, it may available for writing programs on the same website. Another possible feature would be on submission, the user would need to send a "reward key" of some sort, which would be validated by the service before executing the program on the worker, and reward the worker when finished.

The possibility of other protocols of communication and interfaces to the service are open, but we stick to today's ultimately popular HTTP protocol for now.

The design and implementation of workers management is still WIP, but the general idea is any person on an IP network would be able to register themselves as workers on the service and give their CPU time for execution of the programs submitted to the BelieVMr service.