Merge branch 'vendor/GDB'
[dragonfly.git] / contrib / binutils-2.20 / gas / doc / c-sh.texi
1 @c Copyright 1991, 1992, 1993, 1994, 1995, 1997, 2001, 2003, 2004, 2005, 2008
2 @c Free Software Foundation, Inc.
3 @c This is part of the GAS manual.
4 @c For copying conditions, see the file as.texinfo.
5 @page
6 @node SH-Dependent
7 @chapter Renesas / SuperH SH Dependent Features
8
9 @cindex SH support
10 @menu
11 * SH Options::              Options
12 * SH Syntax::               Syntax
13 * SH Floating Point::       Floating Point
14 * SH Directives::           SH Machine Directives
15 * SH Opcodes::              Opcodes
16 @end menu
17
18 @node SH Options
19 @section Options
20
21 @cindex SH options
22 @cindex options, SH
23 @code{@value{AS}} has following command-line options for the Renesas
24 (formerly Hitachi) / SuperH SH family.
25
26 @table @code
27 @kindex --little
28 @kindex --big
29 @kindex --relax
30 @kindex --small
31 @kindex --dsp
32 @kindex --renesas
33 @kindex --allow-reg-prefix
34
35 @item --little
36 Generate little endian code.
37
38 @item --big
39 Generate big endian code.
40
41 @item --relax
42 Alter jump instructions for long displacements.
43
44 @item --small
45 Align sections to 4 byte boundaries, not 16.
46
47 @item --dsp
48 Enable sh-dsp insns, and disable sh3e / sh4 insns.
49
50 @item --renesas
51 Disable optimization with section symbol for compatibility with
52 Renesas assembler.
53
54 @item --allow-reg-prefix
55 Allow '$' as a register name prefix.
56
57 @item --isa=sh4 | sh4a
58 Specify the sh4 or sh4a instruction set.
59 @item --isa=dsp
60 Enable sh-dsp insns, and disable sh3e / sh4 insns.
61 @item --isa=fp
62 Enable sh2e, sh3e, sh4, and sh4a insn sets.
63 @item --isa=all
64 Enable sh1, sh2, sh2e, sh3, sh3e, sh4, sh4a, and sh-dsp insn sets.
65
66 @item -h-tick-hex
67 Support H'00 style hex constants in addition to 0x00 style.
68
69 @end table
70
71 @node SH Syntax
72 @section Syntax
73
74 @menu
75 * SH-Chars::                Special Characters
76 * SH-Regs::                 Register Names
77 * SH-Addressing::           Addressing Modes
78 @end menu
79
80 @node SH-Chars
81 @subsection Special Characters
82
83 @cindex line comment character, SH
84 @cindex SH line comment character
85 @samp{!} is the line comment character.
86
87 @cindex line separator, SH
88 @cindex statement separator, SH
89 @cindex SH line separator
90 You can use @samp{;} instead of a newline to separate statements.
91
92 @cindex symbol names, @samp{$} in
93 @cindex @code{$} in symbol names
94 Since @samp{$} has no special meaning, you may use it in symbol names.
95
96 @node SH-Regs
97 @subsection Register Names
98
99 @cindex SH registers
100 @cindex registers, SH
101 You can use the predefined symbols @samp{r0}, @samp{r1}, @samp{r2},
102 @samp{r3}, @samp{r4}, @samp{r5}, @samp{r6}, @samp{r7}, @samp{r8},
103 @samp{r9}, @samp{r10}, @samp{r11}, @samp{r12}, @samp{r13}, @samp{r14},
104 and @samp{r15} to refer to the SH registers.
105
106 The SH also has these control registers:
107
108 @table @code
109 @item pr
110 procedure register (holds return address)
111
112 @item pc
113 program counter
114
115 @item mach
116 @itemx macl
117 high and low multiply accumulator registers
118
119 @item sr
120 status register
121
122 @item gbr
123 global base register
124
125 @item vbr
126 vector base register (for interrupt vectors)
127 @end table
128
129 @node SH-Addressing
130 @subsection Addressing Modes
131
132 @cindex addressing modes, SH
133 @cindex SH addressing modes
134 @code{@value{AS}} understands the following addressing modes for the SH.
135 @code{R@var{n}} in the following refers to any of the numbered
136 registers, but @emph{not} the control registers.
137
138 @table @code
139 @item R@var{n}
140 Register direct
141
142 @item @@R@var{n}
143 Register indirect
144
145 @item @@-R@var{n}
146 Register indirect with pre-decrement
147
148 @item @@R@var{n}+
149 Register indirect with post-increment
150
151 @item @@(@var{disp}, R@var{n})
152 Register indirect with displacement
153
154 @item @@(R0, R@var{n})
155 Register indexed
156
157 @item @@(@var{disp}, GBR)
158 @code{GBR} offset
159
160 @item @@(R0, GBR)
161 GBR indexed
162
163 @item @var{addr}
164 @itemx @@(@var{disp}, PC)
165 PC relative address (for branch or for addressing memory).  The
166 @code{@value{AS}} implementation allows you to use the simpler form
167 @var{addr} anywhere a PC relative address is called for; the alternate
168 form is supported for compatibility with other assemblers.
169
170 @item #@var{imm}
171 Immediate data
172 @end table
173
174 @node SH Floating Point
175 @section Floating Point
176
177 @cindex floating point, SH (@sc{ieee})
178 @cindex SH floating point (@sc{ieee})
179 SH2E, SH3E and SH4 groups have on-chip floating-point unit (FPU). Other
180 SH groups can use @code{.float} directive to generate @sc{ieee} 
181 floating-point numbers. 
182
183 SH2E and SH3E support single-precision floating point calculations as 
184 well as entirely PCAPI compatible emulation of double-precision 
185 floating point calculations. SH2E and SH3E instructions are a subset of
186 the floating point calculations conforming to the IEEE754 standard.
187
188 In addition to single-precision and double-precision floating-point 
189 operation capability, the on-chip FPU of SH4 has a 128-bit graphic 
190 engine that enables 32-bit floating-point data to be processed 128 
191 bits at a time. It also supports 4 * 4 array operations and inner 
192 product operations. Also, a superscalar architecture is employed that 
193 enables simultaneous execution of two instructions (including FPU 
194 instructions), providing performance of up to twice that of 
195 conventional architectures at the same frequency.
196
197 @node SH Directives
198 @section SH Machine Directives
199
200 @cindex SH machine directives
201 @cindex machine directives, SH
202 @cindex @code{uaword} directive, SH
203 @cindex @code{ualong} directive, SH
204
205 @table @code
206 @item uaword
207 @itemx ualong
208 @code{@value{AS}} will issue a warning when a misaligned @code{.word} or
209 @code{.long} directive is used.  You may use @code{.uaword} or
210 @code{.ualong} to indicate that the value is intentionally misaligned.
211 @end table
212
213 @node SH Opcodes
214 @section Opcodes
215
216 @cindex SH opcode summary
217 @cindex opcode summary, SH
218 @cindex mnemonics, SH
219 @cindex instruction summary, SH
220 For detailed information on the SH machine instruction set, see
221 @cite{SH-Microcomputer User's Manual} (Renesas) or
222 @cite{SH-4 32-bit CPU Core Architecture} (SuperH) and
223 @cite{SuperH (SH) 64-Bit RISC Series} (SuperH).
224
225 @code{@value{AS}} implements all the standard SH opcodes.  No additional
226 pseudo-instructions are needed on this family.  Note, however, that
227 because @code{@value{AS}} supports a simpler form of PC-relative
228 addressing, you may simply write (for example)
229
230 @example
231 mov.l  bar,r0
232 @end example
233
234 @noindent
235 where other assemblers might require an explicit displacement to
236 @code{bar} from the program counter:
237
238 @example
239 mov.l  @@(@var{disp}, PC)
240 @end example
241
242 @ifset SMALL
243 @c this table, due to the multi-col faking and hardcoded order, looks silly
244 @c except in smallbook.  See comments below "@set SMALL" near top of this file.
245
246 Here is a summary of SH opcodes:
247
248 @page
249 @smallexample
250 @i{Legend:}
251 Rn        @r{a numbered register}
252 Rm        @r{another numbered register}
253 #imm      @r{immediate data}
254 disp      @r{displacement}
255 disp8     @r{8-bit displacement}
256 disp12    @r{12-bit displacement}
257
258 add #imm,Rn                    lds.l @@Rn+,PR              
259 add Rm,Rn                      mac.w @@Rm+,@@Rn+           
260 addc Rm,Rn                     mov #imm,Rn                 
261 addv Rm,Rn                     mov Rm,Rn                   
262 and #imm,R0                    mov.b Rm,@@(R0,Rn)          
263 and Rm,Rn                      mov.b Rm,@@-Rn              
264 and.b #imm,@@(R0,GBR)           mov.b Rm,@@Rn               
265 bf disp8                       mov.b @@(disp,Rm),R0        
266 bra disp12                     mov.b @@(disp,GBR),R0       
267 bsr disp12                     mov.b @@(R0,Rm),Rn          
268 bt disp8                       mov.b @@Rm+,Rn              
269 clrmac                         mov.b @@Rm,Rn               
270 clrt                           mov.b R0,@@(disp,Rm)        
271 cmp/eq #imm,R0                 mov.b R0,@@(disp,GBR)       
272 cmp/eq Rm,Rn                   mov.l Rm,@@(disp,Rn)        
273 cmp/ge Rm,Rn                   mov.l Rm,@@(R0,Rn)          
274 cmp/gt Rm,Rn                   mov.l Rm,@@-Rn              
275 cmp/hi Rm,Rn                   mov.l Rm,@@Rn               
276 cmp/hs Rm,Rn                   mov.l @@(disp,Rn),Rm        
277 cmp/pl Rn                      mov.l @@(disp,GBR),R0       
278 cmp/pz Rn                      mov.l @@(disp,PC),Rn        
279 cmp/str Rm,Rn                  mov.l @@(R0,Rm),Rn          
280 div0s Rm,Rn                    mov.l @@Rm+,Rn              
281 div0u                          mov.l @@Rm,Rn               
282 div1 Rm,Rn                     mov.l R0,@@(disp,GBR)       
283 exts.b Rm,Rn                   mov.w Rm,@@(R0,Rn)          
284 exts.w Rm,Rn                   mov.w Rm,@@-Rn              
285 extu.b Rm,Rn                   mov.w Rm,@@Rn               
286 extu.w Rm,Rn                   mov.w @@(disp,Rm),R0        
287 jmp @@Rn                        mov.w @@(disp,GBR),R0       
288 jsr @@Rn                        mov.w @@(disp,PC),Rn        
289 ldc Rn,GBR                     mov.w @@(R0,Rm),Rn          
290 ldc Rn,SR                      mov.w @@Rm+,Rn              
291 ldc Rn,VBR                     mov.w @@Rm,Rn               
292 ldc.l @@Rn+,GBR                 mov.w R0,@@(disp,Rm)        
293 ldc.l @@Rn+,SR                  mov.w R0,@@(disp,GBR)       
294 ldc.l @@Rn+,VBR                 mova @@(disp,PC),R0         
295 lds Rn,MACH                    movt Rn                     
296 lds Rn,MACL                    muls Rm,Rn                  
297 lds Rn,PR                      mulu Rm,Rn                  
298 lds.l @@Rn+,MACH                neg Rm,Rn                   
299 lds.l @@Rn+,MACL                negc Rm,Rn                  
300 @page
301 nop                            stc VBR,Rn                
302 not Rm,Rn                      stc.l GBR,@@-Rn           
303 or #imm,R0                     stc.l SR,@@-Rn            
304 or Rm,Rn                       stc.l VBR,@@-Rn           
305 or.b #imm,@@(R0,GBR)            sts MACH,Rn               
306 rotcl Rn                       sts MACL,Rn               
307 rotcr Rn                       sts PR,Rn                 
308 rotl Rn                        sts.l MACH,@@-Rn          
309 rotr Rn                        sts.l MACL,@@-Rn          
310 rte                            sts.l PR,@@-Rn            
311 rts                            sub Rm,Rn                 
312 sett                           subc Rm,Rn                
313 shal Rn                        subv Rm,Rn                
314 shar Rn                        swap.b Rm,Rn              
315 shll Rn                        swap.w Rm,Rn              
316 shll16 Rn                      tas.b @@Rn                
317 shll2 Rn                       trapa #imm                
318 shll8 Rn                       tst #imm,R0               
319 shlr Rn                        tst Rm,Rn                 
320 shlr16 Rn                      tst.b #imm,@@(R0,GBR)     
321 shlr2 Rn                       xor #imm,R0               
322 shlr8 Rn                       xor Rm,Rn                 
323 sleep                          xor.b #imm,@@(R0,GBR)     
324 stc GBR,Rn                     xtrct Rm,Rn               
325 stc SR,Rn
326 @end smallexample
327 @end ifset
328
329 @ifset Renesas-all
330 @ifclear GENERIC
331 @raisesections
332 @end ifclear
333 @end ifset
334