ca65/da65 Users Guide

Ullrich von Bassewitz,
Groepaz


An Overview on all supported CPUs

1. Overview

2. NMOS branch

3. CMOS branch

4. other

5. Copyright


1. Overview

2. NMOS branch

2.1 6502

The original NMOS 6502 CPU.

For Example: MOS MCS6502 Rev. D, Rockwell R6502, Synertek SY6502, UMC UM6502

(56 instructions, 151 opcodes)

$00  brk
$01  ora (zp,x)
$05  ora zp
$06  asl zp
$08  php
$09  ora #imm
$0a  asl a
$0d  ora addr
$0e  asl addr
$10  bpl rel80
$11  ora (zp),y
$15  ora zp,x
$16  asl zp,x
$18  clc
$19  ora addr,y
$1d  ora addr,x
$1e  asl addr,x
$20  jsr addr
$21  and (zp,x)
$24  bit zp
$25  and zp
$26  rol zp
$28  plp
$29  and #imm
$2a  rol a
$2c  bit addr
$2d  and addr
$2e  rol addr
$30  bmi rel8
$31  and (zp),y
$35  and zp,x
$36  rol zp,x
$38  sec
$39  and addr,y
$3d  and addr,x
$3e  rol addr,x
$40  rti
$41  eor (zp,x)
$45  eor zp
$46  lsr zp
$48  pha
$49  eor #imm
$4a  lsr a
$4c  jmp addr
$4d  eor addr
$4e  lsr addr
$50  bvc rel8
$51  eor (zp),y
$55  eor zp,x
$56  lsr zp,x
$58  cli
$59  eor addr,y
$5d  eor addr,x
$5e  lsr addr,x
$60  rts
$61  adc (zp,x)
$65  adc zp
$66  ror zp
$68  pla
$69  adc #imm
$6a  ror a
$6c  jmp (addr)
$6d  adc addr
$6e  ror addr
$70  bvs rel8
$71  adc (zp),y
$75  adc zp,x
$76  ror zp,x
$78  sei
$79  adc addr,y
$7d  adc addr,x
$7e  ror addr,x
$81  sta (zp,x)
$84  sty zp
$85  sta zp
$86  stx zp
$88  dey
$8a  txa
$8c  sty addr
$8d  sta addr
$8e  stx addr
$90  bcc rel8
$91  sta (zp),y
$94  sty zp,x
$95  sta zp,x
$96  stx zp,y
$98  tya
$99  sta addr,y
$9a  txs
$9d  sta addr,x
$a0  ldy #imm
$a1  lda (zp,x)
$a2  ldx #imm
$a4  ldy zp
$a5  lda zp
$a6  ldx zp
$a8  tay
$a9  lda #imm
$aa  tax
$ac  ldy addr
$ad  lda addr
$ae  ldx addr
$b0  bcs rel8
$b1  lda (zp),y
$b4  ldy zp,x
$b5  lda zp,x
$b6  ldx zp,y
$b8  clv
$b9  lda addr,y
$ba  tsx
$bc  ldy addr,x
$bd  lda addr,x
$be  ldx addr,y
$c0  cpy #imm
$c1  cmp (zp,x)
$c4  cpy zp
$c5  cmp zp
$c6  dec zp
$c8  iny
$c9  cmp #imm
$ca  dex
$cc  cpy addr
$cd  cmp addr
$ce  dec addr
$d0  bne rel8
$d1  cmp (zp),y
$d5  cmp zp,x
$d6  dec zp,x
$d8  cld
$d9  cmp addr,y
$dd  cmp addr,x
$de  dec addr,x
$e0  cpx #imm
$e1  sbc (zp,x)
$e4  cpx zp
$e5  sbc zp
$e6  inc zp
$e8  inx
$e9  sbc #imm
$ea  nop
$ec  cpx addr
$ed  sbc addr
$ee  inc addr
$f0  beq rel81
$f1  sbc (zp),y
$f5  sbc zp,x
$f6  inc zp,x
$f8  sed
$f9  sbc addr,y
$fd  sbc addr,x
$fe  inc addr,x

2.2 6502X

6502X mode is an extension to the normal 6502 mode. In this mode, several mnemonics for undocumented instructions of the NMOS 6502 CPUs are accepted.

Note: Since these instructions are undocumented, there are no official mnemonics for them.

(20 new instructions, 105 new opcodes, 76 instructions/256 opcodes total)

$02  jam
$03  slo (zp,x)
$04  nop zp
$07  slo zp
$0b  anc #imm
$0c  nop addr
$0f  slo addr
$12  jam
$13  slo (zp),y
$14  nop zp,x
$17  slo zp,y
$1a  nop
$1b  slo addr,y
$1c  nop addr,x
$1f  slo addr,x
$22  jam
$23  rla (zp,x)
$27  rla zp
$2b  anc #imm
$2f  rla addr
$32  jam
$33  rla (zp),y
$34  nop zp,x
$37  rla zp,y
$3a  nop
$3b  rla addr,y
$3c  nop addr,x
$3f  rla addr,x
$42  jam
$43  sre (zp,x)
$44  nop zp
$47  sre zp
$4b  alr #imm
$4f  sre addr
$52  jam
$53  sre (zp),y
$54  nop zp,x
$57  sre zp,y
$5a  nop
$5b  sre addr,y
$5c  nop addr,x
$5f  sre addr,x
$62  jam
$63  rra (zp,x)
$64  nop zp
$67  rra zp
$6b  arr #imm
$6f  rra addr
$72  jam
$73  rra (zp),y
$74  nop zp,x
$77  rra zp,y
$7a  nop
$7b  rra addr,y
$7c  nop addr,x
$7f  rra addr,x
$80  nop #imm
$82  nop #imm
$83  sax (zp,x)
$87  sax zp
$89  nop #imm
$8b  ane #imm
$8f  sax addr
$92  jam
$93  sha (zp),y
$97  sax zp,y
$9b  tas addr,y
$9c  shy addr,x
$9e  shx addr,y
$9f  sha addr,y
$a3  lax (zp,x)
$a7  lax zp
$ab  lax #imm
$af  lax addr
$b2  jam
$b3  lax (zp),y
$b7  lax zp,y
$bb  las addr,y
$bf  lax addr,y
$c2  nop #imm
$c3  dcp (zp,x)
$c7  dcp zp
$cb  axs #imm
$cf  dcp addr
$d2  jam
$d3  dcp (zp),y
$d4  nop zp,x
$d7  dcp zp,y
$da  nop
$db  dcp addr,y
$dc  nop addr,x
$df  dcp addr,x
$e2  nop #imm
$e3  isc (zp,x)
$e7  isc zp
$eb  sbc #imm
$ef  isc addr
$f2  jam
$f3  isc (zp),y
$f4  nop zp,x
$f7  isc zp,y
$fa  nop
$fb  isc addr,y
$fc  nop addr,x
$ff  isc addr,x

2.3 6502DTV

The CPU of the C64 DTV is based on the 6510. It adds some instructions, and does not support all undocumented 6510 instructions.

(3+10 new instructions, 3+56 new opcodes, 69 instructions/210 opcodes total)

Opcodes added over 6502 (these are JAM on 6502):

$12  bra rel8
$32  sac #imm
$42  sir #imm

Supported undocumented 6510 instructions (nop, anc, rla, lax, las, alr, arr, rra, shy, shx, axs, sbc):

$04  nop zp
$0b  anc #imm
$0c  nop addr
$14  nop zp,x
$1a  nop
$1c  nop addr,x
$23  rla (zp,x)
$27  rla zp
$2b  anc #imm
$2f  rla addr
$33  rla (zp),y
$34  nop zp,x
$37  rla zp,y
$3a  nop
$3b  rla addr,y
$3c  nop addr,x
$3f  rla addr,x
$44  nop zp
$4b  alr #imm
$54  nop zp,x
$5a  nop
$5c  nop addr,x
$63  rra (zp,x)
$64  nop zp
$67  rra zp
$6b  arr #imm
$6f  rra addr
$73  rra (zp),y
$74  nop zp,x
$77  rra zp,y
$7a  nop
$7b  rra addr,y
$7c  nop addr,x
$7f  rra addr,x
$80  nop #imm
$82  nop #imm
$89  nop #imm
$9c  shy addr,x
$9e  shx addr,y
$a3  lax (zp,x)
$a7  lax zp
$ab  lax #imm
$af  lax addr
$b3  lax (zp),y
$b7  lax zp,y
$bb  las addr,y
$bf  lax addr,y
$c2  nop #imm
$cb  axs #imm
$d4  nop zp,x
$da  nop
$dc  nop addr,x
$e2  nop #imm
$eb  sbc #imm
$f4  nop zp,x
$fa  nop
$fc  nop addr,x

