Fantasy Console
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 
Isabelle L. cdd8206756 lots of work on ceres-asm (not working yet) 5 年前
ceres-asm lots of work on ceres-asm (not working yet) 5 年前
ceres-sys lots of work on ceres-asm (not working yet) 5 年前
src lots of work on ceres-asm (not working yet) 5 年前
.gitignore initial commit! 6 年前
Cargo.lock lots of work on ceres-asm (not working yet) 5 年前
Cargo.toml starting to make ceres-asm 5 年前
LICENSE initial commit! 6 年前
README.md lots of work on ceres-asm (not working yet) 5 年前
justfile lots of work on ceres-asm (not working yet) 5 年前
test.asm lots of work on ceres-asm (not working yet) 5 年前

README.md

CERES-16

a shitty fantasy console written in rust using a proprietary MIPS based asm instruction set. a lot of inspiration from PICO-8. ceres is structured of these crates:

  • ceres-sys: the core system structure of ceres-16
  • ceres-asm: the assembler for ceres-16

Graphics

ceres uses a 256x144 screen with a separate video buffer from the standard memory. colors are 16-bit structured like 0b0000_rrrr_gggg_bbbb where the first four bits are ignored. the video buffer is structured row major where each u16 is an individual pixel

Register layout and info

all registers are unsigned 16 bit

Register number Register name Register usage
0 z0 always contains zero
1 pc program counter
2 sp stack pointer
3 ra return address
4-6 a0-a2 argument registers
7 v0 return register
8 v1 return register 2
9-15 t0-t6 temporary registers

Memory map and info

god oh fuck what am i even doing

instructions

load - ld:signifier

can be vram/cram/imed

  • immediate ld:immd $dest immediate
    opcode signifier destination padding immediate
    00001 100 0000 0000 0000000000000000