Merge pull request #348 from SvOlli/release

ca65: added .P4510 and .IFP4510 pseudo commands
This commit is contained in:
Oliver Schmidt
2016-09-20 16:19:45 +02:00
committed by GitHub
18 changed files with 184 additions and 25 deletions

View File

@@ -12,6 +12,7 @@
; - carry clear and 0 in A for a NMOS 6502 CPU
; - carry set and 1 in A for some CMOS 6502 CPU
; - carry set and 2 in A for a 65816
; - carry set and 3 in A for a 4510
;
; This function uses a $1A opcode which is a INA on the 816 and ignored
; (interpreted as a NOP) on a NMOS 6502. There are several CMOS versions
@@ -22,16 +23,24 @@
_getcpu:
lda #0
inc a ; .byte $1A
inc a ; .byte $1A ; nop on nmos, inc on every cmos
cmp #1
bcc @L9
; This is at least a 65C02, check for a 65816
; This is at least a 65C02, check for a 4510
.byte $42,$ea ; neg on 4510, nop #$ea on 65c02, wdm $ea on 65816
cmp #1
bne @L8
; check for 65816; after 4510, because $eb there is row (rotate word)
xba ; .byte $eb, put $01 in B accu
dec a ; .byte $3a, A=$00 if 65C02
xba ; .byte $eb, get $01 back if 65816
inc a ; .byte $1a, make $01/$02
.byte $2c ; bit instruction to skip next command
@L8: lda #3 ; CPU_4510 constant
@L9: ldx #0 ; Load high byte of word
rts