⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 memory.lisp

📁 开源跨平台Lisp编译器
💻 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 + -