diff options
| author | Andrew Kelley <superjoe30@gmail.com> | 2015-12-11 03:55:26 -0700 |
|---|---|---|
| committer | Andrew Kelley <superjoe30@gmail.com> | 2015-12-11 03:55:26 -0700 |
| commit | d697404f640d25be5fc1a02c5144362c2b329902 (patch) | |
| tree | 73e26c0efea7b15335fe973142e6f91df63fdda8 /std/std.zig | |
| parent | 15ba5bc54e286fb64d67e38857ede4b0dac9c841 (diff) | |
| download | zig-d697404f640d25be5fc1a02c5144362c2b329902.tar.gz zig-d697404f640d25be5fc1a02c5144362c2b329902.zip | |
hello world working without libc
Diffstat (limited to 'std/std.zig')
| -rw-r--r-- | std/std.zig | 21 |
1 files changed, 11 insertions, 10 deletions
diff --git a/std/std.zig b/std/std.zig index 3bcf9e4783..4e523e0015 100644 --- a/std/std.zig +++ b/std/std.zig @@ -1,13 +1,13 @@ fn syscall3(number: isize, arg1: isize, arg2: isize, arg3: isize) -> isize { let mut result : isize; - asm volatile ( - "mov %[number], %%rax\n" - "mov %[arg1], %%rdi\n" - "mov %[arg2], %%rsi\n" - "mov %[arg3], %%rdx\n" - "syscall\n" - "mov %%rax, %[ret]\n" - : [ret] "=r" (result) + asm volatile (" + mov %[number], %%rax + mov %[arg1], %%rdi + mov %[arg2], %%rsi + mov %[arg3], %%rdx + syscall + mov %%rax, %[ret]" + : [ret] "=m" (result) : [number] "r" (number), [arg1] "r" (arg1), [arg2] "r" (arg2), [arg3] "r" (arg3) : "rcx", "r11", "rax", "rdi", "rsi", "rdx"); return result; @@ -16,8 +16,9 @@ fn syscall3(number: isize, arg1: isize, arg2: isize, arg3: isize) -> isize { // TODO error handling // TODO zig strings instead of C strings // TODO handle buffering and flushing -pub print_str(str : *const u8, len: isize) { +// TODO non-i32 integer literals so we can remove the casts +pub fn print_str(str : *const u8, len: isize) { let SYS_write = 1; let stdout_fileno = 1; - syscall3(SYS_write, stdout_fileno, str as isize, str_len); + syscall3(SYS_write as isize, stdout_fileno as isize, str as isize, len); } |