3. CMOS branch

The original CMOS version was apparently developed already back in the Commodore days, but never saw the light of day. It was then licensed by (now) WDC to different other vendors. Unfortunately some of those named their chips "65C02" (not SC), which causes a lot of confusion now. So keep that in mind: some chips that are named "65C02" will only support the original 65SC02 instruction set.

3.1 65SC02 (Original CMOS)

The first CMOS instruction set, without bit manipulation, nor wai/stp. It adds 8 new instructions (phx, phy, plx, ply, bra, stz, tsb, trb) and two new address modes (zeropage-indirect, absolute-x-indexed-indirect) to the original (legal) 6502 instructions.

For example: Synertek SY65C02, GTE G65SC02, CMD G65SC02, NCR 65C02

(8 new instructions, 27 new opcodes, 64 instructions/178 opcodes total)

$04  tsb zp
$0c  tsb abs16
$12  ora (zp)
$14  trb zp
$1a  inc
$1c  trb abs16
$32  and (zp)
$34  bit zp, x
$3a  dec
$3c  bit abs16, x
$52  eor (zp)
$5a  phy
$64  stz zp
$72  adc (zp)
$74  stz zp, x
$7a  ply
$7c  jmp (abs16, x)
$80  bra rel8
$89  bit #imm8
$92  sta (zp)
$9c  stz abs16
$9e  stz abs16, x
$b2  lda (zp)
$d2  cmp (zp)
$da  phx
$f2  sbc (zp)
$fa  plx

3.2 65C02 (CMOS with Rockwell extensions)

The Rockwell extensions add additional bit manipulation and bit test-and-branch commands to the original 65SC02 instruction set.

For Example: Rockwell R65C02, Ricoh RP65C02, NCR 65CX02

(4 new instructions, 32 new opcodes, 68 instructions/210 opcodes total)

$07  rmb0 zp          clear bit in zp location
$0f  bbr0 zp, rel8    branch if bit is not set in zp location
$17  rmb1 zp
$1f  bbr1 zp, rel8
$27  rmb2 zp
$2f  bbr2 zp, rel8
$37  rmb3 zp
$3f  bbr3 zp, rel8
$47  rmb4 zp
$4f  bbr4 zp, rel8
$57  rmb5 zp
$5f  bbr5 zp, rel8
$67  rmb6 zp
$6f  bbr6 zp, rel8
$77  rmb7 zp
$7f  bbr7 zp, rel8
$87  smb0 zp          set bit in zp location
$8f  bbs0 zp, rel8    branch if bit is set in zp location
$97  smb1 zp
$9f  bbs1 zp, rel8
$a7  smb2 zp
$af  bbs2 zp, rel8
$b7  smb3 zp
$bf  bbs3 zp, rel8
$c7  smb4 zp
$cf  bbs4 zp, rel8
$d7  smb5 zp
$df  bbs5 zp, rel8
$e7  smb6 zp
$ef  bbs6 zp, rel8
$f7  smb7 zp
$ff  bbs7 zp, rel8

All "illegal" opcodes perform NOP on this CPU.

3.3 W65C02 (CMOS with WDC extensions)

For their W65C02S WDC took the Rockwell extensions, and added two extra instructions (which they also added to the 65C816/65C802)

(2 new instructions, 2 new opcodes, 70 instructions/212 opcodes total)

$cb  wai    wait for interrupt
$db  stp    wait for reset

All "illegal" opcodes perform NOP on this CPU.

3.4 65CE02 (CMOS with CSG extensions)

CSG took the Rockwell extensions and developed them further. Notable additions are long relative branches/jumps, and finally a real z register. Note that the two opcodes used by the WDC extensions have been repurposed for something else, so the 65CE02 is not 100% compatible with the W65C02.

For Example: CSG 65CE02 (used on the Amiga A2232 Serial Card)

