summaryrefslogtreecommitdiff
path: root/src/backend/utils
diff options
context:
space:
mode:
Diffstat (limited to 'src/backend/utils')
-rw-r--r--src/backend/utils/assign-stack.scm15
-rw-r--r--src/backend/utils/merge-instructions.scm7
2 files changed, 22 insertions, 0 deletions
diff --git a/src/backend/utils/assign-stack.scm b/src/backend/utils/assign-stack.scm
new file mode 100644
index 0000000..dff9fc7
--- /dev/null
+++ b/src/backend/utils/assign-stack.scm
@@ -0,0 +1,15 @@
+(define-module (backend utils assign-stack)
+ #:export (make-location
+ get-frame-size))
+
+
+(define make-location)
+(define get-frame-size)
+(let ((dict (make-hash-table))
+ (ptr 0))
+ (set! make-location
+ (lambda (id)
+ (or (hash-ref dict id)
+ (begin (set! ptr (1+ ptr))
+ (hash-set! dict id (get-frame-size))))))
+ (set! get-frame-size (lambda () (* -4 ptr))))
diff --git a/src/backend/utils/merge-instructions.scm b/src/backend/utils/merge-instructions.scm
new file mode 100644
index 0000000..f9fc043
--- /dev/null
+++ b/src/backend/utils/merge-instructions.scm
@@ -0,0 +1,7 @@
+(define-module (backend utils merge-instructions)
+ #:use-module (srfi srfi-1)
+ #:export (merge-instr))
+
+
+(define (merge-instr lst)
+ (append-map (lambda (x) (if (list? (car x)) x (list x))) lst))