📄 memory.lisp
字号:
;;;; the Sparc definitions of some general purpose memory reference;;;; VOPs inherited by basic memory reference operations;;;; This software is part of the SBCL system. See the README file for;;;; more information.;;;;;;;; This software is derived from the CMU CL system, which was;;;; written at Carnegie Mellon University and released into the;;;; public domain. The software is in the public domain and is;;;; provided with absolutely no warranty. See the COPYING and CREDITS;;;; files for more information.(in-package "SB!VM");;; Cell-Ref and Cell-Set are used to define VOPs like CAR, where the;;; offset to be read or written is a property of the VOP used.(define-vop (cell-ref) (:args (object :scs (descriptor-reg))) (:results (value :scs (descriptor-reg any-reg))) (:variant-vars offset lowtag) (:policy :fast-safe) (:generator 4 (loadw value object offset lowtag)))(define-vop (cell-set) (:args (object :scs (descriptor-reg)) (value :scs (descriptor-reg any-reg))) (:variant-vars offset lowtag) (:policy :fast-safe) (:generator 4 (storew value object offset lowtag)));;; Slot-Ref and Slot-Set are used to define VOPs like Closure-Ref,;;; where the offset is constant at compile time, but varies for;;; different uses. We add in the stardard g-vector overhead.(define-vop (slot-ref) (:args (object :scs (descriptor-reg))) (:results (value :scs (descriptor-reg any-reg))) (:variant-vars base lowtag) (:info offset) (:generator 4 (loadw value object (+ base offset) lowtag)))(define-vop (slot-set) (:args (object :scs (descriptor-reg)) (value :scs (descriptor-reg any-reg))) (:variant-vars base lowtag) (:info offset) (:generator 4 (storew value object (+ base offset) lowtag)));;;; Indexed references:;;; Define some VOPs for indexed memory reference.(macrolet ((define-indexer (name write-p op shift) `(define-vop (,name) (:args (object :scs (descriptor-reg)) (index :scs (any-reg zero immediate)) ,@(when write-p '((value :scs (any-reg descriptor-reg) :target result)))) (:arg-types * tagged-num ,@(when write-p '(*))) (:temporary (:scs (non-descriptor-reg)) temp) (:results (,(if write-p 'result 'value) :scs (any-reg descriptor-reg))) (:result-types *) (:variant-vars offset lowtag) (:policy :fast-safe) (:generator 5 (sc-case index ((immediate zero) (let ((offset (- (+ (if (sc-is index zero) 0 (ash (tn-value index) (- word-shift ,shift))) (ash offset word-shift)) lowtag))) (etypecase offset ((signed-byte 13) (inst ,op value object offset)) ((or (unsigned-byte 32) (signed-byte 32)) (inst li temp offset) (inst ,op value object temp))))) (t ,@(unless (zerop shift) `((inst srl temp index ,shift))) (inst add temp ,(if (zerop shift) 'index 'temp) (- (ash offset word-shift) lowtag)) (inst ,op value object temp))) ,@(when write-p '((move result value))))))) (define-indexer word-index-ref nil ld 0) (define-indexer word-index-set t st 0) (define-indexer halfword-index-ref nil lduh 1) (define-indexer signed-halfword-index-ref nil ldsh 1) (define-indexer halfword-index-set t sth 1) (define-indexer byte-index-ref nil ldub 2) (define-indexer signed-byte-index-ref nil ldsb 2) (define-indexer byte-index-set t stb 2))
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -