diff options
| author | Mistivia <i@mistivia.com> | 2024-12-05 21:49:00 +0800 |
|---|---|---|
| committer | Mistivia <i@mistivia.com> | 2024-12-05 21:49:00 +0800 |
| commit | cd818993399f1fc8fa000b4144730affd291761f (patch) | |
| tree | 13d546dd873ad37e850cf089c322b91a20d25ccf | |
| parent | 79194983d0331d632bd094370a410fa0aaefe6aa (diff) | |
add syscall
| -rw-r--r-- | assembler/fvm-as.scm | 11 | ||||
| -rw-r--r-- | src/fvm.h | 2 | ||||
| -rw-r--r-- | 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) @@ -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 @@ -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 <program-file>\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"); |
