Commit 6a76298740

Robin Voetter <robin@voetter.nl>
2019-09-04 15:59:51
Add missing clobbers on arm-eabi and arm64 syscall conventions
1 parent 5308eb7
Changed files (2)
std/os/linux/arm-eabi.zig
@@ -2,6 +2,7 @@ pub fn syscall0(number: usize) usize {
     return asm volatile ("svc #0"
         : [ret] "={r0}" (-> usize)
         : [number] "{r7}" (number)
+        : "memory"
     );
 }
 
@@ -10,6 +11,7 @@ pub fn syscall1(number: usize, arg1: usize) usize {
         : [ret] "={r0}" (-> usize)
         : [number] "{r7}" (number),
           [arg1] "{r0}" (arg1)
+        : "memory"
     );
 }
 
@@ -19,6 +21,7 @@ pub fn syscall2(number: usize, arg1: usize, arg2: usize) usize {
         : [number] "{r7}" (number),
           [arg1] "{r0}" (arg1),
           [arg2] "{r1}" (arg2)
+        : "memory"
     );
 }
 
@@ -29,6 +32,7 @@ pub fn syscall3(number: usize, arg1: usize, arg2: usize, arg3: usize) usize {
           [arg1] "{r0}" (arg1),
           [arg2] "{r1}" (arg2),
           [arg3] "{r2}" (arg3)
+        : "memory"
     );
 }
 
@@ -40,6 +44,7 @@ pub fn syscall4(number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usiz
           [arg2] "{r1}" (arg2),
           [arg3] "{r2}" (arg3),
           [arg4] "{r3}" (arg4)
+        : "memory"
     );
 }
 
@@ -52,6 +57,7 @@ pub fn syscall5(number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usiz
           [arg3] "{r2}" (arg3),
           [arg4] "{r3}" (arg4),
           [arg5] "{r4}" (arg5)
+        : "memory"
     );
 }
 
@@ -73,6 +79,7 @@ pub fn syscall6(
           [arg4] "{r3}" (arg4),
           [arg5] "{r4}" (arg5),
           [arg6] "{r5}" (arg6)
+        : "memory"
     );
 }
 
std/os/linux/arm64.zig
@@ -2,6 +2,7 @@ pub fn syscall0(number: usize) usize {
     return asm volatile ("svc #0"
         : [ret] "={x0}" (-> usize)
         : [number] "{x8}" (number)
+        : "memory", "cc"
     );
 }
 
@@ -10,6 +11,7 @@ pub fn syscall1(number: usize, arg1: usize) usize {
         : [ret] "={x0}" (-> usize)
         : [number] "{x8}" (number),
           [arg1] "{x0}" (arg1)
+        : "memory", "cc"
     );
 }
 
@@ -19,6 +21,7 @@ pub fn syscall2(number: usize, arg1: usize, arg2: usize) usize {
         : [number] "{x8}" (number),
           [arg1] "{x0}" (arg1),
           [arg2] "{x1}" (arg2)
+        : "memory", "cc"
     );
 }
 
@@ -29,6 +32,7 @@ pub fn syscall3(number: usize, arg1: usize, arg2: usize, arg3: usize) usize {
           [arg1] "{x0}" (arg1),
           [arg2] "{x1}" (arg2),
           [arg3] "{x2}" (arg3)
+        : "memory", "cc"
     );
 }
 
@@ -40,6 +44,7 @@ pub fn syscall4(number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usiz
           [arg2] "{x1}" (arg2),
           [arg3] "{x2}" (arg3),
           [arg4] "{x3}" (arg4)
+        : "memory", "cc"
     );
 }
 
@@ -52,6 +57,7 @@ pub fn syscall5(number: usize, arg1: usize, arg2: usize, arg3: usize, arg4: usiz
           [arg3] "{x2}" (arg3),
           [arg4] "{x3}" (arg4),
           [arg5] "{x4}" (arg5)
+        : "memory", "cc"
     );
 }
 
@@ -73,6 +79,7 @@ pub fn syscall6(
           [arg4] "{x3}" (arg4),
           [arg5] "{x4}" (arg5),
           [arg6] "{x5}" (arg6)
+        : "memory", "cc"
     );
 }