mirror of
https://github.com/cc65/cc65.git
synced 2025-01-10 19:29:45 +00:00
47 lines
1.5 KiB
ArmAsm
47 lines
1.5 KiB
ArmAsm
;
|
|
; Ullrich von Bassewitz, 02.04.1999
|
|
;
|
|
; unsigned char getcpu (void);
|
|
;
|
|
|
|
.export _getcpu
|
|
|
|
; ---------------------------------------------------------------------------
|
|
; Subroutine to detect an 816. Returns
|
|
;
|
|
; - 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
|
|
; of the 6502, but all of them interpret unknown opcodes as NOP so this is
|
|
; just what we want.
|
|
|
|
.p816 ; Enable 65816 instructions
|
|
|
|
_getcpu:
|
|
lda #0
|
|
inc a ; .byte $1A ; nop on nmos, inc on every cmos
|
|
cmp #1
|
|
bcc @L9
|
|
|
|
; 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
|
|
|