(34 new instructions, 46 new opcodes, 102 instructions/256 opcodes total)

$02  cle              clear stack extend disable
$03  see              set stack extend disable
$0b  tsy              transfer stack_ptr_high to Y
$12  ora (zp), z
$13  lbpl rel16
$1b  inz              increment Z
$22  jsr (abs16)
$23  jsr (abs16, x)
$2b  tys              transfer Y to stack_ptr_high
$32  and (zp), z
$33  lbmi rel16
$3b  dez              decrement Z
$42  neg              negate A
$43  asr
$44  asr zp
$4b  taz              transfer A to Z
$52  eor (zp), z
$53  lbvc rel16
$54  asr zp, x
$5b  tab
$5c  aug              "4-byte NOP reserved for future expansion"
$62  rtn #imm8
$63  lbsr rel16       relative jsr, "branch to subroutine"
$64  stz zp           store Z
$6b  tza              transfer Z to A
$72  adc (zp), z
$73  lbvs rel16
$74  stz zp, x        store Z
$7b  tba
$82  sta (off8, s), y
$83  lbra rel16       relative jmp
$8b  sty abs16, x
$92  sta (zp), z
$93  lbcc rel16
$9b  stx abs16, y
$9c  stz abs16        store Z
$9e  stz abs16, x     store Z
$a3  ldz #imm8
$ab  ldz abs16
$b2  lda (zp), z
$b3  lbcs rel16
$bb  ldz abs16, x
$c2  cpz #imm8
$c3  dew zp
$cb  asw abs16
$d2  cmp (zp), z
$d3  lbne rel16
$d4  cpz zp
$db  phz              push Z
$dc  cpz abs16
$e2  lda (off8, s), y
$e3  inw zp
$eb  row abs16
$f2  sbc (zp), z
$f3  lbeq rel16
$f4  phw #imm16
$fb  plz              pull Z
$fc  phw abs16

One notable change is that some instructions of the original CMOS instruction set were changed from "zeropage indirect" addressing to "zeropage indirect, z indexed". This could be done, because the z register is initially guaranteed to be zero, making the CPU binary compatible with older CMOS variants.

$12  ora (zp)  ->  ora (zp), z
$32  and (zp)  ->  and (zp), z
$52  eor (zp)  ->  eor (zp), z
$72  adc (zp)  ->  adc (zp), z
$92  sta (zp)  ->  sta (zp), z
$b2  lda (zp)  ->  cmp (zp), z
$d2  cmp (zp)  ->  lda (zp), z
$f2  sbc (zp)  ->  sbc (zp), z

Additional to that, the meaning of the following instruction changes from "store zero" to "store z register". Again, this makes the CPU binary compatible with older CMOS variants

$64  stz zp
$74  stz zp, x
$9c  stz abs16
$9e  stz abs16, x

The other 65SC02 instructions (phx, phy, plx, ply, tsb, trb, bra) are unchanged.

3.5 4510

The 4510 is a microcontroller that is the core of the Commodore C65 aka C64DX. It contains among other functions a slightly modified 65CE02/4502 CPU, to allow address mapping for 20 bits of address space (1 megabyte addressable area).

The 4510 supports the complete 65CE02 instruction set, but changes the 4-Byte NOP into the "map" instruction:

$5c  map

For more information about the Commodore C65/C64DX and the 4510 CPU, see http://www.zimmers.net/anonftp/pub/cbm/c65/ and Wikipedia.

3.6 45GS02

The 45GS02 is a microcontroller that is the core of the MEGA65. It is an extension of the 4510 CPU and adds 32-bit addressing and a 32-bit pseudo register Q that is comprised of the four registers A, X, Y, and Z.

