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

📄 array.lisp

📁 开源跨平台Lisp编译器
💻 LISP
📖 第 1 页 / 共 2 页
字号:
;;;; the Alpha definitions for array 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");;;; allocator for the array header(define-vop (make-array-header)  (:policy :fast-safe)  (:translate make-array-header)  (:args (type :scs (any-reg))         (rank :scs (any-reg)))  (:arg-types positive-fixnum positive-fixnum)  (:temporary (:scs (any-reg)) bytes)  (:temporary (:scs (non-descriptor-reg)) header)  (:results (result :scs (descriptor-reg)))  (:generator 13    (inst addq rank (+ (* (1+ array-dimensions-offset) n-word-bytes)                       lowtag-mask)          bytes)    (inst li (lognot lowtag-mask) header)    (inst and bytes header bytes)    (inst addq rank (fixnumize (1- array-dimensions-offset)) header)    (inst sll header n-widetag-bits header)    (inst bis header type header)    (inst srl header n-fixnum-tag-bits header)    (pseudo-atomic ()      (inst bis alloc-tn other-pointer-lowtag result)      (storew header result 0 other-pointer-lowtag)      (inst addq alloc-tn bytes alloc-tn))));;;; additional accessors and setters for the array header(define-full-reffer %array-dimension *  array-dimensions-offset other-pointer-lowtag  (any-reg) positive-fixnum sb!kernel:%array-dimension)(define-full-setter %set-array-dimension *  array-dimensions-offset other-pointer-lowtag  (any-reg) positive-fixnum sb!kernel:%set-array-dimension #!+gengc nil)(define-vop (array-rank-vop)  (:translate sb!kernel:%array-rank)  (:policy :fast-safe)  (:args (x :scs (descriptor-reg)))  (:temporary (:scs (non-descriptor-reg)) temp)  (:results (res :scs (any-reg descriptor-reg)))  (:generator 6    (loadw temp x 0 other-pointer-lowtag)    (inst sra temp n-widetag-bits temp)    (inst subq temp (1- array-dimensions-offset) temp)    (inst sll temp n-fixnum-tag-bits res)));;;; bounds checking routine(define-vop (check-bound)  (:translate %check-bound)  (:policy :fast-safe)  (:args (array :scs (descriptor-reg))         (bound :scs (any-reg descriptor-reg))         (index :scs (any-reg descriptor-reg) :target result))  (:results (result :scs (any-reg descriptor-reg)))  (:temporary (:scs (non-descriptor-reg)) temp)  (:vop-var vop)  (:save-p :compute-only)  (:generator 5    (let ((error (generate-error-code vop invalid-array-index-error                                      array bound index)))      (inst cmpult index bound temp)      (inst beq temp error)      (move index result))));;;; accessors/setters;;; Variants built on top of word-index-ref, etc. I.e. those vectors;;; whose elements are represented in integer registers and are built;;; out of 8, 16, or 32 bit elements.(macrolet ((def-full-data-vector-frobs (type element-type &rest scs)             `(progn                (define-full-reffer ,(symbolicate "DATA-VECTOR-REF/" type)                  ,type                  vector-data-offset other-pointer-lowtag                  ,(remove-if (lambda (x) (member x '(null zero))) scs)                  ,element-type                  data-vector-ref)                (define-full-setter ,(symbolicate "DATA-VECTOR-SET/" type)                  ,type                  vector-data-offset other-pointer-lowtag ,scs ,element-type                  data-vector-set #+gengc ,(if (member 'descriptor-reg scs)                                               t                                               nil))))           (def-partial-data-vector-frobs             (type element-type size signed &rest scs)             `(progn                (define-partial-reffer ,(symbolicate "DATA-VECTOR-REF/" type)                  ,type                  ,size ,signed vector-data-offset other-pointer-lowtag ,scs                  ,element-type data-vector-ref)                (define-partial-setter ,(symbolicate "DATA-VECTOR-SET/" type)                  ,type                  ,size vector-data-offset other-pointer-lowtag ,scs                  ,element-type data-vector-set)))           (def-small-data-vector-frobs (type bits)             (let* ((elements-per-word (floor n-word-bits bits))                    (bit-shift (1- (integer-length elements-per-word))))               `(progn                  (define-vop (,(symbolicate 'data-vector-ref/ type))                    (:note "inline array access")                    (:translate data-vector-ref)                    (:policy :fast-safe)                    (:args (object :scs (descriptor-reg))                           (index :scs (unsigned-reg)))                    (:arg-types ,type positive-fixnum)                    (:results (value :scs (any-reg)))                    (:result-types positive-fixnum)                    (:temporary (:scs (interior-reg)) lip)                    (:temporary (:scs (non-descriptor-reg) :to (:result 0))                                temp result)                    (:generator 20                                (inst srl index ,bit-shift temp)                                (inst sll temp n-fixnum-tag-bits temp)                                (inst addq object temp lip)                                (inst ldl result                                      (- (* vector-data-offset n-word-bytes)                                         other-pointer-lowtag)                                      lip)                                (inst and index ,(1- elements-per-word) temp)                                ,@(unless (= bits 1)                                    `((inst sll temp                                            ,(1- (integer-length bits)) temp)))                                (inst srl result temp result)                                (inst and result ,(1- (ash 1 bits)) result)                                (inst sll result n-fixnum-tag-bits value)))                  (define-vop (,(symbolicate 'data-vector-ref-c/ type))                    (:translate data-vector-ref)                    (:policy :fast-safe)                    (:args (object :scs (descriptor-reg)))                    (:arg-types ,type                                (:constant                                 (integer 0                                          ,(1- (* (1+ (- (floor (+ #x7fff                                                                   other-pointer-lowtag)                                                                n-word-bytes)                                                         vector-data-offset))                                                  elements-per-word)))))                    (:info index)                    (:results (result :scs (unsigned-reg)))                    (:result-types positive-fixnum)                    (:generator 15                                (multiple-value-bind (word extra)                                    (floor index ,elements-per-word)                                  (loadw result object (+ word                                                          vector-data-offset)                                         other-pointer-lowtag)                                  (unless (zerop extra)                                    (inst srl result (* extra ,bits) result))                                  (unless (= extra ,(1- elements-per-word))                                    (inst and result ,(1- (ash 1 bits))                                          result)))))                  (define-vop (,(symbolicate 'data-vector-set/ type))                    (:note "inline array store")                    (:translate data-vector-set)                    (:policy :fast-safe)                    (:args (object :scs (descriptor-reg))                           (index :scs (unsigned-reg) :target shift)                           (value :scs (unsigned-reg zero immediate)                                  :target result))                    (:arg-types ,type positive-fixnum positive-fixnum)                    (:results (result :scs (unsigned-reg)))                    (:result-types positive-fixnum)                    (:temporary (:scs (interior-reg)) lip)                    (:temporary (:scs (non-descriptor-reg)) temp old)                    (:temporary (:scs (non-descriptor-reg)                                      :from (:argument 1)) shift)                    (:generator 25                                (inst srl index ,bit-shift temp)                                (inst sll temp n-fixnum-tag-bits temp)                                (inst addq object temp lip)                                (inst ldl old                                      (- (* vector-data-offset n-word-bytes)                                         other-pointer-lowtag)                                      lip)                                (inst and index ,(1- elements-per-word) shift)                                ,@(unless (= bits 1)                                    `((inst sll shift ,(1- (integer-length                                                            bits))                                            shift)))                                (unless (and (sc-is value immediate)                                             (= (tn-value value)                                                ,(1- (ash 1 bits))))                                  (inst li ,(1- (ash 1 bits)) temp)                                  (inst sll temp shift temp)                                  (inst not temp temp)                                  (inst and old temp old))                                (unless (sc-is value zero)                                  (sc-case value                                           (immediate                                            (inst li                                                  (logand (tn-value value)                                                          ,(1- (ash 1 bits)))                                                  temp))                                           (unsigned-reg                                            (inst and value                                                  ,(1- (ash 1 bits))                                                  temp)))                                  (inst sll temp shift temp)                                  (inst bis old temp old))                                (inst stl old                                      (- (* vector-data-offset n-word-bytes)                                         other-pointer-lowtag)                                      lip)                                (sc-case value                                         (immediate                                          (inst li (tn-value value) result))                                         (zero                                          (move zero-tn result))                                         (unsigned-reg                                          (move value result)))))                  (define-vop (,(symbolicate 'data-vector-set-c/ type))                    (:translate data-vector-set)                    (:policy :fast-safe)                    (:args (object :scs (descriptor-reg))                           (value :scs (unsigned-reg zero immediate)                                  :target result))                    (:arg-types ,type                                (:constant                                 (integer 0                                          ,(1- (* (1+ (- (floor (+ #x7fff                                                                   other-pointer-lowtag)                                                                n-word-bytes)                                                         vector-data-offset))                                                  elements-per-word))))                                positive-fixnum)                    (:info index)                    (:results (result :scs (unsigned-reg)))                    (:result-types positive-fixnum)                    (:temporary (:scs (non-descriptor-reg)) temp old)                    (:generator 20                                (multiple-value-bind (word extra)                                    (floor index ,elements-per-word)                                  (inst ldl old                                        (- (* (+ word vector-data-offset)                                              n-word-bytes)                                           other-pointer-lowtag)                                        object)                                  (unless (and (sc-is value immediate)                                               (= (tn-value value)                                                  ,(1- (ash 1 bits))))                                    (cond #+#.(cl:if                                             (cl:= sb-vm:n-word-bits sb-vm:n-machine-word-bits)                                             '(and) '(or))                                          ((= extra ,(1- elements-per-word))                                           (inst sll old ,bits old)                                           (inst srl old ,bits old))                                          (t                                           (inst li                                                 (lognot (ash ,(1- (ash 1                                                                        bits))                                                              (* extra ,bits)))                                                 temp)                                           (inst and old temp old))))                                  (sc-case value                                           (zero)                                           (immediate                                            (let ((value                                                   (ash (logand (tn-value                                                                 value)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -