100 lines
2.8 KiB
Groff
100 lines
2.8 KiB
Groff
.\" $Header$
|
|
.TH M68K2_AS 6ACK
|
|
.ad
|
|
.SH NAME
|
|
m68k2_as \- assembler for Motorola 68000
|
|
.SH SYNOPSIS
|
|
~em/lib/m68k2/as [options] argument ...
|
|
.SH DESCRIPTION
|
|
This assembler is made with the general framework
|
|
described in \fIuni_ass\fP(6). It is an assembler generating relocatable
|
|
object code in \fIack.out\fP(5) format.
|
|
.SH SYNTAX
|
|
.IP registers
|
|
The 68000 has the following registers:
|
|
seven data-registers (d1 - d7), seven address-registers (a1 - a6, sp)
|
|
of which sp is the system stack pointer, a program counter (pc),
|
|
a status register (sr), and a condition codes register (ccr) which is actually
|
|
just the low order byte of the status register.
|
|
.IP "addressing modes"
|
|
.nf
|
|
.ta 8n 16n 24n 32n 40n 48n
|
|
syntax meaning (name)
|
|
|
|
reg contents of \fIreg\fP is operand, where \fIreg\fP is
|
|
one of the registers mentioned above (register direct)
|
|
|
|
(areg) contents of \fIareg\fP is address of operand, where
|
|
\fIareg\fP is an address-register
|
|
(address register indirect)
|
|
|
|
(areg)+ same as (areg), but after the address is used,
|
|
\fIareg\fP is incremented by the operand length
|
|
(postincrement)
|
|
|
|
-(areg) same as (areg), but before the address is used,
|
|
\fIareg\fP is decremented by the operand length
|
|
(predecrement)
|
|
|
|
expr(areg)
|
|
expr(pc) \fIexpr\fP + the contents of the register yields the
|
|
address of the operand (displacement)
|
|
|
|
expr(areg, ireg)
|
|
expr(pc, ireg) \fIexpr\fP + the contents of the register + the contents
|
|
of \fIireg\fP yields the address of the operand. \fIireg\fP is
|
|
an address- or a data-register.
|
|
\fIireg\fP may be followed by .w or .l indicating whether
|
|
the size of the index is a word or a long
|
|
(displacement with index)
|
|
|
|
expr \fIexpr\fP is the address of the operand
|
|
(absolute address)
|
|
|
|
#expr \fIexpr\fP is the operand (immediate)
|
|
.fi
|
|
|
|
Some instructions have as operand a register list. This list consists of
|
|
one or more ranges of registers separated by '/'s. A register range consists
|
|
of either one register (e.g. d3) or two registers separated by a '-'
|
|
(e.g. a2-a4, or d4-d5). The two registers must be in the same set (address-
|
|
or data-registers) and the first must have a lower number than the second.
|
|
.IP instructions
|
|
Some instructions can have a byte, word, or longword operand.
|
|
This may be indicated by prepending the mnemonic with .b, .w, or .l
|
|
respectively. Default is .w.
|
|
.SH "SEE ALSO"
|
|
uni_ass(6),
|
|
ack(1),
|
|
ack.out(5),
|
|
.br
|
|
MC68000 16-bit microprocessor User's manual, Motorola Inc, 1979
|
|
.SH EXAMPLE
|
|
.sp 2
|
|
.nf
|
|
.ta 8n 16n 24n 32n 40n 48n 56n 64n
|
|
.define .cii
|
|
|
|
.sect .text
|
|
.cii:
|
|
movem.l a0/d0/d1,.savreg
|
|
move.l (sp)+,a0 ! return address
|
|
move (sp)+,d0 ! destination size
|
|
sub (sp)+,d0 ! destination - source size
|
|
bgt 1f
|
|
sub d0,sp ! pop extra bytes
|
|
bra 3f
|
|
1:
|
|
move (sp),d1
|
|
ext.l d1
|
|
swap d1
|
|
asr #1,d0
|
|
2:
|
|
move.w d1,-(sp)
|
|
sub #1,d0
|
|
bgt 2b
|
|
3:
|
|
move.l a0,-(sp)
|
|
movem.l .savreg,a0/d0/d1
|
|
rts
|
|
.fi
|