1
0
mirror of https://github.com/ksherlock/x65.git synced 2025-01-21 10:32:14 +00:00
x65/disassembler/README.MD
Carl-Henrik Skårstedt 9cdfeeb0ca Disassembler improvements and c64 labels file
- Adding a labels file with all the c64 hardware addresses
- Labels are tracked outside of the binary file range
- Zero page tracking
- Improved code vs data tracking a bit
2015-12-03 22:53:16 -08:00

118 lines
3.3 KiB
Markdown

#x65 Disassembler
Simple disassembler for 6502, 65C02 and 65816 (default).
## Command Line Options
Typical command line ([*] = optional):
**Usage**
```
x65dsasm binary disasm.txt [$skip[-$end]] [addr=$xxxx] [cpu=6502/65C02/65816]
[mx=0-3] [src] [prg] [data=$xx] [labels=labels.lbl]
```
* binary: file which contains some 65xx series instructions
* disasm.txt: output file (default is stdout)
* $skip-$end: first byte offset to disassemble to last byte offset to disassemble
* addr: disassemble as if loaded at addr (addr)
* data: this number of initial bytes in file is data and not code
* prg: file is a c64 program file starting with the load address
* cpu: set which cpu to disassemble for (default is 6502)
* src: export near assemblable source with guesstimated data blocks
* mx: set the mx flags which control accumulator and index register size
* labels: import labels from a file (each line: label=$xxxx [code]/[data] comment)
### Updates
* c64.lbl file defining all c64 hardware addresses
* Tracking label references outside of the code including zero page
* Data / Code distinction improvements
* **Local labels** to improve code readability
* Improvements to code vs data determination
* Instrument labels through labels text file
* **src** option attempts to generate valid assembler source
### Labels file format
Labels is a text file with one label declaration per line followed by the address to assign and the
type of block to represent (code or data or pointers) followed by an optional comment. The labels
file makes the most sense together with the *src* command line argument.
Addresses can define a range using a '-' after the address followed by an ending address.
No automatic labels will be inserted within this range.
A special data format is pointers indicating a function pointer table, the label should be
defined with a range to limit the size. Each pointer within the pointer table will be
assigned a code label.
Example labels file:
```
Init = $1000 code Entry point into code
SinTable = $1400 data 256 byte sinus table
Interrupt = $10f3 code Interrupt code
Callbacks = $1123-$112b pointers Array of function pointers
VIC_Sprite0_x = $d000 set sprite 0 x position
VIC_Sprite0_y = $d001 set sprite 0 y position
VIC_Sprite1_x = $d002 set sprite 1 x position
VIC_Sprite1_y = $d003 set sprite 1 y position
```
Sample output:
```
; -------------------------------- ;
; Referenced from Label_14 + $7 (subroutine)
; Referenced from Label_14 + $c (subroutine)
Label_11:
lda $03,x
bpl Label_13
; Referenced from Label_14 + $18 (subroutine)
Label_12:
sec
lda #$00
sbc $00,x
sta $00,x
lda #$00
sbc $01,x
sta $01,x
lda #$00
sbc $02,x
sta $02,x
lda #$00
sbc $03,x
sta $03,x
; Referenced from Label_11 + $2 (branch)
Label_13:
rts
; -------------------------------- ;
; Referenced from Label_1 + $1e (subroutine)
; Referenced from Label_16 + $1 (subroutine)
; Referenced from Label_24 + $b (subroutine)
; Referenced from Label_28 + $b (subroutine)
Label_14:
lda $f7
eor $f3
```
```
lda #$e4
jsr Label_16
bne Label_27
beq Label_27
; Referenced from Label_28 + $29 (branch)
Label_29:
rts
; -------------------------------- ;
; Referenced from Label_24 + $0 (data)
Label_30:
dc.b $55, $55, $d5, $ff, $22, $22, $02, $00, $ff, $f2, $ff, $ff, $2e, $00, $00, $00
```