147 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
			
		
		
	
	
			147 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			Groff
		
	
	
	
	
	
| .\" $Header$
 | |
| .TH 6809_AS 1
 | |
| .ad
 | |
| .SH NAME
 | |
| 6809_as \- assembler for 6809
 | |
| .SH SYNOPSIS
 | |
| /usr/em/lib/6809_as [options] argument ...
 | |
| .SH DESCRIPTION
 | |
| This assembler is made with the general framework
 | |
| described in \fIuni_ass\fP(6).
 | |
| .SH SYNTAX
 | |
| .IP registers
 | |
| The 6809 contains four 8-bit registers registers:
 | |
| two accumulators (a and b),
 | |
| a direct page register (dp),
 | |
| and a condition code register (cc),
 | |
| and five 16-bit registers:
 | |
| two index registers (x and y),
 | |
| a user an a hardware stack pointer (u resp. s),
 | |
| and a program counter (pc).
 | |
| The index registers and the stack pointers are indexable.
 | |
| Accumulators a and b can be concatenated to form
 | |
| the double accumulator d,
 | |
| of which a is the high and b is the low byte.
 | |
| An instruction that refers to accumulator a
 | |
| has an "a" as last character.
 | |
| In the same way a "b" means that the instruction
 | |
| uses b as accumulator.
 | |
| .IP "pseudo instructions"
 | |
| The 6809 assembler recognizes one additional instruction
 | |
| that is not translated into a machine instruction: setdp.
 | |
| It expects an expression as argument.
 | |
| This is used for efficient address encoding of some addressing
 | |
| mode (see below).
 | |
| .IP "addressing modes"
 | |
| .nf
 | |
| .ta 8n 16n 24n 32n 40n 48n
 | |
| syntax		meaning (name)
 | |
| 
 | |
| reg		The operand of the instruction is in \fIreg\fP.
 | |
| 
 | |
| reglist		\fIreglist\fP is a either list of registers, seperated
 | |
| 		by ','s, or the word "all". It encodes in a register
 | |
| 		save mask, where "all" means all registers, that can
 | |
| 		be used by the push-pull instructions pshs, pshu,
 | |
| 		puls, and pulu.
 | |
| 
 | |
| <expr		The one-byte value of \fIexpr\fP is an address within
 | |
| 		a 256-byte page. The particular page in use is
 | |
| 		indicated by the contents of dp, so \fIexpr\fP is the
 | |
| 		low byte of the effective address of the operand,
 | |
| 		and dp the high byte. (direct)
 | |
| 
 | |
| >expr		The two-byte value of \fIexpr\fP is the exact memory
 | |
| 		address. Not that this mode always requires one
 | |
| 		byte more than "<expr". (extended)
 | |
| 
 | |
| expr		The value of \fIexpr\fP is an address.
 | |
| 		Except for long branches, this value is examined
 | |
| 		first to see if a short encoding is possible.
 | |
| 		When the instruction is a short branch, the value
 | |
| 		is checked to see if the address is not too remote,
 | |
| 		because in that case this branch is automatically
 | |
| 		replaced by a long branch. When the instruction is
 | |
| 		not a branch, the high byte of the value is compared
 | |
| 		with the value of the argument of the last setdp
 | |
| 		pseudo.  If they are equal, this mode is replaced by
 | |
| 		"<expr", else by ">expr".
 | |
| 		(relative for branch-instructions)
 | |
| 
 | |
| #expr		The value of \fIexpr\fP is one- or two-byte immediate
 | |
| 		data. (immediate)
 | |
| 
 | |
| (expr)		The value of \fIexpr\fP is a pointer to the address
 | |
| 		of the operand. (indirect)
 | |
| 
 | |
| expr, reg	The value of \fIexpr\fP added to the contents of \fIreg\fP
 | |
| 		(which must be a 16-bit register) yields the
 | |
| 		effective address of the operand.
 | |
| 		(constant-offset indexed)
 | |
| 
 | |
| , ireg		The contents of \fIireg\fP (which must be indexable)
 | |
| 		yields the effective address of the operand.
 | |
| 		(constant-offset indexed)
 | |
| 
 | |
| (expr, reg)	The value of \fIexpr\fP added to the contents of \fIreg\fP
 | |
| 		(which must be a 16-bit register) yields a pointer
 | |
| 		to the effective address of the operand.
 | |
| 		(constant-offset indexed indirect)
 | |
| 
 | |
| (, ireg)	The contents of \fIireg\fP (which must be indexable)
 | |
| 		yields a pointer to the effective address of the
 | |
| 		operand. (constant-offset indexed indirect)
 | |
| 
 | |
| ac, ireg	The contents of \fIac\fP (which must be an accumulator)
 | |
| 		added to the contents of \fIireg\fP (which must be
 | |
| 		indexable) yields the effective address of the
 | |
| 		operand. (accumulator indexed)
 | |
| 
 | |
| (ac, ireg)	The contents of \fIac\fP (which must be an accumulator)
 | |
| 		added to the contents of \fIireg\fP (which must be
 | |
| 		indexable) yields a pointer to the effective address
 | |
| 		of the operand. (accumulator indexed indirect)
 | |
| 
 | |
| ,ireg+
 | |
| ,ireg++		The contents of \fIireg\fP (which must be indexable) is
 | |
| 		used as effective address of the operand. After that
 | |
| 		it is incremented by 1 (+) or 2 (++).
 | |
| 		(auto-increment)
 | |
| 
 | |
| (,ireg++)	The contents of \fIireg\fP (which must be indexable) is
 | |
| 		used as a pointer to the effective address of the
 | |
| 		operand. After that it is incremented by 2.
 | |
| 		(auto-increment indirect)
 | |
| 
 | |
| ,-ireg
 | |
| ,--ireg		\fIireg\fP (which must be indexable) is decremented
 | |
| 		by 1 (-) or 2 (--). After that, its contents is used
 | |
| 		as effective address of the operand.
 | |
| 		(auto-decrement)
 | |
| 
 | |
| (,--ireg)	\fIireg\fP (which must be indexable) is decremented by 2.
 | |
| 		After that, its contents is used as a pointer to the
 | |
| 		effective address of the operand.
 | |
| 		(auto-decrement indirect)
 | |
| 
 | |
| .fi
 | |
| .SH "SEE ALSO"
 | |
| uni_ass(6),
 | |
| ack(1),
 | |
| .br
 | |
| MC6809 preliminary programming manual, Motorola Inc., First Edition, 1979
 | |
| .SH EXAMPLE
 | |
| An example of 6809 assembly code.
 | |
| .nf
 | |
| .ta 8n 16n 24n 32n 40n 48n
 | |
| 	contby = 80
 | |
| 
 | |
| 	compgo:	lda	#contby
 | |
| 		ldx	#table - 2	!start of table
 | |
| 
 | |
| 		clrb
 | |
| 	co1:	addb	#2
 | |
| 		lsra
 | |
| 		bcc	co1
 | |
| 		jmp	(b, x)		!accumulator offset indirect
 | |
| .fi
 |