$42 $42 $05      orq zp
$42 $42 $06      aslq zp
$42 $42 $0a      aslq
$42 $42 $0d      orq addr
$42 $42 $0e      aslq addr
$42 $42 $12      orq (zp)
$42 $42 $16      aslq zp,x
$42 $42 $1a      inq
$42 $42 $1e      aslq addr,x
$42 $42 $24      bitq zp
$42 $42 $25      andq zp
$42 $42 $26      rolq zp
$42 $42 $2a      rolq
$42 $42 $2c      bitq addr
$42 $42 $2d      andq addr
$42 $42 $2e      rolq addr
$42 $42 $32      andq (zp)
$42 $42 $36      rolq zp, x
$42 $42 $3a      deq
$42 $42 $3e      rolq addr, x
$42 $42 $43      asrq
$42 $42 $44      asrq zp
$42 $42 $45      eorq zp
$42 $42 $46      lsrq zp
$42 $42 $4a      lsrq
$42 $42 $4d      eorq addr
$42 $42 $4e      lsrq addr
$42 $42 $52      eorq (zp)
$42 $42 $54      asrq zp, x
$42 $42 $56      lsrq zp, x
$42 $42 $5e      lsrq addr, x
$42 $42 $65      adcq zp
$42 $42 $66      rorq zp
$42 $42 $6a      rorq
$42 $42 $6d      adcq addr
$42 $42 $6e      rorq addr
$42 $42 $72      adcq (zp)
$42 $42 $76      rorq zp, x
$42 $42 $7e      rorq addr, x
$42 $42 $85      stq zp
$42 $42 $8d      stq addr
$42 $42 $92      stq (zp)
$42 $42 $a5      ldq zp
$42 $42 $ad      ldq addr
$42 $42 $b2      ldq (zp), z
$42 $42 $c5      cmpq zp
$42 $42 $c6      deq zp
$42 $42 $cd      cmpq addr
$42 $42 $ce      deq addr
$42 $42 $d2      cmpq (zp)
$42 $42 $d6      deq zp, x
$42 $42 $de      deq addr, x
$42 $42 $e5      sbcq zp
$42 $42 $e6      inq zp
$42 $42 $ed      sbcq addr
$42 $42 $ee      inq addr
$42 $42 $f2      sbcq (zp)
$42 $42 $f6      inq zp, x
$42 $42 $fe      inq addr, x

$ea $12          ora [zp], z
$ea $32          and [zp], z
$ea $52          eor [zp], z
$ea $72          adc [zp], z
$ea $92          sta [zp], z
$ea $b2          lda [zp], z
$ea $d2          cmp [zp], z
$ea $f2          sbc [zp], z

$42 $42 $ea $12  orq [zp]
$42 $42 $ea $32  andq [zp]
$42 $42 $ea $52  eorq [zp]
$42 $42 $ea $72  adcq [zp]
$42 $42 $ea $92  stq [zp]
$42 $42 $ea $b2  ldq [zp], z
$42 $42 $ea $d2  cmpq [zp]
$42 $42 $ea $f2  sbcq [zp]

3.7 HUC6280

The HUC6280 is a superset of 65C02. It implements the original CMOS instructions with Rockwell extensions, plus some other instructions:

$02  sxy
$03  st0 #imm
$13  st1 #imm
$22  sax
$23  st2 #imm
$42  say
$43  tma #imm
$44  bsr rel8
$53  tam #imm
$54  csl
$62  cla
$73  tii addr, addr, addr
$82  clx
$83  tst #imm, zp
$82  clx
$83  tst #imm, zp
$93  tst #imm, addr
$a3  tst #imm, zp, x
$b3  tst #imm, addr, x
$c2  cly
$c3  tdd addr, addr, addr
$d3  tin addr, addr, addr
$d4  csh
$e3  tia addr, addr, addr
$f3  tai addr, addr, addr
$f4  set

3.8 M740

The M740 is a microcontroller by Mitsubishi, which was marketed for embedded devices in the mid 80s. It is a superset of 6502, the added CMOS instructions seem to be completely custom however:

$02  jsr (zp)
$03  bbs0 a, rel8
$07  bbs0 zp, rel8
$0b  seb0 a
$0f  seb0 zp
$12  clt
$13  bbc0 a, rel8
$17  bbc0 zp, rel8
$1a  inc a
$1b  clb0 a
$1f  clb0 zp
$22  jsr $ff12
$23  bbs1 a, rel8
$27  bbs1 zp, rel8
$2b  seb1 a
$2f  seb1 zp
$32  set
$33  bbc1 a, rel8
$37  bbc1 zp, rel8
$3a  dec a
$3b  clb1 a
$3c  ldm zp, #imm
$3f  clb1 zp
$42  stp
$43  bbs2 a, rel8
$44  com zp
$47  bbs2 zp, rel8
$4b  seb2 a
$4f  seb2 zp
$53  bbc2 a, rel8
$57  bbc2 zp, rel8
$5b  clb2 a
$5f  clb2 zp
$63  bbs3 a, rel8
$64  tst zp
$67  bbs3 zp, rel8
$6b  seb3 a
$6f  seb3 zp
$73  bbc3 a, rel8
$77  bbc3 zp, rel8
$7b  clb3 a
$7f  clb3 zp
$80  bra rel8
$82  rrf zp
$83  bbs4 a, rel8
$87  bbs4 zp, rel8
$8b  seb4 a
$8f  seb4 zp
$93  bbc4 a, rel8
$97  bbc4 zp, rel8
$9b  clb4 a
$9f  clb4 zp
$a3  bbs5 a, rel8
$a7  bbs5 zp, rel8
$ab  seb5 a
$af  seb5 zp
$b2  lda (zp)
$b3  bbc5 a, rel8
$b7  bbc5 zp, rel8
$bb  clb5 a
$bf  clb5 zp
$c2  slw
$c3  bbs6 a, rel8
$c7  bbs6 zp, rel8
$cb  seb6 a
$cf  seb6 zp
$d3  bbc6 a, rel8
$d7  bbc6 zp, rel8
$db  clb6 a
$df  clb6 zp
$e2  fst
$e3  bbs7 a, rel8
$e7  bbs7 zp, rel8
$eb  seb7 a
$ef  seb7 zp
$f3  bbc7 a, rel8
$f7  bbc7 zp, rel8
$fb  clb7 a
$ff  clb7 zp

Four instructions are the same on 65SC02:

$1a  inc a
$3a  dec a
$80  bra rel8
$b2  lda (zp)

These four instructions are different from 65SC02:

$12  ora (zp)     -> clt
$32  and (zp)     -> set
$3c  bit addr,x   -> ldm zp, #imm
$64  stz zp       -> tst zp

The following 65SC02 instructions are not implemented:

$04  tsb zp
$0c  tsb addr
$14  trb zp
$1c  trb addr
$34  bit zp,y
$52  eor (zp)
$5a  phy
$72  adc (zp)
$74  stz zp,y
$7a  ply
$7c  jmp (addr)
$89  bit #imm8
$92  sta (zp)
$9c  stz addr
$9e  stz addr,x
$d2  cmp (zp)
$da  phx
$f2  sbc (zp)
$fa  plx

For more information about the M740 Controllers, see Wikipedia.

3.9 65816

The W65C816S is a 16bit CPU developed by WDC. The instruction set contains the complete legal 6502 instructions, the original CMOS instructions (65SC02), plus some new instructions and addressing modes. It has wai/stp, but it does NOT have the Rockwell extensions (BBRx, BBSx, RMBx and SMBx bit manipulation instructions).

(24 new instructions, 77 new opcodes, 88 instructions/256 opcodes total)

