AS65 Assembler for R6502 [1.42]. Copyright 1994-2007, Frank A. Kingswood Page 1 ---------------------------------------------------- 6502_functional_test.a65 ---------------------------------------------------- 6104 lines read, no errors in pass 1. ; ; 6 5 0 2 F U N C T I O N A L T E S T ; ; Copyright (C) 2012-2015 Klaus Dormann ; ; This program is free software: you can redistribute it and/or modify ; it under the terms of the GNU General Public License as published by ; the Free Software Foundation, either version 3 of the License, or ; (at your option) any later version. ; ; This program is distributed in the hope that it will be useful, ; but WITHOUT ANY WARRANTY; without even the implied warranty of ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ; GNU General Public License for more details. ; ; You should have received a copy of the GNU General Public License ; along with this program. If not, see <http://www.gnu.org/licenses/>. ; This program is designed to test all opcodes of a 6502 emulator using all ; addressing modes with focus on propper setting of the processor status ; register bits. ; ; version 04-dec-2017 ; contact info at http://2m5.de or email K@2m5.de ; ; assembled with AS65 from http://www.kingswood-consulting.co.uk/assemblers/ ; command line switches: -l -m -s2 -w -h0 ; | | | | no page headers in listing ; | | | wide listing (133 char/col) ; | | write intel hex file instead of binary ; | expand macros in listing ; generate pass2 listing ; ; No IO - should be run from a monitor with access to registers. ; To run load intel hex image with a load command, than alter PC to 400 hex ; (code_segment) and enter a go command. ; Loop on program counter determines error or successful completion of test. ; Check listing for relevant traps (jump/branch *). ; Please note that in early tests some instructions will have to be used before ; they are actually tested! ; ; RESET, NMI or IRQ should not occur and will be trapped if vectors are enabled. ; Tests documented behavior of the original NMOS 6502 only! No unofficial ; opcodes. Additional opcodes of newer versions of the CPU (65C02, 65816) will ; not be tested. Decimal ops will only be tested with valid BCD operands and ; N V Z flags will be ignored. ; ; Debugging hints: ; Most of the code is written sequentially. if you hit a trap, check the ; immediately preceeding code for the instruction to be tested. Results are ; tested first, flags are checked second by pushing them onto the stack and ; pulling them to the accumulator after the result was checked. The "real" ; flags are no longer valid for the tested instruction at this time! ; If the tested instruction was indexed, the relevant index (X or Y) must ; also be checked. Opposed to the flags, X and Y registers are still valid. ; ; versions: ; 28-jul-2012 1st version distributed for testing ; 29-jul-2012 fixed references to location 0, now #0 ; added license - GPLv3 ; 30-jul-2012 added configuration options ; 01-aug-2012 added trap macro to allow user to change error handling ; 01-dec-2012 fixed trap in branch field must be a branch ; 02-mar-2013 fixed PLA flags not tested ; 19-jul-2013 allowed ROM vectors to be loaded when load_data_direct = 0 ; added test sequence check to detect if tests jump their fence ; 23-jul-2013 added RAM integrity check option ; 16-aug-2013 added error report to standard output option ; 13-dec-2014 added binary/decimal opcode table switch test ; 14-dec-2014 improved relative address test ; 23-aug-2015 added option to disable self modifying tests ; 24-aug-2015 all self modifying immediate opcodes now execute in data RAM ; added small branch offset pretest ; 21-oct-2015 added option to disable decimal mode ADC & SBC tests ; 04-dec-2017 fixed BRK only tested with interrupts enabled ; added option to skip the remainder of a failing test ; in report.i65 ; C O N F I G U R A T I O N ;ROM_vectors writable (0=no, 1=yes) ;if ROM vectors can not be used interrupts will not be trapped ;as a consequence BRK can not be tested but will be emulated to test RTI 0001 = ROM_vectors = 1 ;load_data_direct (0=move from code segment, 1=load directly) ;loading directly is preferred but may not be supported by your platform ;0 produces only consecutive object code, 1 is not suitable for a binary image 0001 = load_data_direct = 1 ;I_flag behavior (0=force enabled, 1=force disabled, 2=prohibit change, 3=allow ;change) 2 requires extra code and is not recommended. SEI & CLI can only be ;tested if you allow changing the interrupt status (I_flag = 3) 0003 = I_flag = 3 ;configure memory - try to stay away from memory used by the system ;zero_page memory start address, $50 (80) consecutive Bytes required ; add 2 if I_flag = 2 000a = zero_page = $a ;data_segment memory start address, $6A (106) consecutive Bytes required 0200 = data_segment = $200 if (data_segment & $ff) != 0 ERROR ERROR ERROR low byte of data_segment MUST be $00 !! endif ;code_segment memory start address, 13kB of consecutive space required ; add 2.5 kB if I_flag = 2 0400 = code_segment = $400 ;self modifying code may be disabled to allow running in ROM ;0=part of the code is self modifying and must reside in RAM ;1=tests disabled: branch range 0000 = disable_selfmod = 0 ;report errors through I/O channel (0=use standard self trap loops, 1=include ;report.i65 as I/O channel, add 3.5 kB) 0000 = report = 0 ;RAM integrity test option. Checks for undesired RAM writes. ;set lowest non RAM or RAM mirror address page (-1=disable, 0=64k, $40=16k) ;leave disabled if a monitor, OS or background interrupt is allowed to alter RAM ffff = ram_top = -1 ;disable test decimal mode ADC & SBC, 0=enable, 1=disable, ;2=disable including decimal flag in processor status 0000 = disable_decimal = 0 noopt ;do not take shortcuts ;macros for error & success traps to allow user modification ;example: ;trap macro ; jsr my_error_handler ; endm ;trap_eq macro ; bne skip\? ; trap ;failed equal (zero) ;skip\? ; endm ; ; my_error_handler should pop the calling address from the stack and report it. ; putting larger portions of code (more than 3 bytes) inside the trap macro ; may lead to branch range problems for some tests. if report = 0 trap macro jmp * ;failed anyway endm trap_eq macro beq * ;failed equal (zero) endm trap_ne macro bne * ;failed not equal (non zero) endm trap_cs macro bcs * ;failed carry set endm trap_cc macro bcc * ;failed carry clear endm trap_mi macro bmi * ;failed minus (bit 7 set) endm trap_pl macro bpl * ;failed plus (bit 7 clear) endm trap_vs macro bvs * ;failed overflow set endm trap_vc macro bvc * ;failed overflow clear endm ; please observe that during the test the stack gets invalidated ; therefore a RTS inside the success macro is not possible success macro jmp * ;test passed, no errors endm endif if report = 1 trap macro jsr report_error endm trap_eq macro bne skip\? trap ;failed equal (zero) skip\? endm trap_ne macro beq skip\? trap ;failed not equal (non zero) skip\? endm trap_cs macro bcc skip\? trap ;failed carry set skip\? endm trap_cc macro bcs skip\? trap ;failed carry clear skip\? endm trap_mi macro bpl skip\? trap ;failed minus (bit 7 set) skip\? endm trap_pl macro bmi skip\? trap ;failed plus (bit 7 clear) skip\? endm trap_vs macro bvc skip\? trap ;failed overflow set skip\? endm trap_vc macro bvs skip\? trap ;failed overflow clear skip\? endm ; please observe that during the test the stack gets invalidated ; therefore a RTS inside the success macro is not possible success macro jsr report_success endm endif 0001 = carry equ %00000001 ;flag bits in status 0002 = zero equ %00000010 0004 = intdis equ %00000100 0008 = decmode equ %00001000 0010 = break equ %00010000 0020 = reserv equ %00100000 0040 = overfl equ %01000000 0080 = minus equ %10000000 0001 = fc equ carry 0002 = fz equ zero 0003 = fzc equ carry+zero 0040 = fv equ overfl 0042 = fvz equ overfl+zero 0080 = fn equ minus 0081 = fnc equ minus+carry 0082 = fnz equ minus+zero 0083 = fnzc equ minus+zero+carry 00c0 = fnv equ minus+overfl 0030 = fao equ break+reserv ;bits always on after PHP, BRK 0034 = fai equ fao+intdis ;+ forced interrupt disable 0038 = faod equ fao+decmode ;+ ignore decimal 003c = faid equ fai+decmode ;+ ignore decimal 00ff = m8 equ $ff ;8 bit mask 00fb = m8i equ $ff&~intdis ;8 bit mask - interrupt disable ;macros to allow masking of status bits. ;masking test of decimal bit ;masking of interrupt enable/disable on load and compare ;masking of always on bits after PHP or BRK (unused & break) on compare if disable_decimal < 2 if I_flag = 0 load_flag macro lda #\1&m8i ;force enable interrupts (mask I) endm cmp_flag macro cmp #(\1|fao)&m8i ;I_flag is always enabled + always on bits endm eor_flag macro eor #(\1&m8i|fao) ;mask I, invert expected flags + always on bits endm endif if I_flag = 1 load_flag macro lda #\1|intdis ;force disable interrupts endm cmp_flag macro cmp #(\1|fai)&m8 ;I_flag is always disabled + always on bits endm eor_flag macro eor #(\1|fai) ;invert expected flags + always on bits + I endm endif if I_flag = 2 load_flag macro lda #\1 ora flag_I_on ;restore I-flag and flag_I_off endm cmp_flag macro eor flag_I_on ;I_flag is never changed cmp #(\1|fao)&m8i ;expected flags + always on bits, mask I endm eor_flag macro eor flag_I_on ;I_flag is never changed eor #(\1&m8i|fao) ;mask I, invert expected flags + always on bits endm endif if I_flag = 3 load_flag macro lda #\1 ;allow test to change I-flag (no mask) endm cmp_flag macro cmp #(\1|fao)&m8 ;expected flags + always on bits endm eor_flag macro eor #\1|fao ;invert expected flags + always on bits endm endif else if I_flag = 0 load_flag macro lda #\1&m8i ;force enable interrupts (mask I) endm cmp_flag macro ora #decmode ;ignore decimal mode bit cmp #(\1|faod)&m8i ;I_flag is always enabled + always on bits endm eor_flag macro ora #decmode ;ignore decimal mode bit eor #(\1&m8i|faod) ;mask I, invert expected flags + always on bits endm endif if I_flag = 1 load_flag macro lda #\1|intdis ;force disable interrupts endm cmp_flag macro ora #decmode ;ignore decimal mode bit cmp #(\1|faid)&m8 ;I_flag is always disabled + always on bits endm eor_flag macro ora #decmode ;ignore decimal mode bit eor #(\1|faid) ;invert expected flags + always on bits + I endm endif if I_flag = 2 load_flag macro lda #\1 ora flag_I_on ;restore I-flag and flag_I_off endm cmp_flag macro eor flag_I_on ;I_flag is never changed ora #decmode ;ignore decimal mode bit cmp #(\1|faod)&m8i ;expected flags + always on bits, mask I endm eor_flag macro eor flag_I_on ;I_flag is never changed ora #decmode ;ignore decimal mode bit eor #(\1&m8i|faod) ;mask I, invert expected flags + always on bits endm endif if I_flag = 3 load_flag macro lda #\1 ;allow test to change I-flag (no mask) endm cmp_flag macro ora #decmode ;ignore decimal mode bit cmp #(\1|faod)&m8 ;expected flags + always on bits endm eor_flag macro ora #decmode ;ignore decimal mode bit eor #\1|faod ;invert expected flags + always on bits endm endif endif ;macros to set (register|memory|zeropage) & status set_stat macro ;setting flags in the processor status register load_flag \1 pha ;use stack to load status plp endm set_a macro ;precharging accu & status load_flag \2 pha ;use stack to load status lda #\1 ;precharge accu plp endm set_x macro ;precharging index & status load_flag \2 pha ;use stack to load status ldx #\1 ;precharge index x plp endm set_y macro ;precharging index & status load_flag \2 pha ;use stack to load status ldy #\1 ;precharge index y plp endm set_ax macro ;precharging indexed accu & immediate status load_flag \2 pha ;use stack to load status lda \1,x ;precharge accu plp endm set_ay macro ;precharging indexed accu & immediate status load_flag \2 pha ;use stack to load status lda \1,y ;precharge accu plp endm set_z macro ;precharging indexed zp & immediate status load_flag \2 pha ;use stack to load status lda \1,x ;load to zeropage sta zpt plp endm set_zx macro ;precharging zp,x & immediate status load_flag \2 pha ;use stack to load status lda \1,x ;load to indexed zeropage sta zpt,x plp endm set_abs macro ;precharging indexed memory & immediate status load_flag \2 pha ;use stack to load status lda \1,x ;load to memory sta abst plp endm set_absx macro ;precharging abs,x & immediate status load_flag \2 pha ;use stack to load status lda \1,x ;load to indexed memory sta abst,x plp endm ;macros to test (register|memory|zeropage) & status & (mask) tst_stat macro ;testing flags in the processor status register php ;save status pla ;use stack to retrieve status pha cmp_flag \1 trap_ne plp ;restore status endm tst_a macro ;testing result in accu & flags php ;save flags cmp #\1 ;test result trap_ne pla ;load status pha cmp_flag \2 trap_ne plp ;restore status endm tst_x macro ;testing result in x index & flags php ;save flags cpx #\1 ;test result trap_ne pla ;load status pha cmp_flag \2 trap_ne plp ;restore status endm tst_y macro ;testing result in y index & flags php ;save flags cpy #\1 ;test result trap_ne pla ;load status pha cmp_flag \2 trap_ne plp ;restore status endm tst_ax macro ;indexed testing result in accu & flags php ;save flags cmp \1,x ;test result trap_ne pla ;load status eor_flag \3 cmp \2,x ;test flags trap_ne ; endm tst_ay macro ;indexed testing result in accu & flags php ;save flags cmp \1,y ;test result trap_ne ; pla ;load status eor_flag \3 cmp \2,y ;test flags trap_ne endm tst_z macro ;indexed testing result in zp & flags php ;save flags lda zpt cmp \1,x ;test result trap_ne pla ;load status eor_flag \3 cmp \2,x ;test flags trap_ne endm tst_zx macro ;testing result in zp,x & flags php ;save flags lda zpt,x cmp \1,x ;test result trap_ne pla ;load status eor_flag \3 cmp \2,x ;test flags trap_ne endm tst_abs macro ;indexed testing result in memory & flags php ;save flags lda abst cmp \1,x ;test result trap_ne pla ;load status eor_flag \3 cmp \2,x ;test flags trap_ne endm tst_absx macro ;testing result in abs,x & flags php ;save flags lda abst,x cmp \1,x ;test result trap_ne pla ;load status eor_flag \3 cmp \2,x ;test flags trap_ne endm ; RAM integrity test ; verifies that none of the previous tests has altered RAM outside of the ; designated write areas. ; uses zpt word as indirect pointer, zpt+2 word as checksum if ram_top > -1 check_ram macro cld lda #0 sta zpt ;set low byte of indirect pointer sta zpt+3 ;checksum high byte if disable_selfmod = 0 sta range_adr ;reset self modifying code endif clc ldx #zp_bss-zero_page ;zeropage - write test area ccs3\? adc zero_page,x bcc ccs2\? inc zpt+3 ;carry to high byte clc ccs2\? inx bne ccs3\? ldx #hi(abs1) ;set high byte of indirect pointer stx zpt+1 ldy #lo(abs1) ;data after write & execute test area ccs5\? adc (zpt),y bcc ccs4\? inc zpt+3 ;carry to high byte clc ccs4\? iny bne ccs5\? inx ;advance RAM high address stx zpt+1 cpx #ram_top bne ccs5\? sta zpt+2 ;checksum low is cmp ram_chksm ;checksum low expected trap_ne ;checksum mismatch lda zpt+3 ;checksum high is cmp ram_chksm+1 ;checksum high expected trap_ne ;checksum mismatch endm else check_ram macro ;RAM check disabled - RAM size not set endm endif next_test macro ;make sure, tests don't jump the fence lda test_case ;previous test cmp #test_num trap_ne ;test is out of sequence test_num = test_num + 1 lda #test_num ;*** next tests' number sta test_case ;check_ram ;uncomment to find altered RAM after each test endm if load_data_direct = 1 data else bss ;uninitialized segment, copy of data at end of code! endif ; org zero_page 0000 = org 0 ;edited to provide binaries loading from 0 0000 : 00000000000000.. ds zero_page ;break test interrupt save 000a : 00 irq_a ds 1 ;a register 000b : 00 irq_x ds 1 ;x register if I_flag = 2 ;masking for I bit in status flag_I_on ds 1 ;or mask to load flags flag_I_off ds 1 ;and mask to load flags endif 000c : zpt ;5 bytes store/modify test area ;add/subtract operand generation and result/flag prediction 000c : 00 adfc ds 1 ;carry flag before op 000d : 00 ad1 ds 1 ;operand 1 - accumulator 000e : 00 ad2 ds 1 ;operand 2 - memory / immediate 000f : 00 adrl ds 1 ;expected result bits 0-7 0010 : 00 adrh ds 1 ;expected result bit 8 (carry) 0011 : 00 adrf ds 1 ;expected flags NV0000ZC (only binary mode) 0012 : 00 sb2 ds 1 ;operand 2 complemented for subtract 0013 : zp_bss 0013 : c3824100 zp1 db $c3,$82,$41,0 ;test patterns for LDx BIT ROL ROR ASL LSR 0017 : 7f zp7f db $7f ;test pattern for compare ;logical zeropage operands 0018 : 001f7180 zpOR db 0,$1f,$71,$80 ;test pattern for OR 001c : 0fff7f80 zpAN db $0f,$ff,$7f,$80 ;test pattern for AND 0020 : ff0f8f8f zpEO db $ff,$0f,$8f,$8f ;test pattern for EOR ;indirect addressing pointers 0024 : 1702 ind1 dw abs1 ;indirect pointer to pattern in absolute memory 0026 : 1802 dw abs1+1 0028 : 1902 dw abs1+2 002a : 1a02 dw abs1+3 002c : 1b02 dw abs7f 002e : 1f01 inw1 dw abs1-$f8 ;indirect pointer for wrap-test pattern 0030 : 0302 indt dw abst ;indirect pointer to store area in absolute memory 0032 : 0402 dw abst+1 0034 : 0502 dw abst+2 0036 : 0602 dw abst+3 0038 : 0b01 inwt dw abst-$f8 ;indirect pointer for wrap-test store 003a : 4e02 indAN dw absAN ;indirect pointer to AND pattern in absolute memory 003c : 4f02 dw absAN+1 003e : 5002 dw absAN+2 0040 : 5102 dw absAN+3 0042 : 5202 indEO dw absEO ;indirect pointer to EOR pattern in absolute memory 0044 : 5302 dw absEO+1 0046 : 5402 dw absEO+2 0048 : 5502 dw absEO+3 004a : 4a02 indOR dw absOR ;indirect pointer to OR pattern in absolute memory 004c : 4b02 dw absOR+1 004e : 4c02 dw absOR+2 0050 : 4d02 dw absOR+3 ;add/subtract indirect pointers 0052 : 0302 adi2 dw ada2 ;indirect pointer to operand 2 in absolute memory 0054 : 0402 sbi2 dw sba2 ;indirect pointer to complemented operand 2 (SBC) 0056 : 0401 adiy2 dw ada2-$ff ;with offset for indirect indexed 0058 : 0501 sbiy2 dw sba2-$ff 005a : zp_bss_end 0200 = org data_segment 0200 : 00 test_case ds 1 ;current test number 0201 : 0000 ram_chksm ds 2 ;checksum for RAM integrity test ;add/subtract operand copy - abs tests write area 0203 : abst ;5 bytes store/modify test area 0203 : 00 ada2 ds 1 ;operand 2 0204 : 00 sba2 ds 1 ;operand 2 complemented for subtract 0205 : 000000 ds 3 ;fill remaining bytes 0208 : data_bss if load_data_direct = 1 0208 : 2900 ex_andi and #0 ;execute immediate opcodes 020a : 60 rts 020b : 4900 ex_eori eor #0 ;execute immediate opcodes 020d : 60 rts 020e : 0900 ex_orai ora #0 ;execute immediate opcodes 0210 : 60 rts 0211 : 6900 ex_adci adc #0 ;execute immediate opcodes 0213 : 60 rts 0214 : e900 ex_sbci sbc #0 ;execute immediate opcodes 0216 : 60 rts else ex_andi ds 3 ex_eori ds 3 ex_orai ds 3 ex_adci ds 3 ex_sbci ds 3 endif 0217 : c3824100 abs1 db $c3,$82,$41,0 ;test patterns for LDx BIT ROL ROR ASL LSR 021b : 7f abs7f db $7f ;test pattern for compare ;loads 021c : 80800002 fLDx db fn,fn,0,fz ;expected flags for load ;shifts 0220 : rASL ;expected result ASL & ROL -carry 0220 : 86048200 rROL db $86,$04,$82,0 ; " 0224 : 87058301 rROLc db $87,$05,$83,1 ;expected result ROL +carry 0228 : rLSR ;expected result LSR & ROR -carry 0228 : 61412000 rROR db $61,$41,$20,0 ; " 022c : e1c1a080 rRORc db $e1,$c1,$a0,$80 ;expected result ROR +carry 0230 : fASL ;expected flags for shifts 0230 : 81018002 fROL db fnc,fc,fn,fz ;no carry in 0234 : 81018000 fROLc db fnc,fc,fn,0 ;carry in 0238 : fLSR 0238 : 01000102 fROR db fc,0,fc,fz ;no carry in 023c : 81808180 fRORc db fnc,fn,fnc,fn ;carry in ;increments (decrements) 0240 : 7f80ff0001 rINC db $7f,$80,$ff,0,1 ;expected result for INC/DEC 0245 : 0080800200 fINC db 0,fn,fn,fz,0 ;expected flags for INC/DEC ;logical memory operand 024a : 001f7180 absOR db 0,$1f,$71,$80 ;test pattern for OR 024e : 0fff7f80 absAN db $0f,$ff,$7f,$80 ;test pattern for AND 0252 : ff0f8f8f absEO db $ff,$0f,$8f,$8f ;test pattern for EOR ;logical accu operand 0256 : 00f11f00 absORa db 0,$f1,$1f,0 ;test pattern for OR 025a : f0ffffff absANa db $f0,$ff,$ff,$ff ;test pattern for AND 025e : fff0f00f absEOa db $ff,$f0,$f0,$0f ;test pattern for EOR ;logical results 0262 : 00ff7f80 absrlo db 0,$ff,$7f,$80 0266 : 02800080 absflo db fz,fn,0,fn 026a : data_bss_end code 0400 = org code_segment 0400 : d8 start cld 0401 : a2ff ldx #$ff 0403 : 9a txs 0404 : a900 lda #0 ;*** test 0 = initialize 0406 : 8d0002 sta test_case 0000 = test_num = 0 ;stop interrupts before initializing BSS if I_flag = 1 sei endif ;initialize I/O for report channel if report = 1 jsr report_init endif ;pretest small branch offset 0409 : a205 ldx #5 040b : 4c3304 jmp psb_test 040e : psb_bwok 040e : a005 ldy #5 0410 : d008 bne psb_forw trap ;branch should be taken 0412 : 4c1204 > jmp * ;failed anyway 0415 : 88 dey ;forward landing zone 0416 : 88 dey 0417 : 88 dey 0418 : 88 dey 0419 : 88 dey 041a : psb_forw 041a : 88 dey 041b : 88 dey 041c : 88 dey 041d : 88 dey 041e : 88 dey 041f : f017 beq psb_fwok trap ;forward offset 0421 : 4c2104 > jmp * ;failed anyway 0424 : ca dex ;backward landing zone 0425 : ca dex 0426 : ca dex 0427 : ca dex 0428 : ca dex 0429 : psb_back 0429 : ca dex 042a : ca dex 042b : ca dex 042c : ca dex 042d : ca dex 042e : f0de beq psb_bwok trap ;backward offset 0430 : 4c3004 > jmp * ;failed anyway 0433 : psb_test 0433 : d0f4 bne psb_back trap ;branch should be taken 0435 : 4c3504 > jmp * ;failed anyway 0438 : psb_fwok ;initialize BSS segment if load_data_direct != 1 ldx #zp_end-zp_init-1 ld_zp lda zp_init,x sta zp_bss,x dex bpl ld_zp ldx #data_end-data_init-1 ld_data lda data_init,x sta data_bss,x dex bpl ld_data if ROM_vectors = 1 ldx #5 ld_vect lda vec_init,x sta vec_bss,x dex bpl ld_vect endif endif ;retain status of interrupt flag if I_flag = 2 php pla and #4 ;isolate flag sta flag_I_on ;or mask eor #lo(~4) ;reverse sta flag_I_off ;and mask endif ;generate checksum for RAM integrity test if ram_top > -1 lda #0 sta zpt ;set low byte of indirect pointer sta ram_chksm+1 ;checksum high byte if disable_selfmod = 0 sta range_adr ;reset self modifying code endif clc ldx #zp_bss-zero_page ;zeropage - write test area gcs3 adc zero_page,x bcc gcs2 inc ram_chksm+1 ;carry to high byte clc gcs2 inx bne gcs3 ldx #hi(abs1) ;set high byte of indirect pointer stx zpt+1 ldy #lo(abs1) ;data after write & execute test area gcs5 adc (zpt),y bcc gcs4 inc ram_chksm+1 ;carry to high byte clc gcs4 iny bne gcs5 inx ;advance RAM high address stx zpt+1 cpx #ram_top bne gcs5 sta ram_chksm ;checksum complete endif next_test 0438 : ad0002 > lda test_case ;previous test 043b : c900 > cmp #test_num > trap_ne ;test is out of sequence 043d : d0fe > bne * ;failed not equal (non zero) > 0001 = >test_num = test_num + 1 043f : a901 > lda #test_num ;*** next tests' number 0441 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test if disable_selfmod = 0 ;testing relative addressing with BEQ 0444 : a0fe ldy #$fe ;testing maximum range, not -1/-2 (invalid/self adr) 0446 : range_loop 0446 : 88 dey ;next relative address 0447 : 98 tya 0448 : aa tax ;precharge count to end of loop 0449 : 1008 bpl range_fw ;calculate relative address 044b : 18 clc ;avoid branch self or to relative address of branch 044c : 6902 adc #2 044e : ea nop ;offset landing zone - tolerate +/-5 offset to branch 044f : ea nop 0450 : ea nop 0451 : ea nop 0452 : ea nop 0453 : range_fw 0453 : ea nop 0454 : ea nop 0455 : ea nop 0456 : ea nop 0457 : ea nop 0458 : 497f eor #$7f ;complement except sign 045a : 8de604 sta range_adr ;load into test target 045d : a900 lda #0 ;should set zero flag in status register 045f : 4ce504 jmp range_op 0462 : ca dex ; offset landing zone - backward branch too far 0463 : ca dex 0464 : ca dex 0465 : ca dex 0466 : ca dex ;relative address target field with branch under test in the middle 0467 : ca dex ;-128 - max backward 0468 : ca dex 0469 : ca dex 046a : ca dex 046b : ca dex 046c : ca dex 046d : ca dex 046e : ca dex 046f : ca dex ;-120 0470 : ca dex 0471 : ca dex 0472 : ca dex 0473 : ca dex 0474 : ca dex 0475 : ca dex 0476 : ca dex 0477 : ca dex 0478 : ca dex 0479 : ca dex ;-110 047a : ca dex 047b : ca dex 047c : ca dex 047d : ca dex 047e : ca dex 047f : ca dex 0480 : ca dex 0481 : ca dex 0482 : ca dex 0483 : ca dex ;-100 0484 : ca dex 0485 : ca dex 0486 : ca dex 0487 : ca dex 0488 : ca dex 0489 : ca dex 048a : ca dex 048b : ca dex 048c : ca dex 048d : ca dex ;-90 048e : ca dex 048f : ca dex 0490 : ca dex 0491 : ca dex 0492 : ca dex 0493 : ca dex 0494 : ca dex 0495 : ca dex 0496 : ca dex 0497 : ca dex ;-80 0498 : ca dex 0499 : ca dex 049a : ca dex 049b : ca dex 049c : ca dex 049d : ca dex 049e : ca dex 049f : ca dex 04a0 : ca dex 04a1 : ca dex ;-70 04a2 : ca dex 04a3 : ca dex 04a4 : ca dex 04a5 : ca dex 04a6 : ca dex 04a7 : ca dex 04a8 : ca dex 04a9 : ca dex 04aa : ca dex 04ab : ca dex ;-60 04ac : ca dex 04ad : ca dex 04ae : ca dex 04af : ca dex 04b0 : ca dex 04b1 : ca dex 04b2 : ca dex 04b3 : ca dex 04b4 : ca dex 04b5 : ca dex ;-50 04b6 : ca dex 04b7 : ca dex 04b8 : ca dex 04b9 : ca dex 04ba : ca dex 04bb : ca dex 04bc : ca dex 04bd : ca dex 04be : ca dex 04bf : ca dex ;-40 04c0 : ca dex 04c1 : ca dex 04c2 : ca dex 04c3 : ca dex 04c4 : ca dex 04c5 : ca dex 04c6 : ca dex 04c7 : ca dex 04c8 : ca dex 04c9 : ca dex ;-30 04ca : ca dex 04cb : ca dex 04cc : ca dex 04cd : ca dex 04ce : ca dex 04cf : ca dex 04d0 : ca dex 04d1 : ca dex 04d2 : ca dex 04d3 : ca dex ;-20 04d4 : ca dex 04d5 : ca dex 04d6 : ca dex 04d7 : ca dex 04d8 : ca dex 04d9 : ca dex 04da : ca dex 04db : ca dex 04dc : ca dex 04dd : ca dex ;-10 04de : ca dex 04df : ca dex 04e0 : ca dex 04e1 : ca dex 04e2 : ca dex 04e3 : ca dex 04e4 : ca dex ;-3 04e5 : range_op ;test target with zero flag=0, z=1 if previous dex 04e6 = range_adr = *+1 ;modifiable relative address 04e5 : f03e beq *+64 ;+64 if called without modification 04e7 : ca dex ;+0 04e8 : ca dex 04e9 : ca dex 04ea : ca dex 04eb : ca dex 04ec : ca dex 04ed : ca dex 04ee : ca dex 04ef : ca dex 04f0 : ca dex 04f1 : ca dex ;+10 04f2 : ca dex 04f3 : ca dex 04f4 : ca dex 04f5 : ca dex 04f6 : ca dex 04f7 : ca dex 04f8 : ca dex 04f9 : ca dex 04fa : ca dex 04fb : ca dex ;+20 04fc : ca dex 04fd : ca dex 04fe : ca dex 04ff : ca dex 0500 : ca dex 0501 : ca dex 0502 : ca dex 0503 : ca dex 0504 : ca dex 0505 : ca dex ;+30 0506 : ca dex 0507 : ca dex 0508 : ca dex 0509 : ca dex 050a : ca dex 050b : ca dex 050c : ca dex 050d : ca dex 050e : ca dex 050f : ca dex ;+40 0510 : ca dex 0511 : ca dex 0512 : ca dex 0513 : ca dex 0514 : ca dex 0515 : ca dex 0516 : ca dex 0517 : ca dex 0518 : ca dex 0519 : ca dex ;+50 051a : ca dex 051b : ca dex 051c : ca dex 051d : ca dex 051e : ca dex 051f : ca dex 0520 : ca dex 0521 : ca dex 0522 : ca dex 0523 : ca dex ;+60 0524 : ca dex 0525 : ca dex 0526 : ca dex 0527 : ca dex 0528 : ca dex 0529 : ca dex 052a : ca dex 052b : ca dex 052c : ca dex 052d : ca dex ;+70 052e : ca dex 052f : ca dex 0530 : ca dex 0531 : ca dex 0532 : ca dex 0533 : ca dex 0534 : ca dex 0535 : ca dex 0536 : ca dex 0537 : ca dex ;+80 0538 : ca dex 0539 : ca dex 053a : ca dex 053b : ca dex 053c : ca dex 053d : ca dex 053e : ca dex 053f : ca dex 0540 : ca dex 0541 : ca dex ;+90 0542 : ca dex 0543 : ca dex 0544 : ca dex 0545 : ca dex 0546 : ca dex 0547 : ca dex 0548 : ca dex 0549 : ca dex 054a : ca dex 054b : ca dex ;+100 054c : ca dex 054d : ca dex 054e : ca dex 054f : ca dex 0550 : ca dex 0551 : ca dex 0552 : ca dex 0553 : ca dex 0554 : ca dex 0555 : ca dex ;+110 0556 : ca dex 0557 : ca dex 0558 : ca dex 0559 : ca dex 055a : ca dex 055b : ca dex 055c : ca dex 055d : ca dex 055e : ca dex 055f : ca dex ;+120 0560 : ca dex 0561 : ca dex 0562 : ca dex 0563 : ca dex 0564 : ca dex 0565 : ca dex 0566 : ea nop ;offset landing zone - forward branch too far 0567 : ea nop 0568 : ea nop 0569 : ea nop 056a : ea nop 056b : f008 beq range_ok ;+127 - max forward trap ; bad range 056d : 4c6d05 > jmp * ;failed anyway 0570 : ea nop ;offset landing zone - tolerate +/-5 offset to branch 0571 : ea nop 0572 : ea nop 0573 : ea nop 0574 : ea nop 0575 : range_ok 0575 : ea nop 0576 : ea nop 0577 : ea nop 0578 : ea nop 0579 : ea nop 057a : c000 cpy #0 057c : f003 beq range_end 057e : 4c4604 jmp range_loop 0581 : range_end ;range test successful endif next_test 0581 : ad0002 > lda test_case ;previous test 0584 : c901 > cmp #test_num > trap_ne ;test is out of sequence 0586 : d0fe > bne * ;failed not equal (non zero) > 0002 = >test_num = test_num + 1 0588 : a902 > lda #test_num ;*** next tests' number 058a : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ;partial test BNE & CMP, CPX, CPY immediate 058d : c001 cpy #1 ;testing BNE true 058f : d003 bne test_bne trap 0591 : 4c9105 > jmp * ;failed anyway 0594 : test_bne 0594 : a900 lda #0 0596 : c900 cmp #0 ;test compare immediate trap_ne 0598 : d0fe > bne * ;failed not equal (non zero) trap_cc 059a : 90fe > bcc * ;failed carry clear trap_mi 059c : 30fe > bmi * ;failed minus (bit 7 set) 059e : c901 cmp #1 trap_eq 05a0 : f0fe > beq * ;failed equal (zero) trap_cs 05a2 : b0fe > bcs * ;failed carry set trap_pl 05a4 : 10fe > bpl * ;failed plus (bit 7 clear) 05a6 : aa tax 05a7 : e000 cpx #0 ;test compare x immediate trap_ne 05a9 : d0fe > bne * ;failed not equal (non zero) trap_cc 05ab : 90fe > bcc * ;failed carry clear trap_mi 05ad : 30fe > bmi * ;failed minus (bit 7 set) 05af : e001 cpx #1 trap_eq 05b1 : f0fe > beq * ;failed equal (zero) trap_cs 05b3 : b0fe > bcs * ;failed carry set trap_pl 05b5 : 10fe > bpl * ;failed plus (bit 7 clear) 05b7 : a8 tay 05b8 : c000 cpy #0 ;test compare y immediate trap_ne 05ba : d0fe > bne * ;failed not equal (non zero) trap_cc 05bc : 90fe > bcc * ;failed carry clear trap_mi 05be : 30fe > bmi * ;failed minus (bit 7 set) 05c0 : c001 cpy #1 trap_eq 05c2 : f0fe > beq * ;failed equal (zero) trap_cs 05c4 : b0fe > bcs * ;failed carry set trap_pl 05c6 : 10fe > bpl * ;failed plus (bit 7 clear) next_test 05c8 : ad0002 > lda test_case ;previous test 05cb : c902 > cmp #test_num > trap_ne ;test is out of sequence 05cd : d0fe > bne * ;failed not equal (non zero) > 0003 = >test_num = test_num + 1 05cf : a903 > lda #test_num ;*** next tests' number 05d1 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ;testing stack operations PHA PHP PLA PLP 05d4 : a2ff ldx #$ff ;initialize stack 05d6 : 9a txs 05d7 : a955 lda #$55 05d9 : 48 pha 05da : a9aa lda #$aa 05dc : 48 pha 05dd : cdfe01 cmp $1fe ;on stack ? trap_ne 05e0 : d0fe > bne * ;failed not equal (non zero) 05e2 : ba tsx 05e3 : 8a txa ;overwrite accu 05e4 : c9fd cmp #$fd ;sp decremented? trap_ne 05e6 : d0fe > bne * ;failed not equal (non zero) 05e8 : 68 pla 05e9 : c9aa cmp #$aa ;successful retreived from stack? trap_ne 05eb : d0fe > bne * ;failed not equal (non zero) 05ed : 68 pla 05ee : c955 cmp #$55 trap_ne 05f0 : d0fe > bne * ;failed not equal (non zero) 05f2 : cdff01 cmp $1ff ;remains on stack? trap_ne 05f5 : d0fe > bne * ;failed not equal (non zero) 05f7 : ba tsx 05f8 : e0ff cpx #$ff ;sp incremented? trap_ne 05fa : d0fe > bne * ;failed not equal (non zero) next_test 05fc : ad0002 > lda test_case ;previous test 05ff : c903 > cmp #test_num > trap_ne ;test is out of sequence 0601 : d0fe > bne * ;failed not equal (non zero) > 0004 = >test_num = test_num + 1 0603 : a904 > lda #test_num ;*** next tests' number 0605 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ;testing branch decisions BPL BMI BVC BVS BCC BCS BNE BEQ set_stat $ff ;all on > load_flag $ff 0608 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 060a : 48 > pha ;use stack to load status 060b : 28 > plp 060c : 101a bpl nbr1 ;branches should not be taken 060e : 501b bvc nbr2 0610 : 901c bcc nbr3 0612 : d01d bne nbr4 0614 : 3003 bmi br1 ;branches should be taken trap 0616 : 4c1606 > jmp * ;failed anyway 0619 : 7003 br1 bvs br2 trap 061b : 4c1b06 > jmp * ;failed anyway 061e : b003 br2 bcs br3 trap 0620 : 4c2006 > jmp * ;failed anyway 0623 : f00f br3 beq br4 trap 0625 : 4c2506 > jmp * ;failed anyway 0628 : nbr1 trap ;previous bpl taken 0628 : 4c2806 > jmp * ;failed anyway 062b : nbr2 trap ;previous bvc taken 062b : 4c2b06 > jmp * ;failed anyway 062e : nbr3 trap ;previous bcc taken 062e : 4c2e06 > jmp * ;failed anyway 0631 : nbr4 trap ;previous bne taken 0631 : 4c3106 > jmp * ;failed anyway 0634 : 08 br4 php 0635 : ba tsx 0636 : e0fe cpx #$fe ;sp after php? trap_ne 0638 : d0fe > bne * ;failed not equal (non zero) 063a : 68 pla cmp_flag $ff ;returned all flags on? 063b : c9ff > cmp #($ff |fao)&m8 ;expected flags + always on bits trap_ne 063d : d0fe > bne * ;failed not equal (non zero) 063f : ba tsx 0640 : e0ff cpx #$ff ;sp after php? trap_ne 0642 : d0fe > bne * ;failed not equal (non zero) set_stat 0 ;all off > load_flag 0 0644 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0646 : 48 > pha ;use stack to load status 0647 : 28 > plp 0648 : 301a bmi nbr11 ;branches should not be taken 064a : 701b bvs nbr12 064c : b01c bcs nbr13 064e : f01d beq nbr14 0650 : 1003 bpl br11 ;branches should be taken trap 0652 : 4c5206 > jmp * ;failed anyway 0655 : 5003 br11 bvc br12 trap 0657 : 4c5706 > jmp * ;failed anyway 065a : 9003 br12 bcc br13 trap 065c : 4c5c06 > jmp * ;failed anyway 065f : d00f br13 bne br14 trap 0661 : 4c6106 > jmp * ;failed anyway 0664 : nbr11 trap ;previous bmi taken 0664 : 4c6406 > jmp * ;failed anyway 0667 : nbr12 trap ;previous bvs taken 0667 : 4c6706 > jmp * ;failed anyway 066a : nbr13 trap ;previous bcs taken 066a : 4c6a06 > jmp * ;failed anyway 066d : nbr14 trap ;previous beq taken 066d : 4c6d06 > jmp * ;failed anyway 0670 : 08 br14 php 0671 : 68 pla cmp_flag 0 ;flags off except break (pushed by sw) + reserved? 0672 : c930 > cmp #(0 |fao)&m8 ;expected flags + always on bits trap_ne 0674 : d0fe > bne * ;failed not equal (non zero) ;crosscheck flags set_stat zero > load_flag zero 0676 : a902 > lda #zero ;allow test to change I-flag (no mask) > 0678 : 48 > pha ;use stack to load status 0679 : 28 > plp 067a : d002 bne brzs1 067c : f003 beq brzs2 067e : brzs1 trap ;branch zero/non zero 067e : 4c7e06 > jmp * ;failed anyway 0681 : b002 brzs2 bcs brzs3 0683 : 9003 bcc brzs4 0685 : brzs3 trap ;branch carry/no carry 0685 : 4c8506 > jmp * ;failed anyway 0688 : 3002 brzs4 bmi brzs5 068a : 1003 bpl brzs6 068c : brzs5 trap ;branch minus/plus 068c : 4c8c06 > jmp * ;failed anyway 068f : 7002 brzs6 bvs brzs7 0691 : 5003 bvc brzs8 0693 : brzs7 trap ;branch overflow/no overflow 0693 : 4c9306 > jmp * ;failed anyway 0696 : brzs8 set_stat carry > load_flag carry 0696 : a901 > lda #carry ;allow test to change I-flag (no mask) > 0698 : 48 > pha ;use stack to load status 0699 : 28 > plp 069a : f002 beq brcs1 069c : d003 bne brcs2 069e : brcs1 trap ;branch zero/non zero 069e : 4c9e06 > jmp * ;failed anyway 06a1 : 9002 brcs2 bcc brcs3 06a3 : b003 bcs brcs4 06a5 : brcs3 trap ;branch carry/no carry 06a5 : 4ca506 > jmp * ;failed anyway 06a8 : 3002 brcs4 bmi brcs5 06aa : 1003 bpl brcs6 06ac : brcs5 trap ;branch minus/plus 06ac : 4cac06 > jmp * ;failed anyway 06af : 7002 brcs6 bvs brcs7 06b1 : 5003 bvc brcs8 06b3 : brcs7 trap ;branch overflow/no overflow 06b3 : 4cb306 > jmp * ;failed anyway 06b6 : brcs8 set_stat minus > load_flag minus 06b6 : a980 > lda #minus ;allow test to change I-flag (no mask) > 06b8 : 48 > pha ;use stack to load status 06b9 : 28 > plp 06ba : f002 beq brmi1 06bc : d003 bne brmi2 06be : brmi1 trap ;branch zero/non zero 06be : 4cbe06 > jmp * ;failed anyway 06c1 : b002 brmi2 bcs brmi3 06c3 : 9003 bcc brmi4 06c5 : brmi3 trap ;branch carry/no carry 06c5 : 4cc506 > jmp * ;failed anyway 06c8 : 1002 brmi4 bpl brmi5 06ca : 3003 bmi brmi6 06cc : brmi5 trap ;branch minus/plus 06cc : 4ccc06 > jmp * ;failed anyway 06cf : 7002 brmi6 bvs brmi7 06d1 : 5003 bvc brmi8 06d3 : brmi7 trap ;branch overflow/no overflow 06d3 : 4cd306 > jmp * ;failed anyway 06d6 : brmi8 set_stat overfl > load_flag overfl 06d6 : a940 > lda #overfl ;allow test to change I-flag (no mask) > 06d8 : 48 > pha ;use stack to load status 06d9 : 28 > plp 06da : f002 beq brvs1 06dc : d003 bne brvs2 06de : brvs1 trap ;branch zero/non zero 06de : 4cde06 > jmp * ;failed anyway 06e1 : b002 brvs2 bcs brvs3 06e3 : 9003 bcc brvs4 06e5 : brvs3 trap ;branch carry/no carry 06e5 : 4ce506 > jmp * ;failed anyway 06e8 : 3002 brvs4 bmi brvs5 06ea : 1003 bpl brvs6 06ec : brvs5 trap ;branch minus/plus 06ec : 4cec06 > jmp * ;failed anyway 06ef : 5002 brvs6 bvc brvs7 06f1 : 7003 bvs brvs8 06f3 : brvs7 trap ;branch overflow/no overflow 06f3 : 4cf306 > jmp * ;failed anyway 06f6 : brvs8 set_stat $ff-zero > load_flag $ff-zero 06f6 : a9fd > lda #$ff-zero ;allow test to change I-flag (no mask) > 06f8 : 48 > pha ;use stack to load status 06f9 : 28 > plp 06fa : f002 beq brzc1 06fc : d003 bne brzc2 06fe : brzc1 trap ;branch zero/non zero 06fe : 4cfe06 > jmp * ;failed anyway 0701 : 9002 brzc2 bcc brzc3 0703 : b003 bcs brzc4 0705 : brzc3 trap ;branch carry/no carry 0705 : 4c0507 > jmp * ;failed anyway 0708 : 1002 brzc4 bpl brzc5 070a : 3003 bmi brzc6 070c : brzc5 trap ;branch minus/plus 070c : 4c0c07 > jmp * ;failed anyway 070f : 5002 brzc6 bvc brzc7 0711 : 7003 bvs brzc8 0713 : brzc7 trap ;branch overflow/no overflow 0713 : 4c1307 > jmp * ;failed anyway 0716 : brzc8 set_stat $ff-carry > load_flag $ff-carry 0716 : a9fe > lda #$ff-carry ;allow test to change I-flag (no mask) > 0718 : 48 > pha ;use stack to load status 0719 : 28 > plp 071a : d002 bne brcc1 071c : f003 beq brcc2 071e : brcc1 trap ;branch zero/non zero 071e : 4c1e07 > jmp * ;failed anyway 0721 : b002 brcc2 bcs brcc3 0723 : 9003 bcc brcc4 0725 : brcc3 trap ;branch carry/no carry 0725 : 4c2507 > jmp * ;failed anyway 0728 : 1002 brcc4 bpl brcc5 072a : 3003 bmi brcc6 072c : brcc5 trap ;branch minus/plus 072c : 4c2c07 > jmp * ;failed anyway 072f : 5002 brcc6 bvc brcc7 0731 : 7003 bvs brcc8 0733 : brcc7 trap ;branch overflow/no overflow 0733 : 4c3307 > jmp * ;failed anyway 0736 : brcc8 set_stat $ff-minus > load_flag $ff-minus 0736 : a97f > lda #$ff-minus ;allow test to change I-flag (no mask) > 0738 : 48 > pha ;use stack to load status 0739 : 28 > plp 073a : d002 bne brpl1 073c : f003 beq brpl2 073e : brpl1 trap ;branch zero/non zero 073e : 4c3e07 > jmp * ;failed anyway 0741 : 9002 brpl2 bcc brpl3 0743 : b003 bcs brpl4 0745 : brpl3 trap ;branch carry/no carry 0745 : 4c4507 > jmp * ;failed anyway 0748 : 3002 brpl4 bmi brpl5 074a : 1003 bpl brpl6 074c : brpl5 trap ;branch minus/plus 074c : 4c4c07 > jmp * ;failed anyway 074f : 5002 brpl6 bvc brpl7 0751 : 7003 bvs brpl8 0753 : brpl7 trap ;branch overflow/no overflow 0753 : 4c5307 > jmp * ;failed anyway 0756 : brpl8 set_stat $ff-overfl > load_flag $ff-overfl 0756 : a9bf > lda #$ff-overfl ;allow test to change I-flag (no mask) > 0758 : 48 > pha ;use stack to load status 0759 : 28 > plp 075a : d002 bne brvc1 075c : f003 beq brvc2 075e : brvc1 trap ;branch zero/non zero 075e : 4c5e07 > jmp * ;failed anyway 0761 : 9002 brvc2 bcc brvc3 0763 : b003 bcs brvc4 0765 : brvc3 trap ;branch carry/no carry 0765 : 4c6507 > jmp * ;failed anyway 0768 : 1002 brvc4 bpl brvc5 076a : 3003 bmi brvc6 076c : brvc5 trap ;branch minus/plus 076c : 4c6c07 > jmp * ;failed anyway 076f : 7002 brvc6 bvs brvc7 0771 : 5003 bvc brvc8 0773 : brvc7 trap ;branch overflow/no overflow 0773 : 4c7307 > jmp * ;failed anyway 0776 : brvc8 next_test 0776 : ad0002 > lda test_case ;previous test 0779 : c904 > cmp #test_num > trap_ne ;test is out of sequence 077b : d0fe > bne * ;failed not equal (non zero) > 0005 = >test_num = test_num + 1 077d : a905 > lda #test_num ;*** next tests' number 077f : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; test PHA does not alter flags or accumulator but PLA does 0782 : a255 ldx #$55 ;x & y protected 0784 : a0aa ldy #$aa set_a 1,$ff ;push > load_flag $ff 0786 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0788 : 48 > pha ;use stack to load status 0789 : a901 > lda #1 ;precharge accu 078b : 28 > plp 078c : 48 pha tst_a 1,$ff 078d : 08 > php ;save flags 078e : c901 > cmp #1 ;test result > trap_ne 0790 : d0fe > bne * ;failed not equal (non zero) > 0792 : 68 > pla ;load status 0793 : 48 > pha > cmp_flag $ff 0794 : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits > > trap_ne 0796 : d0fe > bne * ;failed not equal (non zero) > 0798 : 28 > plp ;restore status set_a 0,0 > load_flag 0 0799 : a900 > lda #0 ;allow test to change I-flag (no mask) > 079b : 48 > pha ;use stack to load status 079c : a900 > lda #0 ;precharge accu 079e : 28 > plp 079f : 48 pha tst_a 0,0 07a0 : 08 > php ;save flags 07a1 : c900 > cmp #0 ;test result > trap_ne 07a3 : d0fe > bne * ;failed not equal (non zero) > 07a5 : 68 > pla ;load status 07a6 : 48 > pha > cmp_flag 0 07a7 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 07a9 : d0fe > bne * ;failed not equal (non zero) > 07ab : 28 > plp ;restore status set_a $ff,$ff > load_flag $ff 07ac : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 07ae : 48 > pha ;use stack to load status 07af : a9ff > lda #$ff ;precharge accu 07b1 : 28 > plp 07b2 : 48 pha tst_a $ff,$ff 07b3 : 08 > php ;save flags 07b4 : c9ff > cmp #$ff ;test result > trap_ne 07b6 : d0fe > bne * ;failed not equal (non zero) > 07b8 : 68 > pla ;load status 07b9 : 48 > pha > cmp_flag $ff 07ba : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits > > trap_ne 07bc : d0fe > bne * ;failed not equal (non zero) > 07be : 28 > plp ;restore status set_a 1,0 > load_flag 0 07bf : a900 > lda #0 ;allow test to change I-flag (no mask) > 07c1 : 48 > pha ;use stack to load status 07c2 : a901 > lda #1 ;precharge accu 07c4 : 28 > plp 07c5 : 48 pha tst_a 1,0 07c6 : 08 > php ;save flags 07c7 : c901 > cmp #1 ;test result > trap_ne 07c9 : d0fe > bne * ;failed not equal (non zero) > 07cb : 68 > pla ;load status 07cc : 48 > pha > cmp_flag 0 07cd : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 07cf : d0fe > bne * ;failed not equal (non zero) > 07d1 : 28 > plp ;restore status set_a 0,$ff > load_flag $ff 07d2 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 07d4 : 48 > pha ;use stack to load status 07d5 : a900 > lda #0 ;precharge accu 07d7 : 28 > plp 07d8 : 48 pha tst_a 0,$ff 07d9 : 08 > php ;save flags 07da : c900 > cmp #0 ;test result > trap_ne 07dc : d0fe > bne * ;failed not equal (non zero) > 07de : 68 > pla ;load status 07df : 48 > pha > cmp_flag $ff 07e0 : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits > > trap_ne 07e2 : d0fe > bne * ;failed not equal (non zero) > 07e4 : 28 > plp ;restore status set_a $ff,0 > load_flag 0 07e5 : a900 > lda #0 ;allow test to change I-flag (no mask) > 07e7 : 48 > pha ;use stack to load status 07e8 : a9ff > lda #$ff ;precharge accu 07ea : 28 > plp 07eb : 48 pha tst_a $ff,0 07ec : 08 > php ;save flags 07ed : c9ff > cmp #$ff ;test result > trap_ne 07ef : d0fe > bne * ;failed not equal (non zero) > 07f1 : 68 > pla ;load status 07f2 : 48 > pha > cmp_flag 0 07f3 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 07f5 : d0fe > bne * ;failed not equal (non zero) > 07f7 : 28 > plp ;restore status set_a 0,$ff ;pull > load_flag $ff 07f8 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 07fa : 48 > pha ;use stack to load status 07fb : a900 > lda #0 ;precharge accu 07fd : 28 > plp 07fe : 68 pla tst_a $ff,$ff-zero 07ff : 08 > php ;save flags 0800 : c9ff > cmp #$ff ;test result > trap_ne 0802 : d0fe > bne * ;failed not equal (non zero) > 0804 : 68 > pla ;load status 0805 : 48 > pha > cmp_flag $ff-zero 0806 : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0808 : d0fe > bne * ;failed not equal (non zero) > 080a : 28 > plp ;restore status set_a $ff,0 > load_flag 0 080b : a900 > lda #0 ;allow test to change I-flag (no mask) > 080d : 48 > pha ;use stack to load status 080e : a9ff > lda #$ff ;precharge accu 0810 : 28 > plp 0811 : 68 pla tst_a 0,zero 0812 : 08 > php ;save flags 0813 : c900 > cmp #0 ;test result > trap_ne 0815 : d0fe > bne * ;failed not equal (non zero) > 0817 : 68 > pla ;load status 0818 : 48 > pha > cmp_flag zero 0819 : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits > > trap_ne 081b : d0fe > bne * ;failed not equal (non zero) > 081d : 28 > plp ;restore status set_a $fe,$ff > load_flag $ff 081e : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0820 : 48 > pha ;use stack to load status 0821 : a9fe > lda #$fe ;precharge accu 0823 : 28 > plp 0824 : 68 pla tst_a 1,$ff-zero-minus 0825 : 08 > php ;save flags 0826 : c901 > cmp #1 ;test result > trap_ne 0828 : d0fe > bne * ;failed not equal (non zero) > 082a : 68 > pla ;load status 082b : 48 > pha > cmp_flag $ff-zero-minus 082c : c97d > cmp #($ff-zero-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 082e : d0fe > bne * ;failed not equal (non zero) > 0830 : 28 > plp ;restore status set_a 0,0 > load_flag 0 0831 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0833 : 48 > pha ;use stack to load status 0834 : a900 > lda #0 ;precharge accu 0836 : 28 > plp 0837 : 68 pla tst_a $ff,minus 0838 : 08 > php ;save flags 0839 : c9ff > cmp #$ff ;test result > trap_ne 083b : d0fe > bne * ;failed not equal (non zero) > 083d : 68 > pla ;load status 083e : 48 > pha > cmp_flag minus 083f : c9b0 > cmp #(minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0841 : d0fe > bne * ;failed not equal (non zero) > 0843 : 28 > plp ;restore status set_a $ff,$ff > load_flag $ff 0844 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0846 : 48 > pha ;use stack to load status 0847 : a9ff > lda #$ff ;precharge accu 0849 : 28 > plp 084a : 68 pla tst_a 0,$ff-minus 084b : 08 > php ;save flags 084c : c900 > cmp #0 ;test result > trap_ne 084e : d0fe > bne * ;failed not equal (non zero) > 0850 : 68 > pla ;load status 0851 : 48 > pha > cmp_flag $ff-minus 0852 : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0854 : d0fe > bne * ;failed not equal (non zero) > 0856 : 28 > plp ;restore status set_a $fe,0 > load_flag 0 0857 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0859 : 48 > pha ;use stack to load status 085a : a9fe > lda #$fe ;precharge accu 085c : 28 > plp 085d : 68 pla tst_a 1,0 085e : 08 > php ;save flags 085f : c901 > cmp #1 ;test result > trap_ne 0861 : d0fe > bne * ;failed not equal (non zero) > 0863 : 68 > pla ;load status 0864 : 48 > pha > cmp_flag 0 0865 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0867 : d0fe > bne * ;failed not equal (non zero) > 0869 : 28 > plp ;restore status 086a : e055 cpx #$55 ;x & y unchanged? trap_ne 086c : d0fe > bne * ;failed not equal (non zero) 086e : c0aa cpy #$aa trap_ne 0870 : d0fe > bne * ;failed not equal (non zero) next_test 0872 : ad0002 > lda test_case ;previous test 0875 : c905 > cmp #test_num > trap_ne ;test is out of sequence 0877 : d0fe > bne * ;failed not equal (non zero) > 0006 = >test_num = test_num + 1 0879 : a906 > lda #test_num ;*** next tests' number 087b : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; partial pretest EOR # set_a $3c,0 > load_flag 0 087e : a900 > lda #0 ;allow test to change I-flag (no mask) > 0880 : 48 > pha ;use stack to load status 0881 : a93c > lda #$3c ;precharge accu 0883 : 28 > plp 0884 : 49c3 eor #$c3 tst_a $ff,fn 0886 : 08 > php ;save flags 0887 : c9ff > cmp #$ff ;test result > trap_ne 0889 : d0fe > bne * ;failed not equal (non zero) > 088b : 68 > pla ;load status 088c : 48 > pha > cmp_flag fn 088d : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 088f : d0fe > bne * ;failed not equal (non zero) > 0891 : 28 > plp ;restore status set_a $c3,0 > load_flag 0 0892 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0894 : 48 > pha ;use stack to load status 0895 : a9c3 > lda #$c3 ;precharge accu 0897 : 28 > plp 0898 : 49c3 eor #$c3 tst_a 0,fz 089a : 08 > php ;save flags 089b : c900 > cmp #0 ;test result > trap_ne 089d : d0fe > bne * ;failed not equal (non zero) > 089f : 68 > pla ;load status 08a0 : 48 > pha > cmp_flag fz 08a1 : c932 > cmp #(fz|fao)&m8 ;expected flags + always on bits > > trap_ne 08a3 : d0fe > bne * ;failed not equal (non zero) > 08a5 : 28 > plp ;restore status next_test 08a6 : ad0002 > lda test_case ;previous test 08a9 : c906 > cmp #test_num > trap_ne ;test is out of sequence 08ab : d0fe > bne * ;failed not equal (non zero) > 0007 = >test_num = test_num + 1 08ad : a907 > lda #test_num ;*** next tests' number 08af : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; PC modifying instructions except branches (NOP, JMP, JSR, RTS, BRK, RTI) ; testing NOP 08b2 : a224 ldx #$24 08b4 : a042 ldy #$42 set_a $18,0 > load_flag 0 08b6 : a900 > lda #0 ;allow test to change I-flag (no mask) > 08b8 : 48 > pha ;use stack to load status 08b9 : a918 > lda #$18 ;precharge accu 08bb : 28 > plp 08bc : ea nop tst_a $18,0 08bd : 08 > php ;save flags 08be : c918 > cmp #$18 ;test result > trap_ne 08c0 : d0fe > bne * ;failed not equal (non zero) > 08c2 : 68 > pla ;load status 08c3 : 48 > pha > cmp_flag 0 08c4 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 08c6 : d0fe > bne * ;failed not equal (non zero) > 08c8 : 28 > plp ;restore status 08c9 : e024 cpx #$24 trap_ne 08cb : d0fe > bne * ;failed not equal (non zero) 08cd : c042 cpy #$42 trap_ne 08cf : d0fe > bne * ;failed not equal (non zero) 08d1 : a2db ldx #$db 08d3 : a0bd ldy #$bd set_a $e7,$ff > load_flag $ff 08d5 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 08d7 : 48 > pha ;use stack to load status 08d8 : a9e7 > lda #$e7 ;precharge accu 08da : 28 > plp 08db : ea nop tst_a $e7,$ff 08dc : 08 > php ;save flags 08dd : c9e7 > cmp #$e7 ;test result > trap_ne 08df : d0fe > bne * ;failed not equal (non zero) > 08e1 : 68 > pla ;load status 08e2 : 48 > pha > cmp_flag $ff 08e3 : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits > > trap_ne 08e5 : d0fe > bne * ;failed not equal (non zero) > 08e7 : 28 > plp ;restore status 08e8 : e0db cpx #$db trap_ne 08ea : d0fe > bne * ;failed not equal (non zero) 08ec : c0bd cpy #$bd trap_ne 08ee : d0fe > bne * ;failed not equal (non zero) next_test 08f0 : ad0002 > lda test_case ;previous test 08f3 : c907 > cmp #test_num > trap_ne ;test is out of sequence 08f5 : d0fe > bne * ;failed not equal (non zero) > 0008 = >test_num = test_num + 1 08f7 : a908 > lda #test_num ;*** next tests' number 08f9 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; jump absolute set_stat $0 > load_flag $0 08fc : a900 > lda #$0 ;allow test to change I-flag (no mask) > 08fe : 48 > pha ;use stack to load status 08ff : 28 > plp 0900 : a946 lda #'F' 0902 : a241 ldx #'A' 0904 : a052 ldy #'R' ;N=0, V=0, Z=0, C=0 0906 : 4cef36 jmp test_far 0909 : ea nop 090a : ea nop trap_ne ;runover protection 090b : d0fe > bne * ;failed not equal (non zero) 090d : e8 inx 090e : e8 inx 090f : far_ret trap_eq ;returned flags OK? 090f : f0fe > beq * ;failed equal (zero) trap_pl 0911 : 10fe > bpl * ;failed plus (bit 7 clear) trap_cc 0913 : 90fe > bcc * ;failed carry clear trap_vc 0915 : 50fe > bvc * ;failed overflow clear 0917 : c9ec cmp #('F'^$aa) ;returned registers OK? trap_ne 0919 : d0fe > bne * ;failed not equal (non zero) 091b : e042 cpx #('A'+1) trap_ne 091d : d0fe > bne * ;failed not equal (non zero) 091f : c04f cpy #('R'-3) trap_ne 0921 : d0fe > bne * ;failed not equal (non zero) 0923 : ca dex 0924 : c8 iny 0925 : c8 iny 0926 : c8 iny 0927 : 49aa eor #$aa ;N=0, V=1, Z=0, C=1 0929 : 4c3209 jmp test_near 092c : ea nop 092d : ea nop trap_ne ;runover protection 092e : d0fe > bne * ;failed not equal (non zero) 0930 : e8 inx 0931 : e8 inx 0932 : test_near trap_eq ;passed flags OK? 0932 : f0fe > beq * ;failed equal (zero) trap_mi 0934 : 30fe > bmi * ;failed minus (bit 7 set) trap_cc 0936 : 90fe > bcc * ;failed carry clear trap_vc 0938 : 50fe > bvc * ;failed overflow clear 093a : c946 cmp #'F' ;passed registers OK? trap_ne 093c : d0fe > bne * ;failed not equal (non zero) 093e : e041 cpx #'A' trap_ne 0940 : d0fe > bne * ;failed not equal (non zero) 0942 : c052 cpy #'R' trap_ne 0944 : d0fe > bne * ;failed not equal (non zero) next_test 0946 : ad0002 > lda test_case ;previous test 0949 : c908 > cmp #test_num > trap_ne ;test is out of sequence 094b : d0fe > bne * ;failed not equal (non zero) > 0009 = >test_num = test_num + 1 094d : a909 > lda #test_num ;*** next tests' number 094f : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; jump indirect set_stat 0 > load_flag 0 0952 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0954 : 48 > pha ;use stack to load status 0955 : 28 > plp 0956 : a949 lda #'I' 0958 : a24e ldx #'N' 095a : a044 ldy #'D' ;N=0, V=0, Z=0, C=0 095c : 6c1e37 jmp (ptr_tst_ind) 095f : ea nop trap_ne ;runover protection 0960 : d0fe > bne * ;failed not equal (non zero) 0962 : 88 dey 0963 : 88 dey 0964 : ind_ret 0964 : 08 php ;either SP or Y count will fail, if we do not hit 0965 : 88 dey 0966 : 88 dey 0967 : 88 dey 0968 : 28 plp trap_eq ;returned flags OK? 0969 : f0fe > beq * ;failed equal (zero) trap_pl 096b : 10fe > bpl * ;failed plus (bit 7 clear) trap_cc 096d : 90fe > bcc * ;failed carry clear trap_vc 096f : 50fe > bvc * ;failed overflow clear 0971 : c9e3 cmp #('I'^$aa) ;returned registers OK? trap_ne 0973 : d0fe > bne * ;failed not equal (non zero) 0975 : e04f cpx #('N'+1) trap_ne 0977 : d0fe > bne * ;failed not equal (non zero) 0979 : c03e cpy #('D'-6) trap_ne 097b : d0fe > bne * ;failed not equal (non zero) 097d : ba tsx ;SP check 097e : e0ff cpx #$ff trap_ne 0980 : d0fe > bne * ;failed not equal (non zero) next_test 0982 : ad0002 > lda test_case ;previous test 0985 : c909 > cmp #test_num > trap_ne ;test is out of sequence 0987 : d0fe > bne * ;failed not equal (non zero) > 000a = >test_num = test_num + 1 0989 : a90a > lda #test_num ;*** next tests' number 098b : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; jump subroutine & return from subroutine set_stat 0 > load_flag 0 098e : a900 > lda #0 ;allow test to change I-flag (no mask) > 0990 : 48 > pha ;use stack to load status 0991 : 28 > plp 0992 : a94a lda #'J' 0994 : a253 ldx #'S' 0996 : a052 ldy #'R' ;N=0, V=0, Z=0, C=0 0998 : 205d37 jsr test_jsr 099a = jsr_ret = *-1 ;last address of jsr = return address 099b : 08 php ;either SP or Y count will fail, if we do not hit 099c : 88 dey 099d : 88 dey 099e : 88 dey 099f : 28 plp trap_eq ;returned flags OK? 09a0 : f0fe > beq * ;failed equal (zero) trap_pl 09a2 : 10fe > bpl * ;failed plus (bit 7 clear) trap_cc 09a4 : 90fe > bcc * ;failed carry clear trap_vc 09a6 : 50fe > bvc * ;failed overflow clear 09a8 : c9e0 cmp #('J'^$aa) ;returned registers OK? trap_ne 09aa : d0fe > bne * ;failed not equal (non zero) 09ac : e054 cpx #('S'+1) trap_ne 09ae : d0fe > bne * ;failed not equal (non zero) 09b0 : c04c cpy #('R'-6) trap_ne 09b2 : d0fe > bne * ;failed not equal (non zero) 09b4 : ba tsx ;sp? 09b5 : e0ff cpx #$ff trap_ne 09b7 : d0fe > bne * ;failed not equal (non zero) next_test 09b9 : ad0002 > lda test_case ;previous test 09bc : c90a > cmp #test_num > trap_ne ;test is out of sequence 09be : d0fe > bne * ;failed not equal (non zero) > 000b = >test_num = test_num + 1 09c0 : a90b > lda #test_num ;*** next tests' number 09c2 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; break & return from interrupt if ROM_vectors = 1 load_flag 0 ;with interrupts enabled if allowed! 09c5 : a900 > lda #0 ;allow test to change I-flag (no mask) 09c7 : 48 pha 09c8 : a942 lda #'B' 09ca : a252 ldx #'R' 09cc : a04b ldy #'K' 09ce : 28 plp ;N=0, V=0, Z=0, C=0 09cf : 00 brk else lda #hi brk_ret0 ;emulated break pha lda #lo brk_ret0 pha load_flag fao ;set break & unused on stack pha load_flag intdis ;during interrupt pha lda #'B' ldx #'R' ldy #'K' plp ;N=0, V=0, Z=0, C=0 jmp irq_trap endif 09d0 : 88 dey ;should not be executed 09d1 : brk_ret0 ;address of break return 09d1 : 08 php ;either SP or Y count will fail, if we do not hit 09d2 : 88 dey 09d3 : 88 dey 09d4 : 88 dey 09d5 : c9e8 cmp #'B'^$aa ;returned registers OK? ;the IRQ vector was never executed if A & X stay unmodified trap_ne 09d7 : d0fe > bne * ;failed not equal (non zero) 09d9 : e053 cpx #'R'+1 trap_ne 09db : d0fe > bne * ;failed not equal (non zero) 09dd : c045 cpy #'K'-6 trap_ne 09df : d0fe > bne * ;failed not equal (non zero) 09e1 : 68 pla ;returned flags OK (unchanged)? cmp_flag 0 09e2 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits trap_ne 09e4 : d0fe > bne * ;failed not equal (non zero) 09e6 : ba tsx ;sp? 09e7 : e0ff cpx #$ff trap_ne 09e9 : d0fe > bne * ;failed not equal (non zero) if ROM_vectors = 1 load_flag $ff ;with interrupts disabled if allowed! 09eb : a9ff > lda #$ff ;allow test to change I-flag (no mask) 09ed : 48 pha 09ee : a9bd lda #$ff-'B' 09f0 : a2ad ldx #$ff-'R' 09f2 : a0b4 ldy #$ff-'K' 09f4 : 28 plp ;N=1, V=1, Z=1, C=1 09f5 : 00 brk else lda #hi brk_ret1 ;emulated break pha lda #lo brk_ret1 pha load_flag $ff pha ;set break & unused on stack pha ;actual flags lda #$ff-'B' ldx #$ff-'R' ldy #$ff-'K' plp ;N=1, V=1, Z=1, C=1 jmp irq_trap endif 09f6 : 88 dey ;should not be executed 09f7 : brk_ret1 ;address of break return 09f7 : 08 php ;either SP or Y count will fail, if we do not hit 09f8 : 88 dey 09f9 : 88 dey 09fa : 88 dey 09fb : c917 cmp #($ff-'B')^$aa ;returned registers OK? ;the IRQ vector was never executed if A & X stay unmodified trap_ne 09fd : d0fe > bne * ;failed not equal (non zero) 09ff : e0ae cpx #$ff-'R'+1 trap_ne 0a01 : d0fe > bne * ;failed not equal (non zero) 0a03 : c0ae cpy #$ff-'K'-6 trap_ne 0a05 : d0fe > bne * ;failed not equal (non zero) 0a07 : 68 pla ;returned flags OK (unchanged)? cmp_flag $ff 0a08 : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits trap_ne 0a0a : d0fe > bne * ;failed not equal (non zero) 0a0c : ba tsx ;sp? 0a0d : e0ff cpx #$ff trap_ne 0a0f : d0fe > bne * ;failed not equal (non zero) next_test 0a11 : ad0002 > lda test_case ;previous test 0a14 : c90b > cmp #test_num > trap_ne ;test is out of sequence 0a16 : d0fe > bne * ;failed not equal (non zero) > 000c = >test_num = test_num + 1 0a18 : a90c > lda #test_num ;*** next tests' number 0a1a : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; test set and clear flags CLC CLI CLD CLV SEC SEI SED set_stat $ff > load_flag $ff 0a1d : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0a1f : 48 > pha ;use stack to load status 0a20 : 28 > plp 0a21 : 18 clc tst_stat $ff-carry 0a22 : 08 > php ;save status 0a23 : 68 > pla ;use stack to retrieve status 0a24 : 48 > pha > cmp_flag $ff-carry 0a25 : c9fe > cmp #($ff-carry|fao)&m8 ;expected flags + always on bits > > trap_ne 0a27 : d0fe > bne * ;failed not equal (non zero) > 0a29 : 28 > plp ;restore status 0a2a : 38 sec tst_stat $ff 0a2b : 08 > php ;save status 0a2c : 68 > pla ;use stack to retrieve status 0a2d : 48 > pha > cmp_flag $ff 0a2e : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits > > trap_ne 0a30 : d0fe > bne * ;failed not equal (non zero) > 0a32 : 28 > plp ;restore status if I_flag = 3 0a33 : 58 cli tst_stat $ff-intdis 0a34 : 08 > php ;save status 0a35 : 68 > pla ;use stack to retrieve status 0a36 : 48 > pha > cmp_flag $ff-intdis 0a37 : c9fb > cmp #($ff-intdis|fao)&m8 ;expected flags + always on bits > > trap_ne 0a39 : d0fe > bne * ;failed not equal (non zero) > 0a3b : 28 > plp ;restore status 0a3c : 78 sei tst_stat $ff 0a3d : 08 > php ;save status 0a3e : 68 > pla ;use stack to retrieve status 0a3f : 48 > pha > cmp_flag $ff 0a40 : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits > > trap_ne 0a42 : d0fe > bne * ;failed not equal (non zero) > 0a44 : 28 > plp ;restore status endif 0a45 : d8 cld tst_stat $ff-decmode 0a46 : 08 > php ;save status 0a47 : 68 > pla ;use stack to retrieve status 0a48 : 48 > pha > cmp_flag $ff-decmode 0a49 : c9f7 > cmp #($ff-decmode|fao)&m8 ;expected flags + always on bits > > trap_ne 0a4b : d0fe > bne * ;failed not equal (non zero) > 0a4d : 28 > plp ;restore status 0a4e : f8 sed tst_stat $ff 0a4f : 08 > php ;save status 0a50 : 68 > pla ;use stack to retrieve status 0a51 : 48 > pha > cmp_flag $ff 0a52 : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits > > trap_ne 0a54 : d0fe > bne * ;failed not equal (non zero) > 0a56 : 28 > plp ;restore status 0a57 : b8 clv tst_stat $ff-overfl 0a58 : 08 > php ;save status 0a59 : 68 > pla ;use stack to retrieve status 0a5a : 48 > pha > cmp_flag $ff-overfl 0a5b : c9bf > cmp #($ff-overfl|fao)&m8 ;expected flags + always on bits > > trap_ne 0a5d : d0fe > bne * ;failed not equal (non zero) > 0a5f : 28 > plp ;restore status set_stat 0 > load_flag 0 0a60 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0a62 : 48 > pha ;use stack to load status 0a63 : 28 > plp tst_stat 0 0a64 : 08 > php ;save status 0a65 : 68 > pla ;use stack to retrieve status 0a66 : 48 > pha > cmp_flag 0 0a67 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0a69 : d0fe > bne * ;failed not equal (non zero) > 0a6b : 28 > plp ;restore status 0a6c : 38 sec tst_stat carry 0a6d : 08 > php ;save status 0a6e : 68 > pla ;use stack to retrieve status 0a6f : 48 > pha > cmp_flag carry 0a70 : c931 > cmp #(carry|fao)&m8 ;expected flags + always on bits > > trap_ne 0a72 : d0fe > bne * ;failed not equal (non zero) > 0a74 : 28 > plp ;restore status 0a75 : 18 clc tst_stat 0 0a76 : 08 > php ;save status 0a77 : 68 > pla ;use stack to retrieve status 0a78 : 48 > pha > cmp_flag 0 0a79 : c930 > cmp #(0 |fao)&m8 ;expected flags + always on bits > > trap_ne 0a7b : d0fe > bne * ;failed not equal (non zero) > 0a7d : 28 > plp ;restore status if I_flag = 3 0a7e : 78 sei tst_stat intdis 0a7f : 08 > php ;save status 0a80 : 68 > pla ;use stack to retrieve status 0a81 : 48 > pha > cmp_flag intdis 0a82 : c934 > cmp #(intdis|fao)&m8 ;expected flags + always on bits > > trap_ne 0a84 : d0fe > bne * ;failed not equal (non zero) > 0a86 : 28 > plp ;restore status 0a87 : 58 cli tst_stat 0 0a88 : 08 > php ;save status 0a89 : 68 > pla ;use stack to retrieve status 0a8a : 48 > pha > cmp_flag 0 0a8b : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0a8d : d0fe > bne * ;failed not equal (non zero) > 0a8f : 28 > plp ;restore status endif 0a90 : f8 sed tst_stat decmode 0a91 : 08 > php ;save status 0a92 : 68 > pla ;use stack to retrieve status 0a93 : 48 > pha > cmp_flag decmode 0a94 : c938 > cmp #(decmode|fao)&m8 ;expected flags + always on bits > > trap_ne 0a96 : d0fe > bne * ;failed not equal (non zero) > 0a98 : 28 > plp ;restore status 0a99 : d8 cld tst_stat 0 0a9a : 08 > php ;save status 0a9b : 68 > pla ;use stack to retrieve status 0a9c : 48 > pha > cmp_flag 0 0a9d : c930 > cmp #(0 |fao)&m8 ;expected flags + always on bits > > trap_ne 0a9f : d0fe > bne * ;failed not equal (non zero) > 0aa1 : 28 > plp ;restore status set_stat overfl > load_flag overfl 0aa2 : a940 > lda #overfl ;allow test to change I-flag (no mask) > 0aa4 : 48 > pha ;use stack to load status 0aa5 : 28 > plp tst_stat overfl 0aa6 : 08 > php ;save status 0aa7 : 68 > pla ;use stack to retrieve status 0aa8 : 48 > pha > cmp_flag overfl 0aa9 : c970 > cmp #(overfl|fao)&m8 ;expected flags + always on bits > > trap_ne 0aab : d0fe > bne * ;failed not equal (non zero) > 0aad : 28 > plp ;restore status 0aae : b8 clv tst_stat 0 0aaf : 08 > php ;save status 0ab0 : 68 > pla ;use stack to retrieve status 0ab1 : 48 > pha > cmp_flag 0 0ab2 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0ab4 : d0fe > bne * ;failed not equal (non zero) > 0ab6 : 28 > plp ;restore status next_test 0ab7 : ad0002 > lda test_case ;previous test 0aba : c90c > cmp #test_num > trap_ne ;test is out of sequence 0abc : d0fe > bne * ;failed not equal (non zero) > 000d = >test_num = test_num + 1 0abe : a90d > lda #test_num ;*** next tests' number 0ac0 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; testing index register increment/decrement and transfer ; INX INY DEX DEY TAX TXA TAY TYA 0ac3 : a2fe ldx #$fe set_stat $ff > load_flag $ff 0ac5 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0ac7 : 48 > pha ;use stack to load status 0ac8 : 28 > plp 0ac9 : e8 inx ;ff tst_x $ff,$ff-zero 0aca : 08 > php ;save flags 0acb : e0ff > cpx #$ff ;test result > trap_ne 0acd : d0fe > bne * ;failed not equal (non zero) > 0acf : 68 > pla ;load status 0ad0 : 48 > pha > cmp_flag $ff-zero 0ad1 : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0ad3 : d0fe > bne * ;failed not equal (non zero) > 0ad5 : 28 > plp ;restore status 0ad6 : e8 inx ;00 tst_x 0,$ff-minus 0ad7 : 08 > php ;save flags 0ad8 : e000 > cpx #0 ;test result > trap_ne 0ada : d0fe > bne * ;failed not equal (non zero) > 0adc : 68 > pla ;load status 0add : 48 > pha > cmp_flag $ff-minus 0ade : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0ae0 : d0fe > bne * ;failed not equal (non zero) > 0ae2 : 28 > plp ;restore status 0ae3 : e8 inx ;01 tst_x 1,$ff-minus-zero 0ae4 : 08 > php ;save flags 0ae5 : e001 > cpx #1 ;test result > trap_ne 0ae7 : d0fe > bne * ;failed not equal (non zero) > 0ae9 : 68 > pla ;load status 0aea : 48 > pha > cmp_flag $ff-minus-zero 0aeb : c97d > cmp #($ff-minus-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0aed : d0fe > bne * ;failed not equal (non zero) > 0aef : 28 > plp ;restore status 0af0 : ca dex ;00 tst_x 0,$ff-minus 0af1 : 08 > php ;save flags 0af2 : e000 > cpx #0 ;test result > trap_ne 0af4 : d0fe > bne * ;failed not equal (non zero) > 0af6 : 68 > pla ;load status 0af7 : 48 > pha > cmp_flag $ff-minus 0af8 : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0afa : d0fe > bne * ;failed not equal (non zero) > 0afc : 28 > plp ;restore status 0afd : ca dex ;ff tst_x $ff,$ff-zero 0afe : 08 > php ;save flags 0aff : e0ff > cpx #$ff ;test result > trap_ne 0b01 : d0fe > bne * ;failed not equal (non zero) > 0b03 : 68 > pla ;load status 0b04 : 48 > pha > cmp_flag $ff-zero 0b05 : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0b07 : d0fe > bne * ;failed not equal (non zero) > 0b09 : 28 > plp ;restore status 0b0a : ca dex ;fe set_stat 0 > load_flag 0 0b0b : a900 > lda #0 ;allow test to change I-flag (no mask) > 0b0d : 48 > pha ;use stack to load status 0b0e : 28 > plp 0b0f : e8 inx ;ff tst_x $ff,minus 0b10 : 08 > php ;save flags 0b11 : e0ff > cpx #$ff ;test result > trap_ne 0b13 : d0fe > bne * ;failed not equal (non zero) > 0b15 : 68 > pla ;load status 0b16 : 48 > pha > cmp_flag minus 0b17 : c9b0 > cmp #(minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0b19 : d0fe > bne * ;failed not equal (non zero) > 0b1b : 28 > plp ;restore status 0b1c : e8 inx ;00 tst_x 0,zero 0b1d : 08 > php ;save flags 0b1e : e000 > cpx #0 ;test result > trap_ne 0b20 : d0fe > bne * ;failed not equal (non zero) > 0b22 : 68 > pla ;load status 0b23 : 48 > pha > cmp_flag zero 0b24 : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0b26 : d0fe > bne * ;failed not equal (non zero) > 0b28 : 28 > plp ;restore status 0b29 : e8 inx ;01 tst_x 1,0 0b2a : 08 > php ;save flags 0b2b : e001 > cpx #1 ;test result > trap_ne 0b2d : d0fe > bne * ;failed not equal (non zero) > 0b2f : 68 > pla ;load status 0b30 : 48 > pha > cmp_flag 0 0b31 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0b33 : d0fe > bne * ;failed not equal (non zero) > 0b35 : 28 > plp ;restore status 0b36 : ca dex ;00 tst_x 0,zero 0b37 : 08 > php ;save flags 0b38 : e000 > cpx #0 ;test result > trap_ne 0b3a : d0fe > bne * ;failed not equal (non zero) > 0b3c : 68 > pla ;load status 0b3d : 48 > pha > cmp_flag zero 0b3e : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0b40 : d0fe > bne * ;failed not equal (non zero) > 0b42 : 28 > plp ;restore status 0b43 : ca dex ;ff tst_x $ff,minus 0b44 : 08 > php ;save flags 0b45 : e0ff > cpx #$ff ;test result > trap_ne 0b47 : d0fe > bne * ;failed not equal (non zero) > 0b49 : 68 > pla ;load status 0b4a : 48 > pha > cmp_flag minus 0b4b : c9b0 > cmp #(minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0b4d : d0fe > bne * ;failed not equal (non zero) > 0b4f : 28 > plp ;restore status 0b50 : a0fe ldy #$fe set_stat $ff > load_flag $ff 0b52 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0b54 : 48 > pha ;use stack to load status 0b55 : 28 > plp 0b56 : c8 iny ;ff tst_y $ff,$ff-zero 0b57 : 08 > php ;save flags 0b58 : c0ff > cpy #$ff ;test result > trap_ne 0b5a : d0fe > bne * ;failed not equal (non zero) > 0b5c : 68 > pla ;load status 0b5d : 48 > pha > cmp_flag $ff-zero 0b5e : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0b60 : d0fe > bne * ;failed not equal (non zero) > 0b62 : 28 > plp ;restore status 0b63 : c8 iny ;00 tst_y 0,$ff-minus 0b64 : 08 > php ;save flags 0b65 : c000 > cpy #0 ;test result > trap_ne 0b67 : d0fe > bne * ;failed not equal (non zero) > 0b69 : 68 > pla ;load status 0b6a : 48 > pha > cmp_flag $ff-minus 0b6b : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0b6d : d0fe > bne * ;failed not equal (non zero) > 0b6f : 28 > plp ;restore status 0b70 : c8 iny ;01 tst_y 1,$ff-minus-zero 0b71 : 08 > php ;save flags 0b72 : c001 > cpy #1 ;test result > trap_ne 0b74 : d0fe > bne * ;failed not equal (non zero) > 0b76 : 68 > pla ;load status 0b77 : 48 > pha > cmp_flag $ff-minus-zero 0b78 : c97d > cmp #($ff-minus-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0b7a : d0fe > bne * ;failed not equal (non zero) > 0b7c : 28 > plp ;restore status 0b7d : 88 dey ;00 tst_y 0,$ff-minus 0b7e : 08 > php ;save flags 0b7f : c000 > cpy #0 ;test result > trap_ne 0b81 : d0fe > bne * ;failed not equal (non zero) > 0b83 : 68 > pla ;load status 0b84 : 48 > pha > cmp_flag $ff-minus 0b85 : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0b87 : d0fe > bne * ;failed not equal (non zero) > 0b89 : 28 > plp ;restore status 0b8a : 88 dey ;ff tst_y $ff,$ff-zero 0b8b : 08 > php ;save flags 0b8c : c0ff > cpy #$ff ;test result > trap_ne 0b8e : d0fe > bne * ;failed not equal (non zero) > 0b90 : 68 > pla ;load status 0b91 : 48 > pha > cmp_flag $ff-zero 0b92 : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0b94 : d0fe > bne * ;failed not equal (non zero) > 0b96 : 28 > plp ;restore status 0b97 : 88 dey ;fe set_stat 0 > load_flag 0 0b98 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0b9a : 48 > pha ;use stack to load status 0b9b : 28 > plp 0b9c : c8 iny ;ff tst_y $ff,0+minus 0b9d : 08 > php ;save flags 0b9e : c0ff > cpy #$ff ;test result > trap_ne 0ba0 : d0fe > bne * ;failed not equal (non zero) > 0ba2 : 68 > pla ;load status 0ba3 : 48 > pha > cmp_flag 0+minus 0ba4 : c9b0 > cmp #(0+minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0ba6 : d0fe > bne * ;failed not equal (non zero) > 0ba8 : 28 > plp ;restore status 0ba9 : c8 iny ;00 tst_y 0,zero 0baa : 08 > php ;save flags 0bab : c000 > cpy #0 ;test result > trap_ne 0bad : d0fe > bne * ;failed not equal (non zero) > 0baf : 68 > pla ;load status 0bb0 : 48 > pha > cmp_flag zero 0bb1 : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0bb3 : d0fe > bne * ;failed not equal (non zero) > 0bb5 : 28 > plp ;restore status 0bb6 : c8 iny ;01 tst_y 1,0 0bb7 : 08 > php ;save flags 0bb8 : c001 > cpy #1 ;test result > trap_ne 0bba : d0fe > bne * ;failed not equal (non zero) > 0bbc : 68 > pla ;load status 0bbd : 48 > pha > cmp_flag 0 0bbe : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0bc0 : d0fe > bne * ;failed not equal (non zero) > 0bc2 : 28 > plp ;restore status 0bc3 : 88 dey ;00 tst_y 0,zero 0bc4 : 08 > php ;save flags 0bc5 : c000 > cpy #0 ;test result > trap_ne 0bc7 : d0fe > bne * ;failed not equal (non zero) > 0bc9 : 68 > pla ;load status 0bca : 48 > pha > cmp_flag zero 0bcb : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0bcd : d0fe > bne * ;failed not equal (non zero) > 0bcf : 28 > plp ;restore status 0bd0 : 88 dey ;ff tst_y $ff,minus 0bd1 : 08 > php ;save flags 0bd2 : c0ff > cpy #$ff ;test result > trap_ne 0bd4 : d0fe > bne * ;failed not equal (non zero) > 0bd6 : 68 > pla ;load status 0bd7 : 48 > pha > cmp_flag minus 0bd8 : c9b0 > cmp #(minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0bda : d0fe > bne * ;failed not equal (non zero) > 0bdc : 28 > plp ;restore status 0bdd : a2ff ldx #$ff set_stat $ff > load_flag $ff 0bdf : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0be1 : 48 > pha ;use stack to load status 0be2 : 28 > plp 0be3 : 8a txa tst_a $ff,$ff-zero 0be4 : 08 > php ;save flags 0be5 : c9ff > cmp #$ff ;test result > trap_ne 0be7 : d0fe > bne * ;failed not equal (non zero) > 0be9 : 68 > pla ;load status 0bea : 48 > pha > cmp_flag $ff-zero 0beb : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0bed : d0fe > bne * ;failed not equal (non zero) > 0bef : 28 > plp ;restore status 0bf0 : 08 php 0bf1 : e8 inx ;00 0bf2 : 28 plp 0bf3 : 8a txa tst_a 0,$ff-minus 0bf4 : 08 > php ;save flags 0bf5 : c900 > cmp #0 ;test result > trap_ne 0bf7 : d0fe > bne * ;failed not equal (non zero) > 0bf9 : 68 > pla ;load status 0bfa : 48 > pha > cmp_flag $ff-minus 0bfb : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0bfd : d0fe > bne * ;failed not equal (non zero) > 0bff : 28 > plp ;restore status 0c00 : 08 php 0c01 : e8 inx ;01 0c02 : 28 plp 0c03 : 8a txa tst_a 1,$ff-minus-zero 0c04 : 08 > php ;save flags 0c05 : c901 > cmp #1 ;test result > trap_ne 0c07 : d0fe > bne * ;failed not equal (non zero) > 0c09 : 68 > pla ;load status 0c0a : 48 > pha > cmp_flag $ff-minus-zero 0c0b : c97d > cmp #($ff-minus-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0c0d : d0fe > bne * ;failed not equal (non zero) > 0c0f : 28 > plp ;restore status set_stat 0 > load_flag 0 0c10 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0c12 : 48 > pha ;use stack to load status 0c13 : 28 > plp 0c14 : 8a txa tst_a 1,0 0c15 : 08 > php ;save flags 0c16 : c901 > cmp #1 ;test result > trap_ne 0c18 : d0fe > bne * ;failed not equal (non zero) > 0c1a : 68 > pla ;load status 0c1b : 48 > pha > cmp_flag 0 0c1c : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0c1e : d0fe > bne * ;failed not equal (non zero) > 0c20 : 28 > plp ;restore status 0c21 : 08 php 0c22 : ca dex ;00 0c23 : 28 plp 0c24 : 8a txa tst_a 0,zero 0c25 : 08 > php ;save flags 0c26 : c900 > cmp #0 ;test result > trap_ne 0c28 : d0fe > bne * ;failed not equal (non zero) > 0c2a : 68 > pla ;load status 0c2b : 48 > pha > cmp_flag zero 0c2c : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0c2e : d0fe > bne * ;failed not equal (non zero) > 0c30 : 28 > plp ;restore status 0c31 : 08 php 0c32 : ca dex ;ff 0c33 : 28 plp 0c34 : 8a txa tst_a $ff,minus 0c35 : 08 > php ;save flags 0c36 : c9ff > cmp #$ff ;test result > trap_ne 0c38 : d0fe > bne * ;failed not equal (non zero) > 0c3a : 68 > pla ;load status 0c3b : 48 > pha > cmp_flag minus 0c3c : c9b0 > cmp #(minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0c3e : d0fe > bne * ;failed not equal (non zero) > 0c40 : 28 > plp ;restore status 0c41 : a0ff ldy #$ff set_stat $ff > load_flag $ff 0c43 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0c45 : 48 > pha ;use stack to load status 0c46 : 28 > plp 0c47 : 98 tya tst_a $ff,$ff-zero 0c48 : 08 > php ;save flags 0c49 : c9ff > cmp #$ff ;test result > trap_ne 0c4b : d0fe > bne * ;failed not equal (non zero) > 0c4d : 68 > pla ;load status 0c4e : 48 > pha > cmp_flag $ff-zero 0c4f : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0c51 : d0fe > bne * ;failed not equal (non zero) > 0c53 : 28 > plp ;restore status 0c54 : 08 php 0c55 : c8 iny ;00 0c56 : 28 plp 0c57 : 98 tya tst_a 0,$ff-minus 0c58 : 08 > php ;save flags 0c59 : c900 > cmp #0 ;test result > trap_ne 0c5b : d0fe > bne * ;failed not equal (non zero) > 0c5d : 68 > pla ;load status 0c5e : 48 > pha > cmp_flag $ff-minus 0c5f : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0c61 : d0fe > bne * ;failed not equal (non zero) > 0c63 : 28 > plp ;restore status 0c64 : 08 php 0c65 : c8 iny ;01 0c66 : 28 plp 0c67 : 98 tya tst_a 1,$ff-minus-zero 0c68 : 08 > php ;save flags 0c69 : c901 > cmp #1 ;test result > trap_ne 0c6b : d0fe > bne * ;failed not equal (non zero) > 0c6d : 68 > pla ;load status 0c6e : 48 > pha > cmp_flag $ff-minus-zero 0c6f : c97d > cmp #($ff-minus-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0c71 : d0fe > bne * ;failed not equal (non zero) > 0c73 : 28 > plp ;restore status set_stat 0 > load_flag 0 0c74 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0c76 : 48 > pha ;use stack to load status 0c77 : 28 > plp 0c78 : 98 tya tst_a 1,0 0c79 : 08 > php ;save flags 0c7a : c901 > cmp #1 ;test result > trap_ne 0c7c : d0fe > bne * ;failed not equal (non zero) > 0c7e : 68 > pla ;load status 0c7f : 48 > pha > cmp_flag 0 0c80 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0c82 : d0fe > bne * ;failed not equal (non zero) > 0c84 : 28 > plp ;restore status 0c85 : 08 php 0c86 : 88 dey ;00 0c87 : 28 plp 0c88 : 98 tya tst_a 0,zero 0c89 : 08 > php ;save flags 0c8a : c900 > cmp #0 ;test result > trap_ne 0c8c : d0fe > bne * ;failed not equal (non zero) > 0c8e : 68 > pla ;load status 0c8f : 48 > pha > cmp_flag zero 0c90 : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0c92 : d0fe > bne * ;failed not equal (non zero) > 0c94 : 28 > plp ;restore status 0c95 : 08 php 0c96 : 88 dey ;ff 0c97 : 28 plp 0c98 : 98 tya tst_a $ff,minus 0c99 : 08 > php ;save flags 0c9a : c9ff > cmp #$ff ;test result > trap_ne 0c9c : d0fe > bne * ;failed not equal (non zero) > 0c9e : 68 > pla ;load status 0c9f : 48 > pha > cmp_flag minus 0ca0 : c9b0 > cmp #(minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0ca2 : d0fe > bne * ;failed not equal (non zero) > 0ca4 : 28 > plp ;restore status load_flag $ff 0ca5 : a9ff > lda #$ff ;allow test to change I-flag (no mask) 0ca7 : 48 pha 0ca8 : a2ff ldx #$ff ;ff 0caa : 8a txa 0cab : 28 plp 0cac : a8 tay tst_y $ff,$ff-zero 0cad : 08 > php ;save flags 0cae : c0ff > cpy #$ff ;test result > trap_ne 0cb0 : d0fe > bne * ;failed not equal (non zero) > 0cb2 : 68 > pla ;load status 0cb3 : 48 > pha > cmp_flag $ff-zero 0cb4 : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0cb6 : d0fe > bne * ;failed not equal (non zero) > 0cb8 : 28 > plp ;restore status 0cb9 : 08 php 0cba : e8 inx ;00 0cbb : 8a txa 0cbc : 28 plp 0cbd : a8 tay tst_y 0,$ff-minus 0cbe : 08 > php ;save flags 0cbf : c000 > cpy #0 ;test result > trap_ne 0cc1 : d0fe > bne * ;failed not equal (non zero) > 0cc3 : 68 > pla ;load status 0cc4 : 48 > pha > cmp_flag $ff-minus 0cc5 : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0cc7 : d0fe > bne * ;failed not equal (non zero) > 0cc9 : 28 > plp ;restore status 0cca : 08 php 0ccb : e8 inx ;01 0ccc : 8a txa 0ccd : 28 plp 0cce : a8 tay tst_y 1,$ff-minus-zero 0ccf : 08 > php ;save flags 0cd0 : c001 > cpy #1 ;test result > trap_ne 0cd2 : d0fe > bne * ;failed not equal (non zero) > 0cd4 : 68 > pla ;load status 0cd5 : 48 > pha > cmp_flag $ff-minus-zero 0cd6 : c97d > cmp #($ff-minus-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0cd8 : d0fe > bne * ;failed not equal (non zero) > 0cda : 28 > plp ;restore status load_flag 0 0cdb : a900 > lda #0 ;allow test to change I-flag (no mask) 0cdd : 48 pha 0cde : a900 lda #0 0ce0 : 8a txa 0ce1 : 28 plp 0ce2 : a8 tay tst_y 1,0 0ce3 : 08 > php ;save flags 0ce4 : c001 > cpy #1 ;test result > trap_ne 0ce6 : d0fe > bne * ;failed not equal (non zero) > 0ce8 : 68 > pla ;load status 0ce9 : 48 > pha > cmp_flag 0 0cea : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0cec : d0fe > bne * ;failed not equal (non zero) > 0cee : 28 > plp ;restore status 0cef : 08 php 0cf0 : ca dex ;00 0cf1 : 8a txa 0cf2 : 28 plp 0cf3 : a8 tay tst_y 0,zero 0cf4 : 08 > php ;save flags 0cf5 : c000 > cpy #0 ;test result > trap_ne 0cf7 : d0fe > bne * ;failed not equal (non zero) > 0cf9 : 68 > pla ;load status 0cfa : 48 > pha > cmp_flag zero 0cfb : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0cfd : d0fe > bne * ;failed not equal (non zero) > 0cff : 28 > plp ;restore status 0d00 : 08 php 0d01 : ca dex ;ff 0d02 : 8a txa 0d03 : 28 plp 0d04 : a8 tay tst_y $ff,minus 0d05 : 08 > php ;save flags 0d06 : c0ff > cpy #$ff ;test result > trap_ne 0d08 : d0fe > bne * ;failed not equal (non zero) > 0d0a : 68 > pla ;load status 0d0b : 48 > pha > cmp_flag minus 0d0c : c9b0 > cmp #(minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0d0e : d0fe > bne * ;failed not equal (non zero) > 0d10 : 28 > plp ;restore status load_flag $ff 0d11 : a9ff > lda #$ff ;allow test to change I-flag (no mask) 0d13 : 48 pha 0d14 : a0ff ldy #$ff ;ff 0d16 : 98 tya 0d17 : 28 plp 0d18 : aa tax tst_x $ff,$ff-zero 0d19 : 08 > php ;save flags 0d1a : e0ff > cpx #$ff ;test result > trap_ne 0d1c : d0fe > bne * ;failed not equal (non zero) > 0d1e : 68 > pla ;load status 0d1f : 48 > pha > cmp_flag $ff-zero 0d20 : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0d22 : d0fe > bne * ;failed not equal (non zero) > 0d24 : 28 > plp ;restore status 0d25 : 08 php 0d26 : c8 iny ;00 0d27 : 98 tya 0d28 : 28 plp 0d29 : aa tax tst_x 0,$ff-minus 0d2a : 08 > php ;save flags 0d2b : e000 > cpx #0 ;test result > trap_ne 0d2d : d0fe > bne * ;failed not equal (non zero) > 0d2f : 68 > pla ;load status 0d30 : 48 > pha > cmp_flag $ff-minus 0d31 : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0d33 : d0fe > bne * ;failed not equal (non zero) > 0d35 : 28 > plp ;restore status 0d36 : 08 php 0d37 : c8 iny ;01 0d38 : 98 tya 0d39 : 28 plp 0d3a : aa tax tst_x 1,$ff-minus-zero 0d3b : 08 > php ;save flags 0d3c : e001 > cpx #1 ;test result > trap_ne 0d3e : d0fe > bne * ;failed not equal (non zero) > 0d40 : 68 > pla ;load status 0d41 : 48 > pha > cmp_flag $ff-minus-zero 0d42 : c97d > cmp #($ff-minus-zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0d44 : d0fe > bne * ;failed not equal (non zero) > 0d46 : 28 > plp ;restore status load_flag 0 0d47 : a900 > lda #0 ;allow test to change I-flag (no mask) 0d49 : 48 pha 0d4a : a900 lda #0 ;preset status 0d4c : 98 tya 0d4d : 28 plp 0d4e : aa tax tst_x 1,0 0d4f : 08 > php ;save flags 0d50 : e001 > cpx #1 ;test result > trap_ne 0d52 : d0fe > bne * ;failed not equal (non zero) > 0d54 : 68 > pla ;load status 0d55 : 48 > pha > cmp_flag 0 0d56 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits > > trap_ne 0d58 : d0fe > bne * ;failed not equal (non zero) > 0d5a : 28 > plp ;restore status 0d5b : 08 php 0d5c : 88 dey ;00 0d5d : 98 tya 0d5e : 28 plp 0d5f : aa tax tst_x 0,zero 0d60 : 08 > php ;save flags 0d61 : e000 > cpx #0 ;test result > trap_ne 0d63 : d0fe > bne * ;failed not equal (non zero) > 0d65 : 68 > pla ;load status 0d66 : 48 > pha > cmp_flag zero 0d67 : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits > > trap_ne 0d69 : d0fe > bne * ;failed not equal (non zero) > 0d6b : 28 > plp ;restore status 0d6c : 08 php 0d6d : 88 dey ;ff 0d6e : 98 tya 0d6f : 28 plp 0d70 : aa tax tst_x $ff,minus 0d71 : 08 > php ;save flags 0d72 : e0ff > cpx #$ff ;test result > trap_ne 0d74 : d0fe > bne * ;failed not equal (non zero) > 0d76 : 68 > pla ;load status 0d77 : 48 > pha > cmp_flag minus 0d78 : c9b0 > cmp #(minus|fao)&m8 ;expected flags + always on bits > > trap_ne 0d7a : d0fe > bne * ;failed not equal (non zero) > 0d7c : 28 > plp ;restore status next_test 0d7d : ad0002 > lda test_case ;previous test 0d80 : c90d > cmp #test_num > trap_ne ;test is out of sequence 0d82 : d0fe > bne * ;failed not equal (non zero) > 000e = >test_num = test_num + 1 0d84 : a90e > lda #test_num ;*** next tests' number 0d86 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ;TSX sets NZ - TXS does not ; This section also tests for proper stack wrap around. 0d89 : a201 ldx #1 ;01 set_stat $ff > load_flag $ff 0d8b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0d8d : 48 > pha ;use stack to load status 0d8e : 28 > plp 0d8f : 9a txs 0d90 : 08 php 0d91 : ad0101 lda $101 cmp_flag $ff 0d94 : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits trap_ne 0d96 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 0d98 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0d9a : 48 > pha ;use stack to load status 0d9b : 28 > plp 0d9c : 9a txs 0d9d : 08 php 0d9e : ad0101 lda $101 cmp_flag 0 0da1 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits trap_ne 0da3 : d0fe > bne * ;failed not equal (non zero) 0da5 : ca dex ;00 set_stat $ff > load_flag $ff 0da6 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0da8 : 48 > pha ;use stack to load status 0da9 : 28 > plp 0daa : 9a txs 0dab : 08 php 0dac : ad0001 lda $100 cmp_flag $ff 0daf : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits trap_ne 0db1 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 0db3 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0db5 : 48 > pha ;use stack to load status 0db6 : 28 > plp 0db7 : 9a txs 0db8 : 08 php 0db9 : ad0001 lda $100 cmp_flag 0 0dbc : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits trap_ne 0dbe : d0fe > bne * ;failed not equal (non zero) 0dc0 : ca dex ;ff set_stat $ff > load_flag $ff 0dc1 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0dc3 : 48 > pha ;use stack to load status 0dc4 : 28 > plp 0dc5 : 9a txs 0dc6 : 08 php 0dc7 : adff01 lda $1ff cmp_flag $ff 0dca : c9ff > cmp #($ff|fao)&m8 ;expected flags + always on bits trap_ne 0dcc : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 0dce : a900 > lda #0 ;allow test to change I-flag (no mask) > 0dd0 : 48 > pha ;use stack to load status 0dd1 : 28 > plp 0dd2 : 9a txs 0dd3 : 08 php 0dd4 : adff01 lda $1ff cmp_flag 0 0dd7 : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits 0dd9 : a201 ldx #1 0ddb : 9a txs ;sp=01 set_stat $ff > load_flag $ff 0ddc : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0dde : 48 > pha ;use stack to load status 0ddf : 28 > plp 0de0 : ba tsx ;clears Z, N 0de1 : 08 php ;sp=00 0de2 : e001 cpx #1 trap_ne 0de4 : d0fe > bne * ;failed not equal (non zero) 0de6 : ad0101 lda $101 cmp_flag $ff-minus-zero 0de9 : c97d > cmp #($ff-minus-zero|fao)&m8 ;expected flags + always on bits trap_ne 0deb : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 0ded : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0def : 48 > pha ;use stack to load status 0df0 : 28 > plp 0df1 : ba tsx ;clears N, sets Z 0df2 : 08 php ;sp=ff 0df3 : e000 cpx #0 trap_ne 0df5 : d0fe > bne * ;failed not equal (non zero) 0df7 : ad0001 lda $100 cmp_flag $ff-minus 0dfa : c97f > cmp #($ff-minus|fao)&m8 ;expected flags + always on bits trap_ne 0dfc : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 0dfe : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0e00 : 48 > pha ;use stack to load status 0e01 : 28 > plp 0e02 : ba tsx ;clears N, sets Z 0e03 : 08 php ;sp=fe 0e04 : e0ff cpx #$ff trap_ne 0e06 : d0fe > bne * ;failed not equal (non zero) 0e08 : adff01 lda $1ff cmp_flag $ff-zero 0e0b : c9fd > cmp #($ff-zero|fao)&m8 ;expected flags + always on bits trap_ne 0e0d : d0fe > bne * ;failed not equal (non zero) 0e0f : a201 ldx #1 0e11 : 9a txs ;sp=01 set_stat 0 > load_flag 0 0e12 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0e14 : 48 > pha ;use stack to load status 0e15 : 28 > plp 0e16 : ba tsx ;clears Z, N 0e17 : 08 php ;sp=00 0e18 : e001 cpx #1 trap_ne 0e1a : d0fe > bne * ;failed not equal (non zero) 0e1c : ad0101 lda $101 cmp_flag 0 0e1f : c930 > cmp #(0|fao)&m8 ;expected flags + always on bits trap_ne 0e21 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 0e23 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0e25 : 48 > pha ;use stack to load status 0e26 : 28 > plp 0e27 : ba tsx ;clears N, sets Z 0e28 : 08 php ;sp=ff 0e29 : e000 cpx #0 trap_ne 0e2b : d0fe > bne * ;failed not equal (non zero) 0e2d : ad0001 lda $100 cmp_flag zero 0e30 : c932 > cmp #(zero|fao)&m8 ;expected flags + always on bits trap_ne 0e32 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 0e34 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0e36 : 48 > pha ;use stack to load status 0e37 : 28 > plp 0e38 : ba tsx ;clears N, sets Z 0e39 : 08 php ;sp=fe 0e3a : e0ff cpx #$ff trap_ne 0e3c : d0fe > bne * ;failed not equal (non zero) 0e3e : adff01 lda $1ff cmp_flag minus 0e41 : c9b0 > cmp #(minus|fao)&m8 ;expected flags + always on bits trap_ne 0e43 : d0fe > bne * ;failed not equal (non zero) 0e45 : 68 pla ;sp=ff next_test 0e46 : ad0002 > lda test_case ;previous test 0e49 : c90e > cmp #test_num > trap_ne ;test is out of sequence 0e4b : d0fe > bne * ;failed not equal (non zero) > 000f = >test_num = test_num + 1 0e4d : a90f > lda #test_num ;*** next tests' number 0e4f : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; testing index register load & store LDY LDX STY STX all addressing modes ; LDX / STX - zp,y / abs,y 0e52 : a003 ldy #3 0e54 : tldx set_stat 0 > load_flag 0 0e54 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0e56 : 48 > pha ;use stack to load status 0e57 : 28 > plp 0e58 : b613 ldx zp1,y 0e5a : 08 php ;test stores do not alter flags 0e5b : 8a txa 0e5c : 49c3 eor #$c3 0e5e : 28 plp 0e5f : 990302 sta abst,y 0e62 : 08 php ;flags after load/store sequence 0e63 : 49c3 eor #$c3 0e65 : d91702 cmp abs1,y ;test result trap_ne 0e68 : d0fe > bne * ;failed not equal (non zero) 0e6a : 68 pla ;load status eor_flag 0 0e6b : 4930 > eor #0|fao ;invert expected flags + always on bits 0e6d : d91c02 cmp fLDx,y ;test flags trap_ne 0e70 : d0fe > bne * ;failed not equal (non zero) 0e72 : 88 dey 0e73 : 10df bpl tldx 0e75 : a003 ldy #3 0e77 : tldx1 set_stat $ff > load_flag $ff 0e77 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0e79 : 48 > pha ;use stack to load status 0e7a : 28 > plp 0e7b : b613 ldx zp1,y 0e7d : 08 php ;test stores do not alter flags 0e7e : 8a txa 0e7f : 49c3 eor #$c3 0e81 : 28 plp 0e82 : 990302 sta abst,y 0e85 : 08 php ;flags after load/store sequence 0e86 : 49c3 eor #$c3 0e88 : d91702 cmp abs1,y ;test result trap_ne 0e8b : d0fe > bne * ;failed not equal (non zero) 0e8d : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 0e8e : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 0e90 : d91c02 cmp fLDx,y ;test flags trap_ne 0e93 : d0fe > bne * ;failed not equal (non zero) 0e95 : 88 dey 0e96 : 10df bpl tldx1 0e98 : a003 ldy #3 0e9a : tldx2 set_stat 0 > load_flag 0 0e9a : a900 > lda #0 ;allow test to change I-flag (no mask) > 0e9c : 48 > pha ;use stack to load status 0e9d : 28 > plp 0e9e : be1702 ldx abs1,y 0ea1 : 08 php ;test stores do not alter flags 0ea2 : 8a txa 0ea3 : 49c3 eor #$c3 0ea5 : aa tax 0ea6 : 28 plp 0ea7 : 960c stx zpt,y 0ea9 : 08 php ;flags after load/store sequence 0eaa : 49c3 eor #$c3 0eac : d91300 cmp zp1,y ;test result trap_ne 0eaf : d0fe > bne * ;failed not equal (non zero) 0eb1 : 68 pla ;load status eor_flag 0 0eb2 : 4930 > eor #0|fao ;invert expected flags + always on bits 0eb4 : d91c02 cmp fLDx,y ;test flags trap_ne 0eb7 : d0fe > bne * ;failed not equal (non zero) 0eb9 : 88 dey 0eba : 10de bpl tldx2 0ebc : a003 ldy #3 0ebe : tldx3 set_stat $ff > load_flag $ff 0ebe : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0ec0 : 48 > pha ;use stack to load status 0ec1 : 28 > plp 0ec2 : be1702 ldx abs1,y 0ec5 : 08 php ;test stores do not alter flags 0ec6 : 8a txa 0ec7 : 49c3 eor #$c3 0ec9 : aa tax 0eca : 28 plp 0ecb : 960c stx zpt,y 0ecd : 08 php ;flags after load/store sequence 0ece : 49c3 eor #$c3 0ed0 : d91300 cmp zp1,y ;test result trap_ne 0ed3 : d0fe > bne * ;failed not equal (non zero) 0ed5 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 0ed6 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 0ed8 : d91c02 cmp fLDx,y ;test flags trap_ne 0edb : d0fe > bne * ;failed not equal (non zero) 0edd : 88 dey 0ede : 10de bpl tldx3 0ee0 : a003 ldy #3 ;testing store result 0ee2 : a200 ldx #0 0ee4 : b90c00 tstx lda zpt,y 0ee7 : 49c3 eor #$c3 0ee9 : d91300 cmp zp1,y trap_ne ;store to zp data 0eec : d0fe > bne * ;failed not equal (non zero) 0eee : 960c stx zpt,y ;clear 0ef0 : b90302 lda abst,y 0ef3 : 49c3 eor #$c3 0ef5 : d91702 cmp abs1,y trap_ne ;store to abs data 0ef8 : d0fe > bne * ;failed not equal (non zero) 0efa : 8a txa 0efb : 990302 sta abst,y ;clear 0efe : 88 dey 0eff : 10e3 bpl tstx next_test 0f01 : ad0002 > lda test_case ;previous test 0f04 : c90f > cmp #test_num > trap_ne ;test is out of sequence 0f06 : d0fe > bne * ;failed not equal (non zero) > 0010 = >test_num = test_num + 1 0f08 : a910 > lda #test_num ;*** next tests' number 0f0a : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; indexed wraparound test (only zp should wrap) 0f0d : a0fd ldy #3+$fa 0f0f : b619 tldx4 ldx zp1-$fa&$ff,y ;wrap on indexed zp 0f11 : 8a txa 0f12 : 990901 sta abst-$fa,y ;no STX abs,y! 0f15 : 88 dey 0f16 : c0fa cpy #$fa 0f18 : b0f5 bcs tldx4 0f1a : a0fd ldy #3+$fa 0f1c : be1d01 tldx5 ldx abs1-$fa,y ;no wrap on indexed abs 0f1f : 9612 stx zpt-$fa&$ff,y 0f21 : 88 dey 0f22 : c0fa cpy #$fa 0f24 : b0f6 bcs tldx5 0f26 : a003 ldy #3 ;testing wraparound result 0f28 : a200 ldx #0 0f2a : b90c00 tstx1 lda zpt,y 0f2d : d91300 cmp zp1,y trap_ne ;store to zp data 0f30 : d0fe > bne * ;failed not equal (non zero) 0f32 : 960c stx zpt,y ;clear 0f34 : b90302 lda abst,y 0f37 : d91702 cmp abs1,y trap_ne ;store to abs data 0f3a : d0fe > bne * ;failed not equal (non zero) 0f3c : 8a txa 0f3d : 990302 sta abst,y ;clear 0f40 : 88 dey 0f41 : 10e7 bpl tstx1 next_test 0f43 : ad0002 > lda test_case ;previous test 0f46 : c910 > cmp #test_num > trap_ne ;test is out of sequence 0f48 : d0fe > bne * ;failed not equal (non zero) > 0011 = >test_num = test_num + 1 0f4a : a911 > lda #test_num ;*** next tests' number 0f4c : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; LDY / STY - zp,x / abs,x 0f4f : a203 ldx #3 0f51 : tldy set_stat 0 > load_flag 0 0f51 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0f53 : 48 > pha ;use stack to load status 0f54 : 28 > plp 0f55 : b413 ldy zp1,x 0f57 : 08 php ;test stores do not alter flags 0f58 : 98 tya 0f59 : 49c3 eor #$c3 0f5b : 28 plp 0f5c : 9d0302 sta abst,x 0f5f : 08 php ;flags after load/store sequence 0f60 : 49c3 eor #$c3 0f62 : dd1702 cmp abs1,x ;test result trap_ne 0f65 : d0fe > bne * ;failed not equal (non zero) 0f67 : 68 pla ;load status eor_flag 0 0f68 : 4930 > eor #0|fao ;invert expected flags + always on bits 0f6a : dd1c02 cmp fLDx,x ;test flags trap_ne 0f6d : d0fe > bne * ;failed not equal (non zero) 0f6f : ca dex 0f70 : 10df bpl tldy 0f72 : a203 ldx #3 0f74 : tldy1 set_stat $ff > load_flag $ff 0f74 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0f76 : 48 > pha ;use stack to load status 0f77 : 28 > plp 0f78 : b413 ldy zp1,x 0f7a : 08 php ;test stores do not alter flags 0f7b : 98 tya 0f7c : 49c3 eor #$c3 0f7e : 28 plp 0f7f : 9d0302 sta abst,x 0f82 : 08 php ;flags after load/store sequence 0f83 : 49c3 eor #$c3 0f85 : dd1702 cmp abs1,x ;test result trap_ne 0f88 : d0fe > bne * ;failed not equal (non zero) 0f8a : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 0f8b : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 0f8d : dd1c02 cmp fLDx,x ;test flags trap_ne 0f90 : d0fe > bne * ;failed not equal (non zero) 0f92 : ca dex 0f93 : 10df bpl tldy1 0f95 : a203 ldx #3 0f97 : tldy2 set_stat 0 > load_flag 0 0f97 : a900 > lda #0 ;allow test to change I-flag (no mask) > 0f99 : 48 > pha ;use stack to load status 0f9a : 28 > plp 0f9b : bc1702 ldy abs1,x 0f9e : 08 php ;test stores do not alter flags 0f9f : 98 tya 0fa0 : 49c3 eor #$c3 0fa2 : a8 tay 0fa3 : 28 plp 0fa4 : 940c sty zpt,x 0fa6 : 08 php ;flags after load/store sequence 0fa7 : 49c3 eor #$c3 0fa9 : d513 cmp zp1,x ;test result trap_ne 0fab : d0fe > bne * ;failed not equal (non zero) 0fad : 68 pla ;load status eor_flag 0 0fae : 4930 > eor #0|fao ;invert expected flags + always on bits 0fb0 : dd1c02 cmp fLDx,x ;test flags trap_ne 0fb3 : d0fe > bne * ;failed not equal (non zero) 0fb5 : ca dex 0fb6 : 10df bpl tldy2 0fb8 : a203 ldx #3 0fba : tldy3 set_stat $ff > load_flag $ff 0fba : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 0fbc : 48 > pha ;use stack to load status 0fbd : 28 > plp 0fbe : bc1702 ldy abs1,x 0fc1 : 08 php ;test stores do not alter flags 0fc2 : 98 tya 0fc3 : 49c3 eor #$c3 0fc5 : a8 tay 0fc6 : 28 plp 0fc7 : 940c sty zpt,x 0fc9 : 08 php ;flags after load/store sequence 0fca : 49c3 eor #$c3 0fcc : d513 cmp zp1,x ;test result trap_ne 0fce : d0fe > bne * ;failed not equal (non zero) 0fd0 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 0fd1 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 0fd3 : dd1c02 cmp fLDx,x ;test flags trap_ne 0fd6 : d0fe > bne * ;failed not equal (non zero) 0fd8 : ca dex 0fd9 : 10df bpl tldy3 0fdb : a203 ldx #3 ;testing store result 0fdd : a000 ldy #0 0fdf : b50c tsty lda zpt,x 0fe1 : 49c3 eor #$c3 0fe3 : d513 cmp zp1,x trap_ne ;store to zp,x data 0fe5 : d0fe > bne * ;failed not equal (non zero) 0fe7 : 940c sty zpt,x ;clear 0fe9 : bd0302 lda abst,x 0fec : 49c3 eor #$c3 0fee : dd1702 cmp abs1,x trap_ne ;store to abs,x data 0ff1 : d0fe > bne * ;failed not equal (non zero) 0ff3 : 8a txa 0ff4 : 9d0302 sta abst,x ;clear 0ff7 : ca dex 0ff8 : 10e5 bpl tsty next_test 0ffa : ad0002 > lda test_case ;previous test 0ffd : c911 > cmp #test_num > trap_ne ;test is out of sequence 0fff : d0fe > bne * ;failed not equal (non zero) > 0012 = >test_num = test_num + 1 1001 : a912 > lda #test_num ;*** next tests' number 1003 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; indexed wraparound test (only zp should wrap) 1006 : a2fd ldx #3+$fa 1008 : b419 tldy4 ldy zp1-$fa&$ff,x ;wrap on indexed zp 100a : 98 tya 100b : 9d0901 sta abst-$fa,x ;no STX abs,x! 100e : ca dex 100f : e0fa cpx #$fa 1011 : b0f5 bcs tldy4 1013 : a2fd ldx #3+$fa 1015 : bc1d01 tldy5 ldy abs1-$fa,x ;no wrap on indexed abs 1018 : 9412 sty zpt-$fa&$ff,x 101a : ca dex 101b : e0fa cpx #$fa 101d : b0f6 bcs tldy5 101f : a203 ldx #3 ;testing wraparound result 1021 : a000 ldy #0 1023 : b50c tsty1 lda zpt,x 1025 : d513 cmp zp1,x trap_ne ;store to zp,x data 1027 : d0fe > bne * ;failed not equal (non zero) 1029 : 940c sty zpt,x ;clear 102b : bd0302 lda abst,x 102e : dd1702 cmp abs1,x trap_ne ;store to abs,x data 1031 : d0fe > bne * ;failed not equal (non zero) 1033 : 8a txa 1034 : 9d0302 sta abst,x ;clear 1037 : ca dex 1038 : 10e9 bpl tsty1 next_test 103a : ad0002 > lda test_case ;previous test 103d : c912 > cmp #test_num > trap_ne ;test is out of sequence 103f : d0fe > bne * ;failed not equal (non zero) > 0013 = >test_num = test_num + 1 1041 : a913 > lda #test_num ;*** next tests' number 1043 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; LDX / STX - zp / abs / # set_stat 0 > load_flag 0 1046 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1048 : 48 > pha ;use stack to load status 1049 : 28 > plp 104a : a613 ldx zp1 104c : 08 php ;test stores do not alter flags 104d : 8a txa 104e : 49c3 eor #$c3 1050 : aa tax 1051 : 28 plp 1052 : 8e0302 stx abst 1055 : 08 php ;flags after load/store sequence 1056 : 49c3 eor #$c3 1058 : aa tax 1059 : e0c3 cpx #$c3 ;test result trap_ne 105b : d0fe > bne * ;failed not equal (non zero) 105d : 68 pla ;load status eor_flag 0 105e : 4930 > eor #0|fao ;invert expected flags + always on bits 1060 : cd1c02 cmp fLDx ;test flags trap_ne 1063 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1065 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1067 : 48 > pha ;use stack to load status 1068 : 28 > plp 1069 : a614 ldx zp1+1 106b : 08 php ;test stores do not alter flags 106c : 8a txa 106d : 49c3 eor #$c3 106f : aa tax 1070 : 28 plp 1071 : 8e0402 stx abst+1 1074 : 08 php ;flags after load/store sequence 1075 : 49c3 eor #$c3 1077 : aa tax 1078 : e082 cpx #$82 ;test result trap_ne 107a : d0fe > bne * ;failed not equal (non zero) 107c : 68 pla ;load status eor_flag 0 107d : 4930 > eor #0|fao ;invert expected flags + always on bits 107f : cd1d02 cmp fLDx+1 ;test flags trap_ne 1082 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1084 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1086 : 48 > pha ;use stack to load status 1087 : 28 > plp 1088 : a615 ldx zp1+2 108a : 08 php ;test stores do not alter flags 108b : 8a txa 108c : 49c3 eor #$c3 108e : aa tax 108f : 28 plp 1090 : 8e0502 stx abst+2 1093 : 08 php ;flags after load/store sequence 1094 : 49c3 eor #$c3 1096 : aa tax 1097 : e041 cpx #$41 ;test result trap_ne 1099 : d0fe > bne * ;failed not equal (non zero) 109b : 68 pla ;load status eor_flag 0 109c : 4930 > eor #0|fao ;invert expected flags + always on bits 109e : cd1e02 cmp fLDx+2 ;test flags trap_ne 10a1 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 10a3 : a900 > lda #0 ;allow test to change I-flag (no mask) > 10a5 : 48 > pha ;use stack to load status 10a6 : 28 > plp 10a7 : a616 ldx zp1+3 10a9 : 08 php ;test stores do not alter flags 10aa : 8a txa 10ab : 49c3 eor #$c3 10ad : aa tax 10ae : 28 plp 10af : 8e0602 stx abst+3 10b2 : 08 php ;flags after load/store sequence 10b3 : 49c3 eor #$c3 10b5 : aa tax 10b6 : e000 cpx #0 ;test result trap_ne 10b8 : d0fe > bne * ;failed not equal (non zero) 10ba : 68 pla ;load status eor_flag 0 10bb : 4930 > eor #0|fao ;invert expected flags + always on bits 10bd : cd1f02 cmp fLDx+3 ;test flags trap_ne 10c0 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 10c2 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 10c4 : 48 > pha ;use stack to load status 10c5 : 28 > plp 10c6 : a613 ldx zp1 10c8 : 08 php ;test stores do not alter flags 10c9 : 8a txa 10ca : 49c3 eor #$c3 10cc : aa tax 10cd : 28 plp 10ce : 8e0302 stx abst 10d1 : 08 php ;flags after load/store sequence 10d2 : 49c3 eor #$c3 10d4 : aa tax 10d5 : e0c3 cpx #$c3 ;test result trap_ne ; 10d7 : d0fe > bne * ;failed not equal (non zero) 10d9 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 10da : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 10dc : cd1c02 cmp fLDx ;test flags trap_ne 10df : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 10e1 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 10e3 : 48 > pha ;use stack to load status 10e4 : 28 > plp 10e5 : a614 ldx zp1+1 10e7 : 08 php ;test stores do not alter flags 10e8 : 8a txa 10e9 : 49c3 eor #$c3 10eb : aa tax 10ec : 28 plp 10ed : 8e0402 stx abst+1 10f0 : 08 php ;flags after load/store sequence 10f1 : 49c3 eor #$c3 10f3 : aa tax 10f4 : e082 cpx #$82 ;test result trap_ne 10f6 : d0fe > bne * ;failed not equal (non zero) 10f8 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 10f9 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 10fb : cd1d02 cmp fLDx+1 ;test flags trap_ne 10fe : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1100 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1102 : 48 > pha ;use stack to load status 1103 : 28 > plp 1104 : a615 ldx zp1+2 1106 : 08 php ;test stores do not alter flags 1107 : 8a txa 1108 : 49c3 eor #$c3 110a : aa tax 110b : 28 plp 110c : 8e0502 stx abst+2 110f : 08 php ;flags after load/store sequence 1110 : 49c3 eor #$c3 1112 : aa tax 1113 : e041 cpx #$41 ;test result trap_ne ; 1115 : d0fe > bne * ;failed not equal (non zero) 1117 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1118 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 111a : cd1e02 cmp fLDx+2 ;test flags trap_ne 111d : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 111f : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1121 : 48 > pha ;use stack to load status 1122 : 28 > plp 1123 : a616 ldx zp1+3 1125 : 08 php ;test stores do not alter flags 1126 : 8a txa 1127 : 49c3 eor #$c3 1129 : aa tax 112a : 28 plp 112b : 8e0602 stx abst+3 112e : 08 php ;flags after load/store sequence 112f : 49c3 eor #$c3 1131 : aa tax 1132 : e000 cpx #0 ;test result trap_ne 1134 : d0fe > bne * ;failed not equal (non zero) 1136 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1137 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1139 : cd1f02 cmp fLDx+3 ;test flags trap_ne 113c : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 113e : a900 > lda #0 ;allow test to change I-flag (no mask) > 1140 : 48 > pha ;use stack to load status 1141 : 28 > plp 1142 : ae1702 ldx abs1 1145 : 08 php ;test stores do not alter flags 1146 : 8a txa 1147 : 49c3 eor #$c3 1149 : aa tax 114a : 28 plp 114b : 860c stx zpt 114d : 08 php ;flags after load/store sequence 114e : 49c3 eor #$c3 1150 : c513 cmp zp1 ;test result trap_ne 1152 : d0fe > bne * ;failed not equal (non zero) 1154 : 68 pla ;load status eor_flag 0 1155 : 4930 > eor #0|fao ;invert expected flags + always on bits 1157 : cd1c02 cmp fLDx ;test flags trap_ne 115a : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 115c : a900 > lda #0 ;allow test to change I-flag (no mask) > 115e : 48 > pha ;use stack to load status 115f : 28 > plp 1160 : ae1802 ldx abs1+1 1163 : 08 php ;test stores do not alter flags 1164 : 8a txa 1165 : 49c3 eor #$c3 1167 : aa tax 1168 : 28 plp 1169 : 860d stx zpt+1 116b : 08 php ;flags after load/store sequence 116c : 49c3 eor #$c3 116e : c514 cmp zp1+1 ;test result trap_ne 1170 : d0fe > bne * ;failed not equal (non zero) 1172 : 68 pla ;load status eor_flag 0 1173 : 4930 > eor #0|fao ;invert expected flags + always on bits 1175 : cd1d02 cmp fLDx+1 ;test flags trap_ne 1178 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 117a : a900 > lda #0 ;allow test to change I-flag (no mask) > 117c : 48 > pha ;use stack to load status 117d : 28 > plp 117e : ae1902 ldx abs1+2 1181 : 08 php ;test stores do not alter flags 1182 : 8a txa 1183 : 49c3 eor #$c3 1185 : aa tax 1186 : 28 plp 1187 : 860e stx zpt+2 1189 : 08 php ;flags after load/store sequence 118a : 49c3 eor #$c3 118c : c515 cmp zp1+2 ;test result trap_ne 118e : d0fe > bne * ;failed not equal (non zero) 1190 : 68 pla ;load status eor_flag 0 1191 : 4930 > eor #0|fao ;invert expected flags + always on bits 1193 : cd1e02 cmp fLDx+2 ;test flags trap_ne 1196 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1198 : a900 > lda #0 ;allow test to change I-flag (no mask) > 119a : 48 > pha ;use stack to load status 119b : 28 > plp 119c : ae1a02 ldx abs1+3 119f : 08 php ;test stores do not alter flags 11a0 : 8a txa 11a1 : 49c3 eor #$c3 11a3 : aa tax 11a4 : 28 plp 11a5 : 860f stx zpt+3 11a7 : 08 php ;flags after load/store sequence 11a8 : 49c3 eor #$c3 11aa : c516 cmp zp1+3 ;test result trap_ne 11ac : d0fe > bne * ;failed not equal (non zero) 11ae : 68 pla ;load status eor_flag 0 11af : 4930 > eor #0|fao ;invert expected flags + always on bits 11b1 : cd1f02 cmp fLDx+3 ;test flags trap_ne 11b4 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 11b6 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 11b8 : 48 > pha ;use stack to load status 11b9 : 28 > plp 11ba : ae1702 ldx abs1 11bd : 08 php ;test stores do not alter flags 11be : 8a txa 11bf : 49c3 eor #$c3 11c1 : aa tax 11c2 : 28 plp 11c3 : 860c stx zpt 11c5 : 08 php ;flags after load/store sequence 11c6 : 49c3 eor #$c3 11c8 : aa tax 11c9 : e413 cpx zp1 ;test result trap_ne 11cb : d0fe > bne * ;failed not equal (non zero) 11cd : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 11ce : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 11d0 : cd1c02 cmp fLDx ;test flags trap_ne 11d3 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 11d5 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 11d7 : 48 > pha ;use stack to load status 11d8 : 28 > plp 11d9 : ae1802 ldx abs1+1 11dc : 08 php ;test stores do not alter flags 11dd : 8a txa 11de : 49c3 eor #$c3 11e0 : aa tax 11e1 : 28 plp 11e2 : 860d stx zpt+1 11e4 : 08 php ;flags after load/store sequence 11e5 : 49c3 eor #$c3 11e7 : aa tax 11e8 : e414 cpx zp1+1 ;test result trap_ne 11ea : d0fe > bne * ;failed not equal (non zero) 11ec : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 11ed : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 11ef : cd1d02 cmp fLDx+1 ;test flags trap_ne 11f2 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 11f4 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 11f6 : 48 > pha ;use stack to load status 11f7 : 28 > plp 11f8 : ae1902 ldx abs1+2 11fb : 08 php ;test stores do not alter flags 11fc : 8a txa 11fd : 49c3 eor #$c3 11ff : aa tax 1200 : 28 plp 1201 : 860e stx zpt+2 1203 : 08 php ;flags after load/store sequence 1204 : 49c3 eor #$c3 1206 : aa tax 1207 : e415 cpx zp1+2 ;test result trap_ne 1209 : d0fe > bne * ;failed not equal (non zero) 120b : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 120c : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 120e : cd1e02 cmp fLDx+2 ;test flags trap_ne 1211 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1213 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1215 : 48 > pha ;use stack to load status 1216 : 28 > plp 1217 : ae1a02 ldx abs1+3 121a : 08 php ;test stores do not alter flags 121b : 8a txa 121c : 49c3 eor #$c3 121e : aa tax 121f : 28 plp 1220 : 860f stx zpt+3 1222 : 08 php ;flags after load/store sequence 1223 : 49c3 eor #$c3 1225 : aa tax 1226 : e416 cpx zp1+3 ;test result trap_ne 1228 : d0fe > bne * ;failed not equal (non zero) 122a : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 122b : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 122d : cd1f02 cmp fLDx+3 ;test flags trap_ne 1230 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1232 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1234 : 48 > pha ;use stack to load status 1235 : 28 > plp 1236 : a2c3 ldx #$c3 1238 : 08 php 1239 : ec1702 cpx abs1 ;test result trap_ne 123c : d0fe > bne * ;failed not equal (non zero) 123e : 68 pla ;load status eor_flag 0 123f : 4930 > eor #0|fao ;invert expected flags + always on bits 1241 : cd1c02 cmp fLDx ;test flags trap_ne 1244 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1246 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1248 : 48 > pha ;use stack to load status 1249 : 28 > plp 124a : a282 ldx #$82 124c : 08 php 124d : ec1802 cpx abs1+1 ;test result trap_ne 1250 : d0fe > bne * ;failed not equal (non zero) 1252 : 68 pla ;load status eor_flag 0 1253 : 4930 > eor #0|fao ;invert expected flags + always on bits 1255 : cd1d02 cmp fLDx+1 ;test flags trap_ne 1258 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 125a : a900 > lda #0 ;allow test to change I-flag (no mask) > 125c : 48 > pha ;use stack to load status 125d : 28 > plp 125e : a241 ldx #$41 1260 : 08 php 1261 : ec1902 cpx abs1+2 ;test result trap_ne 1264 : d0fe > bne * ;failed not equal (non zero) 1266 : 68 pla ;load status eor_flag 0 1267 : 4930 > eor #0|fao ;invert expected flags + always on bits 1269 : cd1e02 cmp fLDx+2 ;test flags trap_ne 126c : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 126e : a900 > lda #0 ;allow test to change I-flag (no mask) > 1270 : 48 > pha ;use stack to load status 1271 : 28 > plp 1272 : a200 ldx #0 1274 : 08 php 1275 : ec1a02 cpx abs1+3 ;test result trap_ne 1278 : d0fe > bne * ;failed not equal (non zero) 127a : 68 pla ;load status eor_flag 0 127b : 4930 > eor #0|fao ;invert expected flags + always on bits 127d : cd1f02 cmp fLDx+3 ;test flags trap_ne 1280 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1282 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1284 : 48 > pha ;use stack to load status 1285 : 28 > plp 1286 : a2c3 ldx #$c3 1288 : 08 php 1289 : ec1702 cpx abs1 ;test result trap_ne 128c : d0fe > bne * ;failed not equal (non zero) 128e : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 128f : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1291 : cd1c02 cmp fLDx ;test flags trap_ne 1294 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1296 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1298 : 48 > pha ;use stack to load status 1299 : 28 > plp 129a : a282 ldx #$82 129c : 08 php 129d : ec1802 cpx abs1+1 ;test result trap_ne 12a0 : d0fe > bne * ;failed not equal (non zero) 12a2 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 12a3 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 12a5 : cd1d02 cmp fLDx+1 ;test flags trap_ne 12a8 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 12aa : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 12ac : 48 > pha ;use stack to load status 12ad : 28 > plp 12ae : a241 ldx #$41 12b0 : 08 php 12b1 : ec1902 cpx abs1+2 ;test result trap_ne 12b4 : d0fe > bne * ;failed not equal (non zero) 12b6 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 12b7 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 12b9 : cd1e02 cmp fLDx+2 ;test flags trap_ne 12bc : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 12be : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 12c0 : 48 > pha ;use stack to load status 12c1 : 28 > plp 12c2 : a200 ldx #0 12c4 : 08 php 12c5 : ec1a02 cpx abs1+3 ;test result trap_ne 12c8 : d0fe > bne * ;failed not equal (non zero) 12ca : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 12cb : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 12cd : cd1f02 cmp fLDx+3 ;test flags trap_ne 12d0 : d0fe > bne * ;failed not equal (non zero) 12d2 : a200 ldx #0 12d4 : a50c lda zpt 12d6 : 49c3 eor #$c3 12d8 : c513 cmp zp1 trap_ne ;store to zp data 12da : d0fe > bne * ;failed not equal (non zero) 12dc : 860c stx zpt ;clear 12de : ad0302 lda abst 12e1 : 49c3 eor #$c3 12e3 : cd1702 cmp abs1 trap_ne ;store to abs data 12e6 : d0fe > bne * ;failed not equal (non zero) 12e8 : 8e0302 stx abst ;clear 12eb : a50d lda zpt+1 12ed : 49c3 eor #$c3 12ef : c514 cmp zp1+1 trap_ne ;store to zp data 12f1 : d0fe > bne * ;failed not equal (non zero) 12f3 : 860d stx zpt+1 ;clear 12f5 : ad0402 lda abst+1 12f8 : 49c3 eor #$c3 12fa : cd1802 cmp abs1+1 trap_ne ;store to abs data 12fd : d0fe > bne * ;failed not equal (non zero) 12ff : 8e0402 stx abst+1 ;clear 1302 : a50e lda zpt+2 1304 : 49c3 eor #$c3 1306 : c515 cmp zp1+2 trap_ne ;store to zp data 1308 : d0fe > bne * ;failed not equal (non zero) 130a : 860e stx zpt+2 ;clear 130c : ad0502 lda abst+2 130f : 49c3 eor #$c3 1311 : cd1902 cmp abs1+2 trap_ne ;store to abs data 1314 : d0fe > bne * ;failed not equal (non zero) 1316 : 8e0502 stx abst+2 ;clear 1319 : a50f lda zpt+3 131b : 49c3 eor #$c3 131d : c516 cmp zp1+3 trap_ne ;store to zp data 131f : d0fe > bne * ;failed not equal (non zero) 1321 : 860f stx zpt+3 ;clear 1323 : ad0602 lda abst+3 1326 : 49c3 eor #$c3 1328 : cd1a02 cmp abs1+3 trap_ne ;store to abs data 132b : d0fe > bne * ;failed not equal (non zero) 132d : 8e0602 stx abst+3 ;clear next_test 1330 : ad0002 > lda test_case ;previous test 1333 : c913 > cmp #test_num > trap_ne ;test is out of sequence 1335 : d0fe > bne * ;failed not equal (non zero) > 0014 = >test_num = test_num + 1 1337 : a914 > lda #test_num ;*** next tests' number 1339 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; LDY / STY - zp / abs / # set_stat 0 > load_flag 0 133c : a900 > lda #0 ;allow test to change I-flag (no mask) > 133e : 48 > pha ;use stack to load status 133f : 28 > plp 1340 : a413 ldy zp1 1342 : 08 php ;test stores do not alter flags 1343 : 98 tya 1344 : 49c3 eor #$c3 1346 : a8 tay 1347 : 28 plp 1348 : 8c0302 sty abst 134b : 08 php ;flags after load/store sequence 134c : 49c3 eor #$c3 134e : a8 tay 134f : c0c3 cpy #$c3 ;test result trap_ne 1351 : d0fe > bne * ;failed not equal (non zero) 1353 : 68 pla ;load status eor_flag 0 1354 : 4930 > eor #0|fao ;invert expected flags + always on bits 1356 : cd1c02 cmp fLDx ;test flags trap_ne 1359 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 135b : a900 > lda #0 ;allow test to change I-flag (no mask) > 135d : 48 > pha ;use stack to load status 135e : 28 > plp 135f : a414 ldy zp1+1 1361 : 08 php ;test stores do not alter flags 1362 : 98 tya 1363 : 49c3 eor #$c3 1365 : a8 tay 1366 : 28 plp 1367 : 8c0402 sty abst+1 136a : 08 php ;flags after load/store sequence 136b : 49c3 eor #$c3 136d : a8 tay 136e : c082 cpy #$82 ;test result trap_ne 1370 : d0fe > bne * ;failed not equal (non zero) 1372 : 68 pla ;load status eor_flag 0 1373 : 4930 > eor #0|fao ;invert expected flags + always on bits 1375 : cd1d02 cmp fLDx+1 ;test flags trap_ne 1378 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 137a : a900 > lda #0 ;allow test to change I-flag (no mask) > 137c : 48 > pha ;use stack to load status 137d : 28 > plp 137e : a415 ldy zp1+2 1380 : 08 php ;test stores do not alter flags 1381 : 98 tya 1382 : 49c3 eor #$c3 1384 : a8 tay 1385 : 28 plp 1386 : 8c0502 sty abst+2 1389 : 08 php ;flags after load/store sequence 138a : 49c3 eor #$c3 138c : a8 tay 138d : c041 cpy #$41 ;test result trap_ne 138f : d0fe > bne * ;failed not equal (non zero) 1391 : 68 pla ;load status eor_flag 0 1392 : 4930 > eor #0|fao ;invert expected flags + always on bits 1394 : cd1e02 cmp fLDx+2 ;test flags trap_ne 1397 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1399 : a900 > lda #0 ;allow test to change I-flag (no mask) > 139b : 48 > pha ;use stack to load status 139c : 28 > plp 139d : a416 ldy zp1+3 139f : 08 php ;test stores do not alter flags 13a0 : 98 tya 13a1 : 49c3 eor #$c3 13a3 : a8 tay 13a4 : 28 plp 13a5 : 8c0602 sty abst+3 13a8 : 08 php ;flags after load/store sequence 13a9 : 49c3 eor #$c3 13ab : a8 tay 13ac : c000 cpy #0 ;test result trap_ne 13ae : d0fe > bne * ;failed not equal (non zero) 13b0 : 68 pla ;load status eor_flag 0 13b1 : 4930 > eor #0|fao ;invert expected flags + always on bits 13b3 : cd1f02 cmp fLDx+3 ;test flags trap_ne 13b6 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 13b8 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 13ba : 48 > pha ;use stack to load status 13bb : 28 > plp 13bc : a413 ldy zp1 13be : 08 php ;test stores do not alter flags 13bf : 98 tya 13c0 : 49c3 eor #$c3 13c2 : a8 tay 13c3 : 28 plp 13c4 : 8c0302 sty abst 13c7 : 08 php ;flags after load/store sequence 13c8 : 49c3 eor #$c3 13ca : a8 tay 13cb : c0c3 cpy #$c3 ;test result trap_ne 13cd : d0fe > bne * ;failed not equal (non zero) 13cf : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 13d0 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 13d2 : cd1c02 cmp fLDx ;test flags trap_ne 13d5 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 13d7 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 13d9 : 48 > pha ;use stack to load status 13da : 28 > plp 13db : a414 ldy zp1+1 13dd : 08 php ;test stores do not alter flags 13de : 98 tya 13df : 49c3 eor #$c3 13e1 : a8 tay 13e2 : 28 plp 13e3 : 8c0402 sty abst+1 13e6 : 08 php ;flags after load/store sequence 13e7 : 49c3 eor #$c3 13e9 : a8 tay 13ea : c082 cpy #$82 ;test result trap_ne 13ec : d0fe > bne * ;failed not equal (non zero) 13ee : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 13ef : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 13f1 : cd1d02 cmp fLDx+1 ;test flags trap_ne 13f4 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 13f6 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 13f8 : 48 > pha ;use stack to load status 13f9 : 28 > plp 13fa : a415 ldy zp1+2 13fc : 08 php ;test stores do not alter flags 13fd : 98 tya 13fe : 49c3 eor #$c3 1400 : a8 tay 1401 : 28 plp 1402 : 8c0502 sty abst+2 1405 : 08 php ;flags after load/store sequence 1406 : 49c3 eor #$c3 1408 : a8 tay 1409 : c041 cpy #$41 ;test result trap_ne 140b : d0fe > bne * ;failed not equal (non zero) 140d : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 140e : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1410 : cd1e02 cmp fLDx+2 ;test flags trap_ne 1413 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1415 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1417 : 48 > pha ;use stack to load status 1418 : 28 > plp 1419 : a416 ldy zp1+3 141b : 08 php ;test stores do not alter flags 141c : 98 tya 141d : 49c3 eor #$c3 141f : a8 tay 1420 : 28 plp 1421 : 8c0602 sty abst+3 1424 : 08 php ;flags after load/store sequence 1425 : 49c3 eor #$c3 1427 : a8 tay 1428 : c000 cpy #0 ;test result trap_ne 142a : d0fe > bne * ;failed not equal (non zero) 142c : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 142d : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 142f : cd1f02 cmp fLDx+3 ;test flags trap_ne 1432 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1434 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1436 : 48 > pha ;use stack to load status 1437 : 28 > plp 1438 : ac1702 ldy abs1 143b : 08 php ;test stores do not alter flags 143c : 98 tya 143d : 49c3 eor #$c3 143f : a8 tay 1440 : 28 plp 1441 : 840c sty zpt 1443 : 08 php ;flags after load/store sequence 1444 : 49c3 eor #$c3 1446 : a8 tay 1447 : c413 cpy zp1 ;test result trap_ne 1449 : d0fe > bne * ;failed not equal (non zero) 144b : 68 pla ;load status eor_flag 0 144c : 4930 > eor #0|fao ;invert expected flags + always on bits 144e : cd1c02 cmp fLDx ;test flags trap_ne 1451 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1453 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1455 : 48 > pha ;use stack to load status 1456 : 28 > plp 1457 : ac1802 ldy abs1+1 145a : 08 php ;test stores do not alter flags 145b : 98 tya 145c : 49c3 eor #$c3 145e : a8 tay 145f : 28 plp 1460 : 840d sty zpt+1 1462 : 08 php ;flags after load/store sequence 1463 : 49c3 eor #$c3 1465 : a8 tay 1466 : c414 cpy zp1+1 ;test result trap_ne 1468 : d0fe > bne * ;failed not equal (non zero) 146a : 68 pla ;load status eor_flag 0 146b : 4930 > eor #0|fao ;invert expected flags + always on bits 146d : cd1d02 cmp fLDx+1 ;test flags trap_ne 1470 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1472 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1474 : 48 > pha ;use stack to load status 1475 : 28 > plp 1476 : ac1902 ldy abs1+2 1479 : 08 php ;test stores do not alter flags 147a : 98 tya 147b : 49c3 eor #$c3 147d : a8 tay 147e : 28 plp 147f : 840e sty zpt+2 1481 : 08 php ;flags after load/store sequence 1482 : 49c3 eor #$c3 1484 : a8 tay 1485 : c415 cpy zp1+2 ;test result trap_ne 1487 : d0fe > bne * ;failed not equal (non zero) 1489 : 68 pla ;load status eor_flag 0 148a : 4930 > eor #0|fao ;invert expected flags + always on bits 148c : cd1e02 cmp fLDx+2 ;test flags trap_ne 148f : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1491 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1493 : 48 > pha ;use stack to load status 1494 : 28 > plp 1495 : ac1a02 ldy abs1+3 1498 : 08 php ;test stores do not alter flags 1499 : 98 tya 149a : 49c3 eor #$c3 149c : a8 tay 149d : 28 plp 149e : 840f sty zpt+3 14a0 : 08 php ;flags after load/store sequence 14a1 : 49c3 eor #$c3 14a3 : a8 tay 14a4 : c416 cpy zp1+3 ;test result trap_ne 14a6 : d0fe > bne * ;failed not equal (non zero) 14a8 : 68 pla ;load status eor_flag 0 14a9 : 4930 > eor #0|fao ;invert expected flags + always on bits 14ab : cd1f02 cmp fLDx+3 ;test flags trap_ne 14ae : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 14b0 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 14b2 : 48 > pha ;use stack to load status 14b3 : 28 > plp 14b4 : ac1702 ldy abs1 14b7 : 08 php ;test stores do not alter flags 14b8 : 98 tya 14b9 : 49c3 eor #$c3 14bb : a8 tay 14bc : 28 plp 14bd : 840c sty zpt 14bf : 08 php ;flags after load/store sequence 14c0 : 49c3 eor #$c3 14c2 : a8 tay 14c3 : c513 cmp zp1 ;test result trap_ne 14c5 : d0fe > bne * ;failed not equal (non zero) 14c7 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 14c8 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 14ca : cd1c02 cmp fLDx ;test flags trap_ne 14cd : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 14cf : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 14d1 : 48 > pha ;use stack to load status 14d2 : 28 > plp 14d3 : ac1802 ldy abs1+1 14d6 : 08 php ;test stores do not alter flags 14d7 : 98 tya 14d8 : 49c3 eor #$c3 14da : a8 tay 14db : 28 plp 14dc : 840d sty zpt+1 14de : 08 php ;flags after load/store sequence 14df : 49c3 eor #$c3 14e1 : a8 tay 14e2 : c514 cmp zp1+1 ;test result trap_ne 14e4 : d0fe > bne * ;failed not equal (non zero) 14e6 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 14e7 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 14e9 : cd1d02 cmp fLDx+1 ;test flags trap_ne 14ec : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 14ee : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 14f0 : 48 > pha ;use stack to load status 14f1 : 28 > plp 14f2 : ac1902 ldy abs1+2 14f5 : 08 php ;test stores do not alter flags 14f6 : 98 tya 14f7 : 49c3 eor #$c3 14f9 : a8 tay 14fa : 28 plp 14fb : 840e sty zpt+2 14fd : 08 php ;flags after load/store sequence 14fe : 49c3 eor #$c3 1500 : a8 tay 1501 : c515 cmp zp1+2 ;test result trap_ne 1503 : d0fe > bne * ;failed not equal (non zero) 1505 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1506 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1508 : cd1e02 cmp fLDx+2 ;test flags trap_ne 150b : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 150d : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 150f : 48 > pha ;use stack to load status 1510 : 28 > plp 1511 : ac1a02 ldy abs1+3 1514 : 08 php ;test stores do not alter flags 1515 : 98 tya 1516 : 49c3 eor #$c3 1518 : a8 tay 1519 : 28 plp 151a : 840f sty zpt+3 151c : 08 php ;flags after load/store sequence 151d : 49c3 eor #$c3 151f : a8 tay 1520 : c516 cmp zp1+3 ;test result trap_ne 1522 : d0fe > bne * ;failed not equal (non zero) 1524 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1525 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1527 : cd1f02 cmp fLDx+3 ;test flags trap_ne 152a : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 152c : a900 > lda #0 ;allow test to change I-flag (no mask) > 152e : 48 > pha ;use stack to load status 152f : 28 > plp 1530 : a0c3 ldy #$c3 1532 : 08 php 1533 : cc1702 cpy abs1 ;test result trap_ne 1536 : d0fe > bne * ;failed not equal (non zero) 1538 : 68 pla ;load status eor_flag 0 1539 : 4930 > eor #0|fao ;invert expected flags + always on bits 153b : cd1c02 cmp fLDx ;test flags trap_ne 153e : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1540 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1542 : 48 > pha ;use stack to load status 1543 : 28 > plp 1544 : a082 ldy #$82 1546 : 08 php 1547 : cc1802 cpy abs1+1 ;test result trap_ne 154a : d0fe > bne * ;failed not equal (non zero) 154c : 68 pla ;load status eor_flag 0 154d : 4930 > eor #0|fao ;invert expected flags + always on bits 154f : cd1d02 cmp fLDx+1 ;test flags trap_ne 1552 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1554 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1556 : 48 > pha ;use stack to load status 1557 : 28 > plp 1558 : a041 ldy #$41 155a : 08 php 155b : cc1902 cpy abs1+2 ;test result trap_ne 155e : d0fe > bne * ;failed not equal (non zero) 1560 : 68 pla ;load status eor_flag 0 1561 : 4930 > eor #0|fao ;invert expected flags + always on bits 1563 : cd1e02 cmp fLDx+2 ;test flags trap_ne 1566 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1568 : a900 > lda #0 ;allow test to change I-flag (no mask) > 156a : 48 > pha ;use stack to load status 156b : 28 > plp 156c : a000 ldy #0 156e : 08 php 156f : cc1a02 cpy abs1+3 ;test result trap_ne 1572 : d0fe > bne * ;failed not equal (non zero) 1574 : 68 pla ;load status eor_flag 0 1575 : 4930 > eor #0|fao ;invert expected flags + always on bits 1577 : cd1f02 cmp fLDx+3 ;test flags trap_ne 157a : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 157c : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 157e : 48 > pha ;use stack to load status 157f : 28 > plp 1580 : a0c3 ldy #$c3 1582 : 08 php 1583 : cc1702 cpy abs1 ;test result trap_ne 1586 : d0fe > bne * ;failed not equal (non zero) 1588 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1589 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 158b : cd1c02 cmp fLDx ;test flags trap_ne 158e : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1590 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1592 : 48 > pha ;use stack to load status 1593 : 28 > plp 1594 : a082 ldy #$82 1596 : 08 php 1597 : cc1802 cpy abs1+1 ;test result trap_ne 159a : d0fe > bne * ;failed not equal (non zero) 159c : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 159d : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 159f : cd1d02 cmp fLDx+1 ;test flags trap_ne 15a2 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 15a4 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 15a6 : 48 > pha ;use stack to load status 15a7 : 28 > plp 15a8 : a041 ldy #$41 15aa : 08 php 15ab : cc1902 cpy abs1+2 ;test result trap_ne 15ae : d0fe > bne * ;failed not equal (non zero) 15b0 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 15b1 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 15b3 : cd1e02 cmp fLDx+2 ;test flags trap_ne 15b6 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 15b8 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 15ba : 48 > pha ;use stack to load status 15bb : 28 > plp 15bc : a000 ldy #0 15be : 08 php 15bf : cc1a02 cpy abs1+3 ;test result trap_ne 15c2 : d0fe > bne * ;failed not equal (non zero) 15c4 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 15c5 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 15c7 : cd1f02 cmp fLDx+3 ;test flags trap_ne 15ca : d0fe > bne * ;failed not equal (non zero) 15cc : a000 ldy #0 15ce : a50c lda zpt 15d0 : 49c3 eor #$c3 15d2 : c513 cmp zp1 trap_ne ;store to zp data 15d4 : d0fe > bne * ;failed not equal (non zero) 15d6 : 840c sty zpt ;clear 15d8 : ad0302 lda abst 15db : 49c3 eor #$c3 15dd : cd1702 cmp abs1 trap_ne ;store to abs data 15e0 : d0fe > bne * ;failed not equal (non zero) 15e2 : 8c0302 sty abst ;clear 15e5 : a50d lda zpt+1 15e7 : 49c3 eor #$c3 15e9 : c514 cmp zp1+1 trap_ne ;store to zp+1 data 15eb : d0fe > bne * ;failed not equal (non zero) 15ed : 840d sty zpt+1 ;clear 15ef : ad0402 lda abst+1 15f2 : 49c3 eor #$c3 15f4 : cd1802 cmp abs1+1 trap_ne ;store to abs+1 data 15f7 : d0fe > bne * ;failed not equal (non zero) 15f9 : 8c0402 sty abst+1 ;clear 15fc : a50e lda zpt+2 15fe : 49c3 eor #$c3 1600 : c515 cmp zp1+2 trap_ne ;store to zp+2 data 1602 : d0fe > bne * ;failed not equal (non zero) 1604 : 840e sty zpt+2 ;clear 1606 : ad0502 lda abst+2 1609 : 49c3 eor #$c3 160b : cd1902 cmp abs1+2 trap_ne ;store to abs+2 data 160e : d0fe > bne * ;failed not equal (non zero) 1610 : 8c0502 sty abst+2 ;clear 1613 : a50f lda zpt+3 1615 : 49c3 eor #$c3 1617 : c516 cmp zp1+3 trap_ne ;store to zp+3 data 1619 : d0fe > bne * ;failed not equal (non zero) 161b : 840f sty zpt+3 ;clear 161d : ad0602 lda abst+3 1620 : 49c3 eor #$c3 1622 : cd1a02 cmp abs1+3 trap_ne ;store to abs+3 data 1625 : d0fe > bne * ;failed not equal (non zero) 1627 : 8c0602 sty abst+3 ;clear next_test 162a : ad0002 > lda test_case ;previous test 162d : c914 > cmp #test_num > trap_ne ;test is out of sequence 162f : d0fe > bne * ;failed not equal (non zero) > 0015 = >test_num = test_num + 1 1631 : a915 > lda #test_num ;*** next tests' number 1633 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; testing load / store accumulator LDA / STA all addressing modes ; LDA / STA - zp,x / abs,x 1636 : a203 ldx #3 1638 : tldax set_stat 0 > load_flag 0 1638 : a900 > lda #0 ;allow test to change I-flag (no mask) > 163a : 48 > pha ;use stack to load status 163b : 28 > plp 163c : b513 lda zp1,x 163e : 08 php ;test stores do not alter flags 163f : 49c3 eor #$c3 1641 : 28 plp 1642 : 9d0302 sta abst,x 1645 : 08 php ;flags after load/store sequence 1646 : 49c3 eor #$c3 1648 : dd1702 cmp abs1,x ;test result trap_ne 164b : d0fe > bne * ;failed not equal (non zero) 164d : 68 pla ;load status eor_flag 0 164e : 4930 > eor #0|fao ;invert expected flags + always on bits 1650 : dd1c02 cmp fLDx,x ;test flags trap_ne 1653 : d0fe > bne * ;failed not equal (non zero) 1655 : ca dex 1656 : 10e0 bpl tldax 1658 : a203 ldx #3 165a : tldax1 set_stat $ff > load_flag $ff 165a : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 165c : 48 > pha ;use stack to load status 165d : 28 > plp 165e : b513 lda zp1,x 1660 : 08 php ;test stores do not alter flags 1661 : 49c3 eor #$c3 1663 : 28 plp 1664 : 9d0302 sta abst,x 1667 : 08 php ;flags after load/store sequence 1668 : 49c3 eor #$c3 166a : dd1702 cmp abs1,x ;test result trap_ne 166d : d0fe > bne * ;failed not equal (non zero) 166f : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1670 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1672 : dd1c02 cmp fLDx,x ;test flags trap_ne 1675 : d0fe > bne * ;failed not equal (non zero) 1677 : ca dex 1678 : 10e0 bpl tldax1 167a : a203 ldx #3 167c : tldax2 set_stat 0 > load_flag 0 167c : a900 > lda #0 ;allow test to change I-flag (no mask) > 167e : 48 > pha ;use stack to load status 167f : 28 > plp 1680 : bd1702 lda abs1,x 1683 : 08 php ;test stores do not alter flags 1684 : 49c3 eor #$c3 1686 : 28 plp 1687 : 950c sta zpt,x 1689 : 08 php ;flags after load/store sequence 168a : 49c3 eor #$c3 168c : d513 cmp zp1,x ;test result trap_ne 168e : d0fe > bne * ;failed not equal (non zero) 1690 : 68 pla ;load status eor_flag 0 1691 : 4930 > eor #0|fao ;invert expected flags + always on bits 1693 : dd1c02 cmp fLDx,x ;test flags trap_ne 1696 : d0fe > bne * ;failed not equal (non zero) 1698 : ca dex 1699 : 10e1 bpl tldax2 169b : a203 ldx #3 169d : tldax3 set_stat $ff > load_flag $ff 169d : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 169f : 48 > pha ;use stack to load status 16a0 : 28 > plp 16a1 : bd1702 lda abs1,x 16a4 : 08 php ;test stores do not alter flags 16a5 : 49c3 eor #$c3 16a7 : 28 plp 16a8 : 950c sta zpt,x 16aa : 08 php ;flags after load/store sequence 16ab : 49c3 eor #$c3 16ad : d513 cmp zp1,x ;test result trap_ne 16af : d0fe > bne * ;failed not equal (non zero) 16b1 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 16b2 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 16b4 : dd1c02 cmp fLDx,x ;test flags trap_ne 16b7 : d0fe > bne * ;failed not equal (non zero) 16b9 : ca dex 16ba : 10e1 bpl tldax3 16bc : a203 ldx #3 ;testing store result 16be : a000 ldy #0 16c0 : b50c tstax lda zpt,x 16c2 : 49c3 eor #$c3 16c4 : d513 cmp zp1,x trap_ne ;store to zp,x data 16c6 : d0fe > bne * ;failed not equal (non zero) 16c8 : 940c sty zpt,x ;clear 16ca : bd0302 lda abst,x 16cd : 49c3 eor #$c3 16cf : dd1702 cmp abs1,x trap_ne ;store to abs,x data 16d2 : d0fe > bne * ;failed not equal (non zero) 16d4 : 8a txa 16d5 : 9d0302 sta abst,x ;clear 16d8 : ca dex 16d9 : 10e5 bpl tstax next_test 16db : ad0002 > lda test_case ;previous test 16de : c915 > cmp #test_num > trap_ne ;test is out of sequence 16e0 : d0fe > bne * ;failed not equal (non zero) > 0016 = >test_num = test_num + 1 16e2 : a916 > lda #test_num ;*** next tests' number 16e4 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; LDA / STA - (zp),y / abs,y / (zp,x) 16e7 : a003 ldy #3 16e9 : tlday set_stat 0 > load_flag 0 16e9 : a900 > lda #0 ;allow test to change I-flag (no mask) > 16eb : 48 > pha ;use stack to load status 16ec : 28 > plp 16ed : b124 lda (ind1),y 16ef : 08 php ;test stores do not alter flags 16f0 : 49c3 eor #$c3 16f2 : 28 plp 16f3 : 990302 sta abst,y 16f6 : 08 php ;flags after load/store sequence 16f7 : 49c3 eor #$c3 16f9 : d91702 cmp abs1,y ;test result trap_ne 16fc : d0fe > bne * ;failed not equal (non zero) 16fe : 68 pla ;load status eor_flag 0 16ff : 4930 > eor #0|fao ;invert expected flags + always on bits 1701 : d91c02 cmp fLDx,y ;test flags trap_ne 1704 : d0fe > bne * ;failed not equal (non zero) 1706 : 88 dey 1707 : 10e0 bpl tlday 1709 : a003 ldy #3 170b : tlday1 set_stat $ff > load_flag $ff 170b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 170d : 48 > pha ;use stack to load status 170e : 28 > plp 170f : b124 lda (ind1),y 1711 : 08 php ;test stores do not alter flags 1712 : 49c3 eor #$c3 1714 : 28 plp 1715 : 990302 sta abst,y 1718 : 08 php ;flags after load/store sequence 1719 : 49c3 eor #$c3 171b : d91702 cmp abs1,y ;test result trap_ne 171e : d0fe > bne * ;failed not equal (non zero) 1720 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1721 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1723 : d91c02 cmp fLDx,y ;test flags trap_ne 1726 : d0fe > bne * ;failed not equal (non zero) 1728 : 88 dey 1729 : 10e0 bpl tlday1 172b : a003 ldy #3 ;testing store result 172d : a200 ldx #0 172f : b90302 tstay lda abst,y 1732 : 49c3 eor #$c3 1734 : d91702 cmp abs1,y trap_ne ;store to abs data 1737 : d0fe > bne * ;failed not equal (non zero) 1739 : 8a txa 173a : 990302 sta abst,y ;clear 173d : 88 dey 173e : 10ef bpl tstay 1740 : a003 ldy #3 1742 : tlday2 set_stat 0 > load_flag 0 1742 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1744 : 48 > pha ;use stack to load status 1745 : 28 > plp 1746 : b91702 lda abs1,y 1749 : 08 php ;test stores do not alter flags 174a : 49c3 eor #$c3 174c : 28 plp 174d : 9130 sta (indt),y 174f : 08 php ;flags after load/store sequence 1750 : 49c3 eor #$c3 1752 : d124 cmp (ind1),y ;test result trap_ne 1754 : d0fe > bne * ;failed not equal (non zero) 1756 : 68 pla ;load status eor_flag 0 1757 : 4930 > eor #0|fao ;invert expected flags + always on bits 1759 : d91c02 cmp fLDx,y ;test flags trap_ne 175c : d0fe > bne * ;failed not equal (non zero) 175e : 88 dey 175f : 10e1 bpl tlday2 1761 : a003 ldy #3 1763 : tlday3 set_stat $ff > load_flag $ff 1763 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1765 : 48 > pha ;use stack to load status 1766 : 28 > plp 1767 : b91702 lda abs1,y 176a : 08 php ;test stores do not alter flags 176b : 49c3 eor #$c3 176d : 28 plp 176e : 9130 sta (indt),y 1770 : 08 php ;flags after load/store sequence 1771 : 49c3 eor #$c3 1773 : d124 cmp (ind1),y ;test result trap_ne 1775 : d0fe > bne * ;failed not equal (non zero) 1777 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1778 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 177a : d91c02 cmp fLDx,y ;test flags trap_ne 177d : d0fe > bne * ;failed not equal (non zero) 177f : 88 dey 1780 : 10e1 bpl tlday3 1782 : a003 ldy #3 ;testing store result 1784 : a200 ldx #0 1786 : b90302 tstay1 lda abst,y 1789 : 49c3 eor #$c3 178b : d91702 cmp abs1,y trap_ne ;store to abs data 178e : d0fe > bne * ;failed not equal (non zero) 1790 : 8a txa 1791 : 990302 sta abst,y ;clear 1794 : 88 dey 1795 : 10ef bpl tstay1 1797 : a206 ldx #6 1799 : a003 ldy #3 179b : tldax4 set_stat 0 > load_flag 0 179b : a900 > lda #0 ;allow test to change I-flag (no mask) > 179d : 48 > pha ;use stack to load status 179e : 28 > plp 179f : a124 lda (ind1,x) 17a1 : 08 php ;test stores do not alter flags 17a2 : 49c3 eor #$c3 17a4 : 28 plp 17a5 : 8130 sta (indt,x) 17a7 : 08 php ;flags after load/store sequence 17a8 : 49c3 eor #$c3 17aa : d91702 cmp abs1,y ;test result trap_ne 17ad : d0fe > bne * ;failed not equal (non zero) 17af : 68 pla ;load status eor_flag 0 17b0 : 4930 > eor #0|fao ;invert expected flags + always on bits 17b2 : d91c02 cmp fLDx,y ;test flags trap_ne 17b5 : d0fe > bne * ;failed not equal (non zero) 17b7 : ca dex 17b8 : ca dex 17b9 : 88 dey 17ba : 10df bpl tldax4 17bc : a206 ldx #6 17be : a003 ldy #3 17c0 : tldax5 set_stat $ff > load_flag $ff 17c0 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 17c2 : 48 > pha ;use stack to load status 17c3 : 28 > plp 17c4 : a124 lda (ind1,x) 17c6 : 08 php ;test stores do not alter flags 17c7 : 49c3 eor #$c3 17c9 : 28 plp 17ca : 8130 sta (indt,x) 17cc : 08 php ;flags after load/store sequence 17cd : 49c3 eor #$c3 17cf : d91702 cmp abs1,y ;test result trap_ne 17d2 : d0fe > bne * ;failed not equal (non zero) 17d4 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 17d5 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 17d7 : d91c02 cmp fLDx,y ;test flags trap_ne 17da : d0fe > bne * ;failed not equal (non zero) 17dc : ca dex 17dd : ca dex 17de : 88 dey 17df : 10df bpl tldax5 17e1 : a003 ldy #3 ;testing store result 17e3 : a200 ldx #0 17e5 : b90302 tstay2 lda abst,y 17e8 : 49c3 eor #$c3 17ea : d91702 cmp abs1,y trap_ne ;store to abs data 17ed : d0fe > bne * ;failed not equal (non zero) 17ef : 8a txa 17f0 : 990302 sta abst,y ;clear 17f3 : 88 dey 17f4 : 10ef bpl tstay2 next_test 17f6 : ad0002 > lda test_case ;previous test 17f9 : c916 > cmp #test_num > trap_ne ;test is out of sequence 17fb : d0fe > bne * ;failed not equal (non zero) > 0017 = >test_num = test_num + 1 17fd : a917 > lda #test_num ;*** next tests' number 17ff : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; indexed wraparound test (only zp should wrap) 1802 : a2fd ldx #3+$fa 1804 : b519 tldax6 lda zp1-$fa&$ff,x ;wrap on indexed zp 1806 : 9d0901 sta abst-$fa,x ;no STX abs,x! 1809 : ca dex 180a : e0fa cpx #$fa 180c : b0f6 bcs tldax6 180e : a2fd ldx #3+$fa 1810 : bd1d01 tldax7 lda abs1-$fa,x ;no wrap on indexed abs 1813 : 9512 sta zpt-$fa&$ff,x 1815 : ca dex 1816 : e0fa cpx #$fa 1818 : b0f6 bcs tldax7 181a : a203 ldx #3 ;testing wraparound result 181c : a000 ldy #0 181e : b50c tstax1 lda zpt,x 1820 : d513 cmp zp1,x trap_ne ;store to zp,x data 1822 : d0fe > bne * ;failed not equal (non zero) 1824 : 940c sty zpt,x ;clear 1826 : bd0302 lda abst,x 1829 : dd1702 cmp abs1,x trap_ne ;store to abs,x data 182c : d0fe > bne * ;failed not equal (non zero) 182e : 8a txa 182f : 9d0302 sta abst,x ;clear 1832 : ca dex 1833 : 10e9 bpl tstax1 1835 : a0fb ldy #3+$f8 1837 : a2fe ldx #6+$f8 1839 : a12c tlday4 lda (ind1-$f8&$ff,x) ;wrap on indexed zp indirect 183b : 990b01 sta abst-$f8,y 183e : ca dex 183f : ca dex 1840 : 88 dey 1841 : c0f8 cpy #$f8 1843 : b0f4 bcs tlday4 1845 : a003 ldy #3 ;testing wraparound result 1847 : a200 ldx #0 1849 : b90302 tstay4 lda abst,y 184c : d91702 cmp abs1,y trap_ne ;store to abs data 184f : d0fe > bne * ;failed not equal (non zero) 1851 : 8a txa 1852 : 990302 sta abst,y ;clear 1855 : 88 dey 1856 : 10f1 bpl tstay4 1858 : a0fb ldy #3+$f8 185a : b91f01 tlday5 lda abs1-$f8,y ;no wrap on indexed abs 185d : 9138 sta (inwt),y 185f : 88 dey 1860 : c0f8 cpy #$f8 1862 : b0f6 bcs tlday5 1864 : a003 ldy #3 ;testing wraparound result 1866 : a200 ldx #0 1868 : b90302 tstay5 lda abst,y 186b : d91702 cmp abs1,y trap_ne ;store to abs data 186e : d0fe > bne * ;failed not equal (non zero) 1870 : 8a txa 1871 : 990302 sta abst,y ;clear 1874 : 88 dey 1875 : 10f1 bpl tstay5 1877 : a0fb ldy #3+$f8 1879 : a2fe ldx #6+$f8 187b : b12e tlday6 lda (inw1),y ;no wrap on zp indirect indexed 187d : 8138 sta (indt-$f8&$ff,x) 187f : ca dex 1880 : ca dex 1881 : 88 dey 1882 : c0f8 cpy #$f8 1884 : b0f5 bcs tlday6 1886 : a003 ldy #3 ;testing wraparound result 1888 : a200 ldx #0 188a : b90302 tstay6 lda abst,y 188d : d91702 cmp abs1,y trap_ne ;store to abs data 1890 : d0fe > bne * ;failed not equal (non zero) 1892 : 8a txa 1893 : 990302 sta abst,y ;clear 1896 : 88 dey 1897 : 10f1 bpl tstay6 next_test 1899 : ad0002 > lda test_case ;previous test 189c : c917 > cmp #test_num > trap_ne ;test is out of sequence 189e : d0fe > bne * ;failed not equal (non zero) > 0018 = >test_num = test_num + 1 18a0 : a918 > lda #test_num ;*** next tests' number 18a2 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; LDA / STA - zp / abs / # set_stat 0 > load_flag 0 18a5 : a900 > lda #0 ;allow test to change I-flag (no mask) > 18a7 : 48 > pha ;use stack to load status 18a8 : 28 > plp 18a9 : a513 lda zp1 18ab : 08 php ;test stores do not alter flags 18ac : 49c3 eor #$c3 18ae : 28 plp 18af : 8d0302 sta abst 18b2 : 08 php ;flags after load/store sequence 18b3 : 49c3 eor #$c3 18b5 : c9c3 cmp #$c3 ;test result trap_ne 18b7 : d0fe > bne * ;failed not equal (non zero) 18b9 : 68 pla ;load status eor_flag 0 18ba : 4930 > eor #0|fao ;invert expected flags + always on bits 18bc : cd1c02 cmp fLDx ;test flags trap_ne 18bf : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 18c1 : a900 > lda #0 ;allow test to change I-flag (no mask) > 18c3 : 48 > pha ;use stack to load status 18c4 : 28 > plp 18c5 : a514 lda zp1+1 18c7 : 08 php ;test stores do not alter flags 18c8 : 49c3 eor #$c3 18ca : 28 plp 18cb : 8d0402 sta abst+1 18ce : 08 php ;flags after load/store sequence 18cf : 49c3 eor #$c3 18d1 : c982 cmp #$82 ;test result trap_ne 18d3 : d0fe > bne * ;failed not equal (non zero) 18d5 : 68 pla ;load status eor_flag 0 18d6 : 4930 > eor #0|fao ;invert expected flags + always on bits 18d8 : cd1d02 cmp fLDx+1 ;test flags trap_ne 18db : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 18dd : a900 > lda #0 ;allow test to change I-flag (no mask) > 18df : 48 > pha ;use stack to load status 18e0 : 28 > plp 18e1 : a515 lda zp1+2 18e3 : 08 php ;test stores do not alter flags 18e4 : 49c3 eor #$c3 18e6 : 28 plp 18e7 : 8d0502 sta abst+2 18ea : 08 php ;flags after load/store sequence 18eb : 49c3 eor #$c3 18ed : c941 cmp #$41 ;test result trap_ne 18ef : d0fe > bne * ;failed not equal (non zero) 18f1 : 68 pla ;load status eor_flag 0 18f2 : 4930 > eor #0|fao ;invert expected flags + always on bits 18f4 : cd1e02 cmp fLDx+2 ;test flags trap_ne 18f7 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 18f9 : a900 > lda #0 ;allow test to change I-flag (no mask) > 18fb : 48 > pha ;use stack to load status 18fc : 28 > plp 18fd : a516 lda zp1+3 18ff : 08 php ;test stores do not alter flags 1900 : 49c3 eor #$c3 1902 : 28 plp 1903 : 8d0602 sta abst+3 1906 : 08 php ;flags after load/store sequence 1907 : 49c3 eor #$c3 1909 : c900 cmp #0 ;test result trap_ne 190b : d0fe > bne * ;failed not equal (non zero) 190d : 68 pla ;load status eor_flag 0 190e : 4930 > eor #0|fao ;invert expected flags + always on bits 1910 : cd1f02 cmp fLDx+3 ;test flags trap_ne 1913 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1915 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1917 : 48 > pha ;use stack to load status 1918 : 28 > plp 1919 : a513 lda zp1 191b : 08 php ;test stores do not alter flags 191c : 49c3 eor #$c3 191e : 28 plp 191f : 8d0302 sta abst 1922 : 08 php ;flags after load/store sequence 1923 : 49c3 eor #$c3 1925 : c9c3 cmp #$c3 ;test result trap_ne 1927 : d0fe > bne * ;failed not equal (non zero) 1929 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 192a : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 192c : cd1c02 cmp fLDx ;test flags trap_ne 192f : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1931 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1933 : 48 > pha ;use stack to load status 1934 : 28 > plp 1935 : a514 lda zp1+1 1937 : 08 php ;test stores do not alter flags 1938 : 49c3 eor #$c3 193a : 28 plp 193b : 8d0402 sta abst+1 193e : 08 php ;flags after load/store sequence 193f : 49c3 eor #$c3 1941 : c982 cmp #$82 ;test result trap_ne 1943 : d0fe > bne * ;failed not equal (non zero) 1945 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1946 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1948 : cd1d02 cmp fLDx+1 ;test flags trap_ne 194b : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 194d : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 194f : 48 > pha ;use stack to load status 1950 : 28 > plp 1951 : a515 lda zp1+2 1953 : 08 php ;test stores do not alter flags 1954 : 49c3 eor #$c3 1956 : 28 plp 1957 : 8d0502 sta abst+2 195a : 08 php ;flags after load/store sequence 195b : 49c3 eor #$c3 195d : c941 cmp #$41 ;test result trap_ne 195f : d0fe > bne * ;failed not equal (non zero) 1961 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1962 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1964 : cd1e02 cmp fLDx+2 ;test flags trap_ne 1967 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1969 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 196b : 48 > pha ;use stack to load status 196c : 28 > plp 196d : a516 lda zp1+3 196f : 08 php ;test stores do not alter flags 1970 : 49c3 eor #$c3 1972 : 28 plp 1973 : 8d0602 sta abst+3 1976 : 08 php ;flags after load/store sequence 1977 : 49c3 eor #$c3 1979 : c900 cmp #0 ;test result trap_ne 197b : d0fe > bne * ;failed not equal (non zero) 197d : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 197e : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1980 : cd1f02 cmp fLDx+3 ;test flags trap_ne 1983 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1985 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1987 : 48 > pha ;use stack to load status 1988 : 28 > plp 1989 : ad1702 lda abs1 198c : 08 php ;test stores do not alter flags 198d : 49c3 eor #$c3 198f : 28 plp 1990 : 850c sta zpt 1992 : 08 php ;flags after load/store sequence 1993 : 49c3 eor #$c3 1995 : c513 cmp zp1 ;test result trap_ne 1997 : d0fe > bne * ;failed not equal (non zero) 1999 : 68 pla ;load status eor_flag 0 199a : 4930 > eor #0|fao ;invert expected flags + always on bits 199c : cd1c02 cmp fLDx ;test flags trap_ne 199f : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 19a1 : a900 > lda #0 ;allow test to change I-flag (no mask) > 19a3 : 48 > pha ;use stack to load status 19a4 : 28 > plp 19a5 : ad1802 lda abs1+1 19a8 : 08 php ;test stores do not alter flags 19a9 : 49c3 eor #$c3 19ab : 28 plp 19ac : 850d sta zpt+1 19ae : 08 php ;flags after load/store sequence 19af : 49c3 eor #$c3 19b1 : c514 cmp zp1+1 ;test result trap_ne 19b3 : d0fe > bne * ;failed not equal (non zero) 19b5 : 68 pla ;load status eor_flag 0 19b6 : 4930 > eor #0|fao ;invert expected flags + always on bits 19b8 : cd1d02 cmp fLDx+1 ;test flags trap_ne 19bb : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 19bd : a900 > lda #0 ;allow test to change I-flag (no mask) > 19bf : 48 > pha ;use stack to load status 19c0 : 28 > plp 19c1 : ad1902 lda abs1+2 19c4 : 08 php ;test stores do not alter flags 19c5 : 49c3 eor #$c3 19c7 : 28 plp 19c8 : 850e sta zpt+2 19ca : 08 php ;flags after load/store sequence 19cb : 49c3 eor #$c3 19cd : c515 cmp zp1+2 ;test result trap_ne 19cf : d0fe > bne * ;failed not equal (non zero) 19d1 : 68 pla ;load status eor_flag 0 19d2 : 4930 > eor #0|fao ;invert expected flags + always on bits 19d4 : cd1e02 cmp fLDx+2 ;test flags trap_ne 19d7 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 19d9 : a900 > lda #0 ;allow test to change I-flag (no mask) > 19db : 48 > pha ;use stack to load status 19dc : 28 > plp 19dd : ad1a02 lda abs1+3 19e0 : 08 php ;test stores do not alter flags 19e1 : 49c3 eor #$c3 19e3 : 28 plp 19e4 : 850f sta zpt+3 19e6 : 08 php ;flags after load/store sequence 19e7 : 49c3 eor #$c3 19e9 : c516 cmp zp1+3 ;test result trap_ne 19eb : d0fe > bne * ;failed not equal (non zero) 19ed : 68 pla ;load status eor_flag 0 19ee : 4930 > eor #0|fao ;invert expected flags + always on bits 19f0 : cd1f02 cmp fLDx+3 ;test flags trap_ne 19f3 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 19f5 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 19f7 : 48 > pha ;use stack to load status 19f8 : 28 > plp 19f9 : ad1702 lda abs1 19fc : 08 php ;test stores do not alter flags 19fd : 49c3 eor #$c3 19ff : 28 plp 1a00 : 850c sta zpt 1a02 : 08 php ;flags after load/store sequence 1a03 : 49c3 eor #$c3 1a05 : c513 cmp zp1 ;test result trap_ne 1a07 : d0fe > bne * ;failed not equal (non zero) 1a09 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1a0a : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1a0c : cd1c02 cmp fLDx ;test flags trap_ne 1a0f : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1a11 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1a13 : 48 > pha ;use stack to load status 1a14 : 28 > plp 1a15 : ad1802 lda abs1+1 1a18 : 08 php ;test stores do not alter flags 1a19 : 49c3 eor #$c3 1a1b : 28 plp 1a1c : 850d sta zpt+1 1a1e : 08 php ;flags after load/store sequence 1a1f : 49c3 eor #$c3 1a21 : c514 cmp zp1+1 ;test result trap_ne 1a23 : d0fe > bne * ;failed not equal (non zero) 1a25 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1a26 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1a28 : cd1d02 cmp fLDx+1 ;test flags trap_ne 1a2b : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1a2d : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1a2f : 48 > pha ;use stack to load status 1a30 : 28 > plp 1a31 : ad1902 lda abs1+2 1a34 : 08 php ;test stores do not alter flags 1a35 : 49c3 eor #$c3 1a37 : 28 plp 1a38 : 850e sta zpt+2 1a3a : 08 php ;flags after load/store sequence 1a3b : 49c3 eor #$c3 1a3d : c515 cmp zp1+2 ;test result trap_ne 1a3f : d0fe > bne * ;failed not equal (non zero) 1a41 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1a42 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1a44 : cd1e02 cmp fLDx+2 ;test flags trap_ne 1a47 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1a49 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1a4b : 48 > pha ;use stack to load status 1a4c : 28 > plp 1a4d : ad1a02 lda abs1+3 1a50 : 08 php ;test stores do not alter flags 1a51 : 49c3 eor #$c3 1a53 : 28 plp 1a54 : 850f sta zpt+3 1a56 : 08 php ;flags after load/store sequence 1a57 : 49c3 eor #$c3 1a59 : c516 cmp zp1+3 ;test result trap_ne 1a5b : d0fe > bne * ;failed not equal (non zero) 1a5d : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1a5e : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1a60 : cd1f02 cmp fLDx+3 ;test flags trap_ne 1a63 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1a65 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1a67 : 48 > pha ;use stack to load status 1a68 : 28 > plp 1a69 : a9c3 lda #$c3 1a6b : 08 php 1a6c : cd1702 cmp abs1 ;test result trap_ne 1a6f : d0fe > bne * ;failed not equal (non zero) 1a71 : 68 pla ;load status eor_flag 0 1a72 : 4930 > eor #0|fao ;invert expected flags + always on bits 1a74 : cd1c02 cmp fLDx ;test flags trap_ne 1a77 : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1a79 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1a7b : 48 > pha ;use stack to load status 1a7c : 28 > plp 1a7d : a982 lda #$82 1a7f : 08 php 1a80 : cd1802 cmp abs1+1 ;test result trap_ne 1a83 : d0fe > bne * ;failed not equal (non zero) 1a85 : 68 pla ;load status eor_flag 0 1a86 : 4930 > eor #0|fao ;invert expected flags + always on bits 1a88 : cd1d02 cmp fLDx+1 ;test flags trap_ne 1a8b : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1a8d : a900 > lda #0 ;allow test to change I-flag (no mask) > 1a8f : 48 > pha ;use stack to load status 1a90 : 28 > plp 1a91 : a941 lda #$41 1a93 : 08 php 1a94 : cd1902 cmp abs1+2 ;test result trap_ne 1a97 : d0fe > bne * ;failed not equal (non zero) 1a99 : 68 pla ;load status eor_flag 0 1a9a : 4930 > eor #0|fao ;invert expected flags + always on bits 1a9c : cd1e02 cmp fLDx+2 ;test flags trap_ne 1a9f : d0fe > bne * ;failed not equal (non zero) set_stat 0 > load_flag 0 1aa1 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1aa3 : 48 > pha ;use stack to load status 1aa4 : 28 > plp 1aa5 : a900 lda #0 1aa7 : 08 php 1aa8 : cd1a02 cmp abs1+3 ;test result trap_ne 1aab : d0fe > bne * ;failed not equal (non zero) 1aad : 68 pla ;load status eor_flag 0 1aae : 4930 > eor #0|fao ;invert expected flags + always on bits 1ab0 : cd1f02 cmp fLDx+3 ;test flags trap_ne 1ab3 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1ab5 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1ab7 : 48 > pha ;use stack to load status 1ab8 : 28 > plp 1ab9 : a9c3 lda #$c3 1abb : 08 php 1abc : cd1702 cmp abs1 ;test result trap_ne 1abf : d0fe > bne * ;failed not equal (non zero) 1ac1 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1ac2 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1ac4 : cd1c02 cmp fLDx ;test flags trap_ne 1ac7 : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1ac9 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1acb : 48 > pha ;use stack to load status 1acc : 28 > plp 1acd : a982 lda #$82 1acf : 08 php 1ad0 : cd1802 cmp abs1+1 ;test result trap_ne 1ad3 : d0fe > bne * ;failed not equal (non zero) 1ad5 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1ad6 : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1ad8 : cd1d02 cmp fLDx+1 ;test flags trap_ne 1adb : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1add : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1adf : 48 > pha ;use stack to load status 1ae0 : 28 > plp 1ae1 : a941 lda #$41 1ae3 : 08 php 1ae4 : cd1902 cmp abs1+2 ;test result trap_ne 1ae7 : d0fe > bne * ;failed not equal (non zero) 1ae9 : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1aea : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1aec : cd1e02 cmp fLDx+2 ;test flags trap_ne 1aef : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 1af1 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1af3 : 48 > pha ;use stack to load status 1af4 : 28 > plp 1af5 : a900 lda #0 1af7 : 08 php 1af8 : cd1a02 cmp abs1+3 ;test result trap_ne 1afb : d0fe > bne * ;failed not equal (non zero) 1afd : 68 pla ;load status eor_flag lo~fnz ;mask bits not altered 1afe : 497d > eor #lo~fnz |fao ;invert expected flags + always on bits 1b00 : cd1f02 cmp fLDx+3 ;test flags trap_ne 1b03 : d0fe > bne * ;failed not equal (non zero) 1b05 : a200 ldx #0 1b07 : a50c lda zpt 1b09 : 49c3 eor #$c3 1b0b : c513 cmp zp1 trap_ne ;store to zp data 1b0d : d0fe > bne * ;failed not equal (non zero) 1b0f : 860c stx zpt ;clear 1b11 : ad0302 lda abst 1b14 : 49c3 eor #$c3 1b16 : cd1702 cmp abs1 trap_ne ;store to abs data 1b19 : d0fe > bne * ;failed not equal (non zero) 1b1b : 8e0302 stx abst ;clear 1b1e : a50d lda zpt+1 1b20 : 49c3 eor #$c3 1b22 : c514 cmp zp1+1 trap_ne ;store to zp data 1b24 : d0fe > bne * ;failed not equal (non zero) 1b26 : 860d stx zpt+1 ;clear 1b28 : ad0402 lda abst+1 1b2b : 49c3 eor #$c3 1b2d : cd1802 cmp abs1+1 trap_ne ;store to abs data 1b30 : d0fe > bne * ;failed not equal (non zero) 1b32 : 8e0402 stx abst+1 ;clear 1b35 : a50e lda zpt+2 1b37 : 49c3 eor #$c3 1b39 : c515 cmp zp1+2 trap_ne ;store to zp data 1b3b : d0fe > bne * ;failed not equal (non zero) 1b3d : 860e stx zpt+2 ;clear 1b3f : ad0502 lda abst+2 1b42 : 49c3 eor #$c3 1b44 : cd1902 cmp abs1+2 trap_ne ;store to abs data 1b47 : d0fe > bne * ;failed not equal (non zero) 1b49 : 8e0502 stx abst+2 ;clear 1b4c : a50f lda zpt+3 1b4e : 49c3 eor #$c3 1b50 : c516 cmp zp1+3 trap_ne ;store to zp data 1b52 : d0fe > bne * ;failed not equal (non zero) 1b54 : 860f stx zpt+3 ;clear 1b56 : ad0602 lda abst+3 1b59 : 49c3 eor #$c3 1b5b : cd1a02 cmp abs1+3 trap_ne ;store to abs data 1b5e : d0fe > bne * ;failed not equal (non zero) 1b60 : 8e0602 stx abst+3 ;clear next_test 1b63 : ad0002 > lda test_case ;previous test 1b66 : c918 > cmp #test_num > trap_ne ;test is out of sequence 1b68 : d0fe > bne * ;failed not equal (non zero) > 0019 = >test_num = test_num + 1 1b6a : a919 > lda #test_num ;*** next tests' number 1b6c : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; testing bit test & compares BIT CPX CPY CMP all addressing modes ; BIT - zp / abs set_a $ff,0 > load_flag 0 1b6f : a900 > lda #0 ;allow test to change I-flag (no mask) > 1b71 : 48 > pha ;use stack to load status 1b72 : a9ff > lda #$ff ;precharge accu 1b74 : 28 > plp 1b75 : 2416 bit zp1+3 ;00 - should set Z / clear NV tst_a $ff,fz 1b77 : 08 > php ;save flags 1b78 : c9ff > cmp #$ff ;test result > trap_ne 1b7a : d0fe > bne * ;failed not equal (non zero) > 1b7c : 68 > pla ;load status 1b7d : 48 > pha > cmp_flag fz 1b7e : c932 > cmp #(fz |fao)&m8 ;expected flags + always on bits > > trap_ne 1b80 : d0fe > bne * ;failed not equal (non zero) > 1b82 : 28 > plp ;restore status set_a 1,0 > load_flag 0 1b83 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1b85 : 48 > pha ;use stack to load status 1b86 : a901 > lda #1 ;precharge accu 1b88 : 28 > plp 1b89 : 2415 bit zp1+2 ;41 - should set V (M6) / clear NZ tst_a 1,fv 1b8b : 08 > php ;save flags 1b8c : c901 > cmp #1 ;test result > trap_ne 1b8e : d0fe > bne * ;failed not equal (non zero) > 1b90 : 68 > pla ;load status 1b91 : 48 > pha > cmp_flag fv 1b92 : c970 > cmp #(fv|fao)&m8 ;expected flags + always on bits > > trap_ne 1b94 : d0fe > bne * ;failed not equal (non zero) > 1b96 : 28 > plp ;restore status set_a 1,0 > load_flag 0 1b97 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1b99 : 48 > pha ;use stack to load status 1b9a : a901 > lda #1 ;precharge accu 1b9c : 28 > plp 1b9d : 2414 bit zp1+1 ;82 - should set N (M7) & Z / clear V tst_a 1,fnz 1b9f : 08 > php ;save flags 1ba0 : c901 > cmp #1 ;test result > trap_ne 1ba2 : d0fe > bne * ;failed not equal (non zero) > 1ba4 : 68 > pla ;load status 1ba5 : 48 > pha > cmp_flag fnz 1ba6 : c9b2 > cmp #(fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1ba8 : d0fe > bne * ;failed not equal (non zero) > 1baa : 28 > plp ;restore status set_a 1,0 > load_flag 0 1bab : a900 > lda #0 ;allow test to change I-flag (no mask) > 1bad : 48 > pha ;use stack to load status 1bae : a901 > lda #1 ;precharge accu 1bb0 : 28 > plp 1bb1 : 2413 bit zp1 ;c3 - should set N (M7) & V (M6) / clear Z tst_a 1,fnv 1bb3 : 08 > php ;save flags 1bb4 : c901 > cmp #1 ;test result > trap_ne 1bb6 : d0fe > bne * ;failed not equal (non zero) > 1bb8 : 68 > pla ;load status 1bb9 : 48 > pha > cmp_flag fnv 1bba : c9f0 > cmp #(fnv|fao)&m8 ;expected flags + always on bits > > trap_ne 1bbc : d0fe > bne * ;failed not equal (non zero) > 1bbe : 28 > plp ;restore status set_a $ff,$ff > load_flag $ff 1bbf : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1bc1 : 48 > pha ;use stack to load status 1bc2 : a9ff > lda #$ff ;precharge accu 1bc4 : 28 > plp 1bc5 : 2416 bit zp1+3 ;00 - should set Z / clear NV tst_a $ff,~fnv 1bc7 : 08 > php ;save flags 1bc8 : c9ff > cmp #$ff ;test result > trap_ne 1bca : d0fe > bne * ;failed not equal (non zero) > 1bcc : 68 > pla ;load status 1bcd : 48 > pha > cmp_flag ~fnv 1bce : c93f > cmp #(~fnv |fao)&m8 ;expected flags + always on bits > > trap_ne 1bd0 : d0fe > bne * ;failed not equal (non zero) > 1bd2 : 28 > plp ;restore status set_a 1,$ff > load_flag $ff 1bd3 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1bd5 : 48 > pha ;use stack to load status 1bd6 : a901 > lda #1 ;precharge accu 1bd8 : 28 > plp 1bd9 : 2415 bit zp1+2 ;41 - should set V (M6) / clear NZ tst_a 1,~fnz 1bdb : 08 > php ;save flags 1bdc : c901 > cmp #1 ;test result > trap_ne 1bde : d0fe > bne * ;failed not equal (non zero) > 1be0 : 68 > pla ;load status 1be1 : 48 > pha > cmp_flag ~fnz 1be2 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1be4 : d0fe > bne * ;failed not equal (non zero) > 1be6 : 28 > plp ;restore status set_a 1,$ff > load_flag $ff 1be7 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1be9 : 48 > pha ;use stack to load status 1bea : a901 > lda #1 ;precharge accu 1bec : 28 > plp 1bed : 2414 bit zp1+1 ;82 - should set N (M7) & Z / clear V tst_a 1,~fv 1bef : 08 > php ;save flags 1bf0 : c901 > cmp #1 ;test result > trap_ne 1bf2 : d0fe > bne * ;failed not equal (non zero) > 1bf4 : 68 > pla ;load status 1bf5 : 48 > pha > cmp_flag ~fv 1bf6 : c9bf > cmp #(~fv|fao)&m8 ;expected flags + always on bits > > trap_ne 1bf8 : d0fe > bne * ;failed not equal (non zero) > 1bfa : 28 > plp ;restore status set_a 1,$ff > load_flag $ff 1bfb : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1bfd : 48 > pha ;use stack to load status 1bfe : a901 > lda #1 ;precharge accu 1c00 : 28 > plp 1c01 : 2413 bit zp1 ;c3 - should set N (M7) & V (M6) / clear Z tst_a 1,~fz 1c03 : 08 > php ;save flags 1c04 : c901 > cmp #1 ;test result > trap_ne 1c06 : d0fe > bne * ;failed not equal (non zero) > 1c08 : 68 > pla ;load status 1c09 : 48 > pha > cmp_flag ~fz 1c0a : c9fd > cmp #(~fz|fao)&m8 ;expected flags + always on bits > > trap_ne 1c0c : d0fe > bne * ;failed not equal (non zero) > 1c0e : 28 > plp ;restore status set_a $ff,0 > load_flag 0 1c0f : a900 > lda #0 ;allow test to change I-flag (no mask) > 1c11 : 48 > pha ;use stack to load status 1c12 : a9ff > lda #$ff ;precharge accu 1c14 : 28 > plp 1c15 : 2c1a02 bit abs1+3 ;00 - should set Z / clear NV tst_a $ff,fz 1c18 : 08 > php ;save flags 1c19 : c9ff > cmp #$ff ;test result > trap_ne 1c1b : d0fe > bne * ;failed not equal (non zero) > 1c1d : 68 > pla ;load status 1c1e : 48 > pha > cmp_flag fz 1c1f : c932 > cmp #(fz |fao)&m8 ;expected flags + always on bits > > trap_ne 1c21 : d0fe > bne * ;failed not equal (non zero) > 1c23 : 28 > plp ;restore status set_a 1,0 > load_flag 0 1c24 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1c26 : 48 > pha ;use stack to load status 1c27 : a901 > lda #1 ;precharge accu 1c29 : 28 > plp 1c2a : 2c1902 bit abs1+2 ;41 - should set V (M6) / clear NZ tst_a 1,fv 1c2d : 08 > php ;save flags 1c2e : c901 > cmp #1 ;test result > trap_ne 1c30 : d0fe > bne * ;failed not equal (non zero) > 1c32 : 68 > pla ;load status 1c33 : 48 > pha > cmp_flag fv 1c34 : c970 > cmp #(fv|fao)&m8 ;expected flags + always on bits > > trap_ne 1c36 : d0fe > bne * ;failed not equal (non zero) > 1c38 : 28 > plp ;restore status set_a 1,0 > load_flag 0 1c39 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1c3b : 48 > pha ;use stack to load status 1c3c : a901 > lda #1 ;precharge accu 1c3e : 28 > plp 1c3f : 2c1802 bit abs1+1 ;82 - should set N (M7) & Z / clear V tst_a 1,fnz 1c42 : 08 > php ;save flags 1c43 : c901 > cmp #1 ;test result > trap_ne 1c45 : d0fe > bne * ;failed not equal (non zero) > 1c47 : 68 > pla ;load status 1c48 : 48 > pha > cmp_flag fnz 1c49 : c9b2 > cmp #(fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1c4b : d0fe > bne * ;failed not equal (non zero) > 1c4d : 28 > plp ;restore status set_a 1,0 > load_flag 0 1c4e : a900 > lda #0 ;allow test to change I-flag (no mask) > 1c50 : 48 > pha ;use stack to load status 1c51 : a901 > lda #1 ;precharge accu 1c53 : 28 > plp 1c54 : 2c1702 bit abs1 ;c3 - should set N (M7) & V (M6) / clear Z tst_a 1,fnv 1c57 : 08 > php ;save flags 1c58 : c901 > cmp #1 ;test result > trap_ne 1c5a : d0fe > bne * ;failed not equal (non zero) > 1c5c : 68 > pla ;load status 1c5d : 48 > pha > cmp_flag fnv 1c5e : c9f0 > cmp #(fnv|fao)&m8 ;expected flags + always on bits > > trap_ne 1c60 : d0fe > bne * ;failed not equal (non zero) > 1c62 : 28 > plp ;restore status set_a $ff,$ff > load_flag $ff 1c63 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1c65 : 48 > pha ;use stack to load status 1c66 : a9ff > lda #$ff ;precharge accu 1c68 : 28 > plp 1c69 : 2c1a02 bit abs1+3 ;00 - should set Z / clear NV tst_a $ff,~fnv 1c6c : 08 > php ;save flags 1c6d : c9ff > cmp #$ff ;test result > trap_ne 1c6f : d0fe > bne * ;failed not equal (non zero) > 1c71 : 68 > pla ;load status 1c72 : 48 > pha > cmp_flag ~fnv 1c73 : c93f > cmp #(~fnv |fao)&m8 ;expected flags + always on bits > > trap_ne 1c75 : d0fe > bne * ;failed not equal (non zero) > 1c77 : 28 > plp ;restore status set_a 1,$ff > load_flag $ff 1c78 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1c7a : 48 > pha ;use stack to load status 1c7b : a901 > lda #1 ;precharge accu 1c7d : 28 > plp 1c7e : 2c1902 bit abs1+2 ;41 - should set V (M6) / clear NZ tst_a 1,~fnz 1c81 : 08 > php ;save flags 1c82 : c901 > cmp #1 ;test result > trap_ne 1c84 : d0fe > bne * ;failed not equal (non zero) > 1c86 : 68 > pla ;load status 1c87 : 48 > pha > cmp_flag ~fnz 1c88 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1c8a : d0fe > bne * ;failed not equal (non zero) > 1c8c : 28 > plp ;restore status set_a 1,$ff > load_flag $ff 1c8d : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1c8f : 48 > pha ;use stack to load status 1c90 : a901 > lda #1 ;precharge accu 1c92 : 28 > plp 1c93 : 2c1802 bit abs1+1 ;82 - should set N (M7) & Z / clear V tst_a 1,~fv 1c96 : 08 > php ;save flags 1c97 : c901 > cmp #1 ;test result > trap_ne 1c99 : d0fe > bne * ;failed not equal (non zero) > 1c9b : 68 > pla ;load status 1c9c : 48 > pha > cmp_flag ~fv 1c9d : c9bf > cmp #(~fv|fao)&m8 ;expected flags + always on bits > > trap_ne 1c9f : d0fe > bne * ;failed not equal (non zero) > 1ca1 : 28 > plp ;restore status set_a 1,$ff > load_flag $ff 1ca2 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1ca4 : 48 > pha ;use stack to load status 1ca5 : a901 > lda #1 ;precharge accu 1ca7 : 28 > plp 1ca8 : 2c1702 bit abs1 ;c3 - should set N (M7) & V (M6) / clear Z tst_a 1,~fz 1cab : 08 > php ;save flags 1cac : c901 > cmp #1 ;test result > trap_ne 1cae : d0fe > bne * ;failed not equal (non zero) > 1cb0 : 68 > pla ;load status 1cb1 : 48 > pha > cmp_flag ~fz 1cb2 : c9fd > cmp #(~fz|fao)&m8 ;expected flags + always on bits > > trap_ne 1cb4 : d0fe > bne * ;failed not equal (non zero) > 1cb6 : 28 > plp ;restore status next_test 1cb7 : ad0002 > lda test_case ;previous test 1cba : c919 > cmp #test_num > trap_ne ;test is out of sequence 1cbc : d0fe > bne * ;failed not equal (non zero) > 001a = >test_num = test_num + 1 1cbe : a91a > lda #test_num ;*** next tests' number 1cc0 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; CPX - zp / abs / # set_x $80,0 > load_flag 0 1cc3 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1cc5 : 48 > pha ;use stack to load status 1cc6 : a280 > ldx #$80 ;precharge index x 1cc8 : 28 > plp 1cc9 : e417 cpx zp7f tst_stat fc 1ccb : 08 > php ;save status 1ccc : 68 > pla ;use stack to retrieve status 1ccd : 48 > pha > cmp_flag fc 1cce : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 1cd0 : d0fe > bne * ;failed not equal (non zero) > 1cd2 : 28 > plp ;restore status 1cd3 : ca dex 1cd4 : e417 cpx zp7f tst_stat fzc 1cd6 : 08 > php ;save status 1cd7 : 68 > pla ;use stack to retrieve status 1cd8 : 48 > pha > cmp_flag fzc 1cd9 : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1cdb : d0fe > bne * ;failed not equal (non zero) > 1cdd : 28 > plp ;restore status 1cde : ca dex 1cdf : e417 cpx zp7f tst_x $7e,fn 1ce1 : 08 > php ;save flags 1ce2 : e07e > cpx #$7e ;test result > trap_ne 1ce4 : d0fe > bne * ;failed not equal (non zero) > 1ce6 : 68 > pla ;load status 1ce7 : 48 > pha > cmp_flag fn 1ce8 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1cea : d0fe > bne * ;failed not equal (non zero) > 1cec : 28 > plp ;restore status set_x $80,$ff > load_flag $ff 1ced : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1cef : 48 > pha ;use stack to load status 1cf0 : a280 > ldx #$80 ;precharge index x 1cf2 : 28 > plp 1cf3 : e417 cpx zp7f tst_stat ~fnz 1cf5 : 08 > php ;save status 1cf6 : 68 > pla ;use stack to retrieve status 1cf7 : 48 > pha > cmp_flag ~fnz 1cf8 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1cfa : d0fe > bne * ;failed not equal (non zero) > 1cfc : 28 > plp ;restore status 1cfd : ca dex 1cfe : e417 cpx zp7f tst_stat ~fn 1d00 : 08 > php ;save status 1d01 : 68 > pla ;use stack to retrieve status 1d02 : 48 > pha > cmp_flag ~fn 1d03 : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1d05 : d0fe > bne * ;failed not equal (non zero) > 1d07 : 28 > plp ;restore status 1d08 : ca dex 1d09 : e417 cpx zp7f tst_x $7e,~fzc 1d0b : 08 > php ;save flags 1d0c : e07e > cpx #$7e ;test result > trap_ne 1d0e : d0fe > bne * ;failed not equal (non zero) > 1d10 : 68 > pla ;load status 1d11 : 48 > pha > cmp_flag ~fzc 1d12 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1d14 : d0fe > bne * ;failed not equal (non zero) > 1d16 : 28 > plp ;restore status set_x $80,0 > load_flag 0 1d17 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1d19 : 48 > pha ;use stack to load status 1d1a : a280 > ldx #$80 ;precharge index x 1d1c : 28 > plp 1d1d : ec1b02 cpx abs7f tst_stat fc 1d20 : 08 > php ;save status 1d21 : 68 > pla ;use stack to retrieve status 1d22 : 48 > pha > cmp_flag fc 1d23 : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 1d25 : d0fe > bne * ;failed not equal (non zero) > 1d27 : 28 > plp ;restore status 1d28 : ca dex 1d29 : ec1b02 cpx abs7f tst_stat fzc 1d2c : 08 > php ;save status 1d2d : 68 > pla ;use stack to retrieve status 1d2e : 48 > pha > cmp_flag fzc 1d2f : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1d31 : d0fe > bne * ;failed not equal (non zero) > 1d33 : 28 > plp ;restore status 1d34 : ca dex 1d35 : ec1b02 cpx abs7f tst_x $7e,fn 1d38 : 08 > php ;save flags 1d39 : e07e > cpx #$7e ;test result > trap_ne 1d3b : d0fe > bne * ;failed not equal (non zero) > 1d3d : 68 > pla ;load status 1d3e : 48 > pha > cmp_flag fn 1d3f : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1d41 : d0fe > bne * ;failed not equal (non zero) > 1d43 : 28 > plp ;restore status set_x $80,$ff > load_flag $ff 1d44 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1d46 : 48 > pha ;use stack to load status 1d47 : a280 > ldx #$80 ;precharge index x 1d49 : 28 > plp 1d4a : ec1b02 cpx abs7f tst_stat ~fnz 1d4d : 08 > php ;save status 1d4e : 68 > pla ;use stack to retrieve status 1d4f : 48 > pha > cmp_flag ~fnz 1d50 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1d52 : d0fe > bne * ;failed not equal (non zero) > 1d54 : 28 > plp ;restore status 1d55 : ca dex 1d56 : ec1b02 cpx abs7f tst_stat ~fn 1d59 : 08 > php ;save status 1d5a : 68 > pla ;use stack to retrieve status 1d5b : 48 > pha > cmp_flag ~fn 1d5c : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1d5e : d0fe > bne * ;failed not equal (non zero) > 1d60 : 28 > plp ;restore status 1d61 : ca dex 1d62 : ec1b02 cpx abs7f tst_x $7e,~fzc 1d65 : 08 > php ;save flags 1d66 : e07e > cpx #$7e ;test result > trap_ne 1d68 : d0fe > bne * ;failed not equal (non zero) > 1d6a : 68 > pla ;load status 1d6b : 48 > pha > cmp_flag ~fzc 1d6c : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1d6e : d0fe > bne * ;failed not equal (non zero) > 1d70 : 28 > plp ;restore status set_x $80,0 > load_flag 0 1d71 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1d73 : 48 > pha ;use stack to load status 1d74 : a280 > ldx #$80 ;precharge index x 1d76 : 28 > plp 1d77 : e07f cpx #$7f tst_stat fc 1d79 : 08 > php ;save status 1d7a : 68 > pla ;use stack to retrieve status 1d7b : 48 > pha > cmp_flag fc 1d7c : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 1d7e : d0fe > bne * ;failed not equal (non zero) > 1d80 : 28 > plp ;restore status 1d81 : ca dex 1d82 : e07f cpx #$7f tst_stat fzc 1d84 : 08 > php ;save status 1d85 : 68 > pla ;use stack to retrieve status 1d86 : 48 > pha > cmp_flag fzc 1d87 : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1d89 : d0fe > bne * ;failed not equal (non zero) > 1d8b : 28 > plp ;restore status 1d8c : ca dex 1d8d : e07f cpx #$7f tst_x $7e,fn 1d8f : 08 > php ;save flags 1d90 : e07e > cpx #$7e ;test result > trap_ne 1d92 : d0fe > bne * ;failed not equal (non zero) > 1d94 : 68 > pla ;load status 1d95 : 48 > pha > cmp_flag fn 1d96 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1d98 : d0fe > bne * ;failed not equal (non zero) > 1d9a : 28 > plp ;restore status set_x $80,$ff > load_flag $ff 1d9b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1d9d : 48 > pha ;use stack to load status 1d9e : a280 > ldx #$80 ;precharge index x 1da0 : 28 > plp 1da1 : e07f cpx #$7f tst_stat ~fnz 1da3 : 08 > php ;save status 1da4 : 68 > pla ;use stack to retrieve status 1da5 : 48 > pha > cmp_flag ~fnz 1da6 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1da8 : d0fe > bne * ;failed not equal (non zero) > 1daa : 28 > plp ;restore status 1dab : ca dex 1dac : e07f cpx #$7f tst_stat ~fn 1dae : 08 > php ;save status 1daf : 68 > pla ;use stack to retrieve status 1db0 : 48 > pha > cmp_flag ~fn 1db1 : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1db3 : d0fe > bne * ;failed not equal (non zero) > 1db5 : 28 > plp ;restore status 1db6 : ca dex 1db7 : e07f cpx #$7f tst_x $7e,~fzc 1db9 : 08 > php ;save flags 1dba : e07e > cpx #$7e ;test result > trap_ne 1dbc : d0fe > bne * ;failed not equal (non zero) > 1dbe : 68 > pla ;load status 1dbf : 48 > pha > cmp_flag ~fzc 1dc0 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1dc2 : d0fe > bne * ;failed not equal (non zero) > 1dc4 : 28 > plp ;restore status next_test 1dc5 : ad0002 > lda test_case ;previous test 1dc8 : c91a > cmp #test_num > trap_ne ;test is out of sequence 1dca : d0fe > bne * ;failed not equal (non zero) > 001b = >test_num = test_num + 1 1dcc : a91b > lda #test_num ;*** next tests' number 1dce : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; CPY - zp / abs / # set_y $80,0 > load_flag 0 1dd1 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1dd3 : 48 > pha ;use stack to load status 1dd4 : a080 > ldy #$80 ;precharge index y 1dd6 : 28 > plp 1dd7 : c417 cpy zp7f tst_stat fc 1dd9 : 08 > php ;save status 1dda : 68 > pla ;use stack to retrieve status 1ddb : 48 > pha > cmp_flag fc 1ddc : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 1dde : d0fe > bne * ;failed not equal (non zero) > 1de0 : 28 > plp ;restore status 1de1 : 88 dey 1de2 : c417 cpy zp7f tst_stat fzc 1de4 : 08 > php ;save status 1de5 : 68 > pla ;use stack to retrieve status 1de6 : 48 > pha > cmp_flag fzc 1de7 : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1de9 : d0fe > bne * ;failed not equal (non zero) > 1deb : 28 > plp ;restore status 1dec : 88 dey 1ded : c417 cpy zp7f tst_y $7e,fn 1def : 08 > php ;save flags 1df0 : c07e > cpy #$7e ;test result > trap_ne 1df2 : d0fe > bne * ;failed not equal (non zero) > 1df4 : 68 > pla ;load status 1df5 : 48 > pha > cmp_flag fn 1df6 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1df8 : d0fe > bne * ;failed not equal (non zero) > 1dfa : 28 > plp ;restore status set_y $80,$ff > load_flag $ff 1dfb : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1dfd : 48 > pha ;use stack to load status 1dfe : a080 > ldy #$80 ;precharge index y 1e00 : 28 > plp 1e01 : c417 cpy zp7f tst_stat ~fnz 1e03 : 08 > php ;save status 1e04 : 68 > pla ;use stack to retrieve status 1e05 : 48 > pha > cmp_flag ~fnz 1e06 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1e08 : d0fe > bne * ;failed not equal (non zero) > 1e0a : 28 > plp ;restore status 1e0b : 88 dey 1e0c : c417 cpy zp7f tst_stat ~fn 1e0e : 08 > php ;save status 1e0f : 68 > pla ;use stack to retrieve status 1e10 : 48 > pha > cmp_flag ~fn 1e11 : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1e13 : d0fe > bne * ;failed not equal (non zero) > 1e15 : 28 > plp ;restore status 1e16 : 88 dey 1e17 : c417 cpy zp7f tst_y $7e,~fzc 1e19 : 08 > php ;save flags 1e1a : c07e > cpy #$7e ;test result > trap_ne 1e1c : d0fe > bne * ;failed not equal (non zero) > 1e1e : 68 > pla ;load status 1e1f : 48 > pha > cmp_flag ~fzc 1e20 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1e22 : d0fe > bne * ;failed not equal (non zero) > 1e24 : 28 > plp ;restore status set_y $80,0 > load_flag 0 1e25 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1e27 : 48 > pha ;use stack to load status 1e28 : a080 > ldy #$80 ;precharge index y 1e2a : 28 > plp 1e2b : cc1b02 cpy abs7f tst_stat fc 1e2e : 08 > php ;save status 1e2f : 68 > pla ;use stack to retrieve status 1e30 : 48 > pha > cmp_flag fc 1e31 : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 1e33 : d0fe > bne * ;failed not equal (non zero) > 1e35 : 28 > plp ;restore status 1e36 : 88 dey 1e37 : cc1b02 cpy abs7f tst_stat fzc 1e3a : 08 > php ;save status 1e3b : 68 > pla ;use stack to retrieve status 1e3c : 48 > pha > cmp_flag fzc 1e3d : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1e3f : d0fe > bne * ;failed not equal (non zero) > 1e41 : 28 > plp ;restore status 1e42 : 88 dey 1e43 : cc1b02 cpy abs7f tst_y $7e,fn 1e46 : 08 > php ;save flags 1e47 : c07e > cpy #$7e ;test result > trap_ne 1e49 : d0fe > bne * ;failed not equal (non zero) > 1e4b : 68 > pla ;load status 1e4c : 48 > pha > cmp_flag fn 1e4d : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1e4f : d0fe > bne * ;failed not equal (non zero) > 1e51 : 28 > plp ;restore status set_y $80,$ff > load_flag $ff 1e52 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1e54 : 48 > pha ;use stack to load status 1e55 : a080 > ldy #$80 ;precharge index y 1e57 : 28 > plp 1e58 : cc1b02 cpy abs7f tst_stat ~fnz 1e5b : 08 > php ;save status 1e5c : 68 > pla ;use stack to retrieve status 1e5d : 48 > pha > cmp_flag ~fnz 1e5e : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1e60 : d0fe > bne * ;failed not equal (non zero) > 1e62 : 28 > plp ;restore status 1e63 : 88 dey 1e64 : cc1b02 cpy abs7f tst_stat ~fn 1e67 : 08 > php ;save status 1e68 : 68 > pla ;use stack to retrieve status 1e69 : 48 > pha > cmp_flag ~fn 1e6a : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1e6c : d0fe > bne * ;failed not equal (non zero) > 1e6e : 28 > plp ;restore status 1e6f : 88 dey 1e70 : cc1b02 cpy abs7f tst_y $7e,~fzc 1e73 : 08 > php ;save flags 1e74 : c07e > cpy #$7e ;test result > trap_ne 1e76 : d0fe > bne * ;failed not equal (non zero) > 1e78 : 68 > pla ;load status 1e79 : 48 > pha > cmp_flag ~fzc 1e7a : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1e7c : d0fe > bne * ;failed not equal (non zero) > 1e7e : 28 > plp ;restore status set_y $80,0 > load_flag 0 1e7f : a900 > lda #0 ;allow test to change I-flag (no mask) > 1e81 : 48 > pha ;use stack to load status 1e82 : a080 > ldy #$80 ;precharge index y 1e84 : 28 > plp 1e85 : c07f cpy #$7f tst_stat fc 1e87 : 08 > php ;save status 1e88 : 68 > pla ;use stack to retrieve status 1e89 : 48 > pha > cmp_flag fc 1e8a : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 1e8c : d0fe > bne * ;failed not equal (non zero) > 1e8e : 28 > plp ;restore status 1e8f : 88 dey 1e90 : c07f cpy #$7f tst_stat fzc 1e92 : 08 > php ;save status 1e93 : 68 > pla ;use stack to retrieve status 1e94 : 48 > pha > cmp_flag fzc 1e95 : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1e97 : d0fe > bne * ;failed not equal (non zero) > 1e99 : 28 > plp ;restore status 1e9a : 88 dey 1e9b : c07f cpy #$7f tst_y $7e,fn 1e9d : 08 > php ;save flags 1e9e : c07e > cpy #$7e ;test result > trap_ne 1ea0 : d0fe > bne * ;failed not equal (non zero) > 1ea2 : 68 > pla ;load status 1ea3 : 48 > pha > cmp_flag fn 1ea4 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1ea6 : d0fe > bne * ;failed not equal (non zero) > 1ea8 : 28 > plp ;restore status set_y $80,$ff > load_flag $ff 1ea9 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1eab : 48 > pha ;use stack to load status 1eac : a080 > ldy #$80 ;precharge index y 1eae : 28 > plp 1eaf : c07f cpy #$7f tst_stat ~fnz 1eb1 : 08 > php ;save status 1eb2 : 68 > pla ;use stack to retrieve status 1eb3 : 48 > pha > cmp_flag ~fnz 1eb4 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1eb6 : d0fe > bne * ;failed not equal (non zero) > 1eb8 : 28 > plp ;restore status 1eb9 : 88 dey 1eba : c07f cpy #$7f tst_stat ~fn 1ebc : 08 > php ;save status 1ebd : 68 > pla ;use stack to retrieve status 1ebe : 48 > pha > cmp_flag ~fn 1ebf : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1ec1 : d0fe > bne * ;failed not equal (non zero) > 1ec3 : 28 > plp ;restore status 1ec4 : 88 dey 1ec5 : c07f cpy #$7f tst_y $7e,~fzc 1ec7 : 08 > php ;save flags 1ec8 : c07e > cpy #$7e ;test result > trap_ne 1eca : d0fe > bne * ;failed not equal (non zero) > 1ecc : 68 > pla ;load status 1ecd : 48 > pha > cmp_flag ~fzc 1ece : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1ed0 : d0fe > bne * ;failed not equal (non zero) > 1ed2 : 28 > plp ;restore status next_test 1ed3 : ad0002 > lda test_case ;previous test 1ed6 : c91b > cmp #test_num > trap_ne ;test is out of sequence 1ed8 : d0fe > bne * ;failed not equal (non zero) > 001c = >test_num = test_num + 1 1eda : a91c > lda #test_num ;*** next tests' number 1edc : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; CMP - zp / abs / # set_a $80,0 > load_flag 0 1edf : a900 > lda #0 ;allow test to change I-flag (no mask) > 1ee1 : 48 > pha ;use stack to load status 1ee2 : a980 > lda #$80 ;precharge accu 1ee4 : 28 > plp 1ee5 : c517 cmp zp7f tst_a $80,fc 1ee7 : 08 > php ;save flags 1ee8 : c980 > cmp #$80 ;test result > trap_ne 1eea : d0fe > bne * ;failed not equal (non zero) > 1eec : 68 > pla ;load status 1eed : 48 > pha > cmp_flag fc 1eee : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 1ef0 : d0fe > bne * ;failed not equal (non zero) > 1ef2 : 28 > plp ;restore status set_a $7f,0 > load_flag 0 1ef3 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1ef5 : 48 > pha ;use stack to load status 1ef6 : a97f > lda #$7f ;precharge accu 1ef8 : 28 > plp 1ef9 : c517 cmp zp7f tst_a $7f,fzc 1efb : 08 > php ;save flags 1efc : c97f > cmp #$7f ;test result > trap_ne 1efe : d0fe > bne * ;failed not equal (non zero) > 1f00 : 68 > pla ;load status 1f01 : 48 > pha > cmp_flag fzc 1f02 : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1f04 : d0fe > bne * ;failed not equal (non zero) > 1f06 : 28 > plp ;restore status set_a $7e,0 > load_flag 0 1f07 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1f09 : 48 > pha ;use stack to load status 1f0a : a97e > lda #$7e ;precharge accu 1f0c : 28 > plp 1f0d : c517 cmp zp7f tst_a $7e,fn 1f0f : 08 > php ;save flags 1f10 : c97e > cmp #$7e ;test result > trap_ne 1f12 : d0fe > bne * ;failed not equal (non zero) > 1f14 : 68 > pla ;load status 1f15 : 48 > pha > cmp_flag fn 1f16 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1f18 : d0fe > bne * ;failed not equal (non zero) > 1f1a : 28 > plp ;restore status set_a $80,$ff > load_flag $ff 1f1b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1f1d : 48 > pha ;use stack to load status 1f1e : a980 > lda #$80 ;precharge accu 1f20 : 28 > plp 1f21 : c517 cmp zp7f tst_a $80,~fnz 1f23 : 08 > php ;save flags 1f24 : c980 > cmp #$80 ;test result > trap_ne 1f26 : d0fe > bne * ;failed not equal (non zero) > 1f28 : 68 > pla ;load status 1f29 : 48 > pha > cmp_flag ~fnz 1f2a : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1f2c : d0fe > bne * ;failed not equal (non zero) > 1f2e : 28 > plp ;restore status set_a $7f,$ff > load_flag $ff 1f2f : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1f31 : 48 > pha ;use stack to load status 1f32 : a97f > lda #$7f ;precharge accu 1f34 : 28 > plp 1f35 : c517 cmp zp7f tst_a $7f,~fn 1f37 : 08 > php ;save flags 1f38 : c97f > cmp #$7f ;test result > trap_ne 1f3a : d0fe > bne * ;failed not equal (non zero) > 1f3c : 68 > pla ;load status 1f3d : 48 > pha > cmp_flag ~fn 1f3e : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1f40 : d0fe > bne * ;failed not equal (non zero) > 1f42 : 28 > plp ;restore status set_a $7e,$ff > load_flag $ff 1f43 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1f45 : 48 > pha ;use stack to load status 1f46 : a97e > lda #$7e ;precharge accu 1f48 : 28 > plp 1f49 : c517 cmp zp7f tst_a $7e,~fzc 1f4b : 08 > php ;save flags 1f4c : c97e > cmp #$7e ;test result > trap_ne 1f4e : d0fe > bne * ;failed not equal (non zero) > 1f50 : 68 > pla ;load status 1f51 : 48 > pha > cmp_flag ~fzc 1f52 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1f54 : d0fe > bne * ;failed not equal (non zero) > 1f56 : 28 > plp ;restore status set_a $80,0 > load_flag 0 1f57 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1f59 : 48 > pha ;use stack to load status 1f5a : a980 > lda #$80 ;precharge accu 1f5c : 28 > plp 1f5d : cd1b02 cmp abs7f tst_a $80,fc 1f60 : 08 > php ;save flags 1f61 : c980 > cmp #$80 ;test result > trap_ne 1f63 : d0fe > bne * ;failed not equal (non zero) > 1f65 : 68 > pla ;load status 1f66 : 48 > pha > cmp_flag fc 1f67 : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 1f69 : d0fe > bne * ;failed not equal (non zero) > 1f6b : 28 > plp ;restore status set_a $7f,0 > load_flag 0 1f6c : a900 > lda #0 ;allow test to change I-flag (no mask) > 1f6e : 48 > pha ;use stack to load status 1f6f : a97f > lda #$7f ;precharge accu 1f71 : 28 > plp 1f72 : cd1b02 cmp abs7f tst_a $7f,fzc 1f75 : 08 > php ;save flags 1f76 : c97f > cmp #$7f ;test result > trap_ne 1f78 : d0fe > bne * ;failed not equal (non zero) > 1f7a : 68 > pla ;load status 1f7b : 48 > pha > cmp_flag fzc 1f7c : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1f7e : d0fe > bne * ;failed not equal (non zero) > 1f80 : 28 > plp ;restore status set_a $7e,0 > load_flag 0 1f81 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1f83 : 48 > pha ;use stack to load status 1f84 : a97e > lda #$7e ;precharge accu 1f86 : 28 > plp 1f87 : cd1b02 cmp abs7f tst_a $7e,fn 1f8a : 08 > php ;save flags 1f8b : c97e > cmp #$7e ;test result > trap_ne 1f8d : d0fe > bne * ;failed not equal (non zero) > 1f8f : 68 > pla ;load status 1f90 : 48 > pha > cmp_flag fn 1f91 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1f93 : d0fe > bne * ;failed not equal (non zero) > 1f95 : 28 > plp ;restore status set_a $80,$ff > load_flag $ff 1f96 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1f98 : 48 > pha ;use stack to load status 1f99 : a980 > lda #$80 ;precharge accu 1f9b : 28 > plp 1f9c : cd1b02 cmp abs7f tst_a $80,~fnz 1f9f : 08 > php ;save flags 1fa0 : c980 > cmp #$80 ;test result > trap_ne 1fa2 : d0fe > bne * ;failed not equal (non zero) > 1fa4 : 68 > pla ;load status 1fa5 : 48 > pha > cmp_flag ~fnz 1fa6 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 1fa8 : d0fe > bne * ;failed not equal (non zero) > 1faa : 28 > plp ;restore status set_a $7f,$ff > load_flag $ff 1fab : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1fad : 48 > pha ;use stack to load status 1fae : a97f > lda #$7f ;precharge accu 1fb0 : 28 > plp 1fb1 : cd1b02 cmp abs7f tst_a $7f,~fn 1fb4 : 08 > php ;save flags 1fb5 : c97f > cmp #$7f ;test result > trap_ne 1fb7 : d0fe > bne * ;failed not equal (non zero) > 1fb9 : 68 > pla ;load status 1fba : 48 > pha > cmp_flag ~fn 1fbb : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 1fbd : d0fe > bne * ;failed not equal (non zero) > 1fbf : 28 > plp ;restore status set_a $7e,$ff > load_flag $ff 1fc0 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 1fc2 : 48 > pha ;use stack to load status 1fc3 : a97e > lda #$7e ;precharge accu 1fc5 : 28 > plp 1fc6 : cd1b02 cmp abs7f tst_a $7e,~fzc 1fc9 : 08 > php ;save flags 1fca : c97e > cmp #$7e ;test result > trap_ne 1fcc : d0fe > bne * ;failed not equal (non zero) > 1fce : 68 > pla ;load status 1fcf : 48 > pha > cmp_flag ~fzc 1fd0 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1fd2 : d0fe > bne * ;failed not equal (non zero) > 1fd4 : 28 > plp ;restore status set_a $80,0 > load_flag 0 1fd5 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1fd7 : 48 > pha ;use stack to load status 1fd8 : a980 > lda #$80 ;precharge accu 1fda : 28 > plp 1fdb : c97f cmp #$7f tst_a $80,fc 1fdd : 08 > php ;save flags 1fde : c980 > cmp #$80 ;test result > trap_ne 1fe0 : d0fe > bne * ;failed not equal (non zero) > 1fe2 : 68 > pla ;load status 1fe3 : 48 > pha > cmp_flag fc 1fe4 : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 1fe6 : d0fe > bne * ;failed not equal (non zero) > 1fe8 : 28 > plp ;restore status set_a $7f,0 > load_flag 0 1fe9 : a900 > lda #0 ;allow test to change I-flag (no mask) > 1feb : 48 > pha ;use stack to load status 1fec : a97f > lda #$7f ;precharge accu 1fee : 28 > plp 1fef : c97f cmp #$7f tst_a $7f,fzc 1ff1 : 08 > php ;save flags 1ff2 : c97f > cmp #$7f ;test result > trap_ne 1ff4 : d0fe > bne * ;failed not equal (non zero) > 1ff6 : 68 > pla ;load status 1ff7 : 48 > pha > cmp_flag fzc 1ff8 : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 1ffa : d0fe > bne * ;failed not equal (non zero) > 1ffc : 28 > plp ;restore status set_a $7e,0 > load_flag 0 1ffd : a900 > lda #0 ;allow test to change I-flag (no mask) > 1fff : 48 > pha ;use stack to load status 2000 : a97e > lda #$7e ;precharge accu 2002 : 28 > plp 2003 : c97f cmp #$7f tst_a $7e,fn 2005 : 08 > php ;save flags 2006 : c97e > cmp #$7e ;test result > trap_ne 2008 : d0fe > bne * ;failed not equal (non zero) > 200a : 68 > pla ;load status 200b : 48 > pha > cmp_flag fn 200c : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 200e : d0fe > bne * ;failed not equal (non zero) > 2010 : 28 > plp ;restore status set_a $80,$ff > load_flag $ff 2011 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2013 : 48 > pha ;use stack to load status 2014 : a980 > lda #$80 ;precharge accu 2016 : 28 > plp 2017 : c97f cmp #$7f tst_a $80,~fnz 2019 : 08 > php ;save flags 201a : c980 > cmp #$80 ;test result > trap_ne 201c : d0fe > bne * ;failed not equal (non zero) > 201e : 68 > pla ;load status 201f : 48 > pha > cmp_flag ~fnz 2020 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 2022 : d0fe > bne * ;failed not equal (non zero) > 2024 : 28 > plp ;restore status set_a $7f,$ff > load_flag $ff 2025 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2027 : 48 > pha ;use stack to load status 2028 : a97f > lda #$7f ;precharge accu 202a : 28 > plp 202b : c97f cmp #$7f tst_a $7f,~fn 202d : 08 > php ;save flags 202e : c97f > cmp #$7f ;test result > trap_ne 2030 : d0fe > bne * ;failed not equal (non zero) > 2032 : 68 > pla ;load status 2033 : 48 > pha > cmp_flag ~fn 2034 : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 2036 : d0fe > bne * ;failed not equal (non zero) > 2038 : 28 > plp ;restore status set_a $7e,$ff > load_flag $ff 2039 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 203b : 48 > pha ;use stack to load status 203c : a97e > lda #$7e ;precharge accu 203e : 28 > plp 203f : c97f cmp #$7f tst_a $7e,~fzc 2041 : 08 > php ;save flags 2042 : c97e > cmp #$7e ;test result > trap_ne 2044 : d0fe > bne * ;failed not equal (non zero) > 2046 : 68 > pla ;load status 2047 : 48 > pha > cmp_flag ~fzc 2048 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 204a : d0fe > bne * ;failed not equal (non zero) > 204c : 28 > plp ;restore status 204d : a204 ldx #4 ;with indexing by X set_a $80,0 > load_flag 0 204f : a900 > lda #0 ;allow test to change I-flag (no mask) > 2051 : 48 > pha ;use stack to load status 2052 : a980 > lda #$80 ;precharge accu 2054 : 28 > plp 2055 : d513 cmp zp1,x tst_a $80,fc 2057 : 08 > php ;save flags 2058 : c980 > cmp #$80 ;test result > trap_ne 205a : d0fe > bne * ;failed not equal (non zero) > 205c : 68 > pla ;load status 205d : 48 > pha > cmp_flag fc 205e : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 2060 : d0fe > bne * ;failed not equal (non zero) > 2062 : 28 > plp ;restore status set_a $7f,0 > load_flag 0 2063 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2065 : 48 > pha ;use stack to load status 2066 : a97f > lda #$7f ;precharge accu 2068 : 28 > plp 2069 : d513 cmp zp1,x tst_a $7f,fzc 206b : 08 > php ;save flags 206c : c97f > cmp #$7f ;test result > trap_ne 206e : d0fe > bne * ;failed not equal (non zero) > 2070 : 68 > pla ;load status 2071 : 48 > pha > cmp_flag fzc 2072 : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 2074 : d0fe > bne * ;failed not equal (non zero) > 2076 : 28 > plp ;restore status set_a $7e,0 > load_flag 0 2077 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2079 : 48 > pha ;use stack to load status 207a : a97e > lda #$7e ;precharge accu 207c : 28 > plp 207d : d513 cmp zp1,x tst_a $7e,fn 207f : 08 > php ;save flags 2080 : c97e > cmp #$7e ;test result > trap_ne 2082 : d0fe > bne * ;failed not equal (non zero) > 2084 : 68 > pla ;load status 2085 : 48 > pha > cmp_flag fn 2086 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 2088 : d0fe > bne * ;failed not equal (non zero) > 208a : 28 > plp ;restore status set_a $80,$ff > load_flag $ff 208b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 208d : 48 > pha ;use stack to load status 208e : a980 > lda #$80 ;precharge accu 2090 : 28 > plp 2091 : d513 cmp zp1,x tst_a $80,~fnz 2093 : 08 > php ;save flags 2094 : c980 > cmp #$80 ;test result > trap_ne 2096 : d0fe > bne * ;failed not equal (non zero) > 2098 : 68 > pla ;load status 2099 : 48 > pha > cmp_flag ~fnz 209a : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 209c : d0fe > bne * ;failed not equal (non zero) > 209e : 28 > plp ;restore status set_a $7f,$ff > load_flag $ff 209f : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 20a1 : 48 > pha ;use stack to load status 20a2 : a97f > lda #$7f ;precharge accu 20a4 : 28 > plp 20a5 : d513 cmp zp1,x tst_a $7f,~fn 20a7 : 08 > php ;save flags 20a8 : c97f > cmp #$7f ;test result > trap_ne 20aa : d0fe > bne * ;failed not equal (non zero) > 20ac : 68 > pla ;load status 20ad : 48 > pha > cmp_flag ~fn 20ae : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 20b0 : d0fe > bne * ;failed not equal (non zero) > 20b2 : 28 > plp ;restore status set_a $7e,$ff > load_flag $ff 20b3 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 20b5 : 48 > pha ;use stack to load status 20b6 : a97e > lda #$7e ;precharge accu 20b8 : 28 > plp 20b9 : d513 cmp zp1,x tst_a $7e,~fzc 20bb : 08 > php ;save flags 20bc : c97e > cmp #$7e ;test result > trap_ne 20be : d0fe > bne * ;failed not equal (non zero) > 20c0 : 68 > pla ;load status 20c1 : 48 > pha > cmp_flag ~fzc 20c2 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 20c4 : d0fe > bne * ;failed not equal (non zero) > 20c6 : 28 > plp ;restore status set_a $80,0 > load_flag 0 20c7 : a900 > lda #0 ;allow test to change I-flag (no mask) > 20c9 : 48 > pha ;use stack to load status 20ca : a980 > lda #$80 ;precharge accu 20cc : 28 > plp 20cd : dd1702 cmp abs1,x tst_a $80,fc 20d0 : 08 > php ;save flags 20d1 : c980 > cmp #$80 ;test result > trap_ne 20d3 : d0fe > bne * ;failed not equal (non zero) > 20d5 : 68 > pla ;load status 20d6 : 48 > pha > cmp_flag fc 20d7 : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 20d9 : d0fe > bne * ;failed not equal (non zero) > 20db : 28 > plp ;restore status set_a $7f,0 > load_flag 0 20dc : a900 > lda #0 ;allow test to change I-flag (no mask) > 20de : 48 > pha ;use stack to load status 20df : a97f > lda #$7f ;precharge accu 20e1 : 28 > plp 20e2 : dd1702 cmp abs1,x tst_a $7f,fzc 20e5 : 08 > php ;save flags 20e6 : c97f > cmp #$7f ;test result > trap_ne 20e8 : d0fe > bne * ;failed not equal (non zero) > 20ea : 68 > pla ;load status 20eb : 48 > pha > cmp_flag fzc 20ec : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 20ee : d0fe > bne * ;failed not equal (non zero) > 20f0 : 28 > plp ;restore status set_a $7e,0 > load_flag 0 20f1 : a900 > lda #0 ;allow test to change I-flag (no mask) > 20f3 : 48 > pha ;use stack to load status 20f4 : a97e > lda #$7e ;precharge accu 20f6 : 28 > plp 20f7 : dd1702 cmp abs1,x tst_a $7e,fn 20fa : 08 > php ;save flags 20fb : c97e > cmp #$7e ;test result > trap_ne 20fd : d0fe > bne * ;failed not equal (non zero) > 20ff : 68 > pla ;load status 2100 : 48 > pha > cmp_flag fn 2101 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 2103 : d0fe > bne * ;failed not equal (non zero) > 2105 : 28 > plp ;restore status set_a $80,$ff > load_flag $ff 2106 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2108 : 48 > pha ;use stack to load status 2109 : a980 > lda #$80 ;precharge accu 210b : 28 > plp 210c : dd1702 cmp abs1,x tst_a $80,~fnz 210f : 08 > php ;save flags 2110 : c980 > cmp #$80 ;test result > trap_ne 2112 : d0fe > bne * ;failed not equal (non zero) > 2114 : 68 > pla ;load status 2115 : 48 > pha > cmp_flag ~fnz 2116 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 2118 : d0fe > bne * ;failed not equal (non zero) > 211a : 28 > plp ;restore status set_a $7f,$ff > load_flag $ff 211b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 211d : 48 > pha ;use stack to load status 211e : a97f > lda #$7f ;precharge accu 2120 : 28 > plp 2121 : dd1702 cmp abs1,x tst_a $7f,~fn 2124 : 08 > php ;save flags 2125 : c97f > cmp #$7f ;test result > trap_ne 2127 : d0fe > bne * ;failed not equal (non zero) > 2129 : 68 > pla ;load status 212a : 48 > pha > cmp_flag ~fn 212b : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 212d : d0fe > bne * ;failed not equal (non zero) > 212f : 28 > plp ;restore status set_a $7e,$ff > load_flag $ff 2130 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2132 : 48 > pha ;use stack to load status 2133 : a97e > lda #$7e ;precharge accu 2135 : 28 > plp 2136 : dd1702 cmp abs1,x tst_a $7e,~fzc 2139 : 08 > php ;save flags 213a : c97e > cmp #$7e ;test result > trap_ne 213c : d0fe > bne * ;failed not equal (non zero) > 213e : 68 > pla ;load status 213f : 48 > pha > cmp_flag ~fzc 2140 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 2142 : d0fe > bne * ;failed not equal (non zero) > 2144 : 28 > plp ;restore status 2145 : a004 ldy #4 ;with indexing by Y 2147 : a208 ldx #8 ;with indexed indirect set_a $80,0 > load_flag 0 2149 : a900 > lda #0 ;allow test to change I-flag (no mask) > 214b : 48 > pha ;use stack to load status 214c : a980 > lda #$80 ;precharge accu 214e : 28 > plp 214f : d91702 cmp abs1,y tst_a $80,fc 2152 : 08 > php ;save flags 2153 : c980 > cmp #$80 ;test result > trap_ne 2155 : d0fe > bne * ;failed not equal (non zero) > 2157 : 68 > pla ;load status 2158 : 48 > pha > cmp_flag fc 2159 : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 215b : d0fe > bne * ;failed not equal (non zero) > 215d : 28 > plp ;restore status set_a $7f,0 > load_flag 0 215e : a900 > lda #0 ;allow test to change I-flag (no mask) > 2160 : 48 > pha ;use stack to load status 2161 : a97f > lda #$7f ;precharge accu 2163 : 28 > plp 2164 : d91702 cmp abs1,y tst_a $7f,fzc 2167 : 08 > php ;save flags 2168 : c97f > cmp #$7f ;test result > trap_ne 216a : d0fe > bne * ;failed not equal (non zero) > 216c : 68 > pla ;load status 216d : 48 > pha > cmp_flag fzc 216e : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 2170 : d0fe > bne * ;failed not equal (non zero) > 2172 : 28 > plp ;restore status set_a $7e,0 > load_flag 0 2173 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2175 : 48 > pha ;use stack to load status 2176 : a97e > lda #$7e ;precharge accu 2178 : 28 > plp 2179 : d91702 cmp abs1,y tst_a $7e,fn 217c : 08 > php ;save flags 217d : c97e > cmp #$7e ;test result > trap_ne 217f : d0fe > bne * ;failed not equal (non zero) > 2181 : 68 > pla ;load status 2182 : 48 > pha > cmp_flag fn 2183 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 2185 : d0fe > bne * ;failed not equal (non zero) > 2187 : 28 > plp ;restore status set_a $80,$ff > load_flag $ff 2188 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 218a : 48 > pha ;use stack to load status 218b : a980 > lda #$80 ;precharge accu 218d : 28 > plp 218e : d91702 cmp abs1,y tst_a $80,~fnz 2191 : 08 > php ;save flags 2192 : c980 > cmp #$80 ;test result > trap_ne 2194 : d0fe > bne * ;failed not equal (non zero) > 2196 : 68 > pla ;load status 2197 : 48 > pha > cmp_flag ~fnz 2198 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 219a : d0fe > bne * ;failed not equal (non zero) > 219c : 28 > plp ;restore status set_a $7f,$ff > load_flag $ff 219d : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 219f : 48 > pha ;use stack to load status 21a0 : a97f > lda #$7f ;precharge accu 21a2 : 28 > plp 21a3 : d91702 cmp abs1,y tst_a $7f,~fn 21a6 : 08 > php ;save flags 21a7 : c97f > cmp #$7f ;test result > trap_ne 21a9 : d0fe > bne * ;failed not equal (non zero) > 21ab : 68 > pla ;load status 21ac : 48 > pha > cmp_flag ~fn 21ad : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 21af : d0fe > bne * ;failed not equal (non zero) > 21b1 : 28 > plp ;restore status set_a $7e,$ff > load_flag $ff 21b2 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 21b4 : 48 > pha ;use stack to load status 21b5 : a97e > lda #$7e ;precharge accu 21b7 : 28 > plp 21b8 : d91702 cmp abs1,y tst_a $7e,~fzc 21bb : 08 > php ;save flags 21bc : c97e > cmp #$7e ;test result > trap_ne 21be : d0fe > bne * ;failed not equal (non zero) > 21c0 : 68 > pla ;load status 21c1 : 48 > pha > cmp_flag ~fzc 21c2 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 21c4 : d0fe > bne * ;failed not equal (non zero) > 21c6 : 28 > plp ;restore status set_a $80,0 > load_flag 0 21c7 : a900 > lda #0 ;allow test to change I-flag (no mask) > 21c9 : 48 > pha ;use stack to load status 21ca : a980 > lda #$80 ;precharge accu 21cc : 28 > plp 21cd : c124 cmp (ind1,x) tst_a $80,fc 21cf : 08 > php ;save flags 21d0 : c980 > cmp #$80 ;test result > trap_ne 21d2 : d0fe > bne * ;failed not equal (non zero) > 21d4 : 68 > pla ;load status 21d5 : 48 > pha > cmp_flag fc 21d6 : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 21d8 : d0fe > bne * ;failed not equal (non zero) > 21da : 28 > plp ;restore status set_a $7f,0 > load_flag 0 21db : a900 > lda #0 ;allow test to change I-flag (no mask) > 21dd : 48 > pha ;use stack to load status 21de : a97f > lda #$7f ;precharge accu 21e0 : 28 > plp 21e1 : c124 cmp (ind1,x) tst_a $7f,fzc 21e3 : 08 > php ;save flags 21e4 : c97f > cmp #$7f ;test result > trap_ne 21e6 : d0fe > bne * ;failed not equal (non zero) > 21e8 : 68 > pla ;load status 21e9 : 48 > pha > cmp_flag fzc 21ea : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 21ec : d0fe > bne * ;failed not equal (non zero) > 21ee : 28 > plp ;restore status set_a $7e,0 > load_flag 0 21ef : a900 > lda #0 ;allow test to change I-flag (no mask) > 21f1 : 48 > pha ;use stack to load status 21f2 : a97e > lda #$7e ;precharge accu 21f4 : 28 > plp 21f5 : c124 cmp (ind1,x) tst_a $7e,fn 21f7 : 08 > php ;save flags 21f8 : c97e > cmp #$7e ;test result > trap_ne 21fa : d0fe > bne * ;failed not equal (non zero) > 21fc : 68 > pla ;load status 21fd : 48 > pha > cmp_flag fn 21fe : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 2200 : d0fe > bne * ;failed not equal (non zero) > 2202 : 28 > plp ;restore status set_a $80,$ff > load_flag $ff 2203 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2205 : 48 > pha ;use stack to load status 2206 : a980 > lda #$80 ;precharge accu 2208 : 28 > plp 2209 : c124 cmp (ind1,x) tst_a $80,~fnz 220b : 08 > php ;save flags 220c : c980 > cmp #$80 ;test result > trap_ne 220e : d0fe > bne * ;failed not equal (non zero) > 2210 : 68 > pla ;load status 2211 : 48 > pha > cmp_flag ~fnz 2212 : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 2214 : d0fe > bne * ;failed not equal (non zero) > 2216 : 28 > plp ;restore status set_a $7f,$ff > load_flag $ff 2217 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2219 : 48 > pha ;use stack to load status 221a : a97f > lda #$7f ;precharge accu 221c : 28 > plp 221d : c124 cmp (ind1,x) tst_a $7f,~fn 221f : 08 > php ;save flags 2220 : c97f > cmp #$7f ;test result > trap_ne 2222 : d0fe > bne * ;failed not equal (non zero) > 2224 : 68 > pla ;load status 2225 : 48 > pha > cmp_flag ~fn 2226 : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 2228 : d0fe > bne * ;failed not equal (non zero) > 222a : 28 > plp ;restore status set_a $7e,$ff > load_flag $ff 222b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 222d : 48 > pha ;use stack to load status 222e : a97e > lda #$7e ;precharge accu 2230 : 28 > plp 2231 : c124 cmp (ind1,x) tst_a $7e,~fzc 2233 : 08 > php ;save flags 2234 : c97e > cmp #$7e ;test result > trap_ne 2236 : d0fe > bne * ;failed not equal (non zero) > 2238 : 68 > pla ;load status 2239 : 48 > pha > cmp_flag ~fzc 223a : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 223c : d0fe > bne * ;failed not equal (non zero) > 223e : 28 > plp ;restore status set_a $80,0 > load_flag 0 223f : a900 > lda #0 ;allow test to change I-flag (no mask) > 2241 : 48 > pha ;use stack to load status 2242 : a980 > lda #$80 ;precharge accu 2244 : 28 > plp 2245 : d124 cmp (ind1),y tst_a $80,fc 2247 : 08 > php ;save flags 2248 : c980 > cmp #$80 ;test result > trap_ne 224a : d0fe > bne * ;failed not equal (non zero) > 224c : 68 > pla ;load status 224d : 48 > pha > cmp_flag fc 224e : c931 > cmp #(fc|fao)&m8 ;expected flags + always on bits > > trap_ne 2250 : d0fe > bne * ;failed not equal (non zero) > 2252 : 28 > plp ;restore status set_a $7f,0 > load_flag 0 2253 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2255 : 48 > pha ;use stack to load status 2256 : a97f > lda #$7f ;precharge accu 2258 : 28 > plp 2259 : d124 cmp (ind1),y tst_a $7f,fzc 225b : 08 > php ;save flags 225c : c97f > cmp #$7f ;test result > trap_ne 225e : d0fe > bne * ;failed not equal (non zero) > 2260 : 68 > pla ;load status 2261 : 48 > pha > cmp_flag fzc 2262 : c933 > cmp #(fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 2264 : d0fe > bne * ;failed not equal (non zero) > 2266 : 28 > plp ;restore status set_a $7e,0 > load_flag 0 2267 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2269 : 48 > pha ;use stack to load status 226a : a97e > lda #$7e ;precharge accu 226c : 28 > plp 226d : d124 cmp (ind1),y tst_a $7e,fn 226f : 08 > php ;save flags 2270 : c97e > cmp #$7e ;test result > trap_ne 2272 : d0fe > bne * ;failed not equal (non zero) > 2274 : 68 > pla ;load status 2275 : 48 > pha > cmp_flag fn 2276 : c9b0 > cmp #(fn|fao)&m8 ;expected flags + always on bits > > trap_ne 2278 : d0fe > bne * ;failed not equal (non zero) > 227a : 28 > plp ;restore status set_a $80,$ff > load_flag $ff 227b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 227d : 48 > pha ;use stack to load status 227e : a980 > lda #$80 ;precharge accu 2280 : 28 > plp 2281 : d124 cmp (ind1),y tst_a $80,~fnz 2283 : 08 > php ;save flags 2284 : c980 > cmp #$80 ;test result > trap_ne 2286 : d0fe > bne * ;failed not equal (non zero) > 2288 : 68 > pla ;load status 2289 : 48 > pha > cmp_flag ~fnz 228a : c97d > cmp #(~fnz|fao)&m8 ;expected flags + always on bits > > trap_ne 228c : d0fe > bne * ;failed not equal (non zero) > 228e : 28 > plp ;restore status set_a $7f,$ff > load_flag $ff 228f : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2291 : 48 > pha ;use stack to load status 2292 : a97f > lda #$7f ;precharge accu 2294 : 28 > plp 2295 : d124 cmp (ind1),y tst_a $7f,~fn 2297 : 08 > php ;save flags 2298 : c97f > cmp #$7f ;test result > trap_ne 229a : d0fe > bne * ;failed not equal (non zero) > 229c : 68 > pla ;load status 229d : 48 > pha > cmp_flag ~fn 229e : c97f > cmp #(~fn|fao)&m8 ;expected flags + always on bits > > trap_ne 22a0 : d0fe > bne * ;failed not equal (non zero) > 22a2 : 28 > plp ;restore status set_a $7e,$ff > load_flag $ff 22a3 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 22a5 : 48 > pha ;use stack to load status 22a6 : a97e > lda #$7e ;precharge accu 22a8 : 28 > plp 22a9 : d124 cmp (ind1),y tst_a $7e,~fzc 22ab : 08 > php ;save flags 22ac : c97e > cmp #$7e ;test result > trap_ne 22ae : d0fe > bne * ;failed not equal (non zero) > 22b0 : 68 > pla ;load status 22b1 : 48 > pha > cmp_flag ~fzc 22b2 : c9fc > cmp #(~fzc|fao)&m8 ;expected flags + always on bits > > trap_ne 22b4 : d0fe > bne * ;failed not equal (non zero) > 22b6 : 28 > plp ;restore status next_test 22b7 : ad0002 > lda test_case ;previous test 22ba : c91c > cmp #test_num > trap_ne ;test is out of sequence 22bc : d0fe > bne * ;failed not equal (non zero) > 001d = >test_num = test_num + 1 22be : a91d > lda #test_num ;*** next tests' number 22c0 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; testing shifts - ASL LSR ROL ROR all addressing modes ; shifts - accumulator 22c3 : a203 ldx #3 22c5 : tasl set_ax zp1,0 > load_flag 0 22c5 : a900 > lda #0 ;allow test to change I-flag (no mask) > 22c7 : 48 > pha ;use stack to load status 22c8 : b513 > lda zp1,x ;precharge accu 22ca : 28 > plp 22cb : 0a asl a tst_ax rASL,fASL,0 22cc : 08 > php ;save flags 22cd : dd2002 > cmp rASL,x ;test result > trap_ne 22d0 : d0fe > bne * ;failed not equal (non zero) > 22d2 : 68 > pla ;load status > eor_flag 0 22d3 : 4930 > eor #0|fao ;invert expected flags + always on bits > 22d5 : dd3002 > cmp fASL,x ;test flags > trap_ne ; 22d8 : d0fe > bne * ;failed not equal (non zero) > 22da : ca dex 22db : 10e8 bpl tasl 22dd : a203 ldx #3 22df : tasl1 set_ax zp1,$ff > load_flag $ff 22df : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 22e1 : 48 > pha ;use stack to load status 22e2 : b513 > lda zp1,x ;precharge accu 22e4 : 28 > plp 22e5 : 0a asl a tst_ax rASL,fASL,$ff-fnzc 22e6 : 08 > php ;save flags 22e7 : dd2002 > cmp rASL,x ;test result > trap_ne 22ea : d0fe > bne * ;failed not equal (non zero) > 22ec : 68 > pla ;load status > eor_flag $ff-fnzc 22ed : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 22ef : dd3002 > cmp fASL,x ;test flags > trap_ne ; 22f2 : d0fe > bne * ;failed not equal (non zero) > 22f4 : ca dex 22f5 : 10e8 bpl tasl1 22f7 : a203 ldx #3 22f9 : tlsr set_ax zp1,0 > load_flag 0 22f9 : a900 > lda #0 ;allow test to change I-flag (no mask) > 22fb : 48 > pha ;use stack to load status 22fc : b513 > lda zp1,x ;precharge accu 22fe : 28 > plp 22ff : 4a lsr a tst_ax rLSR,fLSR,0 2300 : 08 > php ;save flags 2301 : dd2802 > cmp rLSR,x ;test result > trap_ne 2304 : d0fe > bne * ;failed not equal (non zero) > 2306 : 68 > pla ;load status > eor_flag 0 2307 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2309 : dd3802 > cmp fLSR,x ;test flags > trap_ne ; 230c : d0fe > bne * ;failed not equal (non zero) > 230e : ca dex 230f : 10e8 bpl tlsr 2311 : a203 ldx #3 2313 : tlsr1 set_ax zp1,$ff > load_flag $ff 2313 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2315 : 48 > pha ;use stack to load status 2316 : b513 > lda zp1,x ;precharge accu 2318 : 28 > plp 2319 : 4a lsr a tst_ax rLSR,fLSR,$ff-fnzc 231a : 08 > php ;save flags 231b : dd2802 > cmp rLSR,x ;test result > trap_ne 231e : d0fe > bne * ;failed not equal (non zero) > 2320 : 68 > pla ;load status > eor_flag $ff-fnzc 2321 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2323 : dd3802 > cmp fLSR,x ;test flags > trap_ne ; 2326 : d0fe > bne * ;failed not equal (non zero) > 2328 : ca dex 2329 : 10e8 bpl tlsr1 232b : a203 ldx #3 232d : trol set_ax zp1,0 > load_flag 0 232d : a900 > lda #0 ;allow test to change I-flag (no mask) > 232f : 48 > pha ;use stack to load status 2330 : b513 > lda zp1,x ;precharge accu 2332 : 28 > plp 2333 : 2a rol a tst_ax rROL,fROL,0 2334 : 08 > php ;save flags 2335 : dd2002 > cmp rROL,x ;test result > trap_ne 2338 : d0fe > bne * ;failed not equal (non zero) > 233a : 68 > pla ;load status > eor_flag 0 233b : 4930 > eor #0|fao ;invert expected flags + always on bits > 233d : dd3002 > cmp fROL,x ;test flags > trap_ne ; 2340 : d0fe > bne * ;failed not equal (non zero) > 2342 : ca dex 2343 : 10e8 bpl trol 2345 : a203 ldx #3 2347 : trol1 set_ax zp1,$ff-fc > load_flag $ff-fc 2347 : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 2349 : 48 > pha ;use stack to load status 234a : b513 > lda zp1,x ;precharge accu 234c : 28 > plp 234d : 2a rol a tst_ax rROL,fROL,$ff-fnzc 234e : 08 > php ;save flags 234f : dd2002 > cmp rROL,x ;test result > trap_ne 2352 : d0fe > bne * ;failed not equal (non zero) > 2354 : 68 > pla ;load status > eor_flag $ff-fnzc 2355 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2357 : dd3002 > cmp fROL,x ;test flags > trap_ne ; 235a : d0fe > bne * ;failed not equal (non zero) > 235c : ca dex 235d : 10e8 bpl trol1 235f : a203 ldx #3 2361 : trolc set_ax zp1,fc > load_flag fc 2361 : a901 > lda #fc ;allow test to change I-flag (no mask) > 2363 : 48 > pha ;use stack to load status 2364 : b513 > lda zp1,x ;precharge accu 2366 : 28 > plp 2367 : 2a rol a tst_ax rROLc,fROLc,0 2368 : 08 > php ;save flags 2369 : dd2402 > cmp rROLc,x ;test result > trap_ne 236c : d0fe > bne * ;failed not equal (non zero) > 236e : 68 > pla ;load status > eor_flag 0 236f : 4930 > eor #0|fao ;invert expected flags + always on bits > 2371 : dd3402 > cmp fROLc,x ;test flags > trap_ne ; 2374 : d0fe > bne * ;failed not equal (non zero) > 2376 : ca dex 2377 : 10e8 bpl trolc 2379 : a203 ldx #3 237b : trolc1 set_ax zp1,$ff > load_flag $ff 237b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 237d : 48 > pha ;use stack to load status 237e : b513 > lda zp1,x ;precharge accu 2380 : 28 > plp 2381 : 2a rol a tst_ax rROLc,fROLc,$ff-fnzc 2382 : 08 > php ;save flags 2383 : dd2402 > cmp rROLc,x ;test result > trap_ne 2386 : d0fe > bne * ;failed not equal (non zero) > 2388 : 68 > pla ;load status > eor_flag $ff-fnzc 2389 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 238b : dd3402 > cmp fROLc,x ;test flags > trap_ne ; 238e : d0fe > bne * ;failed not equal (non zero) > 2390 : ca dex 2391 : 10e8 bpl trolc1 2393 : a203 ldx #3 2395 : tror set_ax zp1,0 > load_flag 0 2395 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2397 : 48 > pha ;use stack to load status 2398 : b513 > lda zp1,x ;precharge accu 239a : 28 > plp 239b : 6a ror a tst_ax rROR,fROR,0 239c : 08 > php ;save flags 239d : dd2802 > cmp rROR,x ;test result > trap_ne 23a0 : d0fe > bne * ;failed not equal (non zero) > 23a2 : 68 > pla ;load status > eor_flag 0 23a3 : 4930 > eor #0|fao ;invert expected flags + always on bits > 23a5 : dd3802 > cmp fROR,x ;test flags > trap_ne ; 23a8 : d0fe > bne * ;failed not equal (non zero) > 23aa : ca dex 23ab : 10e8 bpl tror 23ad : a203 ldx #3 23af : tror1 set_ax zp1,$ff-fc > load_flag $ff-fc 23af : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 23b1 : 48 > pha ;use stack to load status 23b2 : b513 > lda zp1,x ;precharge accu 23b4 : 28 > plp 23b5 : 6a ror a tst_ax rROR,fROR,$ff-fnzc 23b6 : 08 > php ;save flags 23b7 : dd2802 > cmp rROR,x ;test result > trap_ne 23ba : d0fe > bne * ;failed not equal (non zero) > 23bc : 68 > pla ;load status > eor_flag $ff-fnzc 23bd : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 23bf : dd3802 > cmp fROR,x ;test flags > trap_ne ; 23c2 : d0fe > bne * ;failed not equal (non zero) > 23c4 : ca dex 23c5 : 10e8 bpl tror1 23c7 : a203 ldx #3 23c9 : trorc set_ax zp1,fc > load_flag fc 23c9 : a901 > lda #fc ;allow test to change I-flag (no mask) > 23cb : 48 > pha ;use stack to load status 23cc : b513 > lda zp1,x ;precharge accu 23ce : 28 > plp 23cf : 6a ror a tst_ax rRORc,fRORc,0 23d0 : 08 > php ;save flags 23d1 : dd2c02 > cmp rRORc,x ;test result > trap_ne 23d4 : d0fe > bne * ;failed not equal (non zero) > 23d6 : 68 > pla ;load status > eor_flag 0 23d7 : 4930 > eor #0|fao ;invert expected flags + always on bits > 23d9 : dd3c02 > cmp fRORc,x ;test flags > trap_ne ; 23dc : d0fe > bne * ;failed not equal (non zero) > 23de : ca dex 23df : 10e8 bpl trorc 23e1 : a203 ldx #3 23e3 : trorc1 set_ax zp1,$ff > load_flag $ff 23e3 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 23e5 : 48 > pha ;use stack to load status 23e6 : b513 > lda zp1,x ;precharge accu 23e8 : 28 > plp 23e9 : 6a ror a tst_ax rRORc,fRORc,$ff-fnzc 23ea : 08 > php ;save flags 23eb : dd2c02 > cmp rRORc,x ;test result > trap_ne 23ee : d0fe > bne * ;failed not equal (non zero) > 23f0 : 68 > pla ;load status > eor_flag $ff-fnzc 23f1 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 23f3 : dd3c02 > cmp fRORc,x ;test flags > trap_ne ; 23f6 : d0fe > bne * ;failed not equal (non zero) > 23f8 : ca dex 23f9 : 10e8 bpl trorc1 next_test 23fb : ad0002 > lda test_case ;previous test 23fe : c91d > cmp #test_num > trap_ne ;test is out of sequence 2400 : d0fe > bne * ;failed not equal (non zero) > 001e = >test_num = test_num + 1 2402 : a91e > lda #test_num ;*** next tests' number 2404 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; shifts - zeropage 2407 : a203 ldx #3 2409 : tasl2 set_z zp1,0 > load_flag 0 2409 : a900 > lda #0 ;allow test to change I-flag (no mask) > 240b : 48 > pha ;use stack to load status 240c : b513 > lda zp1,x ;load to zeropage 240e : 850c > sta zpt 2410 : 28 > plp 2411 : 060c asl zpt tst_z rASL,fASL,0 2413 : 08 > php ;save flags 2414 : a50c > lda zpt 2416 : dd2002 > cmp rASL,x ;test result > trap_ne 2419 : d0fe > bne * ;failed not equal (non zero) > 241b : 68 > pla ;load status > eor_flag 0 241c : 4930 > eor #0|fao ;invert expected flags + always on bits > 241e : dd3002 > cmp fASL,x ;test flags > trap_ne 2421 : d0fe > bne * ;failed not equal (non zero) > 2423 : ca dex 2424 : 10e3 bpl tasl2 2426 : a203 ldx #3 2428 : tasl3 set_z zp1,$ff > load_flag $ff 2428 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 242a : 48 > pha ;use stack to load status 242b : b513 > lda zp1,x ;load to zeropage 242d : 850c > sta zpt 242f : 28 > plp 2430 : 060c asl zpt tst_z rASL,fASL,$ff-fnzc 2432 : 08 > php ;save flags 2433 : a50c > lda zpt 2435 : dd2002 > cmp rASL,x ;test result > trap_ne 2438 : d0fe > bne * ;failed not equal (non zero) > 243a : 68 > pla ;load status > eor_flag $ff-fnzc 243b : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 243d : dd3002 > cmp fASL,x ;test flags > trap_ne 2440 : d0fe > bne * ;failed not equal (non zero) > 2442 : ca dex 2443 : 10e3 bpl tasl3 2445 : a203 ldx #3 2447 : tlsr2 set_z zp1,0 > load_flag 0 2447 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2449 : 48 > pha ;use stack to load status 244a : b513 > lda zp1,x ;load to zeropage 244c : 850c > sta zpt 244e : 28 > plp 244f : 460c lsr zpt tst_z rLSR,fLSR,0 2451 : 08 > php ;save flags 2452 : a50c > lda zpt 2454 : dd2802 > cmp rLSR,x ;test result > trap_ne 2457 : d0fe > bne * ;failed not equal (non zero) > 2459 : 68 > pla ;load status > eor_flag 0 245a : 4930 > eor #0|fao ;invert expected flags + always on bits > 245c : dd3802 > cmp fLSR,x ;test flags > trap_ne 245f : d0fe > bne * ;failed not equal (non zero) > 2461 : ca dex 2462 : 10e3 bpl tlsr2 2464 : a203 ldx #3 2466 : tlsr3 set_z zp1,$ff > load_flag $ff 2466 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2468 : 48 > pha ;use stack to load status 2469 : b513 > lda zp1,x ;load to zeropage 246b : 850c > sta zpt 246d : 28 > plp 246e : 460c lsr zpt tst_z rLSR,fLSR,$ff-fnzc 2470 : 08 > php ;save flags 2471 : a50c > lda zpt 2473 : dd2802 > cmp rLSR,x ;test result > trap_ne 2476 : d0fe > bne * ;failed not equal (non zero) > 2478 : 68 > pla ;load status > eor_flag $ff-fnzc 2479 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 247b : dd3802 > cmp fLSR,x ;test flags > trap_ne 247e : d0fe > bne * ;failed not equal (non zero) > 2480 : ca dex 2481 : 10e3 bpl tlsr3 2483 : a203 ldx #3 2485 : trol2 set_z zp1,0 > load_flag 0 2485 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2487 : 48 > pha ;use stack to load status 2488 : b513 > lda zp1,x ;load to zeropage 248a : 850c > sta zpt 248c : 28 > plp 248d : 260c rol zpt tst_z rROL,fROL,0 248f : 08 > php ;save flags 2490 : a50c > lda zpt 2492 : dd2002 > cmp rROL,x ;test result > trap_ne 2495 : d0fe > bne * ;failed not equal (non zero) > 2497 : 68 > pla ;load status > eor_flag 0 2498 : 4930 > eor #0|fao ;invert expected flags + always on bits > 249a : dd3002 > cmp fROL,x ;test flags > trap_ne 249d : d0fe > bne * ;failed not equal (non zero) > 249f : ca dex 24a0 : 10e3 bpl trol2 24a2 : a203 ldx #3 24a4 : trol3 set_z zp1,$ff-fc > load_flag $ff-fc 24a4 : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 24a6 : 48 > pha ;use stack to load status 24a7 : b513 > lda zp1,x ;load to zeropage 24a9 : 850c > sta zpt 24ab : 28 > plp 24ac : 260c rol zpt tst_z rROL,fROL,$ff-fnzc 24ae : 08 > php ;save flags 24af : a50c > lda zpt 24b1 : dd2002 > cmp rROL,x ;test result > trap_ne 24b4 : d0fe > bne * ;failed not equal (non zero) > 24b6 : 68 > pla ;load status > eor_flag $ff-fnzc 24b7 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 24b9 : dd3002 > cmp fROL,x ;test flags > trap_ne 24bc : d0fe > bne * ;failed not equal (non zero) > 24be : ca dex 24bf : 10e3 bpl trol3 24c1 : a203 ldx #3 24c3 : trolc2 set_z zp1,fc > load_flag fc 24c3 : a901 > lda #fc ;allow test to change I-flag (no mask) > 24c5 : 48 > pha ;use stack to load status 24c6 : b513 > lda zp1,x ;load to zeropage 24c8 : 850c > sta zpt 24ca : 28 > plp 24cb : 260c rol zpt tst_z rROLc,fROLc,0 24cd : 08 > php ;save flags 24ce : a50c > lda zpt 24d0 : dd2402 > cmp rROLc,x ;test result > trap_ne 24d3 : d0fe > bne * ;failed not equal (non zero) > 24d5 : 68 > pla ;load status > eor_flag 0 24d6 : 4930 > eor #0|fao ;invert expected flags + always on bits > 24d8 : dd3402 > cmp fROLc,x ;test flags > trap_ne 24db : d0fe > bne * ;failed not equal (non zero) > 24dd : ca dex 24de : 10e3 bpl trolc2 24e0 : a203 ldx #3 24e2 : trolc3 set_z zp1,$ff > load_flag $ff 24e2 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 24e4 : 48 > pha ;use stack to load status 24e5 : b513 > lda zp1,x ;load to zeropage 24e7 : 850c > sta zpt 24e9 : 28 > plp 24ea : 260c rol zpt tst_z rROLc,fROLc,$ff-fnzc 24ec : 08 > php ;save flags 24ed : a50c > lda zpt 24ef : dd2402 > cmp rROLc,x ;test result > trap_ne 24f2 : d0fe > bne * ;failed not equal (non zero) > 24f4 : 68 > pla ;load status > eor_flag $ff-fnzc 24f5 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 24f7 : dd3402 > cmp fROLc,x ;test flags > trap_ne 24fa : d0fe > bne * ;failed not equal (non zero) > 24fc : ca dex 24fd : 10e3 bpl trolc3 24ff : a203 ldx #3 2501 : tror2 set_z zp1,0 > load_flag 0 2501 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2503 : 48 > pha ;use stack to load status 2504 : b513 > lda zp1,x ;load to zeropage 2506 : 850c > sta zpt 2508 : 28 > plp 2509 : 660c ror zpt tst_z rROR,fROR,0 250b : 08 > php ;save flags 250c : a50c > lda zpt 250e : dd2802 > cmp rROR,x ;test result > trap_ne 2511 : d0fe > bne * ;failed not equal (non zero) > 2513 : 68 > pla ;load status > eor_flag 0 2514 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2516 : dd3802 > cmp fROR,x ;test flags > trap_ne 2519 : d0fe > bne * ;failed not equal (non zero) > 251b : ca dex 251c : 10e3 bpl tror2 251e : a203 ldx #3 2520 : tror3 set_z zp1,$ff-fc > load_flag $ff-fc 2520 : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 2522 : 48 > pha ;use stack to load status 2523 : b513 > lda zp1,x ;load to zeropage 2525 : 850c > sta zpt 2527 : 28 > plp 2528 : 660c ror zpt tst_z rROR,fROR,$ff-fnzc 252a : 08 > php ;save flags 252b : a50c > lda zpt 252d : dd2802 > cmp rROR,x ;test result > trap_ne 2530 : d0fe > bne * ;failed not equal (non zero) > 2532 : 68 > pla ;load status > eor_flag $ff-fnzc 2533 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2535 : dd3802 > cmp fROR,x ;test flags > trap_ne 2538 : d0fe > bne * ;failed not equal (non zero) > 253a : ca dex 253b : 10e3 bpl tror3 253d : a203 ldx #3 253f : trorc2 set_z zp1,fc > load_flag fc 253f : a901 > lda #fc ;allow test to change I-flag (no mask) > 2541 : 48 > pha ;use stack to load status 2542 : b513 > lda zp1,x ;load to zeropage 2544 : 850c > sta zpt 2546 : 28 > plp 2547 : 660c ror zpt tst_z rRORc,fRORc,0 2549 : 08 > php ;save flags 254a : a50c > lda zpt 254c : dd2c02 > cmp rRORc,x ;test result > trap_ne 254f : d0fe > bne * ;failed not equal (non zero) > 2551 : 68 > pla ;load status > eor_flag 0 2552 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2554 : dd3c02 > cmp fRORc,x ;test flags > trap_ne 2557 : d0fe > bne * ;failed not equal (non zero) > 2559 : ca dex 255a : 10e3 bpl trorc2 255c : a203 ldx #3 255e : trorc3 set_z zp1,$ff > load_flag $ff 255e : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2560 : 48 > pha ;use stack to load status 2561 : b513 > lda zp1,x ;load to zeropage 2563 : 850c > sta zpt 2565 : 28 > plp 2566 : 660c ror zpt tst_z rRORc,fRORc,$ff-fnzc 2568 : 08 > php ;save flags 2569 : a50c > lda zpt 256b : dd2c02 > cmp rRORc,x ;test result > trap_ne 256e : d0fe > bne * ;failed not equal (non zero) > 2570 : 68 > pla ;load status > eor_flag $ff-fnzc 2571 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2573 : dd3c02 > cmp fRORc,x ;test flags > trap_ne 2576 : d0fe > bne * ;failed not equal (non zero) > 2578 : ca dex 2579 : 10e3 bpl trorc3 next_test 257b : ad0002 > lda test_case ;previous test 257e : c91e > cmp #test_num > trap_ne ;test is out of sequence 2580 : d0fe > bne * ;failed not equal (non zero) > 001f = >test_num = test_num + 1 2582 : a91f > lda #test_num ;*** next tests' number 2584 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; shifts - absolute 2587 : a203 ldx #3 2589 : tasl4 set_abs zp1,0 > load_flag 0 2589 : a900 > lda #0 ;allow test to change I-flag (no mask) > 258b : 48 > pha ;use stack to load status 258c : b513 > lda zp1,x ;load to memory 258e : 8d0302 > sta abst 2591 : 28 > plp 2592 : 0e0302 asl abst tst_abs rASL,fASL,0 2595 : 08 > php ;save flags 2596 : ad0302 > lda abst 2599 : dd2002 > cmp rASL,x ;test result > trap_ne 259c : d0fe > bne * ;failed not equal (non zero) > 259e : 68 > pla ;load status > eor_flag 0 259f : 4930 > eor #0|fao ;invert expected flags + always on bits > 25a1 : dd3002 > cmp fASL,x ;test flags > trap_ne 25a4 : d0fe > bne * ;failed not equal (non zero) > 25a6 : ca dex 25a7 : 10e0 bpl tasl4 25a9 : a203 ldx #3 25ab : tasl5 set_abs zp1,$ff > load_flag $ff 25ab : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 25ad : 48 > pha ;use stack to load status 25ae : b513 > lda zp1,x ;load to memory 25b0 : 8d0302 > sta abst 25b3 : 28 > plp 25b4 : 0e0302 asl abst tst_abs rASL,fASL,$ff-fnzc 25b7 : 08 > php ;save flags 25b8 : ad0302 > lda abst 25bb : dd2002 > cmp rASL,x ;test result > trap_ne 25be : d0fe > bne * ;failed not equal (non zero) > 25c0 : 68 > pla ;load status > eor_flag $ff-fnzc 25c1 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 25c3 : dd3002 > cmp fASL,x ;test flags > trap_ne 25c6 : d0fe > bne * ;failed not equal (non zero) > 25c8 : ca dex 25c9 : 10e0 bpl tasl5 25cb : a203 ldx #3 25cd : tlsr4 set_abs zp1,0 > load_flag 0 25cd : a900 > lda #0 ;allow test to change I-flag (no mask) > 25cf : 48 > pha ;use stack to load status 25d0 : b513 > lda zp1,x ;load to memory 25d2 : 8d0302 > sta abst 25d5 : 28 > plp 25d6 : 4e0302 lsr abst tst_abs rLSR,fLSR,0 25d9 : 08 > php ;save flags 25da : ad0302 > lda abst 25dd : dd2802 > cmp rLSR,x ;test result > trap_ne 25e0 : d0fe > bne * ;failed not equal (non zero) > 25e2 : 68 > pla ;load status > eor_flag 0 25e3 : 4930 > eor #0|fao ;invert expected flags + always on bits > 25e5 : dd3802 > cmp fLSR,x ;test flags > trap_ne 25e8 : d0fe > bne * ;failed not equal (non zero) > 25ea : ca dex 25eb : 10e0 bpl tlsr4 25ed : a203 ldx #3 25ef : tlsr5 set_abs zp1,$ff > load_flag $ff 25ef : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 25f1 : 48 > pha ;use stack to load status 25f2 : b513 > lda zp1,x ;load to memory 25f4 : 8d0302 > sta abst 25f7 : 28 > plp 25f8 : 4e0302 lsr abst tst_abs rLSR,fLSR,$ff-fnzc 25fb : 08 > php ;save flags 25fc : ad0302 > lda abst 25ff : dd2802 > cmp rLSR,x ;test result > trap_ne 2602 : d0fe > bne * ;failed not equal (non zero) > 2604 : 68 > pla ;load status > eor_flag $ff-fnzc 2605 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2607 : dd3802 > cmp fLSR,x ;test flags > trap_ne 260a : d0fe > bne * ;failed not equal (non zero) > 260c : ca dex 260d : 10e0 bpl tlsr5 260f : a203 ldx #3 2611 : trol4 set_abs zp1,0 > load_flag 0 2611 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2613 : 48 > pha ;use stack to load status 2614 : b513 > lda zp1,x ;load to memory 2616 : 8d0302 > sta abst 2619 : 28 > plp 261a : 2e0302 rol abst tst_abs rROL,fROL,0 261d : 08 > php ;save flags 261e : ad0302 > lda abst 2621 : dd2002 > cmp rROL,x ;test result > trap_ne 2624 : d0fe > bne * ;failed not equal (non zero) > 2626 : 68 > pla ;load status > eor_flag 0 2627 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2629 : dd3002 > cmp fROL,x ;test flags > trap_ne 262c : d0fe > bne * ;failed not equal (non zero) > 262e : ca dex 262f : 10e0 bpl trol4 2631 : a203 ldx #3 2633 : trol5 set_abs zp1,$ff-fc > load_flag $ff-fc 2633 : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 2635 : 48 > pha ;use stack to load status 2636 : b513 > lda zp1,x ;load to memory 2638 : 8d0302 > sta abst 263b : 28 > plp 263c : 2e0302 rol abst tst_abs rROL,fROL,$ff-fnzc 263f : 08 > php ;save flags 2640 : ad0302 > lda abst 2643 : dd2002 > cmp rROL,x ;test result > trap_ne 2646 : d0fe > bne * ;failed not equal (non zero) > 2648 : 68 > pla ;load status > eor_flag $ff-fnzc 2649 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 264b : dd3002 > cmp fROL,x ;test flags > trap_ne 264e : d0fe > bne * ;failed not equal (non zero) > 2650 : ca dex 2651 : 10e0 bpl trol5 2653 : a203 ldx #3 2655 : trolc4 set_abs zp1,fc > load_flag fc 2655 : a901 > lda #fc ;allow test to change I-flag (no mask) > 2657 : 48 > pha ;use stack to load status 2658 : b513 > lda zp1,x ;load to memory 265a : 8d0302 > sta abst 265d : 28 > plp 265e : 2e0302 rol abst tst_abs rROLc,fROLc,0 2661 : 08 > php ;save flags 2662 : ad0302 > lda abst 2665 : dd2402 > cmp rROLc,x ;test result > trap_ne 2668 : d0fe > bne * ;failed not equal (non zero) > 266a : 68 > pla ;load status > eor_flag 0 266b : 4930 > eor #0|fao ;invert expected flags + always on bits > 266d : dd3402 > cmp fROLc,x ;test flags > trap_ne 2670 : d0fe > bne * ;failed not equal (non zero) > 2672 : ca dex 2673 : 10e0 bpl trolc4 2675 : a203 ldx #3 2677 : trolc5 set_abs zp1,$ff > load_flag $ff 2677 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2679 : 48 > pha ;use stack to load status 267a : b513 > lda zp1,x ;load to memory 267c : 8d0302 > sta abst 267f : 28 > plp 2680 : 2e0302 rol abst tst_abs rROLc,fROLc,$ff-fnzc 2683 : 08 > php ;save flags 2684 : ad0302 > lda abst 2687 : dd2402 > cmp rROLc,x ;test result > trap_ne 268a : d0fe > bne * ;failed not equal (non zero) > 268c : 68 > pla ;load status > eor_flag $ff-fnzc 268d : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 268f : dd3402 > cmp fROLc,x ;test flags > trap_ne 2692 : d0fe > bne * ;failed not equal (non zero) > 2694 : ca dex 2695 : 10e0 bpl trolc5 2697 : a203 ldx #3 2699 : tror4 set_abs zp1,0 > load_flag 0 2699 : a900 > lda #0 ;allow test to change I-flag (no mask) > 269b : 48 > pha ;use stack to load status 269c : b513 > lda zp1,x ;load to memory 269e : 8d0302 > sta abst 26a1 : 28 > plp 26a2 : 6e0302 ror abst tst_abs rROR,fROR,0 26a5 : 08 > php ;save flags 26a6 : ad0302 > lda abst 26a9 : dd2802 > cmp rROR,x ;test result > trap_ne 26ac : d0fe > bne * ;failed not equal (non zero) > 26ae : 68 > pla ;load status > eor_flag 0 26af : 4930 > eor #0|fao ;invert expected flags + always on bits > 26b1 : dd3802 > cmp fROR,x ;test flags > trap_ne 26b4 : d0fe > bne * ;failed not equal (non zero) > 26b6 : ca dex 26b7 : 10e0 bpl tror4 26b9 : a203 ldx #3 26bb : tror5 set_abs zp1,$ff-fc > load_flag $ff-fc 26bb : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 26bd : 48 > pha ;use stack to load status 26be : b513 > lda zp1,x ;load to memory 26c0 : 8d0302 > sta abst 26c3 : 28 > plp 26c4 : 6e0302 ror abst tst_abs rROR,fROR,$ff-fnzc 26c7 : 08 > php ;save flags 26c8 : ad0302 > lda abst 26cb : dd2802 > cmp rROR,x ;test result > trap_ne 26ce : d0fe > bne * ;failed not equal (non zero) > 26d0 : 68 > pla ;load status > eor_flag $ff-fnzc 26d1 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 26d3 : dd3802 > cmp fROR,x ;test flags > trap_ne 26d6 : d0fe > bne * ;failed not equal (non zero) > 26d8 : ca dex 26d9 : 10e0 bpl tror5 26db : a203 ldx #3 26dd : trorc4 set_abs zp1,fc > load_flag fc 26dd : a901 > lda #fc ;allow test to change I-flag (no mask) > 26df : 48 > pha ;use stack to load status 26e0 : b513 > lda zp1,x ;load to memory 26e2 : 8d0302 > sta abst 26e5 : 28 > plp 26e6 : 6e0302 ror abst tst_abs rRORc,fRORc,0 26e9 : 08 > php ;save flags 26ea : ad0302 > lda abst 26ed : dd2c02 > cmp rRORc,x ;test result > trap_ne 26f0 : d0fe > bne * ;failed not equal (non zero) > 26f2 : 68 > pla ;load status > eor_flag 0 26f3 : 4930 > eor #0|fao ;invert expected flags + always on bits > 26f5 : dd3c02 > cmp fRORc,x ;test flags > trap_ne 26f8 : d0fe > bne * ;failed not equal (non zero) > 26fa : ca dex 26fb : 10e0 bpl trorc4 26fd : a203 ldx #3 26ff : trorc5 set_abs zp1,$ff > load_flag $ff 26ff : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2701 : 48 > pha ;use stack to load status 2702 : b513 > lda zp1,x ;load to memory 2704 : 8d0302 > sta abst 2707 : 28 > plp 2708 : 6e0302 ror abst tst_abs rRORc,fRORc,$ff-fnzc 270b : 08 > php ;save flags 270c : ad0302 > lda abst 270f : dd2c02 > cmp rRORc,x ;test result > trap_ne 2712 : d0fe > bne * ;failed not equal (non zero) > 2714 : 68 > pla ;load status > eor_flag $ff-fnzc 2715 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2717 : dd3c02 > cmp fRORc,x ;test flags > trap_ne 271a : d0fe > bne * ;failed not equal (non zero) > 271c : ca dex 271d : 10e0 bpl trorc5 next_test 271f : ad0002 > lda test_case ;previous test 2722 : c91f > cmp #test_num > trap_ne ;test is out of sequence 2724 : d0fe > bne * ;failed not equal (non zero) > 0020 = >test_num = test_num + 1 2726 : a920 > lda #test_num ;*** next tests' number 2728 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; shifts - zp indexed 272b : a203 ldx #3 272d : tasl6 set_zx zp1,0 > load_flag 0 272d : a900 > lda #0 ;allow test to change I-flag (no mask) > 272f : 48 > pha ;use stack to load status 2730 : b513 > lda zp1,x ;load to indexed zeropage 2732 : 950c > sta zpt,x 2734 : 28 > plp 2735 : 160c asl zpt,x tst_zx rASL,fASL,0 2737 : 08 > php ;save flags 2738 : b50c > lda zpt,x 273a : dd2002 > cmp rASL,x ;test result > trap_ne 273d : d0fe > bne * ;failed not equal (non zero) > 273f : 68 > pla ;load status > eor_flag 0 2740 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2742 : dd3002 > cmp fASL,x ;test flags > trap_ne 2745 : d0fe > bne * ;failed not equal (non zero) > 2747 : ca dex 2748 : 10e3 bpl tasl6 274a : a203 ldx #3 274c : tasl7 set_zx zp1,$ff > load_flag $ff 274c : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 274e : 48 > pha ;use stack to load status 274f : b513 > lda zp1,x ;load to indexed zeropage 2751 : 950c > sta zpt,x 2753 : 28 > plp 2754 : 160c asl zpt,x tst_zx rASL,fASL,$ff-fnzc 2756 : 08 > php ;save flags 2757 : b50c > lda zpt,x 2759 : dd2002 > cmp rASL,x ;test result > trap_ne 275c : d0fe > bne * ;failed not equal (non zero) > 275e : 68 > pla ;load status > eor_flag $ff-fnzc 275f : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2761 : dd3002 > cmp fASL,x ;test flags > trap_ne 2764 : d0fe > bne * ;failed not equal (non zero) > 2766 : ca dex 2767 : 10e3 bpl tasl7 2769 : a203 ldx #3 276b : tlsr6 set_zx zp1,0 > load_flag 0 276b : a900 > lda #0 ;allow test to change I-flag (no mask) > 276d : 48 > pha ;use stack to load status 276e : b513 > lda zp1,x ;load to indexed zeropage 2770 : 950c > sta zpt,x 2772 : 28 > plp 2773 : 560c lsr zpt,x tst_zx rLSR,fLSR,0 2775 : 08 > php ;save flags 2776 : b50c > lda zpt,x 2778 : dd2802 > cmp rLSR,x ;test result > trap_ne 277b : d0fe > bne * ;failed not equal (non zero) > 277d : 68 > pla ;load status > eor_flag 0 277e : 4930 > eor #0|fao ;invert expected flags + always on bits > 2780 : dd3802 > cmp fLSR,x ;test flags > trap_ne 2783 : d0fe > bne * ;failed not equal (non zero) > 2785 : ca dex 2786 : 10e3 bpl tlsr6 2788 : a203 ldx #3 278a : tlsr7 set_zx zp1,$ff > load_flag $ff 278a : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 278c : 48 > pha ;use stack to load status 278d : b513 > lda zp1,x ;load to indexed zeropage 278f : 950c > sta zpt,x 2791 : 28 > plp 2792 : 560c lsr zpt,x tst_zx rLSR,fLSR,$ff-fnzc 2794 : 08 > php ;save flags 2795 : b50c > lda zpt,x 2797 : dd2802 > cmp rLSR,x ;test result > trap_ne 279a : d0fe > bne * ;failed not equal (non zero) > 279c : 68 > pla ;load status > eor_flag $ff-fnzc 279d : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 279f : dd3802 > cmp fLSR,x ;test flags > trap_ne 27a2 : d0fe > bne * ;failed not equal (non zero) > 27a4 : ca dex 27a5 : 10e3 bpl tlsr7 27a7 : a203 ldx #3 27a9 : trol6 set_zx zp1,0 > load_flag 0 27a9 : a900 > lda #0 ;allow test to change I-flag (no mask) > 27ab : 48 > pha ;use stack to load status 27ac : b513 > lda zp1,x ;load to indexed zeropage 27ae : 950c > sta zpt,x 27b0 : 28 > plp 27b1 : 360c rol zpt,x tst_zx rROL,fROL,0 27b3 : 08 > php ;save flags 27b4 : b50c > lda zpt,x 27b6 : dd2002 > cmp rROL,x ;test result > trap_ne 27b9 : d0fe > bne * ;failed not equal (non zero) > 27bb : 68 > pla ;load status > eor_flag 0 27bc : 4930 > eor #0|fao ;invert expected flags + always on bits > 27be : dd3002 > cmp fROL,x ;test flags > trap_ne 27c1 : d0fe > bne * ;failed not equal (non zero) > 27c3 : ca dex 27c4 : 10e3 bpl trol6 27c6 : a203 ldx #3 27c8 : trol7 set_zx zp1,$ff-fc > load_flag $ff-fc 27c8 : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 27ca : 48 > pha ;use stack to load status 27cb : b513 > lda zp1,x ;load to indexed zeropage 27cd : 950c > sta zpt,x 27cf : 28 > plp 27d0 : 360c rol zpt,x tst_zx rROL,fROL,$ff-fnzc 27d2 : 08 > php ;save flags 27d3 : b50c > lda zpt,x 27d5 : dd2002 > cmp rROL,x ;test result > trap_ne 27d8 : d0fe > bne * ;failed not equal (non zero) > 27da : 68 > pla ;load status > eor_flag $ff-fnzc 27db : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 27dd : dd3002 > cmp fROL,x ;test flags > trap_ne 27e0 : d0fe > bne * ;failed not equal (non zero) > 27e2 : ca dex 27e3 : 10e3 bpl trol7 27e5 : a203 ldx #3 27e7 : trolc6 set_zx zp1,fc > load_flag fc 27e7 : a901 > lda #fc ;allow test to change I-flag (no mask) > 27e9 : 48 > pha ;use stack to load status 27ea : b513 > lda zp1,x ;load to indexed zeropage 27ec : 950c > sta zpt,x 27ee : 28 > plp 27ef : 360c rol zpt,x tst_zx rROLc,fROLc,0 27f1 : 08 > php ;save flags 27f2 : b50c > lda zpt,x 27f4 : dd2402 > cmp rROLc,x ;test result > trap_ne 27f7 : d0fe > bne * ;failed not equal (non zero) > 27f9 : 68 > pla ;load status > eor_flag 0 27fa : 4930 > eor #0|fao ;invert expected flags + always on bits > 27fc : dd3402 > cmp fROLc,x ;test flags > trap_ne 27ff : d0fe > bne * ;failed not equal (non zero) > 2801 : ca dex 2802 : 10e3 bpl trolc6 2804 : a203 ldx #3 2806 : trolc7 set_zx zp1,$ff > load_flag $ff 2806 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2808 : 48 > pha ;use stack to load status 2809 : b513 > lda zp1,x ;load to indexed zeropage 280b : 950c > sta zpt,x 280d : 28 > plp 280e : 360c rol zpt,x tst_zx rROLc,fROLc,$ff-fnzc 2810 : 08 > php ;save flags 2811 : b50c > lda zpt,x 2813 : dd2402 > cmp rROLc,x ;test result > trap_ne 2816 : d0fe > bne * ;failed not equal (non zero) > 2818 : 68 > pla ;load status > eor_flag $ff-fnzc 2819 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 281b : dd3402 > cmp fROLc,x ;test flags > trap_ne 281e : d0fe > bne * ;failed not equal (non zero) > 2820 : ca dex 2821 : 10e3 bpl trolc7 2823 : a203 ldx #3 2825 : tror6 set_zx zp1,0 > load_flag 0 2825 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2827 : 48 > pha ;use stack to load status 2828 : b513 > lda zp1,x ;load to indexed zeropage 282a : 950c > sta zpt,x 282c : 28 > plp 282d : 760c ror zpt,x tst_zx rROR,fROR,0 282f : 08 > php ;save flags 2830 : b50c > lda zpt,x 2832 : dd2802 > cmp rROR,x ;test result > trap_ne 2835 : d0fe > bne * ;failed not equal (non zero) > 2837 : 68 > pla ;load status > eor_flag 0 2838 : 4930 > eor #0|fao ;invert expected flags + always on bits > 283a : dd3802 > cmp fROR,x ;test flags > trap_ne 283d : d0fe > bne * ;failed not equal (non zero) > 283f : ca dex 2840 : 10e3 bpl tror6 2842 : a203 ldx #3 2844 : tror7 set_zx zp1,$ff-fc > load_flag $ff-fc 2844 : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 2846 : 48 > pha ;use stack to load status 2847 : b513 > lda zp1,x ;load to indexed zeropage 2849 : 950c > sta zpt,x 284b : 28 > plp 284c : 760c ror zpt,x tst_zx rROR,fROR,$ff-fnzc 284e : 08 > php ;save flags 284f : b50c > lda zpt,x 2851 : dd2802 > cmp rROR,x ;test result > trap_ne 2854 : d0fe > bne * ;failed not equal (non zero) > 2856 : 68 > pla ;load status > eor_flag $ff-fnzc 2857 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2859 : dd3802 > cmp fROR,x ;test flags > trap_ne 285c : d0fe > bne * ;failed not equal (non zero) > 285e : ca dex 285f : 10e3 bpl tror7 2861 : a203 ldx #3 2863 : trorc6 set_zx zp1,fc > load_flag fc 2863 : a901 > lda #fc ;allow test to change I-flag (no mask) > 2865 : 48 > pha ;use stack to load status 2866 : b513 > lda zp1,x ;load to indexed zeropage 2868 : 950c > sta zpt,x 286a : 28 > plp 286b : 760c ror zpt,x tst_zx rRORc,fRORc,0 286d : 08 > php ;save flags 286e : b50c > lda zpt,x 2870 : dd2c02 > cmp rRORc,x ;test result > trap_ne 2873 : d0fe > bne * ;failed not equal (non zero) > 2875 : 68 > pla ;load status > eor_flag 0 2876 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2878 : dd3c02 > cmp fRORc,x ;test flags > trap_ne 287b : d0fe > bne * ;failed not equal (non zero) > 287d : ca dex 287e : 10e3 bpl trorc6 2880 : a203 ldx #3 2882 : trorc7 set_zx zp1,$ff > load_flag $ff 2882 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2884 : 48 > pha ;use stack to load status 2885 : b513 > lda zp1,x ;load to indexed zeropage 2887 : 950c > sta zpt,x 2889 : 28 > plp 288a : 760c ror zpt,x tst_zx rRORc,fRORc,$ff-fnzc 288c : 08 > php ;save flags 288d : b50c > lda zpt,x 288f : dd2c02 > cmp rRORc,x ;test result > trap_ne 2892 : d0fe > bne * ;failed not equal (non zero) > 2894 : 68 > pla ;load status > eor_flag $ff-fnzc 2895 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2897 : dd3c02 > cmp fRORc,x ;test flags > trap_ne 289a : d0fe > bne * ;failed not equal (non zero) > 289c : ca dex 289d : 10e3 bpl trorc7 next_test 289f : ad0002 > lda test_case ;previous test 28a2 : c920 > cmp #test_num > trap_ne ;test is out of sequence 28a4 : d0fe > bne * ;failed not equal (non zero) > 0021 = >test_num = test_num + 1 28a6 : a921 > lda #test_num ;*** next tests' number 28a8 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; shifts - abs indexed 28ab : a203 ldx #3 28ad : tasl8 set_absx zp1,0 > load_flag 0 28ad : a900 > lda #0 ;allow test to change I-flag (no mask) > 28af : 48 > pha ;use stack to load status 28b0 : b513 > lda zp1,x ;load to indexed memory 28b2 : 9d0302 > sta abst,x 28b5 : 28 > plp 28b6 : 1e0302 asl abst,x tst_absx rASL,fASL,0 28b9 : 08 > php ;save flags 28ba : bd0302 > lda abst,x 28bd : dd2002 > cmp rASL,x ;test result > trap_ne 28c0 : d0fe > bne * ;failed not equal (non zero) > 28c2 : 68 > pla ;load status > eor_flag 0 28c3 : 4930 > eor #0|fao ;invert expected flags + always on bits > 28c5 : dd3002 > cmp fASL,x ;test flags > trap_ne 28c8 : d0fe > bne * ;failed not equal (non zero) > 28ca : ca dex 28cb : 10e0 bpl tasl8 28cd : a203 ldx #3 28cf : tasl9 set_absx zp1,$ff > load_flag $ff 28cf : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 28d1 : 48 > pha ;use stack to load status 28d2 : b513 > lda zp1,x ;load to indexed memory 28d4 : 9d0302 > sta abst,x 28d7 : 28 > plp 28d8 : 1e0302 asl abst,x tst_absx rASL,fASL,$ff-fnzc 28db : 08 > php ;save flags 28dc : bd0302 > lda abst,x 28df : dd2002 > cmp rASL,x ;test result > trap_ne 28e2 : d0fe > bne * ;failed not equal (non zero) > 28e4 : 68 > pla ;load status > eor_flag $ff-fnzc 28e5 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 28e7 : dd3002 > cmp fASL,x ;test flags > trap_ne 28ea : d0fe > bne * ;failed not equal (non zero) > 28ec : ca dex 28ed : 10e0 bpl tasl9 28ef : a203 ldx #3 28f1 : tlsr8 set_absx zp1,0 > load_flag 0 28f1 : a900 > lda #0 ;allow test to change I-flag (no mask) > 28f3 : 48 > pha ;use stack to load status 28f4 : b513 > lda zp1,x ;load to indexed memory 28f6 : 9d0302 > sta abst,x 28f9 : 28 > plp 28fa : 5e0302 lsr abst,x tst_absx rLSR,fLSR,0 28fd : 08 > php ;save flags 28fe : bd0302 > lda abst,x 2901 : dd2802 > cmp rLSR,x ;test result > trap_ne 2904 : d0fe > bne * ;failed not equal (non zero) > 2906 : 68 > pla ;load status > eor_flag 0 2907 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2909 : dd3802 > cmp fLSR,x ;test flags > trap_ne 290c : d0fe > bne * ;failed not equal (non zero) > 290e : ca dex 290f : 10e0 bpl tlsr8 2911 : a203 ldx #3 2913 : tlsr9 set_absx zp1,$ff > load_flag $ff 2913 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2915 : 48 > pha ;use stack to load status 2916 : b513 > lda zp1,x ;load to indexed memory 2918 : 9d0302 > sta abst,x 291b : 28 > plp 291c : 5e0302 lsr abst,x tst_absx rLSR,fLSR,$ff-fnzc 291f : 08 > php ;save flags 2920 : bd0302 > lda abst,x 2923 : dd2802 > cmp rLSR,x ;test result > trap_ne 2926 : d0fe > bne * ;failed not equal (non zero) > 2928 : 68 > pla ;load status > eor_flag $ff-fnzc 2929 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 292b : dd3802 > cmp fLSR,x ;test flags > trap_ne 292e : d0fe > bne * ;failed not equal (non zero) > 2930 : ca dex 2931 : 10e0 bpl tlsr9 2933 : a203 ldx #3 2935 : trol8 set_absx zp1,0 > load_flag 0 2935 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2937 : 48 > pha ;use stack to load status 2938 : b513 > lda zp1,x ;load to indexed memory 293a : 9d0302 > sta abst,x 293d : 28 > plp 293e : 3e0302 rol abst,x tst_absx rROL,fROL,0 2941 : 08 > php ;save flags 2942 : bd0302 > lda abst,x 2945 : dd2002 > cmp rROL,x ;test result > trap_ne 2948 : d0fe > bne * ;failed not equal (non zero) > 294a : 68 > pla ;load status > eor_flag 0 294b : 4930 > eor #0|fao ;invert expected flags + always on bits > 294d : dd3002 > cmp fROL,x ;test flags > trap_ne 2950 : d0fe > bne * ;failed not equal (non zero) > 2952 : ca dex 2953 : 10e0 bpl trol8 2955 : a203 ldx #3 2957 : trol9 set_absx zp1,$ff-fc > load_flag $ff-fc 2957 : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 2959 : 48 > pha ;use stack to load status 295a : b513 > lda zp1,x ;load to indexed memory 295c : 9d0302 > sta abst,x 295f : 28 > plp 2960 : 3e0302 rol abst,x tst_absx rROL,fROL,$ff-fnzc 2963 : 08 > php ;save flags 2964 : bd0302 > lda abst,x 2967 : dd2002 > cmp rROL,x ;test result > trap_ne 296a : d0fe > bne * ;failed not equal (non zero) > 296c : 68 > pla ;load status > eor_flag $ff-fnzc 296d : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 296f : dd3002 > cmp fROL,x ;test flags > trap_ne 2972 : d0fe > bne * ;failed not equal (non zero) > 2974 : ca dex 2975 : 10e0 bpl trol9 2977 : a203 ldx #3 2979 : trolc8 set_absx zp1,fc > load_flag fc 2979 : a901 > lda #fc ;allow test to change I-flag (no mask) > 297b : 48 > pha ;use stack to load status 297c : b513 > lda zp1,x ;load to indexed memory 297e : 9d0302 > sta abst,x 2981 : 28 > plp 2982 : 3e0302 rol abst,x tst_absx rROLc,fROLc,0 2985 : 08 > php ;save flags 2986 : bd0302 > lda abst,x 2989 : dd2402 > cmp rROLc,x ;test result > trap_ne 298c : d0fe > bne * ;failed not equal (non zero) > 298e : 68 > pla ;load status > eor_flag 0 298f : 4930 > eor #0|fao ;invert expected flags + always on bits > 2991 : dd3402 > cmp fROLc,x ;test flags > trap_ne 2994 : d0fe > bne * ;failed not equal (non zero) > 2996 : ca dex 2997 : 10e0 bpl trolc8 2999 : a203 ldx #3 299b : trolc9 set_absx zp1,$ff > load_flag $ff 299b : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 299d : 48 > pha ;use stack to load status 299e : b513 > lda zp1,x ;load to indexed memory 29a0 : 9d0302 > sta abst,x 29a3 : 28 > plp 29a4 : 3e0302 rol abst,x tst_absx rROLc,fROLc,$ff-fnzc 29a7 : 08 > php ;save flags 29a8 : bd0302 > lda abst,x 29ab : dd2402 > cmp rROLc,x ;test result > trap_ne 29ae : d0fe > bne * ;failed not equal (non zero) > 29b0 : 68 > pla ;load status > eor_flag $ff-fnzc 29b1 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 29b3 : dd3402 > cmp fROLc,x ;test flags > trap_ne 29b6 : d0fe > bne * ;failed not equal (non zero) > 29b8 : ca dex 29b9 : 10e0 bpl trolc9 29bb : a203 ldx #3 29bd : tror8 set_absx zp1,0 > load_flag 0 29bd : a900 > lda #0 ;allow test to change I-flag (no mask) > 29bf : 48 > pha ;use stack to load status 29c0 : b513 > lda zp1,x ;load to indexed memory 29c2 : 9d0302 > sta abst,x 29c5 : 28 > plp 29c6 : 7e0302 ror abst,x tst_absx rROR,fROR,0 29c9 : 08 > php ;save flags 29ca : bd0302 > lda abst,x 29cd : dd2802 > cmp rROR,x ;test result > trap_ne 29d0 : d0fe > bne * ;failed not equal (non zero) > 29d2 : 68 > pla ;load status > eor_flag 0 29d3 : 4930 > eor #0|fao ;invert expected flags + always on bits > 29d5 : dd3802 > cmp fROR,x ;test flags > trap_ne 29d8 : d0fe > bne * ;failed not equal (non zero) > 29da : ca dex 29db : 10e0 bpl tror8 29dd : a203 ldx #3 29df : tror9 set_absx zp1,$ff-fc > load_flag $ff-fc 29df : a9fe > lda #$ff-fc ;allow test to change I-flag (no mask) > 29e1 : 48 > pha ;use stack to load status 29e2 : b513 > lda zp1,x ;load to indexed memory 29e4 : 9d0302 > sta abst,x 29e7 : 28 > plp 29e8 : 7e0302 ror abst,x tst_absx rROR,fROR,$ff-fnzc 29eb : 08 > php ;save flags 29ec : bd0302 > lda abst,x 29ef : dd2802 > cmp rROR,x ;test result > trap_ne 29f2 : d0fe > bne * ;failed not equal (non zero) > 29f4 : 68 > pla ;load status > eor_flag $ff-fnzc 29f5 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 29f7 : dd3802 > cmp fROR,x ;test flags > trap_ne 29fa : d0fe > bne * ;failed not equal (non zero) > 29fc : ca dex 29fd : 10e0 bpl tror9 29ff : a203 ldx #3 2a01 : trorc8 set_absx zp1,fc > load_flag fc 2a01 : a901 > lda #fc ;allow test to change I-flag (no mask) > 2a03 : 48 > pha ;use stack to load status 2a04 : b513 > lda zp1,x ;load to indexed memory 2a06 : 9d0302 > sta abst,x 2a09 : 28 > plp 2a0a : 7e0302 ror abst,x tst_absx rRORc,fRORc,0 2a0d : 08 > php ;save flags 2a0e : bd0302 > lda abst,x 2a11 : dd2c02 > cmp rRORc,x ;test result > trap_ne 2a14 : d0fe > bne * ;failed not equal (non zero) > 2a16 : 68 > pla ;load status > eor_flag 0 2a17 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2a19 : dd3c02 > cmp fRORc,x ;test flags > trap_ne 2a1c : d0fe > bne * ;failed not equal (non zero) > 2a1e : ca dex 2a1f : 10e0 bpl trorc8 2a21 : a203 ldx #3 2a23 : trorc9 set_absx zp1,$ff > load_flag $ff 2a23 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2a25 : 48 > pha ;use stack to load status 2a26 : b513 > lda zp1,x ;load to indexed memory 2a28 : 9d0302 > sta abst,x 2a2b : 28 > plp 2a2c : 7e0302 ror abst,x tst_absx rRORc,fRORc,$ff-fnzc 2a2f : 08 > php ;save flags 2a30 : bd0302 > lda abst,x 2a33 : dd2c02 > cmp rRORc,x ;test result > trap_ne 2a36 : d0fe > bne * ;failed not equal (non zero) > 2a38 : 68 > pla ;load status > eor_flag $ff-fnzc 2a39 : 497c > eor #$ff-fnzc|fao ;invert expected flags + always on bits > 2a3b : dd3c02 > cmp fRORc,x ;test flags > trap_ne 2a3e : d0fe > bne * ;failed not equal (non zero) > 2a40 : ca dex 2a41 : 10e0 bpl trorc9 next_test 2a43 : ad0002 > lda test_case ;previous test 2a46 : c921 > cmp #test_num > trap_ne ;test is out of sequence 2a48 : d0fe > bne * ;failed not equal (non zero) > 0022 = >test_num = test_num + 1 2a4a : a922 > lda #test_num ;*** next tests' number 2a4c : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; testing memory increment/decrement - INC DEC all addressing modes ; zeropage 2a4f : a200 ldx #0 2a51 : a97e lda #$7e 2a53 : 850c sta zpt 2a55 : tinc set_stat 0 > load_flag 0 2a55 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2a57 : 48 > pha ;use stack to load status 2a58 : 28 > plp 2a59 : e60c inc zpt tst_z rINC,fINC,0 2a5b : 08 > php ;save flags 2a5c : a50c > lda zpt 2a5e : dd4002 > cmp rINC,x ;test result > trap_ne 2a61 : d0fe > bne * ;failed not equal (non zero) > 2a63 : 68 > pla ;load status > eor_flag 0 2a64 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2a66 : dd4502 > cmp fINC,x ;test flags > trap_ne 2a69 : d0fe > bne * ;failed not equal (non zero) > 2a6b : e8 inx 2a6c : e002 cpx #2 2a6e : d004 bne tinc1 2a70 : a9fe lda #$fe 2a72 : 850c sta zpt 2a74 : e005 tinc1 cpx #5 2a76 : d0dd bne tinc 2a78 : ca dex 2a79 : e60c inc zpt 2a7b : tdec set_stat 0 > load_flag 0 2a7b : a900 > lda #0 ;allow test to change I-flag (no mask) > 2a7d : 48 > pha ;use stack to load status 2a7e : 28 > plp 2a7f : c60c dec zpt tst_z rINC,fINC,0 2a81 : 08 > php ;save flags 2a82 : a50c > lda zpt 2a84 : dd4002 > cmp rINC,x ;test result > trap_ne 2a87 : d0fe > bne * ;failed not equal (non zero) > 2a89 : 68 > pla ;load status > eor_flag 0 2a8a : 4930 > eor #0|fao ;invert expected flags + always on bits > 2a8c : dd4502 > cmp fINC,x ;test flags > trap_ne 2a8f : d0fe > bne * ;failed not equal (non zero) > 2a91 : ca dex 2a92 : 300a bmi tdec1 2a94 : e001 cpx #1 2a96 : d0e3 bne tdec 2a98 : a981 lda #$81 2a9a : 850c sta zpt 2a9c : d0dd bne tdec 2a9e : tdec1 2a9e : a200 ldx #0 2aa0 : a97e lda #$7e 2aa2 : 850c sta zpt 2aa4 : tinc10 set_stat $ff > load_flag $ff 2aa4 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2aa6 : 48 > pha ;use stack to load status 2aa7 : 28 > plp 2aa8 : e60c inc zpt tst_z rINC,fINC,$ff-fnz 2aaa : 08 > php ;save flags 2aab : a50c > lda zpt 2aad : dd4002 > cmp rINC,x ;test result > trap_ne 2ab0 : d0fe > bne * ;failed not equal (non zero) > 2ab2 : 68 > pla ;load status > eor_flag $ff-fnz 2ab3 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2ab5 : dd4502 > cmp fINC,x ;test flags > trap_ne 2ab8 : d0fe > bne * ;failed not equal (non zero) > 2aba : e8 inx 2abb : e002 cpx #2 2abd : d004 bne tinc11 2abf : a9fe lda #$fe 2ac1 : 850c sta zpt 2ac3 : e005 tinc11 cpx #5 2ac5 : d0dd bne tinc10 2ac7 : ca dex 2ac8 : e60c inc zpt 2aca : tdec10 set_stat $ff > load_flag $ff 2aca : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2acc : 48 > pha ;use stack to load status 2acd : 28 > plp 2ace : c60c dec zpt tst_z rINC,fINC,$ff-fnz 2ad0 : 08 > php ;save flags 2ad1 : a50c > lda zpt 2ad3 : dd4002 > cmp rINC,x ;test result > trap_ne 2ad6 : d0fe > bne * ;failed not equal (non zero) > 2ad8 : 68 > pla ;load status > eor_flag $ff-fnz 2ad9 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2adb : dd4502 > cmp fINC,x ;test flags > trap_ne 2ade : d0fe > bne * ;failed not equal (non zero) > 2ae0 : ca dex 2ae1 : 300a bmi tdec11 2ae3 : e001 cpx #1 2ae5 : d0e3 bne tdec10 2ae7 : a981 lda #$81 2ae9 : 850c sta zpt 2aeb : d0dd bne tdec10 2aed : tdec11 next_test 2aed : ad0002 > lda test_case ;previous test 2af0 : c922 > cmp #test_num > trap_ne ;test is out of sequence 2af2 : d0fe > bne * ;failed not equal (non zero) > 0023 = >test_num = test_num + 1 2af4 : a923 > lda #test_num ;*** next tests' number 2af6 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; absolute memory 2af9 : a200 ldx #0 2afb : a97e lda #$7e 2afd : 8d0302 sta abst 2b00 : tinc2 set_stat 0 > load_flag 0 2b00 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2b02 : 48 > pha ;use stack to load status 2b03 : 28 > plp 2b04 : ee0302 inc abst tst_abs rINC,fINC,0 2b07 : 08 > php ;save flags 2b08 : ad0302 > lda abst 2b0b : dd4002 > cmp rINC,x ;test result > trap_ne 2b0e : d0fe > bne * ;failed not equal (non zero) > 2b10 : 68 > pla ;load status > eor_flag 0 2b11 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2b13 : dd4502 > cmp fINC,x ;test flags > trap_ne 2b16 : d0fe > bne * ;failed not equal (non zero) > 2b18 : e8 inx 2b19 : e002 cpx #2 2b1b : d005 bne tinc3 2b1d : a9fe lda #$fe 2b1f : 8d0302 sta abst 2b22 : e005 tinc3 cpx #5 2b24 : d0da bne tinc2 2b26 : ca dex 2b27 : ee0302 inc abst 2b2a : tdec2 set_stat 0 > load_flag 0 2b2a : a900 > lda #0 ;allow test to change I-flag (no mask) > 2b2c : 48 > pha ;use stack to load status 2b2d : 28 > plp 2b2e : ce0302 dec abst tst_abs rINC,fINC,0 2b31 : 08 > php ;save flags 2b32 : ad0302 > lda abst 2b35 : dd4002 > cmp rINC,x ;test result > trap_ne 2b38 : d0fe > bne * ;failed not equal (non zero) > 2b3a : 68 > pla ;load status > eor_flag 0 2b3b : 4930 > eor #0|fao ;invert expected flags + always on bits > 2b3d : dd4502 > cmp fINC,x ;test flags > trap_ne 2b40 : d0fe > bne * ;failed not equal (non zero) > 2b42 : ca dex 2b43 : 300b bmi tdec3 2b45 : e001 cpx #1 2b47 : d0e1 bne tdec2 2b49 : a981 lda #$81 2b4b : 8d0302 sta abst 2b4e : d0da bne tdec2 2b50 : tdec3 2b50 : a200 ldx #0 2b52 : a97e lda #$7e 2b54 : 8d0302 sta abst 2b57 : tinc12 set_stat $ff > load_flag $ff 2b57 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2b59 : 48 > pha ;use stack to load status 2b5a : 28 > plp 2b5b : ee0302 inc abst tst_abs rINC,fINC,$ff-fnz 2b5e : 08 > php ;save flags 2b5f : ad0302 > lda abst 2b62 : dd4002 > cmp rINC,x ;test result > trap_ne 2b65 : d0fe > bne * ;failed not equal (non zero) > 2b67 : 68 > pla ;load status > eor_flag $ff-fnz 2b68 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2b6a : dd4502 > cmp fINC,x ;test flags > trap_ne 2b6d : d0fe > bne * ;failed not equal (non zero) > 2b6f : e8 inx 2b70 : e002 cpx #2 2b72 : d005 bne tinc13 2b74 : a9fe lda #$fe 2b76 : 8d0302 sta abst 2b79 : e005 tinc13 cpx #5 2b7b : d0da bne tinc12 2b7d : ca dex 2b7e : ee0302 inc abst 2b81 : tdec12 set_stat $ff > load_flag $ff 2b81 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2b83 : 48 > pha ;use stack to load status 2b84 : 28 > plp 2b85 : ce0302 dec abst tst_abs rINC,fINC,$ff-fnz 2b88 : 08 > php ;save flags 2b89 : ad0302 > lda abst 2b8c : dd4002 > cmp rINC,x ;test result > trap_ne 2b8f : d0fe > bne * ;failed not equal (non zero) > 2b91 : 68 > pla ;load status > eor_flag $ff-fnz 2b92 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2b94 : dd4502 > cmp fINC,x ;test flags > trap_ne 2b97 : d0fe > bne * ;failed not equal (non zero) > 2b99 : ca dex 2b9a : 300b bmi tdec13 2b9c : e001 cpx #1 2b9e : d0e1 bne tdec12 2ba0 : a981 lda #$81 2ba2 : 8d0302 sta abst 2ba5 : d0da bne tdec12 2ba7 : tdec13 next_test 2ba7 : ad0002 > lda test_case ;previous test 2baa : c923 > cmp #test_num > trap_ne ;test is out of sequence 2bac : d0fe > bne * ;failed not equal (non zero) > 0024 = >test_num = test_num + 1 2bae : a924 > lda #test_num ;*** next tests' number 2bb0 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; zeropage indexed 2bb3 : a200 ldx #0 2bb5 : a97e lda #$7e 2bb7 : 950c tinc4 sta zpt,x set_stat 0 > load_flag 0 2bb9 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2bbb : 48 > pha ;use stack to load status 2bbc : 28 > plp 2bbd : f60c inc zpt,x tst_zx rINC,fINC,0 2bbf : 08 > php ;save flags 2bc0 : b50c > lda zpt,x 2bc2 : dd4002 > cmp rINC,x ;test result > trap_ne 2bc5 : d0fe > bne * ;failed not equal (non zero) > 2bc7 : 68 > pla ;load status > eor_flag 0 2bc8 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2bca : dd4502 > cmp fINC,x ;test flags > trap_ne 2bcd : d0fe > bne * ;failed not equal (non zero) > 2bcf : b50c lda zpt,x 2bd1 : e8 inx 2bd2 : e002 cpx #2 2bd4 : d002 bne tinc5 2bd6 : a9fe lda #$fe 2bd8 : e005 tinc5 cpx #5 2bda : d0db bne tinc4 2bdc : ca dex 2bdd : a902 lda #2 2bdf : 950c tdec4 sta zpt,x set_stat 0 > load_flag 0 2be1 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2be3 : 48 > pha ;use stack to load status 2be4 : 28 > plp 2be5 : d60c dec zpt,x tst_zx rINC,fINC,0 2be7 : 08 > php ;save flags 2be8 : b50c > lda zpt,x 2bea : dd4002 > cmp rINC,x ;test result > trap_ne 2bed : d0fe > bne * ;failed not equal (non zero) > 2bef : 68 > pla ;load status > eor_flag 0 2bf0 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2bf2 : dd4502 > cmp fINC,x ;test flags > trap_ne 2bf5 : d0fe > bne * ;failed not equal (non zero) > 2bf7 : b50c lda zpt,x 2bf9 : ca dex 2bfa : 3008 bmi tdec5 2bfc : e001 cpx #1 2bfe : d0df bne tdec4 2c00 : a981 lda #$81 2c02 : d0db bne tdec4 2c04 : tdec5 2c04 : a200 ldx #0 2c06 : a97e lda #$7e 2c08 : 950c tinc14 sta zpt,x set_stat $ff > load_flag $ff 2c0a : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2c0c : 48 > pha ;use stack to load status 2c0d : 28 > plp 2c0e : f60c inc zpt,x tst_zx rINC,fINC,$ff-fnz 2c10 : 08 > php ;save flags 2c11 : b50c > lda zpt,x 2c13 : dd4002 > cmp rINC,x ;test result > trap_ne 2c16 : d0fe > bne * ;failed not equal (non zero) > 2c18 : 68 > pla ;load status > eor_flag $ff-fnz 2c19 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2c1b : dd4502 > cmp fINC,x ;test flags > trap_ne 2c1e : d0fe > bne * ;failed not equal (non zero) > 2c20 : b50c lda zpt,x 2c22 : e8 inx 2c23 : e002 cpx #2 2c25 : d002 bne tinc15 2c27 : a9fe lda #$fe 2c29 : e005 tinc15 cpx #5 2c2b : d0db bne tinc14 2c2d : ca dex 2c2e : a902 lda #2 2c30 : 950c tdec14 sta zpt,x set_stat $ff > load_flag $ff 2c32 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2c34 : 48 > pha ;use stack to load status 2c35 : 28 > plp 2c36 : d60c dec zpt,x tst_zx rINC,fINC,$ff-fnz 2c38 : 08 > php ;save flags 2c39 : b50c > lda zpt,x 2c3b : dd4002 > cmp rINC,x ;test result > trap_ne 2c3e : d0fe > bne * ;failed not equal (non zero) > 2c40 : 68 > pla ;load status > eor_flag $ff-fnz 2c41 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2c43 : dd4502 > cmp fINC,x ;test flags > trap_ne 2c46 : d0fe > bne * ;failed not equal (non zero) > 2c48 : b50c lda zpt,x 2c4a : ca dex 2c4b : 3008 bmi tdec15 2c4d : e001 cpx #1 2c4f : d0df bne tdec14 2c51 : a981 lda #$81 2c53 : d0db bne tdec14 2c55 : tdec15 next_test 2c55 : ad0002 > lda test_case ;previous test 2c58 : c924 > cmp #test_num > trap_ne ;test is out of sequence 2c5a : d0fe > bne * ;failed not equal (non zero) > 0025 = >test_num = test_num + 1 2c5c : a925 > lda #test_num ;*** next tests' number 2c5e : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; memory indexed 2c61 : a200 ldx #0 2c63 : a97e lda #$7e 2c65 : 9d0302 tinc6 sta abst,x set_stat 0 > load_flag 0 2c68 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2c6a : 48 > pha ;use stack to load status 2c6b : 28 > plp 2c6c : fe0302 inc abst,x tst_absx rINC,fINC,0 2c6f : 08 > php ;save flags 2c70 : bd0302 > lda abst,x 2c73 : dd4002 > cmp rINC,x ;test result > trap_ne 2c76 : d0fe > bne * ;failed not equal (non zero) > 2c78 : 68 > pla ;load status > eor_flag 0 2c79 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2c7b : dd4502 > cmp fINC,x ;test flags > trap_ne 2c7e : d0fe > bne * ;failed not equal (non zero) > 2c80 : bd0302 lda abst,x 2c83 : e8 inx 2c84 : e002 cpx #2 2c86 : d002 bne tinc7 2c88 : a9fe lda #$fe 2c8a : e005 tinc7 cpx #5 2c8c : d0d7 bne tinc6 2c8e : ca dex 2c8f : a902 lda #2 2c91 : 9d0302 tdec6 sta abst,x set_stat 0 > load_flag 0 2c94 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2c96 : 48 > pha ;use stack to load status 2c97 : 28 > plp 2c98 : de0302 dec abst,x tst_absx rINC,fINC,0 2c9b : 08 > php ;save flags 2c9c : bd0302 > lda abst,x 2c9f : dd4002 > cmp rINC,x ;test result > trap_ne 2ca2 : d0fe > bne * ;failed not equal (non zero) > 2ca4 : 68 > pla ;load status > eor_flag 0 2ca5 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2ca7 : dd4502 > cmp fINC,x ;test flags > trap_ne 2caa : d0fe > bne * ;failed not equal (non zero) > 2cac : bd0302 lda abst,x 2caf : ca dex 2cb0 : 3008 bmi tdec7 2cb2 : e001 cpx #1 2cb4 : d0db bne tdec6 2cb6 : a981 lda #$81 2cb8 : d0d7 bne tdec6 2cba : tdec7 2cba : a200 ldx #0 2cbc : a97e lda #$7e 2cbe : 9d0302 tinc16 sta abst,x set_stat $ff > load_flag $ff 2cc1 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2cc3 : 48 > pha ;use stack to load status 2cc4 : 28 > plp 2cc5 : fe0302 inc abst,x tst_absx rINC,fINC,$ff-fnz 2cc8 : 08 > php ;save flags 2cc9 : bd0302 > lda abst,x 2ccc : dd4002 > cmp rINC,x ;test result > trap_ne 2ccf : d0fe > bne * ;failed not equal (non zero) > 2cd1 : 68 > pla ;load status > eor_flag $ff-fnz 2cd2 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2cd4 : dd4502 > cmp fINC,x ;test flags > trap_ne 2cd7 : d0fe > bne * ;failed not equal (non zero) > 2cd9 : bd0302 lda abst,x 2cdc : e8 inx 2cdd : e002 cpx #2 2cdf : d002 bne tinc17 2ce1 : a9fe lda #$fe 2ce3 : e005 tinc17 cpx #5 2ce5 : d0d7 bne tinc16 2ce7 : ca dex 2ce8 : a902 lda #2 2cea : 9d0302 tdec16 sta abst,x set_stat $ff > load_flag $ff 2ced : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2cef : 48 > pha ;use stack to load status 2cf0 : 28 > plp 2cf1 : de0302 dec abst,x tst_absx rINC,fINC,$ff-fnz 2cf4 : 08 > php ;save flags 2cf5 : bd0302 > lda abst,x 2cf8 : dd4002 > cmp rINC,x ;test result > trap_ne 2cfb : d0fe > bne * ;failed not equal (non zero) > 2cfd : 68 > pla ;load status > eor_flag $ff-fnz 2cfe : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2d00 : dd4502 > cmp fINC,x ;test flags > trap_ne 2d03 : d0fe > bne * ;failed not equal (non zero) > 2d05 : bd0302 lda abst,x 2d08 : ca dex 2d09 : 3008 bmi tdec17 2d0b : e001 cpx #1 2d0d : d0db bne tdec16 2d0f : a981 lda #$81 2d11 : d0d7 bne tdec16 2d13 : tdec17 next_test 2d13 : ad0002 > lda test_case ;previous test 2d16 : c925 > cmp #test_num > trap_ne ;test is out of sequence 2d18 : d0fe > bne * ;failed not equal (non zero) > 0026 = >test_num = test_num + 1 2d1a : a926 > lda #test_num ;*** next tests' number 2d1c : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; testing logical instructions - AND EOR ORA all addressing modes ; AND 2d1f : a203 ldx #3 ;immediate 2d21 : b51c tand lda zpAN,x 2d23 : 8d0902 sta ex_andi+1 ;set AND # operand set_ax absANa,0 > load_flag 0 2d26 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2d28 : 48 > pha ;use stack to load status 2d29 : bd5a02 > lda absANa,x ;precharge accu 2d2c : 28 > plp 2d2d : 200802 jsr ex_andi ;execute AND # in RAM tst_ax absrlo,absflo,0 2d30 : 08 > php ;save flags 2d31 : dd6202 > cmp absrlo,x ;test result > trap_ne 2d34 : d0fe > bne * ;failed not equal (non zero) > 2d36 : 68 > pla ;load status > eor_flag 0 2d37 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2d39 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2d3c : d0fe > bne * ;failed not equal (non zero) > 2d3e : ca dex 2d3f : 10e0 bpl tand 2d41 : a203 ldx #3 2d43 : b51c tand1 lda zpAN,x 2d45 : 8d0902 sta ex_andi+1 ;set AND # operand set_ax absANa,$ff > load_flag $ff 2d48 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2d4a : 48 > pha ;use stack to load status 2d4b : bd5a02 > lda absANa,x ;precharge accu 2d4e : 28 > plp 2d4f : 200802 jsr ex_andi ;execute AND # in RAM tst_ax absrlo,absflo,$ff-fnz 2d52 : 08 > php ;save flags 2d53 : dd6202 > cmp absrlo,x ;test result > trap_ne 2d56 : d0fe > bne * ;failed not equal (non zero) > 2d58 : 68 > pla ;load status > eor_flag $ff-fnz 2d59 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2d5b : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2d5e : d0fe > bne * ;failed not equal (non zero) > 2d60 : ca dex 2d61 : 10e0 bpl tand1 2d63 : a203 ldx #3 ;zp 2d65 : b51c tand2 lda zpAN,x 2d67 : 850c sta zpt set_ax absANa,0 > load_flag 0 2d69 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2d6b : 48 > pha ;use stack to load status 2d6c : bd5a02 > lda absANa,x ;precharge accu 2d6f : 28 > plp 2d70 : 250c and zpt tst_ax absrlo,absflo,0 2d72 : 08 > php ;save flags 2d73 : dd6202 > cmp absrlo,x ;test result > trap_ne 2d76 : d0fe > bne * ;failed not equal (non zero) > 2d78 : 68 > pla ;load status > eor_flag 0 2d79 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2d7b : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2d7e : d0fe > bne * ;failed not equal (non zero) > 2d80 : ca dex 2d81 : 10e2 bpl tand2 2d83 : a203 ldx #3 2d85 : b51c tand3 lda zpAN,x 2d87 : 850c sta zpt set_ax absANa,$ff > load_flag $ff 2d89 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2d8b : 48 > pha ;use stack to load status 2d8c : bd5a02 > lda absANa,x ;precharge accu 2d8f : 28 > plp 2d90 : 250c and zpt tst_ax absrlo,absflo,$ff-fnz 2d92 : 08 > php ;save flags 2d93 : dd6202 > cmp absrlo,x ;test result > trap_ne 2d96 : d0fe > bne * ;failed not equal (non zero) > 2d98 : 68 > pla ;load status > eor_flag $ff-fnz 2d99 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2d9b : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2d9e : d0fe > bne * ;failed not equal (non zero) > 2da0 : ca dex 2da1 : 10e2 bpl tand3 2da3 : a203 ldx #3 ;abs 2da5 : b51c tand4 lda zpAN,x 2da7 : 8d0302 sta abst set_ax absANa,0 > load_flag 0 2daa : a900 > lda #0 ;allow test to change I-flag (no mask) > 2dac : 48 > pha ;use stack to load status 2dad : bd5a02 > lda absANa,x ;precharge accu 2db0 : 28 > plp 2db1 : 2d0302 and abst tst_ax absrlo,absflo,0 2db4 : 08 > php ;save flags 2db5 : dd6202 > cmp absrlo,x ;test result > trap_ne 2db8 : d0fe > bne * ;failed not equal (non zero) > 2dba : 68 > pla ;load status > eor_flag 0 2dbb : 4930 > eor #0|fao ;invert expected flags + always on bits > 2dbd : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2dc0 : d0fe > bne * ;failed not equal (non zero) > 2dc2 : ca dex 2dc3 : 10e0 bpl tand4 2dc5 : a203 ldx #3 2dc7 : b51c tand5 lda zpAN,x 2dc9 : 8d0302 sta abst set_ax absANa,$ff > load_flag $ff 2dcc : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2dce : 48 > pha ;use stack to load status 2dcf : bd5a02 > lda absANa,x ;precharge accu 2dd2 : 28 > plp 2dd3 : 2d0302 and abst tst_ax absrlo,absflo,$ff-fnz 2dd6 : 08 > php ;save flags 2dd7 : dd6202 > cmp absrlo,x ;test result > trap_ne 2dda : d0fe > bne * ;failed not equal (non zero) > 2ddc : 68 > pla ;load status > eor_flag $ff-fnz 2ddd : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2ddf : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2de2 : d0fe > bne * ;failed not equal (non zero) > 2de4 : ca dex 2de5 : 1002 bpl tand6 2de7 : a203 ldx #3 ;zp,x 2de9 : tand6 set_ax absANa,0 > load_flag 0 2de9 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2deb : 48 > pha ;use stack to load status 2dec : bd5a02 > lda absANa,x ;precharge accu 2def : 28 > plp 2df0 : 351c and zpAN,x tst_ax absrlo,absflo,0 2df2 : 08 > php ;save flags 2df3 : dd6202 > cmp absrlo,x ;test result > trap_ne 2df6 : d0fe > bne * ;failed not equal (non zero) > 2df8 : 68 > pla ;load status > eor_flag 0 2df9 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2dfb : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2dfe : d0fe > bne * ;failed not equal (non zero) > 2e00 : ca dex 2e01 : 10e6 bpl tand6 2e03 : a203 ldx #3 2e05 : tand7 set_ax absANa,$ff > load_flag $ff 2e05 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2e07 : 48 > pha ;use stack to load status 2e08 : bd5a02 > lda absANa,x ;precharge accu 2e0b : 28 > plp 2e0c : 351c and zpAN,x tst_ax absrlo,absflo,$ff-fnz 2e0e : 08 > php ;save flags 2e0f : dd6202 > cmp absrlo,x ;test result > trap_ne 2e12 : d0fe > bne * ;failed not equal (non zero) > 2e14 : 68 > pla ;load status > eor_flag $ff-fnz 2e15 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2e17 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2e1a : d0fe > bne * ;failed not equal (non zero) > 2e1c : ca dex 2e1d : 10e6 bpl tand7 2e1f : a203 ldx #3 ;abs,x 2e21 : tand8 set_ax absANa,0 > load_flag 0 2e21 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2e23 : 48 > pha ;use stack to load status 2e24 : bd5a02 > lda absANa,x ;precharge accu 2e27 : 28 > plp 2e28 : 3d4e02 and absAN,x tst_ax absrlo,absflo,0 2e2b : 08 > php ;save flags 2e2c : dd6202 > cmp absrlo,x ;test result > trap_ne 2e2f : d0fe > bne * ;failed not equal (non zero) > 2e31 : 68 > pla ;load status > eor_flag 0 2e32 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2e34 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2e37 : d0fe > bne * ;failed not equal (non zero) > 2e39 : ca dex 2e3a : 10e5 bpl tand8 2e3c : a203 ldx #3 2e3e : tand9 set_ax absANa,$ff > load_flag $ff 2e3e : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2e40 : 48 > pha ;use stack to load status 2e41 : bd5a02 > lda absANa,x ;precharge accu 2e44 : 28 > plp 2e45 : 3d4e02 and absAN,x tst_ax absrlo,absflo,$ff-fnz 2e48 : 08 > php ;save flags 2e49 : dd6202 > cmp absrlo,x ;test result > trap_ne 2e4c : d0fe > bne * ;failed not equal (non zero) > 2e4e : 68 > pla ;load status > eor_flag $ff-fnz 2e4f : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2e51 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2e54 : d0fe > bne * ;failed not equal (non zero) > 2e56 : ca dex 2e57 : 10e5 bpl tand9 2e59 : a003 ldy #3 ;abs,y 2e5b : tand10 set_ay absANa,0 > load_flag 0 2e5b : a900 > lda #0 ;allow test to change I-flag (no mask) > 2e5d : 48 > pha ;use stack to load status 2e5e : b95a02 > lda absANa,y ;precharge accu 2e61 : 28 > plp 2e62 : 394e02 and absAN,y tst_ay absrlo,absflo,0 2e65 : 08 > php ;save flags 2e66 : d96202 > cmp absrlo,y ;test result > trap_ne ; 2e69 : d0fe > bne * ;failed not equal (non zero) > 2e6b : 68 > pla ;load status > eor_flag 0 2e6c : 4930 > eor #0|fao ;invert expected flags + always on bits > 2e6e : d96602 > cmp absflo,y ;test flags > trap_ne 2e71 : d0fe > bne * ;failed not equal (non zero) > 2e73 : 88 dey 2e74 : 10e5 bpl tand10 2e76 : a003 ldy #3 2e78 : tand11 set_ay absANa,$ff > load_flag $ff 2e78 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2e7a : 48 > pha ;use stack to load status 2e7b : b95a02 > lda absANa,y ;precharge accu 2e7e : 28 > plp 2e7f : 394e02 and absAN,y tst_ay absrlo,absflo,$ff-fnz 2e82 : 08 > php ;save flags 2e83 : d96202 > cmp absrlo,y ;test result > trap_ne ; 2e86 : d0fe > bne * ;failed not equal (non zero) > 2e88 : 68 > pla ;load status > eor_flag $ff-fnz 2e89 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2e8b : d96602 > cmp absflo,y ;test flags > trap_ne 2e8e : d0fe > bne * ;failed not equal (non zero) > 2e90 : 88 dey 2e91 : 10e5 bpl tand11 2e93 : a206 ldx #6 ;(zp,x) 2e95 : a003 ldy #3 2e97 : tand12 set_ay absANa,0 > load_flag 0 2e97 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2e99 : 48 > pha ;use stack to load status 2e9a : b95a02 > lda absANa,y ;precharge accu 2e9d : 28 > plp 2e9e : 213a and (indAN,x) tst_ay absrlo,absflo,0 2ea0 : 08 > php ;save flags 2ea1 : d96202 > cmp absrlo,y ;test result > trap_ne ; 2ea4 : d0fe > bne * ;failed not equal (non zero) > 2ea6 : 68 > pla ;load status > eor_flag 0 2ea7 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2ea9 : d96602 > cmp absflo,y ;test flags > trap_ne 2eac : d0fe > bne * ;failed not equal (non zero) > 2eae : ca dex 2eaf : ca dex 2eb0 : 88 dey 2eb1 : 10e4 bpl tand12 2eb3 : a206 ldx #6 2eb5 : a003 ldy #3 2eb7 : tand13 set_ay absANa,$ff > load_flag $ff 2eb7 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2eb9 : 48 > pha ;use stack to load status 2eba : b95a02 > lda absANa,y ;precharge accu 2ebd : 28 > plp 2ebe : 213a and (indAN,x) tst_ay absrlo,absflo,$ff-fnz 2ec0 : 08 > php ;save flags 2ec1 : d96202 > cmp absrlo,y ;test result > trap_ne ; 2ec4 : d0fe > bne * ;failed not equal (non zero) > 2ec6 : 68 > pla ;load status > eor_flag $ff-fnz 2ec7 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2ec9 : d96602 > cmp absflo,y ;test flags > trap_ne 2ecc : d0fe > bne * ;failed not equal (non zero) > 2ece : ca dex 2ecf : ca dex 2ed0 : 88 dey 2ed1 : 10e4 bpl tand13 2ed3 : a003 ldy #3 ;(zp),y 2ed5 : tand14 set_ay absANa,0 > load_flag 0 2ed5 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2ed7 : 48 > pha ;use stack to load status 2ed8 : b95a02 > lda absANa,y ;precharge accu 2edb : 28 > plp 2edc : 313a and (indAN),y tst_ay absrlo,absflo,0 2ede : 08 > php ;save flags 2edf : d96202 > cmp absrlo,y ;test result > trap_ne ; 2ee2 : d0fe > bne * ;failed not equal (non zero) > 2ee4 : 68 > pla ;load status > eor_flag 0 2ee5 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2ee7 : d96602 > cmp absflo,y ;test flags > trap_ne 2eea : d0fe > bne * ;failed not equal (non zero) > 2eec : 88 dey 2eed : 10e6 bpl tand14 2eef : a003 ldy #3 2ef1 : tand15 set_ay absANa,$ff > load_flag $ff 2ef1 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2ef3 : 48 > pha ;use stack to load status 2ef4 : b95a02 > lda absANa,y ;precharge accu 2ef7 : 28 > plp 2ef8 : 313a and (indAN),y tst_ay absrlo,absflo,$ff-fnz 2efa : 08 > php ;save flags 2efb : d96202 > cmp absrlo,y ;test result > trap_ne ; 2efe : d0fe > bne * ;failed not equal (non zero) > 2f00 : 68 > pla ;load status > eor_flag $ff-fnz 2f01 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2f03 : d96602 > cmp absflo,y ;test flags > trap_ne 2f06 : d0fe > bne * ;failed not equal (non zero) > 2f08 : 88 dey 2f09 : 10e6 bpl tand15 next_test 2f0b : ad0002 > lda test_case ;previous test 2f0e : c926 > cmp #test_num > trap_ne ;test is out of sequence 2f10 : d0fe > bne * ;failed not equal (non zero) > 0027 = >test_num = test_num + 1 2f12 : a927 > lda #test_num ;*** next tests' number 2f14 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; EOR 2f17 : a203 ldx #3 ;immediate - self modifying code 2f19 : b520 teor lda zpEO,x 2f1b : 8d0c02 sta ex_eori+1 ;set EOR # operand set_ax absEOa,0 > load_flag 0 2f1e : a900 > lda #0 ;allow test to change I-flag (no mask) > 2f20 : 48 > pha ;use stack to load status 2f21 : bd5e02 > lda absEOa,x ;precharge accu 2f24 : 28 > plp 2f25 : 200b02 jsr ex_eori ;execute EOR # in RAM tst_ax absrlo,absflo,0 2f28 : 08 > php ;save flags 2f29 : dd6202 > cmp absrlo,x ;test result > trap_ne 2f2c : d0fe > bne * ;failed not equal (non zero) > 2f2e : 68 > pla ;load status > eor_flag 0 2f2f : 4930 > eor #0|fao ;invert expected flags + always on bits > 2f31 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2f34 : d0fe > bne * ;failed not equal (non zero) > 2f36 : ca dex 2f37 : 10e0 bpl teor 2f39 : a203 ldx #3 2f3b : b520 teor1 lda zpEO,x 2f3d : 8d0c02 sta ex_eori+1 ;set EOR # operand set_ax absEOa,$ff > load_flag $ff 2f40 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2f42 : 48 > pha ;use stack to load status 2f43 : bd5e02 > lda absEOa,x ;precharge accu 2f46 : 28 > plp 2f47 : 200b02 jsr ex_eori ;execute EOR # in RAM tst_ax absrlo,absflo,$ff-fnz 2f4a : 08 > php ;save flags 2f4b : dd6202 > cmp absrlo,x ;test result > trap_ne 2f4e : d0fe > bne * ;failed not equal (non zero) > 2f50 : 68 > pla ;load status > eor_flag $ff-fnz 2f51 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2f53 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2f56 : d0fe > bne * ;failed not equal (non zero) > 2f58 : ca dex 2f59 : 10e0 bpl teor1 2f5b : a203 ldx #3 ;zp 2f5d : b520 teor2 lda zpEO,x 2f5f : 850c sta zpt set_ax absEOa,0 > load_flag 0 2f61 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2f63 : 48 > pha ;use stack to load status 2f64 : bd5e02 > lda absEOa,x ;precharge accu 2f67 : 28 > plp 2f68 : 450c eor zpt tst_ax absrlo,absflo,0 2f6a : 08 > php ;save flags 2f6b : dd6202 > cmp absrlo,x ;test result > trap_ne 2f6e : d0fe > bne * ;failed not equal (non zero) > 2f70 : 68 > pla ;load status > eor_flag 0 2f71 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2f73 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2f76 : d0fe > bne * ;failed not equal (non zero) > 2f78 : ca dex 2f79 : 10e2 bpl teor2 2f7b : a203 ldx #3 2f7d : b520 teor3 lda zpEO,x 2f7f : 850c sta zpt set_ax absEOa,$ff > load_flag $ff 2f81 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2f83 : 48 > pha ;use stack to load status 2f84 : bd5e02 > lda absEOa,x ;precharge accu 2f87 : 28 > plp 2f88 : 450c eor zpt tst_ax absrlo,absflo,$ff-fnz 2f8a : 08 > php ;save flags 2f8b : dd6202 > cmp absrlo,x ;test result > trap_ne 2f8e : d0fe > bne * ;failed not equal (non zero) > 2f90 : 68 > pla ;load status > eor_flag $ff-fnz 2f91 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2f93 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2f96 : d0fe > bne * ;failed not equal (non zero) > 2f98 : ca dex 2f99 : 10e2 bpl teor3 2f9b : a203 ldx #3 ;abs 2f9d : b520 teor4 lda zpEO,x 2f9f : 8d0302 sta abst set_ax absEOa,0 > load_flag 0 2fa2 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2fa4 : 48 > pha ;use stack to load status 2fa5 : bd5e02 > lda absEOa,x ;precharge accu 2fa8 : 28 > plp 2fa9 : 4d0302 eor abst tst_ax absrlo,absflo,0 2fac : 08 > php ;save flags 2fad : dd6202 > cmp absrlo,x ;test result > trap_ne 2fb0 : d0fe > bne * ;failed not equal (non zero) > 2fb2 : 68 > pla ;load status > eor_flag 0 2fb3 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2fb5 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2fb8 : d0fe > bne * ;failed not equal (non zero) > 2fba : ca dex 2fbb : 10e0 bpl teor4 2fbd : a203 ldx #3 2fbf : b520 teor5 lda zpEO,x 2fc1 : 8d0302 sta abst set_ax absEOa,$ff > load_flag $ff 2fc4 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2fc6 : 48 > pha ;use stack to load status 2fc7 : bd5e02 > lda absEOa,x ;precharge accu 2fca : 28 > plp 2fcb : 4d0302 eor abst tst_ax absrlo,absflo,$ff-fnz 2fce : 08 > php ;save flags 2fcf : dd6202 > cmp absrlo,x ;test result > trap_ne 2fd2 : d0fe > bne * ;failed not equal (non zero) > 2fd4 : 68 > pla ;load status > eor_flag $ff-fnz 2fd5 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 2fd7 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2fda : d0fe > bne * ;failed not equal (non zero) > 2fdc : ca dex 2fdd : 1002 bpl teor6 2fdf : a203 ldx #3 ;zp,x 2fe1 : teor6 set_ax absEOa,0 > load_flag 0 2fe1 : a900 > lda #0 ;allow test to change I-flag (no mask) > 2fe3 : 48 > pha ;use stack to load status 2fe4 : bd5e02 > lda absEOa,x ;precharge accu 2fe7 : 28 > plp 2fe8 : 5520 eor zpEO,x tst_ax absrlo,absflo,0 2fea : 08 > php ;save flags 2feb : dd6202 > cmp absrlo,x ;test result > trap_ne 2fee : d0fe > bne * ;failed not equal (non zero) > 2ff0 : 68 > pla ;load status > eor_flag 0 2ff1 : 4930 > eor #0|fao ;invert expected flags + always on bits > 2ff3 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 2ff6 : d0fe > bne * ;failed not equal (non zero) > 2ff8 : ca dex 2ff9 : 10e6 bpl teor6 2ffb : a203 ldx #3 2ffd : teor7 set_ax absEOa,$ff > load_flag $ff 2ffd : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 2fff : 48 > pha ;use stack to load status 3000 : bd5e02 > lda absEOa,x ;precharge accu 3003 : 28 > plp 3004 : 5520 eor zpEO,x tst_ax absrlo,absflo,$ff-fnz 3006 : 08 > php ;save flags 3007 : dd6202 > cmp absrlo,x ;test result > trap_ne 300a : d0fe > bne * ;failed not equal (non zero) > 300c : 68 > pla ;load status > eor_flag $ff-fnz 300d : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 300f : dd6602 > cmp absflo,x ;test flags > trap_ne ; 3012 : d0fe > bne * ;failed not equal (non zero) > 3014 : ca dex 3015 : 10e6 bpl teor7 3017 : a203 ldx #3 ;abs,x 3019 : teor8 set_ax absEOa,0 > load_flag 0 3019 : a900 > lda #0 ;allow test to change I-flag (no mask) > 301b : 48 > pha ;use stack to load status 301c : bd5e02 > lda absEOa,x ;precharge accu 301f : 28 > plp 3020 : 5d5202 eor absEO,x tst_ax absrlo,absflo,0 3023 : 08 > php ;save flags 3024 : dd6202 > cmp absrlo,x ;test result > trap_ne 3027 : d0fe > bne * ;failed not equal (non zero) > 3029 : 68 > pla ;load status > eor_flag 0 302a : 4930 > eor #0|fao ;invert expected flags + always on bits > 302c : dd6602 > cmp absflo,x ;test flags > trap_ne ; 302f : d0fe > bne * ;failed not equal (non zero) > 3031 : ca dex 3032 : 10e5 bpl teor8 3034 : a203 ldx #3 3036 : teor9 set_ax absEOa,$ff > load_flag $ff 3036 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 3038 : 48 > pha ;use stack to load status 3039 : bd5e02 > lda absEOa,x ;precharge accu 303c : 28 > plp 303d : 5d5202 eor absEO,x tst_ax absrlo,absflo,$ff-fnz 3040 : 08 > php ;save flags 3041 : dd6202 > cmp absrlo,x ;test result > trap_ne 3044 : d0fe > bne * ;failed not equal (non zero) > 3046 : 68 > pla ;load status > eor_flag $ff-fnz 3047 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 3049 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 304c : d0fe > bne * ;failed not equal (non zero) > 304e : ca dex 304f : 10e5 bpl teor9 3051 : a003 ldy #3 ;abs,y 3053 : teor10 set_ay absEOa,0 > load_flag 0 3053 : a900 > lda #0 ;allow test to change I-flag (no mask) > 3055 : 48 > pha ;use stack to load status 3056 : b95e02 > lda absEOa,y ;precharge accu 3059 : 28 > plp 305a : 595202 eor absEO,y tst_ay absrlo,absflo,0 305d : 08 > php ;save flags 305e : d96202 > cmp absrlo,y ;test result > trap_ne ; 3061 : d0fe > bne * ;failed not equal (non zero) > 3063 : 68 > pla ;load status > eor_flag 0 3064 : 4930 > eor #0|fao ;invert expected flags + always on bits > 3066 : d96602 > cmp absflo,y ;test flags > trap_ne 3069 : d0fe > bne * ;failed not equal (non zero) > 306b : 88 dey 306c : 10e5 bpl teor10 306e : a003 ldy #3 3070 : teor11 set_ay absEOa,$ff > load_flag $ff 3070 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 3072 : 48 > pha ;use stack to load status 3073 : b95e02 > lda absEOa,y ;precharge accu 3076 : 28 > plp 3077 : 595202 eor absEO,y tst_ay absrlo,absflo,$ff-fnz 307a : 08 > php ;save flags 307b : d96202 > cmp absrlo,y ;test result > trap_ne ; 307e : d0fe > bne * ;failed not equal (non zero) > 3080 : 68 > pla ;load status > eor_flag $ff-fnz 3081 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 3083 : d96602 > cmp absflo,y ;test flags > trap_ne 3086 : d0fe > bne * ;failed not equal (non zero) > 3088 : 88 dey 3089 : 10e5 bpl teor11 308b : a206 ldx #6 ;(zp,x) 308d : a003 ldy #3 308f : teor12 set_ay absEOa,0 > load_flag 0 308f : a900 > lda #0 ;allow test to change I-flag (no mask) > 3091 : 48 > pha ;use stack to load status 3092 : b95e02 > lda absEOa,y ;precharge accu 3095 : 28 > plp 3096 : 4142 eor (indEO,x) tst_ay absrlo,absflo,0 3098 : 08 > php ;save flags 3099 : d96202 > cmp absrlo,y ;test result > trap_ne ; 309c : d0fe > bne * ;failed not equal (non zero) > 309e : 68 > pla ;load status > eor_flag 0 309f : 4930 > eor #0|fao ;invert expected flags + always on bits > 30a1 : d96602 > cmp absflo,y ;test flags > trap_ne 30a4 : d0fe > bne * ;failed not equal (non zero) > 30a6 : ca dex 30a7 : ca dex 30a8 : 88 dey 30a9 : 10e4 bpl teor12 30ab : a206 ldx #6 30ad : a003 ldy #3 30af : teor13 set_ay absEOa,$ff > load_flag $ff 30af : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 30b1 : 48 > pha ;use stack to load status 30b2 : b95e02 > lda absEOa,y ;precharge accu 30b5 : 28 > plp 30b6 : 4142 eor (indEO,x) tst_ay absrlo,absflo,$ff-fnz 30b8 : 08 > php ;save flags 30b9 : d96202 > cmp absrlo,y ;test result > trap_ne ; 30bc : d0fe > bne * ;failed not equal (non zero) > 30be : 68 > pla ;load status > eor_flag $ff-fnz 30bf : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 30c1 : d96602 > cmp absflo,y ;test flags > trap_ne 30c4 : d0fe > bne * ;failed not equal (non zero) > 30c6 : ca dex 30c7 : ca dex 30c8 : 88 dey 30c9 : 10e4 bpl teor13 30cb : a003 ldy #3 ;(zp),y 30cd : teor14 set_ay absEOa,0 > load_flag 0 30cd : a900 > lda #0 ;allow test to change I-flag (no mask) > 30cf : 48 > pha ;use stack to load status 30d0 : b95e02 > lda absEOa,y ;precharge accu 30d3 : 28 > plp 30d4 : 5142 eor (indEO),y tst_ay absrlo,absflo,0 30d6 : 08 > php ;save flags 30d7 : d96202 > cmp absrlo,y ;test result > trap_ne ; 30da : d0fe > bne * ;failed not equal (non zero) > 30dc : 68 > pla ;load status > eor_flag 0 30dd : 4930 > eor #0|fao ;invert expected flags + always on bits > 30df : d96602 > cmp absflo,y ;test flags > trap_ne 30e2 : d0fe > bne * ;failed not equal (non zero) > 30e4 : 88 dey 30e5 : 10e6 bpl teor14 30e7 : a003 ldy #3 30e9 : teor15 set_ay absEOa,$ff > load_flag $ff 30e9 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 30eb : 48 > pha ;use stack to load status 30ec : b95e02 > lda absEOa,y ;precharge accu 30ef : 28 > plp 30f0 : 5142 eor (indEO),y tst_ay absrlo,absflo,$ff-fnz 30f2 : 08 > php ;save flags 30f3 : d96202 > cmp absrlo,y ;test result > trap_ne ; 30f6 : d0fe > bne * ;failed not equal (non zero) > 30f8 : 68 > pla ;load status > eor_flag $ff-fnz 30f9 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 30fb : d96602 > cmp absflo,y ;test flags > trap_ne 30fe : d0fe > bne * ;failed not equal (non zero) > 3100 : 88 dey 3101 : 10e6 bpl teor15 next_test 3103 : ad0002 > lda test_case ;previous test 3106 : c927 > cmp #test_num > trap_ne ;test is out of sequence 3108 : d0fe > bne * ;failed not equal (non zero) > 0028 = >test_num = test_num + 1 310a : a928 > lda #test_num ;*** next tests' number 310c : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; OR 310f : a203 ldx #3 ;immediate - self modifying code 3111 : b518 tora lda zpOR,x 3113 : 8d0f02 sta ex_orai+1 ;set ORA # operand set_ax absORa,0 > load_flag 0 3116 : a900 > lda #0 ;allow test to change I-flag (no mask) > 3118 : 48 > pha ;use stack to load status 3119 : bd5602 > lda absORa,x ;precharge accu 311c : 28 > plp 311d : 200e02 jsr ex_orai ;execute ORA # in RAM tst_ax absrlo,absflo,0 3120 : 08 > php ;save flags 3121 : dd6202 > cmp absrlo,x ;test result > trap_ne 3124 : d0fe > bne * ;failed not equal (non zero) > 3126 : 68 > pla ;load status > eor_flag 0 3127 : 4930 > eor #0|fao ;invert expected flags + always on bits > 3129 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 312c : d0fe > bne * ;failed not equal (non zero) > 312e : ca dex 312f : 10e0 bpl tora 3131 : a203 ldx #3 3133 : b518 tora1 lda zpOR,x 3135 : 8d0f02 sta ex_orai+1 ;set ORA # operand set_ax absORa,$ff > load_flag $ff 3138 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 313a : 48 > pha ;use stack to load status 313b : bd5602 > lda absORa,x ;precharge accu 313e : 28 > plp 313f : 200e02 jsr ex_orai ;execute ORA # in RAM tst_ax absrlo,absflo,$ff-fnz 3142 : 08 > php ;save flags 3143 : dd6202 > cmp absrlo,x ;test result > trap_ne 3146 : d0fe > bne * ;failed not equal (non zero) > 3148 : 68 > pla ;load status > eor_flag $ff-fnz 3149 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 314b : dd6602 > cmp absflo,x ;test flags > trap_ne ; 314e : d0fe > bne * ;failed not equal (non zero) > 3150 : ca dex 3151 : 10e0 bpl tora1 3153 : a203 ldx #3 ;zp 3155 : b518 tora2 lda zpOR,x 3157 : 850c sta zpt set_ax absORa,0 > load_flag 0 3159 : a900 > lda #0 ;allow test to change I-flag (no mask) > 315b : 48 > pha ;use stack to load status 315c : bd5602 > lda absORa,x ;precharge accu 315f : 28 > plp 3160 : 050c ora zpt tst_ax absrlo,absflo,0 3162 : 08 > php ;save flags 3163 : dd6202 > cmp absrlo,x ;test result > trap_ne 3166 : d0fe > bne * ;failed not equal (non zero) > 3168 : 68 > pla ;load status > eor_flag 0 3169 : 4930 > eor #0|fao ;invert expected flags + always on bits > 316b : dd6602 > cmp absflo,x ;test flags > trap_ne ; 316e : d0fe > bne * ;failed not equal (non zero) > 3170 : ca dex 3171 : 10e2 bpl tora2 3173 : a203 ldx #3 3175 : b518 tora3 lda zpOR,x 3177 : 850c sta zpt set_ax absORa,$ff > load_flag $ff 3179 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 317b : 48 > pha ;use stack to load status 317c : bd5602 > lda absORa,x ;precharge accu 317f : 28 > plp 3180 : 050c ora zpt tst_ax absrlo,absflo,$ff-fnz 3182 : 08 > php ;save flags 3183 : dd6202 > cmp absrlo,x ;test result > trap_ne 3186 : d0fe > bne * ;failed not equal (non zero) > 3188 : 68 > pla ;load status > eor_flag $ff-fnz 3189 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 318b : dd6602 > cmp absflo,x ;test flags > trap_ne ; 318e : d0fe > bne * ;failed not equal (non zero) > 3190 : ca dex 3191 : 10e2 bpl tora3 3193 : a203 ldx #3 ;abs 3195 : b518 tora4 lda zpOR,x 3197 : 8d0302 sta abst set_ax absORa,0 > load_flag 0 319a : a900 > lda #0 ;allow test to change I-flag (no mask) > 319c : 48 > pha ;use stack to load status 319d : bd5602 > lda absORa,x ;precharge accu 31a0 : 28 > plp 31a1 : 0d0302 ora abst tst_ax absrlo,absflo,0 31a4 : 08 > php ;save flags 31a5 : dd6202 > cmp absrlo,x ;test result > trap_ne 31a8 : d0fe > bne * ;failed not equal (non zero) > 31aa : 68 > pla ;load status > eor_flag 0 31ab : 4930 > eor #0|fao ;invert expected flags + always on bits > 31ad : dd6602 > cmp absflo,x ;test flags > trap_ne ; 31b0 : d0fe > bne * ;failed not equal (non zero) > 31b2 : ca dex 31b3 : 10e0 bpl tora4 31b5 : a203 ldx #3 31b7 : b518 tora5 lda zpOR,x 31b9 : 8d0302 sta abst set_ax absORa,$ff > load_flag $ff 31bc : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 31be : 48 > pha ;use stack to load status 31bf : bd5602 > lda absORa,x ;precharge accu 31c2 : 28 > plp 31c3 : 0d0302 ora abst tst_ax absrlo,absflo,$ff-fnz 31c6 : 08 > php ;save flags 31c7 : dd6202 > cmp absrlo,x ;test result > trap_ne 31ca : d0fe > bne * ;failed not equal (non zero) > 31cc : 68 > pla ;load status > eor_flag $ff-fnz 31cd : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 31cf : dd6602 > cmp absflo,x ;test flags > trap_ne ; 31d2 : d0fe > bne * ;failed not equal (non zero) > 31d4 : ca dex 31d5 : 1002 bpl tora6 31d7 : a203 ldx #3 ;zp,x 31d9 : tora6 set_ax absORa,0 > load_flag 0 31d9 : a900 > lda #0 ;allow test to change I-flag (no mask) > 31db : 48 > pha ;use stack to load status 31dc : bd5602 > lda absORa,x ;precharge accu 31df : 28 > plp 31e0 : 1518 ora zpOR,x tst_ax absrlo,absflo,0 31e2 : 08 > php ;save flags 31e3 : dd6202 > cmp absrlo,x ;test result > trap_ne 31e6 : d0fe > bne * ;failed not equal (non zero) > 31e8 : 68 > pla ;load status > eor_flag 0 31e9 : 4930 > eor #0|fao ;invert expected flags + always on bits > 31eb : dd6602 > cmp absflo,x ;test flags > trap_ne ; 31ee : d0fe > bne * ;failed not equal (non zero) > 31f0 : ca dex 31f1 : 10e6 bpl tora6 31f3 : a203 ldx #3 31f5 : tora7 set_ax absORa,$ff > load_flag $ff 31f5 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 31f7 : 48 > pha ;use stack to load status 31f8 : bd5602 > lda absORa,x ;precharge accu 31fb : 28 > plp 31fc : 1518 ora zpOR,x tst_ax absrlo,absflo,$ff-fnz 31fe : 08 > php ;save flags 31ff : dd6202 > cmp absrlo,x ;test result > trap_ne 3202 : d0fe > bne * ;failed not equal (non zero) > 3204 : 68 > pla ;load status > eor_flag $ff-fnz 3205 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 3207 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 320a : d0fe > bne * ;failed not equal (non zero) > 320c : ca dex 320d : 10e6 bpl tora7 320f : a203 ldx #3 ;abs,x 3211 : tora8 set_ax absORa,0 > load_flag 0 3211 : a900 > lda #0 ;allow test to change I-flag (no mask) > 3213 : 48 > pha ;use stack to load status 3214 : bd5602 > lda absORa,x ;precharge accu 3217 : 28 > plp 3218 : 1d4a02 ora absOR,x tst_ax absrlo,absflo,0 321b : 08 > php ;save flags 321c : dd6202 > cmp absrlo,x ;test result > trap_ne 321f : d0fe > bne * ;failed not equal (non zero) > 3221 : 68 > pla ;load status > eor_flag 0 3222 : 4930 > eor #0|fao ;invert expected flags + always on bits > 3224 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 3227 : d0fe > bne * ;failed not equal (non zero) > 3229 : ca dex 322a : 10e5 bpl tora8 322c : a203 ldx #3 322e : tora9 set_ax absORa,$ff > load_flag $ff 322e : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 3230 : 48 > pha ;use stack to load status 3231 : bd5602 > lda absORa,x ;precharge accu 3234 : 28 > plp 3235 : 1d4a02 ora absOR,x tst_ax absrlo,absflo,$ff-fnz 3238 : 08 > php ;save flags 3239 : dd6202 > cmp absrlo,x ;test result > trap_ne 323c : d0fe > bne * ;failed not equal (non zero) > 323e : 68 > pla ;load status > eor_flag $ff-fnz 323f : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 3241 : dd6602 > cmp absflo,x ;test flags > trap_ne ; 3244 : d0fe > bne * ;failed not equal (non zero) > 3246 : ca dex 3247 : 10e5 bpl tora9 3249 : a003 ldy #3 ;abs,y 324b : tora10 set_ay absORa,0 > load_flag 0 324b : a900 > lda #0 ;allow test to change I-flag (no mask) > 324d : 48 > pha ;use stack to load status 324e : b95602 > lda absORa,y ;precharge accu 3251 : 28 > plp 3252 : 194a02 ora absOR,y tst_ay absrlo,absflo,0 3255 : 08 > php ;save flags 3256 : d96202 > cmp absrlo,y ;test result > trap_ne ; 3259 : d0fe > bne * ;failed not equal (non zero) > 325b : 68 > pla ;load status > eor_flag 0 325c : 4930 > eor #0|fao ;invert expected flags + always on bits > 325e : d96602 > cmp absflo,y ;test flags > trap_ne 3261 : d0fe > bne * ;failed not equal (non zero) > 3263 : 88 dey 3264 : 10e5 bpl tora10 3266 : a003 ldy #3 3268 : tora11 set_ay absORa,$ff > load_flag $ff 3268 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 326a : 48 > pha ;use stack to load status 326b : b95602 > lda absORa,y ;precharge accu 326e : 28 > plp 326f : 194a02 ora absOR,y tst_ay absrlo,absflo,$ff-fnz 3272 : 08 > php ;save flags 3273 : d96202 > cmp absrlo,y ;test result > trap_ne ; 3276 : d0fe > bne * ;failed not equal (non zero) > 3278 : 68 > pla ;load status > eor_flag $ff-fnz 3279 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 327b : d96602 > cmp absflo,y ;test flags > trap_ne 327e : d0fe > bne * ;failed not equal (non zero) > 3280 : 88 dey 3281 : 10e5 bpl tora11 3283 : a206 ldx #6 ;(zp,x) 3285 : a003 ldy #3 3287 : tora12 set_ay absORa,0 > load_flag 0 3287 : a900 > lda #0 ;allow test to change I-flag (no mask) > 3289 : 48 > pha ;use stack to load status 328a : b95602 > lda absORa,y ;precharge accu 328d : 28 > plp 328e : 014a ora (indOR,x) tst_ay absrlo,absflo,0 3290 : 08 > php ;save flags 3291 : d96202 > cmp absrlo,y ;test result > trap_ne ; 3294 : d0fe > bne * ;failed not equal (non zero) > 3296 : 68 > pla ;load status > eor_flag 0 3297 : 4930 > eor #0|fao ;invert expected flags + always on bits > 3299 : d96602 > cmp absflo,y ;test flags > trap_ne 329c : d0fe > bne * ;failed not equal (non zero) > 329e : ca dex 329f : ca dex 32a0 : 88 dey 32a1 : 10e4 bpl tora12 32a3 : a206 ldx #6 32a5 : a003 ldy #3 32a7 : tora13 set_ay absORa,$ff > load_flag $ff 32a7 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 32a9 : 48 > pha ;use stack to load status 32aa : b95602 > lda absORa,y ;precharge accu 32ad : 28 > plp 32ae : 014a ora (indOR,x) tst_ay absrlo,absflo,$ff-fnz 32b0 : 08 > php ;save flags 32b1 : d96202 > cmp absrlo,y ;test result > trap_ne ; 32b4 : d0fe > bne * ;failed not equal (non zero) > 32b6 : 68 > pla ;load status > eor_flag $ff-fnz 32b7 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 32b9 : d96602 > cmp absflo,y ;test flags > trap_ne 32bc : d0fe > bne * ;failed not equal (non zero) > 32be : ca dex 32bf : ca dex 32c0 : 88 dey 32c1 : 10e4 bpl tora13 32c3 : a003 ldy #3 ;(zp),y 32c5 : tora14 set_ay absORa,0 > load_flag 0 32c5 : a900 > lda #0 ;allow test to change I-flag (no mask) > 32c7 : 48 > pha ;use stack to load status 32c8 : b95602 > lda absORa,y ;precharge accu 32cb : 28 > plp 32cc : 114a ora (indOR),y tst_ay absrlo,absflo,0 32ce : 08 > php ;save flags 32cf : d96202 > cmp absrlo,y ;test result > trap_ne ; 32d2 : d0fe > bne * ;failed not equal (non zero) > 32d4 : 68 > pla ;load status > eor_flag 0 32d5 : 4930 > eor #0|fao ;invert expected flags + always on bits > 32d7 : d96602 > cmp absflo,y ;test flags > trap_ne 32da : d0fe > bne * ;failed not equal (non zero) > 32dc : 88 dey 32dd : 10e6 bpl tora14 32df : a003 ldy #3 32e1 : tora15 set_ay absORa,$ff > load_flag $ff 32e1 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 32e3 : 48 > pha ;use stack to load status 32e4 : b95602 > lda absORa,y ;precharge accu 32e7 : 28 > plp 32e8 : 114a ora (indOR),y tst_ay absrlo,absflo,$ff-fnz 32ea : 08 > php ;save flags 32eb : d96202 > cmp absrlo,y ;test result > trap_ne ; 32ee : d0fe > bne * ;failed not equal (non zero) > 32f0 : 68 > pla ;load status > eor_flag $ff-fnz 32f1 : 497d > eor #$ff-fnz|fao ;invert expected flags + always on bits > 32f3 : d96602 > cmp absflo,y ;test flags > trap_ne 32f6 : d0fe > bne * ;failed not equal (non zero) > 32f8 : 88 dey 32f9 : 10e6 bpl tora15 if I_flag = 3 32fb : 58 cli endif next_test 32fc : ad0002 > lda test_case ;previous test 32ff : c928 > cmp #test_num > trap_ne ;test is out of sequence 3301 : d0fe > bne * ;failed not equal (non zero) > 0029 = >test_num = test_num + 1 3303 : a929 > lda #test_num ;*** next tests' number 3305 : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; full binary add/subtract test ; iterates through all combinations of operands and carry input ; uses increments/decrements to predict result & result flags 3308 : d8 cld 3309 : a20e ldx #ad2 ;for indexed test 330b : a0ff ldy #$ff ;max range 330d : a900 lda #0 ;start with adding zeroes & no carry 330f : 850c sta adfc ;carry in - for diag 3311 : 850d sta ad1 ;operand 1 - accumulator 3313 : 850e sta ad2 ;operand 2 - memory or immediate 3315 : 8d0302 sta ada2 ;non zp 3318 : 850f sta adrl ;expected result bits 0-7 331a : 8510 sta adrh ;expected result bit 8 (carry out) 331c : a9ff lda #$ff ;complemented operand 2 for subtract 331e : 8512 sta sb2 3320 : 8d0402 sta sba2 ;non zp 3323 : a902 lda #2 ;expected Z-flag 3325 : 8511 sta adrf 3327 : 18 tadd clc ;test with carry clear 3328 : 20a235 jsr chkadd 332b : e60c inc adfc ;now with carry 332d : e60f inc adrl ;result +1 332f : 08 php ;save N & Z from low result 3330 : 08 php 3331 : 68 pla ;accu holds expected flags 3332 : 2982 and #$82 ;mask N & Z 3334 : 28 plp 3335 : d002 bne tadd1 3337 : e610 inc adrh ;result bit 8 - carry 3339 : 0510 tadd1 ora adrh ;merge C to expected flags 333b : 8511 sta adrf ;save expected flags except overflow 333d : 38 sec ;test with carry set 333e : 20a235 jsr chkadd 3341 : c60c dec adfc ;same for operand +1 but no carry 3343 : e60d inc ad1 3345 : d0e0 bne tadd ;iterate op1 3347 : a900 lda #0 ;preset result to op2 when op1 = 0 3349 : 8510 sta adrh 334b : ee0302 inc ada2 334e : e60e inc ad2 3350 : 08 php ;save NZ as operand 2 becomes the new result 3351 : 68 pla 3352 : 2982 and #$82 ;mask N00000Z0 3354 : 8511 sta adrf ;no need to check carry as we are adding to 0 3356 : c612 dec sb2 ;complement subtract operand 2 3358 : ce0402 dec sba2 335b : a50e lda ad2 335d : 850f sta adrl 335f : d0c6 bne tadd ;iterate op2 if disable_decimal < 1 next_test 3361 : ad0002 > lda test_case ;previous test 3364 : c929 > cmp #test_num > trap_ne ;test is out of sequence 3366 : d0fe > bne * ;failed not equal (non zero) > 002a = >test_num = test_num + 1 3368 : a92a > lda #test_num ;*** next tests' number 336a : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; decimal add/subtract test ; *** WARNING - tests documented behavior only! *** ; only valid BCD operands are tested, N V Z flags are ignored ; iterates through all valid combinations of operands and carry input ; uses increments/decrements to predict result & carry flag 336d : f8 sed 336e : a20e ldx #ad2 ;for indexed test 3370 : a0ff ldy #$ff ;max range 3372 : a999 lda #$99 ;start with adding 99 to 99 with carry 3374 : 850d sta ad1 ;operand 1 - accumulator 3376 : 850e sta ad2 ;operand 2 - memory or immediate 3378 : 8d0302 sta ada2 ;non zp 337b : 850f sta adrl ;expected result bits 0-7 337d : a901 lda #1 ;set carry in & out 337f : 850c sta adfc ;carry in - for diag 3381 : 8510 sta adrh ;expected result bit 8 (carry out) 3383 : a900 lda #0 ;complemented operand 2 for subtract 3385 : 8512 sta sb2 3387 : 8d0402 sta sba2 ;non zp 338a : 38 tdad sec ;test with carry set 338b : 206f34 jsr chkdad 338e : c60c dec adfc ;now with carry clear 3390 : a50f lda adrl ;decimal adjust result 3392 : d008 bne tdad1 ;skip clear carry & preset result 99 (9A-1) 3394 : c610 dec adrh 3396 : a999 lda #$99 3398 : 850f sta adrl 339a : d012 bne tdad3 339c : 290f tdad1 and #$f ;lower nibble mask 339e : d00c bne tdad2 ;no decimal adjust needed 33a0 : c60f dec adrl ;decimal adjust (?0-6) 33a2 : c60f dec adrl 33a4 : c60f dec adrl 33a6 : c60f dec adrl 33a8 : c60f dec adrl 33aa : c60f dec adrl 33ac : c60f tdad2 dec adrl ;result -1 33ae : 18 tdad3 clc ;test with carry clear 33af : 206f34 jsr chkdad 33b2 : e60c inc adfc ;same for operand -1 but with carry 33b4 : a50d lda ad1 ;decimal adjust operand 1 33b6 : f015 beq tdad5 ;iterate operand 2 33b8 : 290f and #$f ;lower nibble mask 33ba : d00c bne tdad4 ;skip decimal adjust 33bc : c60d dec ad1 ;decimal adjust (?0-6) 33be : c60d dec ad1 33c0 : c60d dec ad1 33c2 : c60d dec ad1 33c4 : c60d dec ad1 33c6 : c60d dec ad1 33c8 : c60d tdad4 dec ad1 ;operand 1 -1 33ca : 4c8a33 jmp tdad ;iterate op1 33cd : a999 tdad5 lda #$99 ;precharge op1 max 33cf : 850d sta ad1 33d1 : a50e lda ad2 ;decimal adjust operand 2 33d3 : f030 beq tdad7 ;end of iteration 33d5 : 290f and #$f ;lower nibble mask 33d7 : d018 bne tdad6 ;skip decimal adjust 33d9 : c60e dec ad2 ;decimal adjust (?0-6) 33db : c60e dec ad2 33dd : c60e dec ad2 33df : c60e dec ad2 33e1 : c60e dec ad2 33e3 : c60e dec ad2 33e5 : e612 inc sb2 ;complemented decimal adjust for subtract (?9+6) 33e7 : e612 inc sb2 33e9 : e612 inc sb2 33eb : e612 inc sb2 33ed : e612 inc sb2 33ef : e612 inc sb2 33f1 : c60e tdad6 dec ad2 ;operand 2 -1 33f3 : e612 inc sb2 ;complemented operand for subtract 33f5 : a512 lda sb2 33f7 : 8d0402 sta sba2 ;copy as non zp operand 33fa : a50e lda ad2 33fc : 8d0302 sta ada2 ;copy as non zp operand 33ff : 850f sta adrl ;new result since op1+carry=00+carry +op2=op2 3401 : e610 inc adrh ;result carry 3403 : d085 bne tdad ;iterate op2 3405 : tdad7 next_test 3405 : ad0002 > lda test_case ;previous test 3408 : c92a > cmp #test_num > trap_ne ;test is out of sequence 340a : d0fe > bne * ;failed not equal (non zero) > 002b = >test_num = test_num + 1 340c : a92b > lda #test_num ;*** next tests' number 340e : 8d0002 > sta test_case > ;check_ram ;uncomment to find altered RAM after each test ; decimal/binary switch test ; tests CLD, SED, PLP, RTI to properly switch between decimal & binary opcode ; tables 3411 : 18 clc 3412 : d8 cld 3413 : 08 php 3414 : a955 lda #$55 3416 : 6955 adc #$55 3418 : c9aa cmp #$aa trap_ne ;expected binary result after cld 341a : d0fe > bne * ;failed not equal (non zero) 341c : 18 clc 341d : f8 sed 341e : 08 php 341f : a955 lda #$55 3421 : 6955 adc #$55 3423 : c910 cmp #$10 trap_ne ;expected decimal result after sed 3425 : d0fe > bne * ;failed not equal (non zero) 3427 : d8 cld 3428 : 28 plp 3429 : a955 lda #$55 342b : 6955 adc #$55 342d : c910 cmp #$10 trap_ne ;expected decimal result after plp D=1 342f : d0fe > bne * ;failed not equal (non zero) 3431 : 28 plp 3432 : a955 lda #$55 3434 : 6955 adc #$55 3436 : c9aa cmp #$aa trap_ne ;expected binary result after plp D=0 3438 : d0fe > bne * ;failed not equal (non zero) 343a : 18 clc 343b : a934 lda #hi bin_rti_ret ;emulated interrupt for rti 343d : 48 pha 343e : a955 lda #lo bin_rti_ret 3440 : 48 pha 3441 : 08 php 3442 : f8 sed 3443 : a934 lda #hi dec_rti_ret ;emulated interrupt for rti 3445 : 48 pha 3446 : a94c lda #lo dec_rti_ret 3448 : 48 pha 3449 : 08 php 344a : d8 cld 344b : 40 rti 344c : dec_rti_ret 344c : a955 lda #$55 344e : 6955 adc #$55 3450 : c910 cmp #$10 trap_ne ;expected decimal result after rti D=1 3452 : d0fe > bne * ;failed not equal (non zero) 3454 : 40 rti 3455 : bin_rti_ret 3455 : a955 lda #$55 3457 : 6955 adc #$55 3459 : c9aa cmp #$aa trap_ne ;expected binary result after rti D=0 345b : d0fe > bne * ;failed not equal (non zero) endif 345d : ad0002 lda test_case 3460 : c92b cmp #test_num trap_ne ;previous test is out of sequence 3462 : d0fe > bne * ;failed not equal (non zero) 3464 : a9f0 lda #$f0 ;mark opcode testing complete 3466 : 8d0002 sta test_case ; final RAM integrity test ; verifies that none of the previous tests has altered RAM outside of the ; designated write areas. check_ram > ;RAM check disabled - RAM size not set ; *** DEBUG INFO *** ; to debug checksum errors uncomment check_ram in the next_test macro to ; narrow down the responsible opcode. ; may give false errors when monitor, OS or other background activity is ; allowed during previous tests. ; S U C C E S S ************************************************ ; ------------- success ;if you get here everything went well 3469 : 4c6934 > jmp * ;test passed, no errors ; ------------- ; S U C C E S S ************************************************ 346c : 4c0004 jmp start ;run again if disable_decimal < 1 ; core subroutine of the decimal add/subtract test ; *** WARNING - tests documented behavior only! *** ; only valid BCD operands are tested, N V Z flags are ignored ; iterates through all valid combinations of operands and carry input ; uses increments/decrements to predict result & carry flag 346f : chkdad ; decimal ADC / SBC zp 346f : 08 php ;save carry for subtract 3470 : a50d lda ad1 3472 : 650e adc ad2 ;perform add 3474 : 08 php 3475 : c50f cmp adrl ;check result trap_ne ;bad result 3477 : d0fe > bne * ;failed not equal (non zero) 3479 : 68 pla ;check flags 347a : 2901 and #1 ;mask carry 347c : c510 cmp adrh trap_ne ;bad carry 347e : d0fe > bne * ;failed not equal (non zero) 3480 : 28 plp 3481 : 08 php ;save carry for next add 3482 : a50d lda ad1 3484 : e512 sbc sb2 ;perform subtract 3486 : 08 php 3487 : c50f cmp adrl ;check result trap_ne ;bad result 3489 : d0fe > bne * ;failed not equal (non zero) 348b : 68 pla ;check flags 348c : 2901 and #1 ;mask carry 348e : c510 cmp adrh trap_ne ;bad flags 3490 : d0fe > bne * ;failed not equal (non zero) 3492 : 28 plp ; decimal ADC / SBC abs 3493 : 08 php ;save carry for subtract 3494 : a50d lda ad1 3496 : 6d0302 adc ada2 ;perform add 3499 : 08 php 349a : c50f cmp adrl ;check result trap_ne ;bad result 349c : d0fe > bne * ;failed not equal (non zero) 349e : 68 pla ;check flags 349f : 2901 and #1 ;mask carry 34a1 : c510 cmp adrh trap_ne ;bad carry 34a3 : d0fe > bne * ;failed not equal (non zero) 34a5 : 28 plp 34a6 : 08 php ;save carry for next add 34a7 : a50d lda ad1 34a9 : ed0402 sbc sba2 ;perform subtract 34ac : 08 php 34ad : c50f cmp adrl ;check result trap_ne ;bad result 34af : d0fe > bne * ;failed not equal (non zero) 34b1 : 68 pla ;check flags 34b2 : 2901 and #1 ;mask carry 34b4 : c510 cmp adrh trap_ne ;bad carry 34b6 : d0fe > bne * ;failed not equal (non zero) 34b8 : 28 plp ; decimal ADC / SBC # 34b9 : 08 php ;save carry for subtract 34ba : a50e lda ad2 34bc : 8d1202 sta ex_adci+1 ;set ADC # operand 34bf : a50d lda ad1 34c1 : 201102 jsr ex_adci ;execute ADC # in RAM 34c4 : 08 php 34c5 : c50f cmp adrl ;check result trap_ne ;bad result 34c7 : d0fe > bne * ;failed not equal (non zero) 34c9 : 68 pla ;check flags 34ca : 2901 and #1 ;mask carry 34cc : c510 cmp adrh trap_ne ;bad carry 34ce : d0fe > bne * ;failed not equal (non zero) 34d0 : 28 plp 34d1 : 08 php ;save carry for next add 34d2 : a512 lda sb2 34d4 : 8d1502 sta ex_sbci+1 ;set SBC # operand 34d7 : a50d lda ad1 34d9 : 201402 jsr ex_sbci ;execute SBC # in RAM 34dc : 08 php 34dd : c50f cmp adrl ;check result trap_ne ;bad result 34df : d0fe > bne * ;failed not equal (non zero) 34e1 : 68 pla ;check flags 34e2 : 2901 and #1 ;mask carry 34e4 : c510 cmp adrh trap_ne ;bad carry 34e6 : d0fe > bne * ;failed not equal (non zero) 34e8 : 28 plp ; decimal ADC / SBC zp,x 34e9 : 08 php ;save carry for subtract 34ea : a50d lda ad1 34ec : 7500 adc 0,x ;perform add 34ee : 08 php 34ef : c50f cmp adrl ;check result trap_ne ;bad result 34f1 : d0fe > bne * ;failed not equal (non zero) 34f3 : 68 pla ;check flags 34f4 : 2901 and #1 ;mask carry 34f6 : c510 cmp adrh trap_ne ;bad carry 34f8 : d0fe > bne * ;failed not equal (non zero) 34fa : 28 plp 34fb : 08 php ;save carry for next add 34fc : a50d lda ad1 34fe : f504 sbc sb2-ad2,x ;perform subtract 3500 : 08 php 3501 : c50f cmp adrl ;check result trap_ne ;bad result 3503 : d0fe > bne * ;failed not equal (non zero) 3505 : 68 pla ;check flags 3506 : 2901 and #1 ;mask carry 3508 : c510 cmp adrh trap_ne ;bad carry 350a : d0fe > bne * ;failed not equal (non zero) 350c : 28 plp ; decimal ADC / SBC abs,x 350d : 08 php ;save carry for subtract 350e : a50d lda ad1 3510 : 7df501 adc ada2-ad2,x ;perform add 3513 : 08 php 3514 : c50f cmp adrl ;check result trap_ne ;bad result 3516 : d0fe > bne * ;failed not equal (non zero) 3518 : 68 pla ;check flags 3519 : 2901 and #1 ;mask carry 351b : c510 cmp adrh trap_ne ;bad carry 351d : d0fe > bne * ;failed not equal (non zero) 351f : 28 plp 3520 : 08 php ;save carry for next add 3521 : a50d lda ad1 3523 : fdf601 sbc sba2-ad2,x ;perform subtract 3526 : 08 php 3527 : c50f cmp adrl ;check result trap_ne ;bad result 3529 : d0fe > bne * ;failed not equal (non zero) 352b : 68 pla ;check flags 352c : 2901 and #1 ;mask carry 352e : c510 cmp adrh trap_ne ;bad carry 3530 : d0fe > bne * ;failed not equal (non zero) 3532 : 28 plp ; decimal ADC / SBC abs,y 3533 : 08 php ;save carry for subtract 3534 : a50d lda ad1 3536 : 790401 adc ada2-$ff,y ;perform add 3539 : 08 php 353a : c50f cmp adrl ;check result trap_ne ;bad result 353c : d0fe > bne * ;failed not equal (non zero) 353e : 68 pla ;check flags 353f : 2901 and #1 ;mask carry 3541 : c510 cmp adrh trap_ne ;bad carry 3543 : d0fe > bne * ;failed not equal (non zero) 3545 : 28 plp 3546 : 08 php ;save carry for next add 3547 : a50d lda ad1 3549 : f90501 sbc sba2-$ff,y ;perform subtract 354c : 08 php 354d : c50f cmp adrl ;check result trap_ne ;bad result 354f : d0fe > bne * ;failed not equal (non zero) 3551 : 68 pla ;check flags 3552 : 2901 and #1 ;mask carry 3554 : c510 cmp adrh trap_ne ;bad carry 3556 : d0fe > bne * ;failed not equal (non zero) 3558 : 28 plp ; decimal ADC / SBC (zp,x) 3559 : 08 php ;save carry for subtract 355a : a50d lda ad1 355c : 6144 adc (lo adi2-ad2,x) ;perform add 355e : 08 php 355f : c50f cmp adrl ;check result trap_ne ;bad result 3561 : d0fe > bne * ;failed not equal (non zero) 3563 : 68 pla ;check flags 3564 : 2901 and #1 ;mask carry 3566 : c510 cmp adrh trap_ne ;bad carry 3568 : d0fe > bne * ;failed not equal (non zero) 356a : 28 plp 356b : 08 php ;save carry for next add 356c : a50d lda ad1 356e : e146 sbc (lo sbi2-ad2,x) ;perform subtract 3570 : 08 php 3571 : c50f cmp adrl ;check result trap_ne ;bad result 3573 : d0fe > bne * ;failed not equal (non zero) 3575 : 68 pla ;check flags 3576 : 2901 and #1 ;mask carry 3578 : c510 cmp adrh trap_ne ;bad carry 357a : d0fe > bne * ;failed not equal (non zero) 357c : 28 plp ; decimal ADC / SBC (abs),y 357d : 08 php ;save carry for subtract 357e : a50d lda ad1 3580 : 7156 adc (adiy2),y ;perform add 3582 : 08 php 3583 : c50f cmp adrl ;check result trap_ne ;bad result 3585 : d0fe > bne * ;failed not equal (non zero) 3587 : 68 pla ;check flags 3588 : 2901 and #1 ;mask carry 358a : c510 cmp adrh trap_ne ;bad carry 358c : d0fe > bne * ;failed not equal (non zero) 358e : 28 plp 358f : 08 php ;save carry for next add 3590 : a50d lda ad1 3592 : f158 sbc (sbiy2),y ;perform subtract 3594 : 08 php 3595 : c50f cmp adrl ;check result trap_ne ;bad result 3597 : d0fe > bne * ;failed not equal (non zero) 3599 : 68 pla ;check flags 359a : 2901 and #1 ;mask carry 359c : c510 cmp adrh trap_ne ;bad carry 359e : d0fe > bne * ;failed not equal (non zero) 35a0 : 28 plp 35a1 : 60 rts endif ; core subroutine of the full binary add/subtract test ; iterates through all combinations of operands and carry input ; uses increments/decrements to predict result & result flags 35a2 : a511 chkadd lda adrf ;add V-flag if overflow 35a4 : 2983 and #$83 ;keep N-----ZC / clear V 35a6 : 48 pha 35a7 : a50d lda ad1 ;test sign unequal between operands 35a9 : 450e eor ad2 35ab : 300a bmi ckad1 ;no overflow possible - operands have different sign 35ad : a50d lda ad1 ;test sign equal between operands and result 35af : 450f eor adrl 35b1 : 1004 bpl ckad1 ;no overflow occured - operand and result have same sign 35b3 : 68 pla 35b4 : 0940 ora #$40 ;set V 35b6 : 48 pha 35b7 : 68 ckad1 pla 35b8 : 8511 sta adrf ;save expected flags ; binary ADC / SBC zp 35ba : 08 php ;save carry for subtract 35bb : a50d lda ad1 35bd : 650e adc ad2 ;perform add 35bf : 08 php 35c0 : c50f cmp adrl ;check result trap_ne ;bad result 35c2 : d0fe > bne * ;failed not equal (non zero) 35c4 : 68 pla ;check flags 35c5 : 29c3 and #$c3 ;mask NV----ZC 35c7 : c511 cmp adrf trap_ne ;bad flags 35c9 : d0fe > bne * ;failed not equal (non zero) 35cb : 28 plp 35cc : 08 php ;save carry for next add 35cd : a50d lda ad1 35cf : e512 sbc sb2 ;perform subtract 35d1 : 08 php 35d2 : c50f cmp adrl ;check result trap_ne ;bad result 35d4 : d0fe > bne * ;failed not equal (non zero) 35d6 : 68 pla ;check flags 35d7 : 29c3 and #$c3 ;mask NV----ZC 35d9 : c511 cmp adrf trap_ne ;bad flags 35db : d0fe > bne * ;failed not equal (non zero) 35dd : 28 plp ; binary ADC / SBC abs 35de : 08 php ;save carry for subtract 35df : a50d lda ad1 35e1 : 6d0302 adc ada2 ;perform add 35e4 : 08 php 35e5 : c50f cmp adrl ;check result trap_ne ;bad result 35e7 : d0fe > bne * ;failed not equal (non zero) 35e9 : 68 pla ;check flags 35ea : 29c3 and #$c3 ;mask NV----ZC 35ec : c511 cmp adrf trap_ne ;bad flags 35ee : d0fe > bne * ;failed not equal (non zero) 35f0 : 28 plp 35f1 : 08 php ;save carry for next add 35f2 : a50d lda ad1 35f4 : ed0402 sbc sba2 ;perform subtract 35f7 : 08 php 35f8 : c50f cmp adrl ;check result trap_ne ;bad result 35fa : d0fe > bne * ;failed not equal (non zero) 35fc : 68 pla ;check flags 35fd : 29c3 and #$c3 ;mask NV----ZC 35ff : c511 cmp adrf trap_ne ;bad flags 3601 : d0fe > bne * ;failed not equal (non zero) 3603 : 28 plp ; binary ADC / SBC # 3604 : 08 php ;save carry for subtract 3605 : a50e lda ad2 3607 : 8d1202 sta ex_adci+1 ;set ADC # operand 360a : a50d lda ad1 360c : 201102 jsr ex_adci ;execute ADC # in RAM 360f : 08 php 3610 : c50f cmp adrl ;check result trap_ne ;bad result 3612 : d0fe > bne * ;failed not equal (non zero) 3614 : 68 pla ;check flags 3615 : 29c3 and #$c3 ;mask NV----ZC 3617 : c511 cmp adrf trap_ne ;bad flags 3619 : d0fe > bne * ;failed not equal (non zero) 361b : 28 plp 361c : 08 php ;save carry for next add 361d : a512 lda sb2 361f : 8d1502 sta ex_sbci+1 ;set SBC # operand 3622 : a50d lda ad1 3624 : 201402 jsr ex_sbci ;execute SBC # in RAM 3627 : 08 php 3628 : c50f cmp adrl ;check result trap_ne ;bad result 362a : d0fe > bne * ;failed not equal (non zero) 362c : 68 pla ;check flags 362d : 29c3 and #$c3 ;mask NV----ZC 362f : c511 cmp adrf trap_ne ;bad flags 3631 : d0fe > bne * ;failed not equal (non zero) 3633 : 28 plp ; binary ADC / SBC zp,x 3634 : 08 php ;save carry for subtract 3635 : a50d lda ad1 3637 : 7500 adc 0,x ;perform add 3639 : 08 php 363a : c50f cmp adrl ;check result trap_ne ;bad result 363c : d0fe > bne * ;failed not equal (non zero) 363e : 68 pla ;check flags 363f : 29c3 and #$c3 ;mask NV----ZC 3641 : c511 cmp adrf trap_ne ;bad flags 3643 : d0fe > bne * ;failed not equal (non zero) 3645 : 28 plp 3646 : 08 php ;save carry for next add 3647 : a50d lda ad1 3649 : f504 sbc sb2-ad2,x ;perform subtract 364b : 08 php 364c : c50f cmp adrl ;check result trap_ne ;bad result 364e : d0fe > bne * ;failed not equal (non zero) 3650 : 68 pla ;check flags 3651 : 29c3 and #$c3 ;mask NV----ZC 3653 : c511 cmp adrf trap_ne ;bad flags 3655 : d0fe > bne * ;failed not equal (non zero) 3657 : 28 plp ; binary ADC / SBC abs,x 3658 : 08 php ;save carry for subtract 3659 : a50d lda ad1 365b : 7df501 adc ada2-ad2,x ;perform add 365e : 08 php 365f : c50f cmp adrl ;check result trap_ne ;bad result 3661 : d0fe > bne * ;failed not equal (non zero) 3663 : 68 pla ;check flags 3664 : 29c3 and #$c3 ;mask NV----ZC 3666 : c511 cmp adrf trap_ne ;bad flags 3668 : d0fe > bne * ;failed not equal (non zero) 366a : 28 plp 366b : 08 php ;save carry for next add 366c : a50d lda ad1 366e : fdf601 sbc sba2-ad2,x ;perform subtract 3671 : 08 php 3672 : c50f cmp adrl ;check result trap_ne ;bad result 3674 : d0fe > bne * ;failed not equal (non zero) 3676 : 68 pla ;check flags 3677 : 29c3 and #$c3 ;mask NV----ZC 3679 : c511 cmp adrf trap_ne ;bad flags 367b : d0fe > bne * ;failed not equal (non zero) 367d : 28 plp ; binary ADC / SBC abs,y 367e : 08 php ;save carry for subtract 367f : a50d lda ad1 3681 : 790401 adc ada2-$ff,y ;perform add 3684 : 08 php 3685 : c50f cmp adrl ;check result trap_ne ;bad result 3687 : d0fe > bne * ;failed not equal (non zero) 3689 : 68 pla ;check flags 368a : 29c3 and #$c3 ;mask NV----ZC 368c : c511 cmp adrf trap_ne ;bad flags 368e : d0fe > bne * ;failed not equal (non zero) 3690 : 28 plp 3691 : 08 php ;save carry for next add 3692 : a50d lda ad1 3694 : f90501 sbc sba2-$ff,y ;perform subtract 3697 : 08 php 3698 : c50f cmp adrl ;check result trap_ne ;bad result 369a : d0fe > bne * ;failed not equal (non zero) 369c : 68 pla ;check flags 369d : 29c3 and #$c3 ;mask NV----ZC 369f : c511 cmp adrf trap_ne ;bad flags 36a1 : d0fe > bne * ;failed not equal (non zero) 36a3 : 28 plp ; binary ADC / SBC (zp,x) 36a4 : 08 php ;save carry for subtract 36a5 : a50d lda ad1 36a7 : 6144 adc (lo adi2-ad2,x) ;perform add 36a9 : 08 php 36aa : c50f cmp adrl ;check result trap_ne ;bad result 36ac : d0fe > bne * ;failed not equal (non zero) 36ae : 68 pla ;check flags 36af : 29c3 and #$c3 ;mask NV----ZC 36b1 : c511 cmp adrf trap_ne ;bad flags 36b3 : d0fe > bne * ;failed not equal (non zero) 36b5 : 28 plp 36b6 : 08 php ;save carry for next add 36b7 : a50d lda ad1 36b9 : e146 sbc (lo sbi2-ad2,x) ;perform subtract 36bb : 08 php 36bc : c50f cmp adrl ;check result trap_ne ;bad result 36be : d0fe > bne * ;failed not equal (non zero) 36c0 : 68 pla ;check flags 36c1 : 29c3 and #$c3 ;mask NV----ZC 36c3 : c511 cmp adrf trap_ne ;bad flags 36c5 : d0fe > bne * ;failed not equal (non zero) 36c7 : 28 plp ; binary ADC / SBC (abs),y 36c8 : 08 php ;save carry for subtract 36c9 : a50d lda ad1 36cb : 7156 adc (adiy2),y ;perform add 36cd : 08 php 36ce : c50f cmp adrl ;check result trap_ne ;bad result 36d0 : d0fe > bne * ;failed not equal (non zero) 36d2 : 68 pla ;check flags 36d3 : 29c3 and #$c3 ;mask NV----ZC 36d5 : c511 cmp adrf trap_ne ;bad flags 36d7 : d0fe > bne * ;failed not equal (non zero) 36d9 : 28 plp 36da : 08 php ;save carry for next add 36db : a50d lda ad1 36dd : f158 sbc (sbiy2),y ;perform subtract 36df : 08 php 36e0 : c50f cmp adrl ;check result trap_ne ;bad result 36e2 : d0fe > bne * ;failed not equal (non zero) 36e4 : 68 pla ;check flags 36e5 : 29c3 and #$c3 ;mask NV----ZC 36e7 : c511 cmp adrf trap_ne ;bad flags 36e9 : d0fe > bne * ;failed not equal (non zero) 36eb : 28 plp 36ec : 60 rts ; target for the jump absolute test 36ed : 88 dey 36ee : 88 dey 36ef : test_far 36ef : 08 php ;either SP or Y count will fail, if we do not hit 36f0 : 88 dey 36f1 : 88 dey 36f2 : 88 dey 36f3 : 28 plp trap_cs ;flags loaded? 36f4 : b0fe > bcs * ;failed carry set trap_vs 36f6 : 70fe > bvs * ;failed overflow set trap_mi 36f8 : 30fe > bmi * ;failed minus (bit 7 set) trap_eq 36fa : f0fe > beq * ;failed equal (zero) 36fc : c946 cmp #'F' ;registers loaded? trap_ne 36fe : d0fe > bne * ;failed not equal (non zero) 3700 : e041 cpx #'A' trap_ne 3702 : d0fe > bne * ;failed not equal (non zero) 3704 : c04f cpy #('R'-3) trap_ne 3706 : d0fe > bne * ;failed not equal (non zero) 3708 : 48 pha ;save a,x 3709 : 8a txa 370a : 48 pha 370b : ba tsx 370c : e0fd cpx #$fd ;check SP trap_ne 370e : d0fe > bne * ;failed not equal (non zero) 3710 : 68 pla ;restore x 3711 : aa tax set_stat $ff > load_flag $ff 3712 : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 3714 : 48 > pha ;use stack to load status 3715 : 28 > plp 3716 : 68 pla ;restore a 3717 : e8 inx ;return registers with modifications 3718 : 49aa eor #$aa ;N=1, V=1, Z=0, C=1 371a : 4c0f09 jmp far_ret ; target for the jump indirect test 371d : 00 align 371e : 2737 ptr_tst_ind dw test_ind 3720 : 6409 ptr_ind_ret dw ind_ret trap ;runover protection 3722 : 4c2237 > jmp * ;failed anyway 3725 : 88 dey 3726 : 88 dey 3727 : test_ind 3727 : 08 php ;either SP or Y count will fail, if we do not hit 3728 : 88 dey 3729 : 88 dey 372a : 88 dey 372b : 28 plp trap_cs ;flags loaded? 372c : b0fe > bcs * ;failed carry set trap_vs 372e : 70fe > bvs * ;failed overflow set trap_mi 3730 : 30fe > bmi * ;failed minus (bit 7 set) trap_eq 3732 : f0fe > beq * ;failed equal (zero) 3734 : c949 cmp #'I' ;registers loaded? trap_ne 3736 : d0fe > bne * ;failed not equal (non zero) 3738 : e04e cpx #'N' trap_ne 373a : d0fe > bne * ;failed not equal (non zero) 373c : c041 cpy #('D'-3) trap_ne 373e : d0fe > bne * ;failed not equal (non zero) 3740 : 48 pha ;save a,x 3741 : 8a txa 3742 : 48 pha 3743 : ba tsx 3744 : e0fd cpx #$fd ;check SP trap_ne 3746 : d0fe > bne * ;failed not equal (non zero) 3748 : 68 pla ;restore x 3749 : aa tax set_stat $ff > load_flag $ff 374a : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 374c : 48 > pha ;use stack to load status 374d : 28 > plp 374e : 68 pla ;restore a 374f : e8 inx ;return registers with modifications 3750 : 49aa eor #$aa ;N=1, V=1, Z=0, C=1 3752 : 6c2037 jmp (ptr_ind_ret) trap ;runover protection 3755 : 4c5537 > jmp * ;failed anyway 3758 : 4c0004 jmp start ;catastrophic error - cannot continue ; target for the jump subroutine test 375b : 88 dey 375c : 88 dey 375d : test_jsr 375d : 08 php ;either SP or Y count will fail, if we do not hit 375e : 88 dey 375f : 88 dey 3760 : 88 dey 3761 : 28 plp trap_cs ;flags loaded? 3762 : b0fe > bcs * ;failed carry set trap_vs 3764 : 70fe > bvs * ;failed overflow set trap_mi 3766 : 30fe > bmi * ;failed minus (bit 7 set) trap_eq 3768 : f0fe > beq * ;failed equal (zero) 376a : c94a cmp #'J' ;registers loaded? trap_ne 376c : d0fe > bne * ;failed not equal (non zero) 376e : e053 cpx #'S' trap_ne 3770 : d0fe > bne * ;failed not equal (non zero) 3772 : c04f cpy #('R'-3) trap_ne 3774 : d0fe > bne * ;failed not equal (non zero) 3776 : 48 pha ;save a,x 3777 : 8a txa 3778 : 48 pha 3779 : ba tsx ;sp -4? (return addr,a,x) 377a : e0fb cpx #$fb trap_ne 377c : d0fe > bne * ;failed not equal (non zero) 377e : adff01 lda $1ff ;propper return on stack 3781 : c909 cmp #hi(jsr_ret) trap_ne 3783 : d0fe > bne * ;failed not equal (non zero) 3785 : adfe01 lda $1fe 3788 : c99a cmp #lo(jsr_ret) trap_ne 378a : d0fe > bne * ;failed not equal (non zero) set_stat $ff > load_flag $ff 378c : a9ff > lda #$ff ;allow test to change I-flag (no mask) > 378e : 48 > pha ;use stack to load status 378f : 28 > plp 3790 : 68 pla ;pull x,a 3791 : aa tax 3792 : 68 pla 3793 : e8 inx ;return registers with modifications 3794 : 49aa eor #$aa ;N=1, V=1, Z=0, C=1 3796 : 60 rts trap ;runover protection 3797 : 4c9737 > jmp * ;failed anyway 379a : 4c0004 jmp start ;catastrophic error - cannot continue ;trap in case of unexpected IRQ, NMI, BRK, RESET - BRK test target 379d : nmi_trap trap ;check stack for conditions at NMI 379d : 4c9d37 > jmp * ;failed anyway 37a0 : 4c0004 jmp start ;catastrophic error - cannot continue 37a3 : res_trap trap ;unexpected RESET 37a3 : 4ca337 > jmp * ;failed anyway 37a6 : 4c0004 jmp start ;catastrophic error - cannot continue 37a9 : 88 dey 37aa : 88 dey 37ab : irq_trap ;BRK test or unextpected BRK or IRQ 37ab : 08 php ;either SP or Y count will fail, if we do not hit 37ac : 88 dey 37ad : 88 dey 37ae : 88 dey ;next traps could be caused by unexpected BRK or IRQ ;check stack for BREAK and originating location ;possible jump/branch into weeds (uninitialized space) 37af : c9bd cmp #$ff-'B' ;BRK pass 2 registers loaded? 37b1 : f042 beq break2 37b3 : c942 cmp #'B' ;BRK pass 1 registers loaded? trap_ne 37b5 : d0fe > bne * ;failed not equal (non zero) 37b7 : e052 cpx #'R' trap_ne 37b9 : d0fe > bne * ;failed not equal (non zero) 37bb : c048 cpy #'K'-3 trap_ne 37bd : d0fe > bne * ;failed not equal (non zero) 37bf : 850a sta irq_a ;save registers during break test 37c1 : 860b stx irq_x 37c3 : ba tsx ;test break on stack 37c4 : bd0201 lda $102,x cmp_flag 0 ;break test should have B=1 & unused=1 on stack 37c7 : c930 > cmp #(0 |fao)&m8 ;expected flags + always on bits trap_ne ; - no break flag on stack 37c9 : d0fe > bne * ;failed not equal (non zero) 37cb : 68 pla cmp_flag intdis ;should have added interrupt disable 37cc : c934 > cmp #(intdis |fao)&m8 ;expected flags + always on bits trap_ne 37ce : d0fe > bne * ;failed not equal (non zero) 37d0 : ba tsx 37d1 : e0fc cpx #$fc ;sp -3? (return addr, flags) trap_ne 37d3 : d0fe > bne * ;failed not equal (non zero) 37d5 : adff01 lda $1ff ;propper return on stack 37d8 : c909 cmp #hi(brk_ret0) trap_ne 37da : d0fe > bne * ;failed not equal (non zero) 37dc : adfe01 lda $1fe 37df : c9d1 cmp #lo(brk_ret0) trap_ne 37e1 : d0fe > bne * ;failed not equal (non zero) load_flag $ff 37e3 : a9ff > lda #$ff ;allow test to change I-flag (no mask) 37e5 : 48 pha 37e6 : a60b ldx irq_x 37e8 : e8 inx ;return registers with modifications 37e9 : a50a lda irq_a 37eb : 49aa eor #$aa 37ed : 28 plp ;N=1, V=1, Z=1, C=1 but original flags should be restored 37ee : 40 rti trap ;runover protection 37ef : 4cef37 > jmp * ;failed anyway 37f2 : 4c0004 jmp start ;catastrophic error - cannot continue 37f5 : break2 ;BRK pass 2 37f5 : e0ad cpx #$ff-'R' trap_ne 37f7 : d0fe > bne * ;failed not equal (non zero) 37f9 : c0b1 cpy #$ff-'K'-3 trap_ne 37fb : d0fe > bne * ;failed not equal (non zero) 37fd : 850a sta irq_a ;save registers during break test 37ff : 860b stx irq_x 3801 : ba tsx ;test break on stack 3802 : bd0201 lda $102,x cmp_flag $ff ;break test should have B=1 3805 : c9ff > cmp #($ff |fao)&m8 ;expected flags + always on bits trap_ne ; - no break flag on stack 3807 : d0fe > bne * ;failed not equal (non zero) 3809 : 68 pla 380a : 0908 ora #decmode ;ignore decmode cleared if 65c02 cmp_flag $ff ;actual passed flags 380c : c9ff > cmp #($ff |fao)&m8 ;expected flags + always on bits trap_ne 380e : d0fe > bne * ;failed not equal (non zero) 3810 : ba tsx 3811 : e0fc cpx #$fc ;sp -3? (return addr, flags) trap_ne 3813 : d0fe > bne * ;failed not equal (non zero) 3815 : adff01 lda $1ff ;propper return on stack 3818 : c909 cmp #hi(brk_ret1) trap_ne 381a : d0fe > bne * ;failed not equal (non zero) 381c : adfe01 lda $1fe 381f : c9f7 cmp #lo(brk_ret1) trap_ne 3821 : d0fe > bne * ;failed not equal (non zero) load_flag intdis 3823 : a904 > lda #intdis ;allow test to change I-flag (no mask) 3825 : 48 pha 3826 : a60b ldx irq_x 3828 : e8 inx ;return registers with modifications 3829 : a50a lda irq_a 382b : 49aa eor #$aa 382d : 28 plp ;N=0, V=0, Z=0, C=0 but original flags should be restored 382e : 40 rti trap ;runover protection 382f : 4c2f38 > jmp * ;failed anyway 3832 : 4c0004 jmp start ;catastrophic error - cannot continue if report = 1 include "report.i65" endif ;copy of data to initialize BSS segment if load_data_direct != 1 zp_init zp1_ db $c3,$82,$41,0 ;test patterns for LDx BIT ROL ROR ASL LSR zp7f_ db $7f ;test pattern for compare ;logical zeropage operands zpOR_ db 0,$1f,$71,$80 ;test pattern for OR zpAN_ db $0f,$ff,$7f,$80 ;test pattern for AND zpEO_ db $ff,$0f,$8f,$8f ;test pattern for EOR ;indirect addressing pointers ind1_ dw abs1 ;indirect pointer to pattern in absolute memory dw abs1+1 dw abs1+2 dw abs1+3 dw abs7f inw1_ dw abs1-$f8 ;indirect pointer for wrap-test pattern indt_ dw abst ;indirect pointer to store area in absolute memory dw abst+1 dw abst+2 dw abst+3 inwt_ dw abst-$f8 ;indirect pointer for wrap-test store indAN_ dw absAN ;indirect pointer to AND pattern in absolute memory dw absAN+1 dw absAN+2 dw absAN+3 indEO_ dw absEO ;indirect pointer to EOR pattern in absolute memory dw absEO+1 dw absEO+2 dw absEO+3 indOR_ dw absOR ;indirect pointer to OR pattern in absolute memory dw absOR+1 dw absOR+2 dw absOR+3 ;add/subtract indirect pointers adi2_ dw ada2 ;indirect pointer to operand 2 in absolute memory sbi2_ dw sba2 ;indirect pointer to complemented operand 2 (SBC) adiy2_ dw ada2-$ff ;with offset for indirect indexed sbiy2_ dw sba2-$ff zp_end if (zp_end - zp_init) != (zp_bss_end - zp_bss) ;force assembler error if size is different ERROR ERROR ERROR ;mismatch between bss and zeropage data endif data_init ex_and_ and #0 ;execute immediate opcodes rts ex_eor_ eor #0 ;execute immediate opcodes rts ex_ora_ ora #0 ;execute immediate opcodes rts ex_adc_ adc #0 ;execute immediate opcodes rts ex_sbc_ sbc #0 ;execute immediate opcodes rts abs1_ db $c3,$82,$41,0 ;test patterns for LDx BIT ROL ROR ASL LSR abs7f_ db $7f ;test pattern for compare ;loads fLDx_ db fn,fn,0,fz ;expected flags for load ;shifts rASL_ ;expected result ASL & ROL -carry rROL_ db $86,$04,$82,0 ; " rROLc_ db $87,$05,$83,1 ;expected result ROL +carry rLSR_ ;expected result LSR & ROR -carry rROR_ db $61,$41,$20,0 ; " rRORc_ db $e1,$c1,$a0,$80 ;expected result ROR +carry fASL_ ;expected flags for shifts fROL_ db fnc,fc,fn,fz ;no carry in fROLc_ db fnc,fc,fn,0 ;carry in fLSR_ fROR_ db fc,0,fc,fz ;no carry in fRORc_ db fnc,fn,fnc,fn ;carry in ;increments (decrements) rINC_ db $7f,$80,$ff,0,1 ;expected result for INC/DEC fINC_ db 0,fn,fn,fz,0 ;expected flags for INC/DEC ;logical memory operand absOR_ db 0,$1f,$71,$80 ;test pattern for OR absAN_ db $0f,$ff,$7f,$80 ;test pattern for AND absEO_ db $ff,$0f,$8f,$8f ;test pattern for EOR ;logical accu operand absORa_ db 0,$f1,$1f,0 ;test pattern for OR absANa_ db $f0,$ff,$ff,$ff ;test pattern for AND absEOa_ db $ff,$f0,$f0,$0f ;test pattern for EOR ;logical results absrlo_ db 0,$ff,$7f,$80 absflo_ db fz,fn,0,fn data_end if (data_end - data_init) != (data_bss_end - data_bss) ;force assembler error if size is different ERROR ERROR ERROR ;mismatch between bss and data endif vec_init dw nmi_trap dw res_trap dw irq_trap vec_bss equ $fffa endif ;end of RAM init data if (load_data_direct = 1) & (ROM_vectors = 1) fffa = org $fffa ;vectors fffa : 9d37 dw nmi_trap fffc : a337 dw res_trap fffe : ab37 dw irq_trap endif fffa = end start No errors in pass 2. Wrote binary from address $0000 through $ffff. Total size 65536 bytes. Program start address is at $0400 (1024).