-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcompile-ops.rkt
59 lines (54 loc) · 1.35 KB
/
compile-ops.rkt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#lang racket
(provide compile-op0 compile-op1)
(require "ast.rkt")
(require "types.rkt")
(require "assert.rkt")
(require a86/ast)
(define rax 'rax)
(define rdi 'rdi) ; arg
(define r9 'r9) ; scratch
;; Op0 -> Asm
(define (compile-op0 p)
(match p
['void (seq (Mov rax (value->bits (void))))]
['read-byte (seq (Call 'read_byte))]
['peek-byte (seq (Call 'peek_byte))]))
;; Op1 -> Asm
(define (compile-op1 p)
(match p
['add1
(seq (assert-integer rax)
(Add rax (value->bits 1)))]
['sub1
(seq (assert-integer rax)
(Sub rax (value->bits 1)))]
['zero?
(seq (assert-integer rax)
(Cmp rax 0)
if-equal)]
['char?
(seq (And rax mask-char)
(Cmp rax type-char)
if-equal)]
['char->integer
(seq (assert-char rax)
(Sar rax char-shift)
(Sal rax int-shift))]
['integer->char
(seq (assert-codepoint rax)
(Sar rax int-shift)
(Sal rax char-shift)
(Xor rax type-char))]
['eof-object?
(seq (Cmp rax (value->bits eof))
if-equal)]
['write-byte
(seq (assert-byte rax)
(Mov rdi rax)
(Call 'write_byte))]))
;; Asm
;; set rax to #t or #f if comparison flag is equal
(define if-equal
(seq (Mov rax (value->bits #f))
(Mov r9 (value->bits #t))
(Cmove rax r9)))