1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
|
@c Copyright (C) 2000-2017 Free Software Foundation, Inc.
@c This is part of the GAS manual.
@c For copying conditions, see the file as.texinfo.
@ifset GENERIC
@page
@node ARC-Dependent
@chapter ARC Dependent Features
@end ifset
@ifclear GENERIC
@node Machine Dependencies
@chapter ARC Dependent Features
@end ifclear
@set ARC_CORE_DEFAULT 6
@cindex ARC support
@menu
* ARC Options:: Options
* ARC Syntax:: Syntax
* ARC Directives:: ARC Machine Directives
* ARC Modifiers:: ARC Assembler Modifiers
* ARC Symbols:: ARC Pre-defined Symbols
* ARC Opcodes:: Opcodes
@end menu
@node ARC Options
@section Options
@cindex ARC options
@cindex options for ARC
The following options control the type of CPU for which code is
assembled, and generic constraints on the code generated:
@table @code
@item -mcpu=@var{cpu}
@cindex @code{-mcpu=@var{cpu}} command line option, ARC
Set architecture type and register usage for @var{cpu}. There are
also shortcut alias options available for backward compatibility and
convenience. Supported values for @var{cpu} are
@table @code
@cindex @code{mA6} command line option, ARC
@cindex @code{marc600} command line option, ARC
@item arc600
Assemble for ARC 600. Aliases: @code{-mA6}, @code{-mARC600}.
@item arc600_norm
Assemble for ARC 600 with norm instructions.
@item arc600_mul64
Assemble for ARC 600 with mul64 instructions.
@item arc600_mul32x16
Assemble for ARC 600 with mul32x16 instructions.
@item arc601
@cindex @code{mARC601} command line option, ARC
Assemble for ARC 601. Alias: @code{-mARC601}.
@item arc601_norm
Assemble for ARC 601 with norm instructions.
@item arc601_mul64
Assemble for ARC 601 with mul64 instructions.
@item arc601_mul32x16
Assemble for ARC 601 with mul32x16 instructions.
@item arc700
@cindex @code{mA7} command line option, ARC
@cindex @code{mARC700} command line option, ARC
Assemble for ARC 700. Aliases: @code{-mA7}, @code{-mARC700}.
@item arcem
@cindex @code{mEM} command line option, ARC
Assemble for ARC EM. Aliases: @code{-mEM}
@item em
Assemble for ARC EM, identical as arcem variant.
@item em4
Assemble for ARC EM with code-density instructions.
@item em4_dmips
Assemble for ARC EM with code-density instructions.
@item em4_fpus
Assemble for ARC EM with code-density instructions.
@item em4_fpuda
Assemble for ARC EM with code-density, and double-precision assist
instructions.
@item quarkse_em
Assemble for QuarkSE-EM cpu.
@item archs
@cindex @code{mHS} command line option, ARC
Assemble for ARC HS. Aliases: @code{-mHS}, @code{-mav2hs}.
@item hs
Assemble for ARC HS.
@item hs34
Assemble for ARC HS34.
@item hs38
Assemble for ARC HS38.
@item hs38_linux
Assemble for ARC HS38 with floating point support on.
@item nps400
@cindex @code{mnps400} command line option, ARC
Assemble for ARC 700 with NPS-400 extended instructions.
@end table
Note: the @code{.cpu} directive (@pxref{ARC Directives}) can
to be used to select a core variant from within assembly code.
@cindex @code{-EB} command line option, ARC
@item -EB
This option specifies that the output generated by the assembler should
be marked as being encoded for a big-endian processor.
@cindex @code{-EL} command line option, ARC
@item -EL
This option specifies that the output generated by the assembler should
be marked as being encoded for a little-endian processor - this is the
default.
@cindex @code{-mcode-density} command line option, ARC
@item -mcode-density
This option turns on Code Density instructions. Only valid for ARC EM
processors.
@cindex @code{-mrelax} command line option, ARC
@item -mrelax
Enable support for assembly-time relaxation. The assembler will
replace a longer version of an instruction with a shorter one,
whenever it is possible.
@cindex @code{-mnps400} command line option, ARC
@item -mnps400
Enable support for NPS-400 extended instructions.
@cindex @code{-mspfp} command line option, ARC
@item -mspfp
Enable support for single-precision floating point instructions.
@cindex @code{-mdpfp} command line option, ARC
@item -mdpfp
Enable support for double-precision floating point instructions.
@cindex @code{-mfpuda} command line option, ARC
@item -mfpuda
Enable support for double-precision assist floating point instructions.
Only valid for ARC EM processors.
@end table
@node ARC Syntax
@section Syntax
@menu
* ARC-Chars:: Special Characters
* ARC-Regs:: Register Names
@end menu
@node ARC-Chars
@subsection Special Characters
@table @code
@item %
@cindex register name prefix character, ARC
@cindex ARC register name prefix character
A register name can optionally be prefixed by a @samp{%} character. So
register @code{%r0} is equivalent to @code{r0} in the assembly code.
@item #
@cindex line comment character, ARC
@cindex ARC line comment character
The presence of a @samp{#} character within a line (but not at the
start of a line) indicates the start of a comment that extends to the
end of the current line.
@emph{Note:} if a line starts with a @samp{#} character then it can
also be a logical line number directive (@pxref{Comments}) or a
preprocessor control command (@pxref{Preprocessing}).
@item @@
@cindex symbol prefix character, ARC
@cindex ARC symbol prefix character
Prefixing an operand with an @samp{@@} specifies that the operand is a
symbol and not a register. This is how the assembler disambiguates
the use of an ARC register name as a symbol. So the instruction
@example
mov r0, @@r0
@end example
moves the address of symbol @code{r0} into register @code{r0}.
@item `
@cindex line separator, ARC
@cindex statement separator, ARC
@cindex ARC line separator
The @samp{`} (backtick) character is used to separate statements on a
single line.
@cindex line
@item -
@cindex C preprocessor macro separator, ARC
@cindex ARC C preprocessor macro separator
Used as a separator to obtain a sequence of commands from a C
preprocessor macro.
@end table
@node ARC-Regs
@subsection Register Names
@cindex ARC register names
@cindex register names, ARC
The ARC assembler uses the following register names for its core
registers:
@table @code
@item r0-r31
@cindex core general registers, ARC
@cindex ARC core general registers
The core general registers. Registers @code{r26} through @code{r31}
have special functions, and are usually referred to by those synonyms.
@item gp
@cindex global pointer, ARC
@cindex ARC global pointer
The global pointer and a synonym for @code{r26}.
@item fp
@cindex frame pointer, ARC
@cindex ARC frame pointer
The frame pointer and a synonym for @code{r27}.
@item sp
@cindex stack pointer, ARC
@cindex ARC stack pointer
The stack pointer and a synonym for @code{r28}.
@item ilink1
@cindex level 1 interrupt link register, ARC
@cindex ARC level 1 interrupt link register
For ARC 600 and ARC 700, the level 1 interrupt link register and a
synonym for @code{r29}. Not supported for ARCv2.
@item ilink
@cindex interrupt link register, ARC
@cindex ARC interrupt link register
For ARCv2, the interrupt link register and a synonym for @code{r29}.
Not supported for ARC 600 and ARC 700.
@item ilink2
@cindex level 2 interrupt link register, ARC
@cindex ARC level 2 interrupt link register
For ARC 600 and ARC 700, the level 2 interrupt link register and a
synonym for @code{r30}. Not supported for ARC v2.
@item blink
@cindex link register, ARC
@cindex ARC link register
The link register and a synonym for @code{r31}.
@item r32-r59
@cindex extension core registers, ARC
@cindex ARC extension core registers
The extension core registers.
@item lp_count
@cindex loop counter, ARC
@cindex ARC loop counter
The loop count register.
@item pcl
@cindex word aligned program counter, ARC
@cindex ARC word aligned program counter
The word aligned program counter.
@end table
In addition the ARC processor has a large number of @emph{auxiliary
registers}. The precise set depends on the extensions being
supported, but the following baseline set are always defined:
@table @code
@item identity
@cindex Processor Identification register, ARC
@cindex ARC Processor Identification register
Processor Identification register. Auxiliary register address 0x4.
@item pc
@cindex Program Counter, ARC
@cindex ARC Program Counter
Program Counter. Auxiliary register address 0x6.
@item status32
@cindex Status register, ARC
@cindex ARC Status register
Status register. Auxiliary register address 0x0a.
@item bta
@cindex Branch Target Address, ARC
@cindex ARC Branch Target Address
Branch Target Address. Auxiliary register address 0x412.
@item ecr
@cindex Exception Cause Register, ARC
@cindex ARC Exception Cause Register
Exception Cause Register. Auxiliary register address 0x403.
@item int_vector_base
@cindex Interrupt Vector Base address, ARC
@cindex ARC Interrupt Vector Base address
Interrupt Vector Base address. Auxiliary register address 0x25.
@item status32_p0
@cindex Stored STATUS32 register on entry to level P0 interrupts, ARC
@cindex ARC Stored STATUS32 register on entry to level P0 interrupts
Stored STATUS32 register on entry to level P0 interrupts. Auxiliary
register address 0xb.
@item aux_user_sp
@cindex Saved User Stack Pointer, ARC
@cindex ARC Saved User Stack Pointer
Saved User Stack Pointer. Auxiliary register address 0xd.
@item eret
@cindex Exception Return Address, ARC
@cindex ARC Exception Return Address
Exception Return Address. Auxiliary register address 0x400.
@item erbta
@cindex BTA saved on exception entry, ARC
@cindex ARC BTA saved on exception entry
BTA saved on exception entry. Auxiliary register address 0x401.
@item erstatus
@cindex STATUS32 saved on exception, ARC
@cindex ARC STATUS32 saved on exception
STATUS32 saved on exception. Auxiliary register address 0x402.
@item bcr_ver
@cindex Build Configuration Registers Version, ARC
@cindex ARC Build Configuration Registers Version
Build Configuration Registers Version. Auxiliary register address 0x60.
@item bta_link_build
@cindex Build configuration for: BTA Registers, ARC
@cindex ARC Build configuration for: BTA Registers
Build configuration for: BTA Registers. Auxiliary register address 0x63.
@item vecbase_ac_build
@cindex Build configuration for: Interrupts, ARC
@cindex ARC Build configuration for: Interrupts
Build configuration for: Interrupts. Auxiliary register address 0x68.
@item rf_build
@cindex Build configuration for: Core Registers, ARC
@cindex ARC Build configuration for: Core Registers
Build configuration for: Core Registers. Auxiliary register address 0x6e.
@item dccm_build
@cindex DCCM RAM Configuration Register, ARC
@cindex ARC DCCM RAM Configuration Register
DCCM RAM Configuration Register. Auxiliary register address 0xc1.
@end table
Additional auxiliary register names are defined according to the
processor architecture version and extensions selected by the options.
@node ARC Directives
@section ARC Machine Directives
@cindex machine directives, ARC
@cindex ARC machine directives
The ARC version of @code{@value{AS}} supports the following additional
machine directives:
@table @code
@cindex @code{lcomm} directive
@item .lcomm @var{symbol}, @var{length}[, @var{alignment}]
Reserve @var{length} (an absolute expression) bytes for a local common
denoted by @var{symbol}. The section and value of @var{symbol} are
those of the new local common. The addresses are allocated in the bss
section, so that at run-time the bytes start off zeroed. Since
@var{symbol} is not declared global, it is normally not visible to
@code{@value{LD}}. The optional third parameter, @var{alignment},
specifies the desired alignment of the symbol in the bss section,
specified as a byte boundary (for example, an alignment of 16 means
that the least significant 4 bits of the address should be zero). The
alignment must be an absolute expression, and it must be a power of
two. If no alignment is specified, as will set the alignment to the
largest power of two less than or equal to the size of the symbol, up
to a maximum of 16.
@cindex @code{lcommon} directive, ARC
@item .lcommon @var{symbol}, @var{length}[, @var{alignment}]
The same as @code{lcomm} directive.
@cindex @code{cpu} directive, ARC
@item .cpu @var{cpu}
The @code{.cpu} directive must be followed by the desired core
version. Permitted values for CPU are:
@table @code
@item ARC600
Assemble for the ARC600 instruction set.
@item arc600_norm
Assemble for ARC 600 with norm instructions.
@item arc600_mul64
Assemble for ARC 600 with mul64 instructions.
@item arc600_mul32x16
Assemble for ARC 600 with mul32x16 instructions.
@item arc601
Assemble for ARC 601 instruction set.
@item arc601_norm
Assemble for ARC 601 with norm instructions.
@item arc601_mul64
Assemble for ARC 601 with mul64 instructions.
@item arc601_mul32x16
Assemble for ARC 601 with mul32x16 instructions.
@item ARC700
Assemble for the ARC700 instruction set.
@item NPS400
Assemble for the NPS400 instruction set.
@item EM
Assemble for the ARC EM instruction set.
@item arcem
Assemble for ARC EM instruction set
@item em4
Assemble for ARC EM with code-density instructions.
@item em4_dmips
Assemble for ARC EM with code-density instructions.
@item em4_fpus
Assemble for ARC EM with code-density instructions.
@item em4_fpuda
Assemble for ARC EM with code-density, and double-precision assist
instructions.
@item quarkse_em
Assemble for QuarkSE-EM instruction set.
@item HS
Assemble for the ARC HS instruction set.
@item archs
Assemble for ARC HS instruction set.
@item hs
Assemble for ARC HS instruction set.
@item hs34
Assemble for ARC HS34 instruction set.
@item hs38
Assemble for ARC HS38 instruction set.
@item hs38_linux
Assemble for ARC HS38 with floating point support on.
@end table
Note: the @code{.cpu} directive overrides the command line option
@code{-mcpu=@var{cpu}}; a warning is emitted when the version is not
consistent between the two.
@item .extAuxRegister @var{name}, @var{addr}, @var{mode}
@cindex @code{extAuxRegister} directive, ARC
Auxiliary registers can be defined in the assembler source code by
using this directive. The first parameter, @var{name}, is the name of the
new auxiliary register. The second parameter, @var{addr}, is
address the of the auxiliary register. The third parameter,
@var{mode}, specifies whether the register is readable and/or writable
and is one of:
@table @code
@item r
Read only;
@item w
Write only;
@item r|w
Read and write.
@end table
For example:
@example
.extAuxRegister mulhi, 0x12, w
@end example
specifies a write only extension auxiliary register, @var{mulhi} at
address 0x12.
@item .extCondCode @var{suffix}, @var{val}
@cindex @code{extCondCode} directive, ARC
ARC supports extensible condition codes. This directive defines a new
condition code, to be known by the suffix, @var{suffix} and will
depend on the value, @var{val} in the condition code.
For example:
@example
.extCondCode is_busy,0x14
add.is_busy r1,r2,r3
@end example
will only execute the @code{add} instruction if the condition code
value is 0x14.
@item .extCoreRegister @var{name}, @var{regnum}, @var{mode}, @var{shortcut}
@cindex @code{extCoreRegister} directive, ARC
Specifies an extension core register named @var{name} as a synonym for
the register numbered @var{regnum}. The register number must be
between 32 and 59. The third argument, @var{mode}, indicates whether
the register is readable and/or writable and is one of:
@table @code
@item r
Read only;
@item w
Write only;
@item r|w
Read and write.
@end table
The final parameter, @var{shortcut} indicates whether the register has
a short cut in the pipeline. The valid values are:
@table @code
@item can_shortcut
The register has a short cut in the pipeline;
@item cannot_shortcut
The register does not have a short cut in the pipeline.
@end table
For example:
@example
.extCoreRegister mlo, 57, r , can_shortcut
@end example
defines a read only extension core register, @code{mlo}, which is
register 57, and can short cut the pipeline.
@item .extInstruction @var{name}, @var{opcode}, @var{subopcode}, @var{suffixclass}, @var{syntaxclass}
@cindex @code{extInstruction} directive, ARC
ARC allows the user to specify extension instructions. These
extension instructions are not macros; the assembler creates encodings
for use of these instructions according to the specification by the
user.
The first argument, @var{name}, gives the name of the instruction.
The second argument, @var{opcode}, is the opcode to be used (bits 31:27
in the encoding).
The third argument, @var{subopcode}, is the sub-opcode to be used, but
the correct value also depends on the fifth argument,
@var{syntaxclass}
The fourth argument, @var{suffixclass}, determines the kinds of
suffixes to be allowed. Valid values are:
@table @code
@item SUFFIX_NONE
No suffixes are permitted;
@item SUFFIX_COND
Conditional suffixes are permitted;
@item SUFFIX_FLAG
Flag setting suffixes are permitted.
@item SUFFIX_COND|SUFFIX_FLAG
Both conditional and flag setting suffices are permitted.
@end table
The fifth and final argument, @var{syntaxclass}, determines the syntax
class for the instruction. It can have the following values:
@table @code
@item SYNTAX_2OP
Two Operand Instruction;
@item SYNTAX_3OP
Three Operand Instruction.
@item SYNTAX_1OP
One Operand Instruction.
@item SYNTAX_NOP
No Operand Instruction.
@end table
The syntax class may be followed by @samp{|} and one of the following
modifiers.
@table @code
@item OP1_MUST_BE_IMM
Modifies syntax class @code{SYNTAX_3OP}, specifying that the first
operand of a three-operand instruction must be an immediate (i.e., the
result is discarded). This is usually used to set the flags using
specific instructions and not retain results.
@item OP1_IMM_IMPLIED
Modifies syntax class @code{SYNTAX_20P}, specifying that there is an
implied immediate destination operand which does not appear in the
syntax.
For example, if the source code contains an instruction like:
@example
inst r1,r2
@end example
the first argument is an implied immediate (that is, the result is
discarded). This is the same as though the source code were: inst
0,r1,r2.
@end table
For example, defining a 64-bit multiplier with immediate operands:
@example
.extInstruction mp64, 0x07, 0x2d, SUFFIX_COND|SUFFIX_FLAG,
SYNTAX_3OP|OP1_MUST_BE_IMM
@end example
which specifies an extension instruction named @code{mp64} with 3
operands. It sets the flags and can be used with a condition code,
for which the first operand is an immediate, i.e. equivalent to
discarding the result of the operation.
A two operands instruction variant would be:
@example
.extInstruction mul64, 0x07, 0x2d, SUFFIX_COND,
SYNTAX_2OP|OP1_IMM_IMPLIED
@end example
which describes a two operand instruction with an implicit first
immediate operand. The result of this operation would be discarded.
@end table
@node ARC Modifiers
@section ARC Assembler Modifiers
The following additional assembler modifiers have been added for
position-independent code. These modifiers are available only with
the ARC 700 and above processors and generate relocation entries,
which are interpreted by the linker as follows:
@table @code
@item @@pcl(@var{symbol})
@cindex @@pcl(@var{symbol}), ARC modifier
Relative distance of @var{symbol}'s from the current program counter
location.
@item @@gotpc(@var{symbol})
@cindex @@gotpc(@var{symbol}), ARC modifier
Relative distance of @var{symbol}'s Global Offset Table entry from the
current program counter location.
@item @@gotoff(@var{symbol})
@cindex @@gotoff(@var{symbol}), ARC modifier
Distance of @var{symbol} from the base of the Global Offset Table.
@item @@plt(@var{symbol})
@cindex @@plt(@var{symbol}), ARC modifier
Distance of @var{symbol}'s Procedure Linkage Table entry from the
current program counter. This is valid only with branch and link
instructions and PC-relative calls.
@item @@sda(@var{symbol})
@cindex @@sda(@var{symbol}), ARC modifier
Relative distance of @var{symbol} from the base of the Small Data
Pointer.
@end table
@node ARC Symbols
@section ARC Pre-defined Symbols
The following assembler symbols will prove useful when developing
position-independent code. These symbols are available only with the
ARC 700 and above processors.
@table @code
@item __GLOBAL_OFFSET_TABLE__
@cindex __GLOBAL_OFFSET_TABLE__, ARC pre-defined symbol
Symbol referring to the base of the Global Offset Table.
@item __DYNAMIC__
@cindex __DYNAMIC__, ARC pre-defined symbol
An alias for the Global Offset Table
@code{Base__GLOBAL_OFFSET_TABLE__}. It can be used only with
@code{@@gotpc} modifiers.
@end table
@node ARC Opcodes
@section Opcodes
@cindex ARC opcodes
@cindex opcodes for ARC
For information on the ARC instruction set, see @cite{ARC Programmers
Reference Manual}, available where you download the processor IP library.
|