mirror of
https://github.com/ksherlock/x65.git
synced 2025-01-21 10:32:14 +00:00
9cdfeeb0ca
- 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
118 lines
3.3 KiB
Markdown
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
|
|
``` |