mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-04-30 20:00:19 +02:00
RTL compiler: Compile TC7 branches.
* module/system/vm/assembler.scm: * module/system/vm/disassembler.scm (code-annotation): * module/language/cps/primitives.scm (*branching-primcall-arities*): * module/language/cps/compile-rtl.scm (emit-rtl-sequence): Add support for compiling symbol?, variable?, vector?, and string? branches.
This commit is contained in:
parent
4fc6b4d2c5
commit
be8b62ca7f
5 changed files with 57 additions and 4 deletions
|
@ -214,9 +214,19 @@ address of that offset."
|
|||
(((or 'br
|
||||
'br-if-nargs-ne 'br-if-nargs-lt 'br-if-nargs-gt
|
||||
'br-if-true 'br-if-null 'br-if-nil 'br-if-pair 'br-if-struct
|
||||
'br-if-char 'br-if-tc7 'br-if-eq 'br-if-eqv 'br-if-equal
|
||||
'br-if-char 'br-if-eq 'br-if-eqv 'br-if-equal
|
||||
'br-if-= 'br-if-< 'br-if-<= 'br-if-> 'br-if->=) _ ... target)
|
||||
(list "-> ~A" (vector-ref labels (- (+ offset target) start))))
|
||||
(('br-if-tc7 slot invert? tc7 target)
|
||||
(list "~A -> ~A"
|
||||
(let ((tag (case tc7
|
||||
((5) "symbol?")
|
||||
((7) "variable?")
|
||||
((13) "vector?")
|
||||
((15) "string?")
|
||||
(else (number->string tc7)))))
|
||||
(if invert? (string-append "not " tag) tag))
|
||||
(vector-ref labels (- (+ offset target) start))))
|
||||
(('prompt tag escape-only? proc-slot handler)
|
||||
;; The H is for handler.
|
||||
(list "H -> ~A" (vector-ref labels (- (+ offset handler) start))))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue