1. Purpose 2. Linker 3. Supported syntax 3.1. Mnemonics 3.2. Addressing modes 3.3. Operand size control 3.4. Expression evaluation 3.5. Segments 3.6. Comments 3.7. Command separation 3.8. Code pointer relocation |
3.9. Branch labels 3.10. Preprocessor 3.11. Object file format 3.12. Automatic jump size detection 3.13. IPS output support 3.14. Linkage selection 4. Examples and more documentation 5. Changelog 6. Known bugs 7. Copying 8. 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.text
and data
segments are saved into
the o65 file. Labels are saved in all segments.
*= $34F200
to change
where the code goes by default.-
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.
With the .link
statement, you can change that.
.link page $3F
declares that this object should be
placed into page $3F.
.link group 1
declares that this object should be
placed to the same page together with all other objects that
want to be linked in group 1. This is useful when you want to
ensure that certain tables or routines go to the same page,
even if they are not in the same compilation unit.
The linkage selection statement is only honored by the
sneslink
program, distributed in this archive.
#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: Sun, 22 Feb 2004 03:22:08 +0200)
with docmaker.php
(last updated: Fri, 2 Jan 2004 17:31:18 +0200)
at Sun, 22 Feb 2004 03:34:07 +0200