1 ;;;; the Sparc definitions of some general purpose memory reference
2 ;;;; VOPs inherited by basic memory reference operations
4 ;;;; This software is part of the SBCL system. See the README file for
7 ;;;; This software is derived from the CMU CL system, which was
8 ;;;; written at Carnegie Mellon University and released into the
9 ;;;; public domain. The software is in the public domain and is
10 ;;;; provided with absolutely no warranty. See the COPYING and CREDITS
11 ;;;; files for more information.
15 ;;; Cell-Ref and Cell-Set are used to define VOPs like CAR, where the
16 ;;; offset to be read or written is a property of the VOP used.
17 (define-vop (cell-ref)
18 (:args
(object :scs
(descriptor-reg)))
19 (:results
(value :scs
(descriptor-reg any-reg
)))
20 (:variant-vars offset lowtag
)
23 (loadw value object offset lowtag
)))
25 (define-vop (cell-set)
26 (:args
(object :scs
(descriptor-reg))
27 (value :scs
(descriptor-reg any-reg
)))
28 (:variant-vars offset lowtag
)
31 (storew value object offset lowtag
)))
34 ;;;; Indexed references:
36 ;;; Define some VOPs for indexed memory reference.
37 (macrolet ((define-indexer (name write-p op shift
)
39 (:args
(object :scs
(descriptor-reg))
40 (index :scs
(any-reg zero immediate
))
41 ,@(when write-p
'((value :scs
(any-reg descriptor-reg
)))))
42 (:arg-types
* tagged-num
,@(when write-p
'(*)))
43 (:temporary
(:scs
(non-descriptor-reg)) temp
)
45 `((:results
(value :scs
(any-reg descriptor-reg
)))
47 (:variant-vars offset lowtag
)
52 (let ((offset (- (+ (if (sc-is index zero
)
55 (- word-shift
,shift
)))
56 (ash offset word-shift
))
60 (inst ,op value object offset
))
61 ((or (unsigned-byte 32) (signed-byte 32))
63 (inst ,op value object temp
)))))
65 ,@(unless (zerop shift
)
66 `((inst srl temp index
,shift
)))
67 (inst add temp
,(if (zerop shift
) 'index
'temp
)
68 (- (ash offset word-shift
) lowtag
))
69 (inst ,op value object temp
)))))))
70 (define-indexer word-index-ref nil ld
0)
71 (define-indexer word-index-set t st
0)
72 (define-indexer halfword-index-ref nil lduh
1)
73 (define-indexer signed-halfword-index-ref nil ldsh
1)
74 (define-indexer halfword-index-set t sth
1)
75 (define-indexer byte-index-ref nil ldub
2)
76 (define-indexer signed-byte-index-ref nil ldsb
2)
77 (define-indexer byte-index-set t stb
2))