Split 2002x-operand-formats test
My original goal was to add a sign-extended decimal format, but that
turned out to be awkward. It works for data items and instructions
with immediate operands (e.g. "LDA #-1"), but is either wrong or
useless for address operands, since most assemblers treat integers
as 32-bit values. (LDA -1 is not LDA $FFFF, it's LDA $FFFFFFFF,
which is not useful unless your asm is doing an implicit mod.)
There's also a bit of variability in how assemblers treat negative
values, so I'm shelving the idea for now. I'm keeping the updated
tests, which are now split into 6502 / 65816 parts.
Also, updated the formatter to output all decimal values as unsigned.
Most assemblers were fine with negative values, but 64tass .dword
insists on positive. Rather than make the opcode conditional on the
value's range, we now just always output unsigned decimal, which
all current assemblers accept.
2020-06-08 17:47:26 -07:00
|
|
|
;Project file was edited to force ASCII formatting for some operands.
|
2018-10-23 16:06:29 -07:00
|
|
|
.cpu "65816"
|
2020-07-02 08:14:42 -07:00
|
|
|
.enc "sg_hiascii"
|
2019-08-21 13:30:25 -07:00
|
|
|
.cdef $20,$7e,$a0
|
2020-07-02 08:14:42 -07:00
|
|
|
.enc "sg_ascii"
|
2019-08-20 11:21:30 -07:00
|
|
|
.cdef $20,$7e,$20
|
2018-10-23 16:06:29 -07:00
|
|
|
* = $1000
|
|
|
|
.as
|
|
|
|
.xs
|
|
|
|
clc
|
|
|
|
xce
|
Split 2002x-operand-formats test
My original goal was to add a sign-extended decimal format, but that
turned out to be awkward. It works for data items and instructions
with immediate operands (e.g. "LDA #-1"), but is either wrong or
useless for address operands, since most assemblers treat integers
as 32-bit values. (LDA -1 is not LDA $FFFF, it's LDA $FFFFFFFF,
which is not useful unless your asm is doing an implicit mod.)
There's also a bit of variability in how assemblers treat negative
values, so I'm shelving the idea for now. I'm keeping the updated
tests, which are now split into 6502 / 65816 parts.
Also, updated the formatter to output all decimal values as unsigned.
Most assemblers were fine with negative values, but 64tass .dword
insists on positive. Rather than make the opcode conditional on the
value's range, we now just always output unsigned decimal, which
all current assemblers accept.
2020-06-08 17:47:26 -07:00
|
|
|
rep #$30
|
2018-10-23 16:06:29 -07:00
|
|
|
.al
|
|
|
|
.xl
|
Split 2002x-operand-formats test
My original goal was to add a sign-extended decimal format, but that
turned out to be awkward. It works for data items and instructions
with immediate operands (e.g. "LDA #-1"), but is either wrong or
useless for address operands, since most assemblers treat integers
as 32-bit values. (LDA -1 is not LDA $FFFF, it's LDA $FFFFFFFF,
which is not useful unless your asm is doing an implicit mod.)
There's also a bit of variability in how assemblers treat negative
values, so I'm shelving the idea for now. I'm keeping the updated
tests, which are now split into 6502 / 65816 parts.
Also, updated the formatter to output all decimal values as unsigned.
Most assemblers were fine with negative values, but 64tass .dword
insists on positive. Rather than make the opcode conditional on the
value's range, we now just always output unsigned decimal, which
all current assemblers accept.
2020-06-08 17:47:26 -07:00
|
|
|
lda #$1234
|
|
|
|
lda #4660
|
|
|
|
lda #4660
|
|
|
|
lda #%0001001000110100
|
|
|
|
lda #$fffe
|
|
|
|
lda #65534
|
|
|
|
lda #65534
|
|
|
|
lda #%1111111111111110
|
|
|
|
lda $fffefd
|
|
|
|
lda 16776957
|
|
|
|
lda 16776957
|
|
|
|
lda %111111111111111011111101
|
2018-10-23 16:06:29 -07:00
|
|
|
lda #'h'
|
2019-08-11 17:59:20 -07:00
|
|
|
lda #'H' | $80
|
2018-10-23 16:06:29 -07:00
|
|
|
lda #$6868
|
Split 2002x-operand-formats test
My original goal was to add a sign-extended decimal format, but that
turned out to be awkward. It works for data items and instructions
with immediate operands (e.g. "LDA #-1"), but is either wrong or
useless for address operands, since most assemblers treat integers
as 32-bit values. (LDA -1 is not LDA $FFFF, it's LDA $FFFFFFFF,
which is not useful unless your asm is doing an implicit mod.)
There's also a bit of variability in how assemblers treat negative
values, so I'm shelving the idea for now. I'm keeping the updated
tests, which are now split into 6502 / 65816 parts.
Also, updated the formatter to output all decimal values as unsigned.
Most assemblers were fine with negative values, but 64tass .dword
insists on positive. Rather than make the opcode conditional on the
value's range, we now just always output unsigned decimal, which
all current assemblers accept.
2020-06-08 17:47:26 -07:00
|
|
|
lda @l'h'
|
|
|
|
lda @l'H' | $80
|
2018-10-23 16:06:29 -07:00
|
|
|
rts
|
|
|
|
|