From cd818993399f1fc8fa000b4144730affd291761f Mon Sep 17 00:00:00 2001 From: Mistivia Date: Thu, 5 Dec 2024 21:49:00 +0800 Subject: add syscall --- assembler/fvm-as.scm | 11 +++++------ src/fvm.h | 2 +- src/main.c | 7 +++++++ 3 files changed, 13 insertions(+), 7 deletions(-) diff --git a/assembler/fvm-as.scm b/assembler/fvm-as.scm index 8730e66..555f36f 100644 --- a/assembler/fvm-as.scm +++ b/assembler/fvm-as.scm @@ -153,15 +153,14 @@ (define (output-prog prog output-file) (define (write-number x port) - (cond ((or (rational? x) - (real? x)) (write-string - (blob->string (f64vector->blob (f64vector x))) - #f - port)) - ((integer? x) (write-string (blob->string + (cond ((exact-integer? x) (write-string (blob->string (u64vector->blob (u64vector x))) #f port)) + ((real? x) (write-string + (blob->string (f64vector->blob (f64vector x))) + #f + port)) (else (abort "Expect a number")))) (call-with-output-file output-file (lambda (port) diff --git a/src/fvm.h b/src/fvm.h index 8d8cb87..9cd18a4 100644 --- a/src/fvm.h +++ b/src/fvm.h @@ -9,7 +9,7 @@ typedef double fvm_float_t;; struct fvm; // return non-zero if vm should be suspended -typedef int64_t (*fvm_syscall_fn_t)(struct fvm* vm); +typedef void (*fvm_syscall_fn_t)(struct fvm* vm); struct fvm { fvm_word_t sp; // stack pointer diff --git a/src/main.c b/src/main.c index 21b31c2..7740d52 100644 --- a/src/main.c +++ b/src/main.c @@ -3,12 +3,19 @@ #include "fvm.h" +static void printnum(struct fvm *vm) { + int64_t n = fvm_pop(vm); + printf("%lld\n", n); +} + int main(int argc, char **argv) { struct fvm vm; if (argc < 2) { fprintf(stderr, "Usage: fvm \n"); return -1; } + vm.syscall_table = malloc(256 * sizeof(fvm_syscall_fn_t)); + vm.syscall_table[1] = &printnum; FILE* fp = fopen(argv[1], "rb"); if (fp == NULL) { fprintf(stderr, "Failed to open file.\n"); -- cgit v1.0