65Dis

From BeebWiki
Jump to: navigation, search
    REM > 65Dis
    REM Simple disassembly program
    REM By J.G.Harston
    DIM ctrl% 31,data% 3:X%=ctrl%:Y%=X% DIV 256
    INPUT "Address: &"A$:addr%=EVAL("&"+A$)
    INPUT "ROM number: &"A$:addr%=addr%+65536*EVAL("&F"+A$)
    REPEAT
      FOR Z%=0 TO 2:data%?Z%=FNrm(addr%+Z%):NEXT
      num%=FNDis_Code(M%,addr%,data%)
      PRINTFNh0(addr%,6);" ";
      FOR Z%=data% TO data%-1+num%:PRINTFNh0(?Z%,2);" ";:NEXT
      PRINTTAB(20);$(X%+4)
      addr%=addr%+num%
    UNTIL0
    :
    DEFFNh0(A%,N%):=RIGHT$("0000000"+STR$~A%,N%)
    DEFFNrm(!&F6):LOCAL Y%:Y%=?&F8 EOR &F0:IF?&F8<&80:IF?&F7>&BF:?&F9=0
    IF!&F6<0:IF?&F7>&7F OR Y%=&E:=(USR&FFB9)AND&FF ELSE =?!&F6
    :
    REM > Dis65 1.00 - 11-Nov-1989 - 65x02 disassembly routines
    REM v1.01 - &B8 returns CLV instead of SEV, LDX/STX addr,Y returned
    :
    DEFFNDis_Name(cpu%)="65x02"
    DEFFNDis_Code(cpu%,Ptr%,Data%):LOCAL op%,ins%,md%,b0%,num%
    num%=1:op%=?Data%:ins%=op%DIV32:md%=(op%AND31)DIV4:b0%=(op%AND3)
    X%!0=0:$(X%+4)=FN_diss:X%?3=num%:=num%
    DEFFN_diss
    IF(op%AND&F)=8:=MID$("PHPCLCPLPSECPHACLIPLASEIDEYTYATAYCLVINYCLDINXSED",1+3*(op%DIV16),3)
    IF(op%AND&8F)=&8A:=MID$("TXATXSTAXTSXDEXPHXNOPPLX",3*(op%DIV16)-23,3)
    IFop%=&20:="JSR "+FNmde(3)
    IF(op%AND&9F)=0:X%?2=(op%AND64):=MID$("BRK***RTIRTS",ins%*3+1,3)
    IF(op%AND&DF)=&5A:=MID$("PHYPLY",ins%*3-5,3)
    IFop%=&89:="BIT "+FNmde(2)
    IFb0%=1:=FNalu(ins%)+" "+FNmde(md%)
    IF(op%AND31)=&12:=FNalu(ins%)+" "+FNmde(8)
    IF(op%AND&EF)=&64:="STZ "+FNmde(md%)
    IF(op%AND&FD)=&9C:="STZ "+FNmde(b0%*2+3)
    IF(op%AND&D7)=&96:=FNrot(ins%)+" "+FNmde(md%AND3)+",Y"
    IF(op%AND7)=6:=FNrot(ins%)+" "+FNmde(md%)
    IF(op%AND&1F)=16:num%=2:="B"+MID$("PLMIVCVSCCCSNEEQ",1+2*ins%,2)+" "+FNjr(Data%?1)
    IF(op%AND&8F)=10:=FNrot((ins%+(md%AND4)*1.5)EOR((md%>4)AND1))+" A"
    IF(op%AND&E7)=4:="T"+MID$("SR",1+(md%DIV4),1)+"B "+FNmde(md%AND3)
    IF(op%AND&D3)=&C0:=FNbxy(ins%)+" "+FNmde(((md%EOR3)-1)AND3)
    IF(op%AND&E7)=&24:="BIT "+FNmde(md%)
    IF(op%AND&C7)=&84:=FNbxy(ins%)+" "+FNmde(md%)
    IF(op%AND&FD)=&A0:="LD"+MID$("YX",1+((op%AND2)DIV2),1)+" "+FNmde(2)
    IF(op%AND&CF)=&4C:IFop%<>&5C:X%?2=64:="JMP "+LEFT$("(",op%>&5F)+FNmde(md%)+LEFT$(")",op%>&5F)
    IFop%=&80:num%=2:X%?2=64:="BRA "+FNjr(Data%?1)
    X%?2=128:="EQUB &"+FNh0(op%,2)
    :
    DEFFNalu(A%)=MID$("ORAANDEORADCSTALDACMPSBC",A%*3+1,3)
    DEFFNrot(A%)=MID$("ASLROLLSRRORSTXLDXDECINC",A%*3+1,3)
    DEFFNbxy(A%)=MID$("***BIT***STZSTYLDYCPYCPX",A%*3+1,3)
    :
    DEFFNmde(A%):num%=2:IFA%=2:="#&"+FNh0(Data%?1,2)
    IF(A%AND2):num%=3:="&"+FNh0(Data%!1,4)+LEFT$(",X",A%=7)+LEFT$(",Y",A%=6)
    IF(A%AND1):="&"+FNh0(Data%?1,2)+LEFT$(",X",A%=5)
    ="(&"+FNh0(Data%!1,2)+LEFT$(",X",A%=0)+")"+LEFT$(",Y",A%=4)
    :
    DEFFNjr(A%):IFA%<128:="&"+FNh0(Ptr%+A%+2,4) ELSE ="&"+FNh0(Ptr%+A%+2-256,4)