From 8a01908b1c8e4828ca6fc0e0e075217f879263a7 Mon Sep 17 00:00:00 2001 From: Lucas Schumacher Date: Mon, 14 Apr 2025 17:53:51 -0400 Subject: [PATCH] Fit mips write return value --- arch/mips.c | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/arch/mips.c b/arch/mips.c index ec7e14e..1d23708 100644 --- a/arch/mips.c +++ b/arch/mips.c @@ -15,14 +15,15 @@ void exit(int8_t status){ intptr_t write(int32_t fd, const void* buf, intptr_t size){ intptr_t n_written = 0; - asm ( - "move $a0, %2\n" - "move $a1, %0\n" - "move $a2, %1\n" + asm volatile ( + "move $a0, %1\n" + "move $a1, %2\n" + "move $a2, %3\n" "li $v0, 4004\n" "syscall\n" - : //TODO: n_written - : "r"(buf), "r"(size), "r"(fd) + "move %0, $v0\n" + : "=r"(n_written) + : "r"(fd), "r"(buf), "r"(size) : "a0", "a1", "a2", "v0" //TODO: temp registers clobbered by syscall should probably also be listed but this fn returns right away so it should be fine? ); return n_written;