mirror of
https://git.savannah.gnu.org/git/guile.git
synced 2025-06-15 08:10:17 +02:00
Add scm-ref, etc instructions for generic heap object field access
* libguile/vm-engine.c (allocate-words, allocate-words/immediate) (scm-ref, scm-set!, scm-ref/tag, scm-set!/tag, scm-ref/immediate) (scm-set!/immediate): New instructions for generic access to fields in heap objects. * module/language/cps/cse.scm (compute-equivalent-subexpressions): * module/language/cps/effects-analysis.scm: * module/language/cps/reify-primitives.scm (reify-primitives): * module/language/cps/specialize-primcalls.scm (specialize-primcalls): * module/language/cps/types.scm (allocate-words) (allocate-words/immediate, scm-ref, scm-ref/immediate, scm-ref/tag) (scm-set!/tag, scm-set!, scm-set!/immediate, word-ref) (word-ref/immediate, word-set!, word-set!/immediate): * module/system/vm/assembler.scm: * module/language/cps/compile-bytecode.scm (compile-function): Add support for the new instructions.
This commit is contained in:
parent
9db628ee29
commit
315dd366ee
8 changed files with 357 additions and 14 deletions
|
@ -39,6 +39,7 @@
|
|||
#:use-module (language cps intmap)
|
||||
#:use-module (language cps intset)
|
||||
#:use-module (system vm assembler)
|
||||
#:use-module (system base types internal)
|
||||
#:export (compile-bytecode))
|
||||
|
||||
(define (kw-arg-ref args kw default)
|
||||
|
@ -155,6 +156,28 @@
|
|||
(emit-define! asm (from-sp dst) (from-sp (slot sym))))
|
||||
(($ $primcall 'resolve (bound?) (name))
|
||||
(emit-resolve asm (from-sp dst) bound? (from-sp (slot name))))
|
||||
(($ $primcall 'allocate-words annotation (nfields))
|
||||
(emit-allocate-words asm (from-sp dst) (from-sp (slot nfields))))
|
||||
(($ $primcall 'allocate-words/immediate (annotation . nfields))
|
||||
(emit-allocate-words/immediate asm (from-sp dst) nfields))
|
||||
(($ $primcall 'scm-ref annotation (obj idx))
|
||||
(emit-scm-ref asm (from-sp dst) (from-sp (slot obj))
|
||||
(from-sp (slot idx))))
|
||||
(($ $primcall 'scm-ref/tag annotation (obj))
|
||||
(let ((tag (match annotation
|
||||
('pair %tc1-pair)
|
||||
('struct %tc3-struct))))
|
||||
(emit-scm-ref/tag asm (from-sp dst) (from-sp (slot obj)) tag)))
|
||||
(($ $primcall 'scm-ref/immediate (annotation . idx) (obj))
|
||||
(emit-scm-ref/immediate asm (from-sp dst) (from-sp (slot obj)) idx))
|
||||
(($ $primcall 'word-ref annotation (obj idx))
|
||||
(emit-word-ref asm (from-sp dst) (from-sp (slot obj))
|
||||
(from-sp (slot idx))))
|
||||
(($ $primcall 'word-ref/immediate (annotation . idx) (obj))
|
||||
(emit-word-ref/immediate asm (from-sp dst) (from-sp (slot obj)) idx))
|
||||
(($ $primcall 'struct-ref/immediate idx (struct))
|
||||
(emit-struct-ref/immediate asm (from-sp dst) (from-sp (slot struct))
|
||||
idx))
|
||||
(($ $primcall 'free-ref idx (closure))
|
||||
(emit-free-ref asm (from-sp dst) (from-sp (slot closure)) idx))
|
||||
(($ $primcall 'vector-ref #f (vector index))
|
||||
|
@ -312,6 +335,24 @@
|
|||
(emit-j asm (forward-label khandler-body))))))
|
||||
(($ $primcall 'cache-current-module! (scope) (mod))
|
||||
(emit-cache-current-module! asm (from-sp (slot mod)) scope))
|
||||
(($ $primcall 'scm-set! annotation (obj idx val))
|
||||
(emit-scm-set! asm (from-sp (slot obj)) (from-sp (slot idx))
|
||||
(from-sp (slot val))))
|
||||
(($ $primcall 'scm-set!/tag annotation (obj val))
|
||||
(let ((tag (match annotation
|
||||
('pair %tc1-pair)
|
||||
('struct %tc3-struct))))
|
||||
(emit-scm-set!/tag asm (from-sp (slot obj)) tag
|
||||
(from-sp (slot val)))))
|
||||
(($ $primcall 'scm-set!/immediate (annotation . idx) (obj val))
|
||||
(emit-scm-set!/immediate asm (from-sp (slot obj)) idx
|
||||
(from-sp (slot val))))
|
||||
(($ $primcall 'word-set! annotation (obj idx val))
|
||||
(emit-word-set! asm (from-sp (slot obj)) (from-sp (slot idx))
|
||||
(from-sp (slot val))))
|
||||
(($ $primcall 'word-set!/immediate (annotation . idx) (obj val))
|
||||
(emit-word-set!/immediate asm (from-sp (slot obj)) idx
|
||||
(from-sp (slot val))))
|
||||
(($ $primcall 'free-set! idx (closure value))
|
||||
(emit-free-set! asm (from-sp (slot closure)) (from-sp (slot value))
|
||||
idx))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue