Initial revision
This commit is contained in:
parent
4e461a9860
commit
d9fe7e9cf0
1 changed files with 96 additions and 0 deletions
96
man/6805_as.1
Normal file
96
man/6805_as.1
Normal file
|
@ -0,0 +1,96 @@
|
|||
.\" $Header$
|
||||
.TH 6805_AS 1
|
||||
.ad
|
||||
.SH NAME
|
||||
6805_as \- assembler for Motorola 6805
|
||||
.SH SYNOPSIS
|
||||
/usr/em/lib/6805_as [options] argument ...
|
||||
.SH DESCRIPTION
|
||||
This assembler is made with the general framework
|
||||
described in \fIuni_ass\fP(6).
|
||||
.SH SYNTAX
|
||||
.IP registers
|
||||
The 6805 has an accumulator register A and an index register X. An
|
||||
instruction (from the read-modify-write group) that references the
|
||||
A-register has an "a" suffixed to the mnemonic. In a similar way
|
||||
the X-register, apart from indexing operations, is addressed with
|
||||
an "x" suffix, i.e. "lsra" and "negx".
|
||||
.IP "addressing modes"
|
||||
The assembler automatically selects the shortest opcode if
|
||||
appropriate and possible. Thus "sub 10" will use the direct
|
||||
addressing mode whereas "neg 0,x" will use indexed (no offset) mode.
|
||||
There are sick constructions where the assembler can't find out
|
||||
the shortest form in time. In those cases the longest form is used.
|
||||
.br
|
||||
Branches are handled in much the same way. If a branch is out of
|
||||
range it is replaced by a reversed condition branch, followed by
|
||||
a jump, automatically.
|
||||
.sp
|
||||
.nf
|
||||
.ta 8 16 24 32 40 48
|
||||
syntax meaning (name)
|
||||
|
||||
#expr a one byte value (immediate)
|
||||
<expr 1-byte zero page address. Allowed in
|
||||
the register/memory and read-modify-
|
||||
write instruction groups. (direct)
|
||||
>expr 2-byte address. Allowed in the register
|
||||
memory group. (extended)
|
||||
expr 1-byte address if appropriate, 2-byte
|
||||
in other cases. (auto-direct/extended)
|
||||
,x indexed with zero offset. (indexed)
|
||||
<expr,x indexed with 8 bit offset. (indexed-1)
|
||||
>expr,x indexed with 16 bit offset. (indexed-2)
|
||||
expr,x indexed with the shortest possible off-
|
||||
set. (auto indexed)
|
||||
bit,expr bit number and direct address.
|
||||
(bit set/clear)
|
||||
bit,expr,tag bit number, direct address and branch
|
||||
tag. Automatically changed to reversed
|
||||
condition branch and jump if appropri-
|
||||
ate. (bit test and branch)
|
||||
tag branch tag. Converted to reversed con-
|
||||
dition branch and jump if appropriate.
|
||||
(branch)
|
||||
.fi
|
||||
.IP "PSEUDO INSTRUCTIONS"
|
||||
|
||||
.dram use the zero page ram/io segment.
|
||||
.dprom use the zero page (ep)rom segment.
|
||||
.cmos assemble cmos version instructions.
|
||||
.SH "SEE ALSO"
|
||||
uni_ass(6),
|
||||
ack(1),
|
||||
.br
|
||||
M6805 HMOS, M146805 CMOS family, Motorola,
|
||||
Prentice-Hall, Inc., 1983, (ISBN 0-13-541375-3).
|
||||
.SH EXAMPLE
|
||||
An example of Motorola 6805 assembly code.
|
||||
.sp 2
|
||||
.nf
|
||||
.ta 8 16 32 40 48 56 64
|
||||
.dram
|
||||
one: .space 1 ! a-port
|
||||
.dprom
|
||||
c1: .byte 1
|
||||
.text
|
||||
start: ldx #c1 ! load address of c1
|
||||
txa
|
||||
sta one
|
||||
add c1 ! add one
|
||||
brset 1,one,whoop ! jif bit one of aport
|
||||
bset 1,one ! set it now
|
||||
.data
|
||||
.ascii "unused string"
|
||||
.text
|
||||
whoop: nop
|
||||
.org 0xff8
|
||||
.word start ! set vector address
|
||||
.text
|
||||
nop ! resume code
|
||||
.fi
|
||||
.SH AUTHOR
|
||||
Written by Gijs Mos.
|
||||
Not a member of the ACK group.
|
||||
.SH BUGS
|
||||
The assembler has not been well tested.
|
Loading…
Reference in a new issue