$02  cop imm8               coprocessor operation
$03  ora offs8, s
$07  ora [dp]
$0b  phd                    push direct page register
$0f  ora abs24
$13  ora (offs8, s), y
$17  ora [dp], y
$1b  tcs                    transfer C to stack pointer
$1f  ora abs24, x
$22  jsl abs24
$23  and offs8, s
$27  and [dp]
$2b  pld                    pull direct page register
$2f  and abs24
$33  and (offs8, s), y
$37  and [dp], y
$3b  tsc                    transfer stack pointer to C
$3f  and abs24, x
$42  wdm                    (reserved for future expansion)
$43  eor offs8, s
$44  mvp src, dst
$47  eor [dp]
$4b  phk                    push program bank register
$4f  eor abs24
$53  eor (offs8, s), y
$54  mvn src, dst
$57  eor [dp], y
$5b  tcd                    transfer C to direct page register
$5c  jml abs24
$5f  eor abs24, x
$62  per rel16              push effective relative address
$63  adc offs8, s
$67  adc [dp]
$6b  rtl                    return long (fetches 24-bit address from stack)
$6f  adc abs24
$73  adc (offs8, s), y
$77  adc [dp], y
$7b  tdc                    transfer direct page register to C
$7f  adc abs24, x
$82  brl rel16              branch long (16-bit offset)
$83  sta offs8, s
$87  sta [dp]
$8b  phb                    push data bank register
$8f  sta abs24
$93  sta (offs8, s), y
$97  sta [dp], y
$9b  txy                    transfer X to Y
$9f  sta abs24, x
$a3  lda offs8, s
$a7  lda [dp]
$ab  plb                    pull data bank register
$af  lda abs24
$b3  lda (offs8, s), y
$b7  lda [dp], y
$bb  tyx                    transfer Y to X
$bf  lda abs24, x
$c2  rep #imm8              clear bits in status register
$c3  cmp offs8, s
$c7  cmp [dp]
$cb  wai                    wait for interrupt
$cf  cmp abs24
$d3  cmp (offs8, s), y
$d4  pei (dp)               push effective indirect address
$d7  cmp [dp], y
$db  stp                    wait for reset
$dc  jmp [abs16]
$df  cmp abs24, x
$e2  sep #imm8              set bits in status register
$e3  sbc offs8, s
$e7  sbc [dp]
$eb  xba                    exchange high and low bytes of accumulator
$ef  sbc abs24
$f3  sbc (offs8, s), y
$f4  pea abs16              push effective absolute address
$f7  sbc [dp], y
$fb  xce                    exchange Carry and Emulation bits
$fc  jsr (abs16, x)
$ff  sbc abs24, x

4. other

4.1 Sweet16

SWEET 16 is an interpreter for a pseudo 16 bit CPU written by Steve Wozniak for the Apple ][ machines. It is available in the Apple ][ ROM.

It implements the following opcodes:

00   1     RTN                                (Return to 6502 mode)
01   2     BR        ea                       (Branch always)
02   2     BNC       ea                       (Branch if No Carry)
03   2     BC        ea                       (Branch if Carry)
04   2     BP        ea                       (Branch if Plus)
05   2     BM        ea                       (Branch if Minus)
06   2     BZ        ea                       (Branch if Zero)
07   2     BNZ       ea                       (Branch if NonZero)
08   2     BM1       ea                       (Branch if Minus 1)
09   2     BNM1      ea                       (Branch if Not Minus 1)
0A   1     BK                                 (Break to Monitor)
0B   1     RS                                 (Return from Subroutine)
0C   1     BS        ea                       (Branch to Subroutine)
1n   3     SET       Rn    R<-2 byte constant (Set Constant) (load register immediate)
2n   1     LD        Rn    ACC<-R             (Load)
3n   1     ST        Rn    ACC->R (Store)
4n   1     LD        @Rn   ACC<-@R, R<-R+1    (Load Indirect)
5n   1     ST        @Rn   ACC->@R, R<-R+1    (Store Indirect)
6n   1     LDD       @Rn   ACC<-@R double     (Load Double Indirect)
7n   1     STD       @Rn   ACC->@R double     (Store Double Indirect)
8n   1     POP       @Rn   R<-R-1, ACC<-@R    (pop) (Pop Indirect)
9n   1     STP       @Rn   R<-R-1, ACC->@R    (Store POP Indirect)
An   1     ADD       Rn    ACC<-@R            (pop) double (Add)
Bn   1     SUB       Rn    compare ACC to R   (Sub)
Cn   1     POPD      @Rn   ACC<-ACC+R         (Pop Double Indirect)
Dn   1     CPR       Rn    ACC<-ACC-R         (Compare)
En   1     INR       Rn    R<-R+1             (Increment)
Fn   1     DCR       Rn    R<-R-1             (Decrement)

For more information about SWEET 16, see http://www.6502.org/source/interpreters/sweet16.htm.

5. Copyright

ca65 (and all cc65 binutils) are (C) Copyright 1998-2003 Ullrich von Bassewitz. For usage of the binaries and/or sources the following conditions do apply:

This software is provided 'as-is', without any expressed or implied warranty. In no event will the authors be held liable for any damages arising from the use of this software.

Permission is granted to anyone to use this software for any purpose, including commercial applications, and to alter it and redistribute it freely, subject to the following restrictions:

  1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.
  2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.
  3. This notice may not be removed or altered from any source distribution.