1. Purpose 2. Supported syntax 2.1. Mnemonics 2.2. Addressing modes 2.3. Operand size control 2.4. Expression evaluation 2.5. Segments 2.6. Comments 2.7. Command separation |
2.8. Branch labels 2.9. Preprocessor 2.10. Object file format 2.11. Automatic jump size detection 3. Examples and more documentation 4. Changelog 5. Known bugs 6. Copying 7. Downloading |
The produced object file is binary-compatible with those made with XA65.
adc
, and
, asl
, bcc
,
bcs
, beq
, bit
, bmi
,
bne
, bpl
, bra
, brk
,
brl
, bvc
, bvs
, clc
,
cld
, cli
, clv
, cmp
,
cop
, cpx
, cpy
, db
,
dec
, dex
, dey
, eor
,
inc
, inx
, iny
, jml
,
jmp
, jsl
, jsr
, lda
,
ldx
, ldy
, lsr
, mvn
,
mvp
, nop
, ora
, pea
,
pei
, per
, pha
, phb
,
phd
, phk
, php
, phx
,
phy
, pla
, plb
, pld
,
plp
, plx
, ply
, rep
,
rol
, ror
, rti
, rtl
,
rts
, sbc
, sec
, sed
,
sei
, sep
, sta
, stp
,
stx
, sty
, stz
, tax
,
tay
, tcd
, tcs
, tdc
,
trb
, tsb
, tsc
, tsx
,
txa
, txs
, txy
, tya
,
tyx
, wai
, xba
, xce
nop
; clc
lda #value
; rep #value
etc (size may depend on an operand size setting)bra end
brl end
; per end+2
lda $12
lda $12,x
; lda $12,y
lda ($12)
; pei ($12)
lda ($12,x)
lda ($12),y
lda [$12]
lda [$12],y
lda $1234
lda $1234,x
; lda $1234,y
lda $123456
lda $123456,x
lda $12,s
lda ($12,s),y
lda ($1234)
lda [$1234]
lda ($1234,x)
mvn $7E,$7F
.as
, .al
, .xs
&
.xl
are used to decide what size accumulator and index mode
for the assembler to use. .as
and .xs
are for
8bit operands, and .al
and .xl
are for 16 bit operands.
I've found it handy to define these macroes:
#define SET_8_BIT_A() sep #$20 : .as #define SET_16_BIT_A() rep #$20 : .al #define SET_8_BIT_X() sep #$10 : .xs #define SET_16_BIT_X() rep #$10 : .xl #define SET_8_BIT_AX() sep #$30 : .xs : .as #define SET_16_BIT_AX() rep #$30 : .xl : .alIn addition to these modes, there are several operand prefixes that can be used to force a certain operand size/type.
lda !$f0
would use 16-bit address instead of direct page.lda @$1234
would use a long (24-bit) address instead of absolute 16-bit address.lda #<var
can be used to load the lower 8-bits of an external variable.lda #>var
can be used to load the upper 8-bits of an external variable.lda #^var
can be used to load the segment part (8-bits) of an external variable.lda @var,x
can be used to use absolute-indexed-long mode instead of the default, absolute.bra somewhere+1
lda #!address + $100
ldy #$1234 + ($6C * 3)
text
, data
, zero
and bss
..text
, .data
, .zero
and .bss
respectively to select the segment.
-
can be defined for branches backward
and +
for branches forward.; Space-fill the buffer to end phx cpx #$0010 bcs + ;jumps to the next "+" SET_8_BIT_A() lda #$FF - sta $94A0,x sta $94B0,x inx cpx #$0010 bcc - ;jumps to the previous "-" SET_16_BIT_A() + lda W_VRAMADDR sta @$002116 pla
#ifdef
, #ifndef
, #define
,
#if
, #endif
and #include
like
in any C program.
--jumps
option is enabled, all short
jumps are automatically turned into near jumps when
needed.
#include
d files aren't being properly preprocessed.If you happen to see this program useful for you, I'd appreciate if you tell me :) Perhaps it would motivate me to enhance the program.
Generated from
progdesc.php
(last updated: Fri, 3 Oct 2003 17:29:59 +0300)
with docmaker.php
(last updated: Thu, 13 Feb 2003 15:11:29 +0200)
at Fri, 3 Oct 2003 17:36:22 +0300