about summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--401sleep.mu21
-rw-r--r--prototypes/tile/1.mu22
-rw-r--r--prototypes/tile/2.mu22
3 files changed, 21 insertions, 44 deletions
diff --git a/401sleep.mu b/401sleep.mu
new file mode 100644
index 00000000..79ad6bd5
--- /dev/null
+++ b/401sleep.mu
@@ -0,0 +1,21 @@
+type timespec {
+  tv_sec: int
+  tv_nsec: int
+}
+
+# prototype wrapper around syscall_nanosleep
+# nsecs must be less than 999999999 or 0x3b9ac9ff nanoseconds
+fn sleep secs: int, nsecs: int {
+  var t: timespec
+  # initialize t
+  var tmp/eax: (addr int) <- get t, tv_sec
+  var tmp2/ecx: int <- copy secs
+  copy-to *tmp, tmp2
+  tmp <- get t, tv_nsec
+  tmp2 <- copy nsecs
+  copy-to *tmp, tmp2
+  # perform the syscall
+  var t-addr/ebx: (addr timespec) <- address t
+  var rem-addr/ecx: (addr timespec) <- copy 0
+  syscall_nanosleep
+}
diff --git a/prototypes/tile/1.mu b/prototypes/tile/1.mu
index f0f42709..42c1f08b 100644
--- a/prototypes/tile/1.mu
+++ b/prototypes/tile/1.mu
@@ -45,25 +45,3 @@ fn animate row: int {
     loop
   }
 }
-
-type timespec {
-  tv_sec: int
-  tv_nsec: int
-}
-
-# prototype wrapper around syscall_nanosleep
-# nsecs must be less than 999999999 or 0x3b9ac9ff nanoseconds
-fn sleep secs: int, nsecs: int {
-  var t: timespec
-  # initialize t
-  var tmp/eax: (addr int) <- get t, tv_sec
-  var tmp2/ecx: int <- copy secs
-  copy-to *tmp, tmp2
-  tmp <- get t, tv_nsec
-  tmp2 <- copy nsecs
-  copy-to *tmp, tmp2
-  # perform the syscall
-  var t-addr/ebx: (addr timespec) <- address t
-  var rem-addr/ecx: (addr timespec) <- copy 0
-  syscall_nanosleep
-}
diff --git a/prototypes/tile/2.mu b/prototypes/tile/2.mu
index 078cac17..53cc3af1 100644
--- a/prototypes/tile/2.mu
+++ b/prototypes/tile/2.mu
@@ -75,25 +75,3 @@ $render:render-loop: {
     loop
   }
 }
-
-type timespec {
-  tv_sec: int
-  tv_nsec: int
-}
-
-# prototype wrapper around syscall_nanosleep
-# nsecs must be less than 999999999 or 0x3b9ac9ff nanoseconds
-fn sleep secs: int, nsecs: int {
-  var t: timespec
-  # initialize t
-  var tmp/eax: (addr int) <- get t, tv_sec
-  var tmp2/ecx: int <- copy secs
-  copy-to *tmp, tmp2
-  tmp <- get t, tv_nsec
-  tmp2 <- copy nsecs
-  copy-to *tmp, tmp2
-  # perform the syscall
-  var t-addr/ebx: (addr timespec) <- address t
-  var rem-addr/ecx: (addr timespec) <- copy 0
-  syscall_nanosleep
-}