1 @c Copyright (C) 1991-2024 Free Software Foundation, Inc.
2 @c This is part of the GAS manual.
3 @c For copying conditions, see the file as.texinfo.
6 @node OpenRISC-Dependent
7 @chapter OPENRISC Dependent Features
10 @node Machine Dependencies
11 @chapter OPENRISC Dependent Features
14 @cindex OPENRISC support
16 * OpenRISC-Syntax:: Syntax
17 * OpenRISC-Float:: Floating Point
18 * OpenRISC-Directives:: OpenRISC Machine Directives
19 * OpenRISC-Opcodes:: Opcodes
22 @cindex OPENRISC syntax
23 @cindex syntax, OPENRISC
25 @section OpenRISC Syntax
26 The assembler syntax follows the OpenRISC 1000 Architecture Manual.
29 * OpenRISC-Chars:: Special Characters
30 * OpenRISC-Regs:: Register Names
31 * OpenRISC-Relocs:: Relocations
35 @subsection Special Characters
37 @cindex line comment character, OpenRISC
38 @cindex OpenRISC line comment character
39 A @samp{#} character appearing anywhere on a line indicates the start
40 of a comment that extends to the end of that line.
42 @cindex line separator, OpenRISC
43 @cindex statement separator, OpenRISC
44 @cindex OpenRISC line separator
45 @samp{;} can be used instead of a newline to separate statements.
48 @subsection Register Names
49 @cindex OpenRISC registers
50 @cindex register names, OpenRISC
52 The OpenRISC register file contains 32 general purpose registers.
56 The 32 general purpose registers are referred to as @samp{r@var{n}}.
59 The stack pointer register @samp{r1} can be referenced using the alias
63 The frame pointer register @samp{r2} can be referenced using the alias
67 The link register @samp{r9} can be referenced using the alias @samp{lr}.
70 Floating point operations use the same general purpose registers. The
71 instructions @code{lf.itof.s} (single precision) and @code{lf.itof.d} (double
72 precision) can be used to convert integer values to floating point.
73 Likewise, instructions @code{lf.ftoi.s} (single precision) and
74 @code{lf.ftoi.d} (double precision) can be used to convert floating point to
77 OpenRISC also contains privileged special purpose registers (SPRs). The
78 SPRs are accessed using the @code{l.mfspr} and @code{l.mtspr} instructions.
81 @subsection Relocations
82 @cindex OpenRISC relocations
83 @cindex relocations, OpenRISC
85 ELF relocations are available as defined in the OpenRISC architecture
88 @code{R_OR1K_HI_16_IN_INSN} is obtained using @samp{hi} and
89 @code{R_OR1K_LO_16_IN_INSN} and @code{R_OR1K_SLO16} are obtained using
90 @samp{lo}. For signed offsets @code{R_OR1K_AHI16} is obtained from
91 @samp{ha}. For example:
94 l.movhi r5, hi(symbol)
95 l.ori r5, r5, lo(symbol)
97 l.movhi r5, ha(symbol)
98 l.addi r5, r5, lo(symbol)
101 These ``high'' mnemonics extract bits 31:16 of their operand,
102 and the ``low'' mnemonics extract bits 15:0 of their operand.
104 The PC relative relocation @code{R_OR1K_GOTPC_HI16} can be obtained by
105 enclosing an operand inside of @samp{gotpchi}. Likewise, the
106 @code{R_OR1K_GOTPC_LO16} relocation can be obtained using @samp{gotpclo}.
107 These are mostly used when assembling PIC code. For example, the
108 standard PIC sequence on OpenRISC to get the base of the global offset
109 table, PC relative, into a register, can be performed as:
113 l.movhi r17, gotpchi(_GLOBAL_OFFSET_TABLE_-4)
114 l.ori r17, r17, gotpclo(_GLOBAL_OFFSET_TABLE_+0)
118 Several relocations exist to allow the link editor to perform GOT data
119 references. The @code{R_OR1K_GOT16} relocation can obtained by enclosing an
120 operand inside of @samp{got}. For example, assuming the GOT base is in
124 l.lwz r19, got(a)(r17)
128 Also, several relocations exist for local GOT references. The
129 @code{R_OR1K_GOTOFF_AHI16} relocation can obtained by enclosing an operand
130 inside of @samp{gotoffha}. Likewise, @code{R_OR1K_GOTOFF_LO16} and
131 @code{R_OR1K_GOTOFF_SLO16} can be obtained by enclosing an operand inside of
132 @samp{gotofflo}. For example, assuming the GOT base is in register
136 l.movhi r19, gotoffha(symbol)
138 l.lwz r19, gotofflo(symbol)(r19)
141 The above PC relative relocations use a @code{l.jal} (jump) instruction
142 and reading of the link register to load the PC. OpenRISC also supports
143 page offset PC relative locations without a jump instruction using the
144 @code{l.adrp} instruction. By default the @code{l.adrp} instruction will
145 create an @code{R_OR1K_PCREL_PG21} relocation.
146 Likewise, @code{BFD_RELOC_OR1K_LO13} and @code{BFD_RELOC_OR1K_SLO13} can
147 be obtained by enclosing an operand inside of @samp{po}. For example:
151 l.ori r4, r3, po(symbol)
152 l.lbz r5, po(symbol)(r3)
153 l.sb po(symbol)(r3), r6
156 Likewise the page offset relocations can be used with GOT references. The
157 relocation @code{R_OR1K_GOT_PG21} can be obtained by enclosing an
158 @code{l.adrp} immediate operand inside of @samp{got}. Likewise,
159 @code{R_OR1K_GOT_LO13} can be obtained by enclosing an operand inside of
160 @samp{gotpo}. For example to load the value of a GOT symbol into register
164 l.adrp r17, got(_GLOBAL_OFFSET_TABLE_)
165 l.lwz r5, gotpo(symbol)(r17)
168 There are many relocations that can be requested for access to
169 thread local storage variables. All of the OpenRISC TLS mnemonics
174 @code{R_OR1K_TLS_GD_HI16} is requested using @samp{tlsgdhi}.
176 @code{R_OR1K_TLS_GD_LO16} is requested using @samp{tlsgdlo}.
178 @code{R_OR1K_TLS_GD_PG21} is requested using @samp{tldgd}.
180 @code{R_OR1K_TLS_GD_LO13} is requested using @samp{tlsgdpo}.
183 @code{R_OR1K_TLS_LDM_HI16} is requested using @samp{tlsldmhi}.
185 @code{R_OR1K_TLS_LDM_LO16} is requested using @samp{tlsldmlo}.
187 @code{R_OR1K_TLS_LDM_PG21} is requested using @samp{tldldm}.
189 @code{R_OR1K_TLS_LDM_LO13} is requested using @samp{tlsldmpo}.
192 @code{R_OR1K_TLS_LDO_HI16} is requested using @samp{dtpoffhi}.
194 @code{R_OR1K_TLS_LDO_LO16} is requested using @samp{dtpofflo}.
197 @code{R_OR1K_TLS_IE_HI16} is requested using @samp{gottpoffhi}.
199 @code{R_OR1K_TLS_IE_AHI16} is requested using @samp{gottpoffha}.
201 @code{R_OR1K_TLS_IE_LO16} is requested using @samp{gottpofflo}.
203 @code{R_OR1K_TLS_IE_PG21} is requested using @samp{gottp}.
205 @code{R_OR1K_TLS_IE_LO13} is requested using @samp{gottppo}.
208 @code{R_OR1K_TLS_LE_HI16} is requested using @samp{tpoffhi}.
210 @code{R_OR1K_TLS_LE_AHI16} is requested using @samp{tpoffha}.
212 @code{R_OR1K_TLS_LE_LO16} is requested using @samp{tpofflo}.
214 @code{R_OR1K_TLS_LE_SLO16} also is requested using @samp{tpofflo}
215 depending on the instruction format.
218 Here are some example TLS model sequences.
220 First, General Dynamic:
223 l.movhi r17, tlsgdhi(symbol)
224 l.ori r17, r17, tlsgdlo(symbol)
227 l.jal plt(__tls_get_addr)
234 l.movhi r17, gottpoffhi(symbol)
236 l.lwz r17, gottpofflo(symbol)(r17)
241 And finally, Local Exec:
244 l.movhi r17, tpoffha(symbol)
246 l.addi r17, r17, tpofflo(symbol)
251 @section Floating Point
253 @cindex floating point, OPENRISC (@sc{ieee})
254 @cindex OPENRISC floating point (@sc{ieee})
255 OpenRISC uses @sc{ieee} floating-point numbers.
257 @node OpenRISC-Directives
258 @section OpenRISC Machine Directives
260 @cindex OPENRISC machine directives
261 @cindex machine directives, OPENRISC
262 The OpenRISC version of @code{@value{AS}} supports the following additional
266 @cindex @code{align} directive, OpenRISC
268 This must be followed by the desired alignment in bytes.
270 @cindex @code{word} directive, OpenRISC
272 On the OpenRISC, the @code{.word} directive produces a 32 bit value.
274 @cindex @code{nodelay} directive, OpenRISC
276 On the OpenRISC, the @code{.nodelay} directive sets a flag in elf binaries
277 indicating that the binary is generated catering for no delay slots.
279 @cindex @code{proc} directive, OpenRISC
281 This directive is ignored. Any text following it on the same
282 line is also ignored.
284 @cindex @code{endproc} directive, OpenRISC
286 This directive is ignored. Any text following it on the same
287 line is also ignored.
290 @node OpenRISC-Opcodes
293 @cindex OpenRISC opcode summary
294 @cindex opcode summary, OpenRISC
295 @cindex mnemonics, OpenRISC
296 @cindex instruction summary, LM32
297 For detailed information on the OpenRISC machine instruction set, see
298 @url{http://www.openrisc.io/architecture/}.
300 @code{@value{AS}} implements all the standard OpenRISC opcodes.