/* code601.c */ /*****************************************************************************/ /* AS-Portierung */ /* */ /* Codegenerator PowerPC-Familie */ /* */ /* Historie: 17.10.1996 Grundsteinlegung */ /* 30. 8.1998 Umstellung auf 32-Bit-Zugriffe */ /* Header-ID per Abfrage */ /* 3. 1.1999 ChkPC-Anpassung */ /* 9. 3.1999 MMU-Instruktionen */ /* 10. 3.1999 PPC403-MMU-Befehle */ /* 28. 3.1999 PPC403GB auf GC korrigiert (erst der hat eine MMU) */ /* 8. 9.1999 REG-Befehl nachgeruestet */ /* */ /*****************************************************************************/ #include "stdinc.h" #include #include #include "endian.h" #include "strutil.h" #include "asmdef.h" #include "asmsub.h" #include "asmpars.h" #include "asmallg.h" #include "codepseudo.h" #include "codevars.h" #include "headids.h" typedef struct { char *Name; LongWord Code; Byte CPUMask; } BaseOrder; #define FixedOrderCount 8 #define Reg1OrderCount 4 #define FReg1OrderCount 2 #define CReg1OrderCount 1 #define CBit1OrderCount 4 #define Reg2OrderCount 29 #define CReg2OrderCount 2 #define FReg2OrderCount 14 #define Reg2BOrderCount 2 #define Reg2SwapOrderCount 6 #define NoDestOrderCount 10 #define Reg3OrderCount 91 #define CReg3OrderCount 8 #define FReg3OrderCount 10 #define Reg3SwapOrderCount 49 #define MixedOrderCount 8 #define FReg4OrderCount 16 #define RegDispOrderCount 16 #define FRegDispOrderCount 8 #define Reg2ImmOrderCount 12 #define Imm16OrderCount 7 #define Imm16SwapOrderCount 6 static BaseOrder *FixedOrders; static BaseOrder *Reg1Orders; static BaseOrder *CReg1Orders; static BaseOrder *CBit1Orders; static BaseOrder *FReg1Orders; static BaseOrder *Reg2Orders; static BaseOrder *CReg2Orders; static BaseOrder *FReg2Orders; static BaseOrder *Reg2BOrders; static BaseOrder *Reg2SwapOrders; static BaseOrder *NoDestOrders; static BaseOrder *Reg3Orders; static BaseOrder *CReg3Orders; static BaseOrder *FReg3Orders; static BaseOrder *Reg3SwapOrders; static BaseOrder *MixedOrders; static BaseOrder *FReg4Orders; static BaseOrder *RegDispOrders; static BaseOrder *FRegDispOrders; static BaseOrder *Reg2ImmOrders; static BaseOrder *Imm16Orders; static BaseOrder *Imm16SwapOrders; static SimpProc SaveInitProc; static Boolean BigEnd; static CPUVar CPU403, CPU403C, CPU505, CPU601, CPU6000; #define M_403 0x01 #define M_403C 0x02 #define M_505 0x04 #define M_601 0x08 #define M_6000 0x10 /*-------------------------------------------------------------------------*/ /* PROCEDURE EnterByte(b:Byte); BEGIN if Odd(CodeLen) BEGIN BAsmCode[CodeLen]:=BAsmCode[CodeLen-1]; BAsmCode[CodeLen-1]:=b; END else BEGIN BAsmCode[CodeLen]:=b; END; Inc(CodeLen); END; */ /*-------------------------------------------------------------------------*/ static void AddFixed(char *NName1, char *NName2, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=FixedOrderCount) exit(255); FixedOrders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; FixedOrders[InstrZ].Code=NCode; FixedOrders[InstrZ++].CPUMask=NMask; END static void AddReg1(char *NName1, char *NName2, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=Reg1OrderCount) exit(255); Reg1Orders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; Reg1Orders[InstrZ].Code=NCode; Reg1Orders[InstrZ++].CPUMask=NMask; END static void AddCReg1(char *NName1, char *NName2, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=CReg1OrderCount) exit(255); CReg1Orders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; CReg1Orders[InstrZ].Code=NCode; CReg1Orders[InstrZ++].CPUMask=NMask; END static void AddCBit1(char *NName1, char *NName2, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=CBit1OrderCount) exit(255); CBit1Orders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; CBit1Orders[InstrZ].Code=NCode; CBit1Orders[InstrZ++].CPUMask=NMask; END static void AddFReg1(char *NName1, char *NName2, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=FReg1OrderCount) exit(255); FReg1Orders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; FReg1Orders[InstrZ].Code=NCode; FReg1Orders[InstrZ++].CPUMask=NMask; END static void AddSReg2(char *NName, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=Reg2OrderCount) exit(255); if (NName==Nil) exit(255); Reg2Orders[InstrZ].Name=NName; Reg2Orders[InstrZ].Code=NCode; Reg2Orders[InstrZ++].CPUMask=NMask; END static void AddReg2(char *NName1, char *NName2, LongInt NCode, Byte NMask, Boolean WithOE, Boolean WithFL) BEGIN String NName; strcpy(NName,(MomCPU==CPU6000)?NName2:NName1); AddSReg2(strdup(NName),NCode,NMask); if (WithOE) BEGIN strcat(NName,"O"); AddSReg2(strdup(NName),NCode | 0x400,NMask); NName[strlen(NName)-1]='\0'; END if (WithFL) BEGIN strcat(NName,"."); AddSReg2(strdup(NName),NCode | 0x001,NMask); NName[strlen(NName)-1]='\0'; if (WithOE) BEGIN strcat(NName,"O."); AddSReg2(strdup(NName),NCode | 0x401,NMask); END END END static void AddCReg2(char *NName1, char *NName2, LongWord NCode, Byte NMask) BEGIN if (InstrZ>=CReg2OrderCount) exit(255); CReg2Orders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; CReg2Orders[InstrZ].Code=NCode; CReg2Orders[InstrZ++].CPUMask=NMask; END static void AddSFReg2(char *NName, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=FReg2OrderCount) exit(255); if (NName==Nil) exit(255); FReg2Orders[InstrZ].Name=NName; FReg2Orders[InstrZ].Code=NCode; FReg2Orders[InstrZ++].CPUMask=NMask; END static void AddFReg2(char *NName1, char *NName2, LongInt NCode, Byte NMask, Boolean WithFL) BEGIN String NName; strcpy(NName,(MomCPU==CPU6000)?NName2:NName1); AddSFReg2(strdup(NName),NCode,NMask); if (WithFL) BEGIN strcat(NName,"."); AddSFReg2(strdup(NName),NCode | 0x001,NMask); END END static void AddReg2B(char *NName1, char *NName2, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=Reg2BOrderCount) exit(255); Reg2BOrders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; Reg2BOrders[InstrZ].Code=NCode; Reg2BOrders[InstrZ++].CPUMask=NMask; END static void AddSReg2Swap(char *NName, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=Reg2SwapOrderCount) exit(255); if (NName==Nil) exit(255); Reg2SwapOrders[InstrZ].Name=NName; Reg2SwapOrders[InstrZ].Code=NCode; Reg2SwapOrders[InstrZ++].CPUMask=NMask; END static void AddReg2Swap(char *NName1, char *NName2, LongInt NCode, Byte NMask, Boolean WithOE, Boolean WithFL) BEGIN String NName; strcpy(NName,(MomCPU==CPU6000)?NName2:NName1); AddSReg2Swap(strdup(NName),NCode,NMask); if (WithOE) BEGIN strcat(NName,"O"); AddSReg2Swap(strdup(NName),NCode | 0x400,NMask); NName[strlen(NName)-1]='\0'; END if (WithFL) BEGIN strcat(NName,"."); AddSReg2Swap(strdup(NName),NCode | 0x001,NMask); NName[strlen(NName)-1]='\0'; if (WithOE) BEGIN strcat(NName,"O."); AddSReg2Swap(strdup(NName),NCode | 0x401,NMask); END END END static void AddNoDest(char *NName1, char *NName2, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=NoDestOrderCount) exit(255); NoDestOrders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; NoDestOrders[InstrZ].Code=NCode; NoDestOrders[InstrZ++].CPUMask=NMask; END static void AddSReg3(char *NName, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=Reg3OrderCount) exit(255); if (NName==Nil) exit(255); Reg3Orders[InstrZ].Name=NName; Reg3Orders[InstrZ].Code=NCode; Reg3Orders[InstrZ++].CPUMask=NMask; END static void AddReg3(char *NName1, char *NName2, LongInt NCode, Byte NMask, Boolean WithOE, Boolean WithFL) BEGIN String NName; strcpy(NName,(MomCPU==CPU6000)?NName2:NName1); AddSReg3(strdup(NName),NCode,NMask); if (WithOE) BEGIN strcat(NName,"O"); AddSReg3(strdup(NName),NCode | 0x400,NMask); NName[strlen(NName)-1]='\0'; END if (WithFL) BEGIN strcat(NName,"."); AddSReg3(strdup(NName),NCode | 0x001,NMask); NName[strlen(NName)-1]='\0'; if (WithOE) BEGIN strcat(NName,"O."); AddSReg3(strdup(NName),NCode | 0x401,NMask); END END END static void AddCReg3(char *NName, LongWord NCode, CPUVar NMask) BEGIN if (InstrZ>=CReg3OrderCount) exit(255); CReg3Orders[InstrZ].Name=NName; CReg3Orders[InstrZ].Code=NCode; CReg3Orders[InstrZ++].CPUMask=NMask; END static void AddSFReg3(char *NName, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=FReg3OrderCount) exit(255); if (NName==Nil) exit(255); FReg3Orders[InstrZ].Name=NName; FReg3Orders[InstrZ].Code=NCode; FReg3Orders[InstrZ++].CPUMask=NMask; END static void AddFReg3(char *NName1, char *NName2, LongInt NCode, Byte NMask, Boolean WithFL) BEGIN String NName; strcpy(NName,(MomCPU==CPU6000)?NName2:NName1); AddSFReg3(strdup(NName),NCode,NMask); if (WithFL) BEGIN strcat(NName,"."); AddSFReg3(strdup(NName),NCode | 0x001,NMask); END END static void AddSReg3Swap(char *NName, LongInt NCode, Byte NMask) BEGIN if (InstrZ>=Reg3SwapOrderCount) exit(255); if (NName==Nil) exit(255); Reg3SwapOrders[InstrZ].Name=NName; Reg3SwapOrders[InstrZ].Code=NCode; Reg3SwapOrders[InstrZ++].CPUMask=NMask; END static void AddReg3Swap(char *NName1, char *NName2, LongInt NCode, Byte NMask, Boolean WithFL) BEGIN String NName; strcpy(NName,(MomCPU==CPU6000)?NName2:NName1); AddSReg3Swap(strdup(NName),NCode,NMask); if (WithFL) BEGIN strcat(NName,"."); AddSReg3Swap(strdup(NName),NCode | 0x001,NMask); END END static void AddMixed(char *NName1, char *NName2, LongWord NCode, Byte NMask) BEGIN if (InstrZ>=MixedOrderCount) exit(255); MixedOrders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; MixedOrders[InstrZ].Code=NCode; MixedOrders[InstrZ++].CPUMask=NMask; END static void AddSFReg4(char *NName, LongWord NCode, Byte NMask) BEGIN if (InstrZ>=FReg4OrderCount) exit(255); if (NName==Nil) exit(255); FReg4Orders[InstrZ].Name=NName; FReg4Orders[InstrZ].Code=NCode; FReg4Orders[InstrZ++].CPUMask=NMask; END static void AddFReg4(char *NName1, char *NName2, LongWord NCode, Byte NMask, Boolean WithFL) BEGIN String NName; strcpy(NName,(MomCPU==CPU6000)?NName2:NName1); AddSFReg4(strdup(NName),NCode,NMask); if (WithFL) BEGIN strcat(NName,"."); AddSFReg4(strdup(NName),NCode | 0x001,NMask); END END static void AddRegDisp(char *NName1, char *NName2, LongWord NCode, Byte NMask) BEGIN if (InstrZ>=RegDispOrderCount) exit(255); RegDispOrders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; RegDispOrders[InstrZ].Code=NCode; RegDispOrders[InstrZ++].CPUMask=NMask; END static void AddFRegDisp(char *NName1, char *NName2, LongWord NCode, Byte NMask) BEGIN if (InstrZ>=FRegDispOrderCount) exit(255); FRegDispOrders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; FRegDispOrders[InstrZ].Code=NCode; FRegDispOrders[InstrZ++].CPUMask=NMask; END static void AddSReg2Imm(char *NName, LongWord NCode, Byte NMask) BEGIN if (InstrZ>=Reg2ImmOrderCount) exit(255); if (NName==Nil) exit(255); Reg2ImmOrders[InstrZ].Name=NName; Reg2ImmOrders[InstrZ].Code=NCode; Reg2ImmOrders[InstrZ++].CPUMask=NMask; END static void AddReg2Imm(char *NName1, char *NName2, LongWord NCode, Byte NMask, Boolean WithFL) BEGIN String NName; strcpy(NName,(MomCPU==CPU6000)?NName2:NName1); AddSReg2Imm(strdup(NName),NCode,NMask); if (WithFL) BEGIN strcat(NName,"."); AddSReg2Imm(strdup(NName),NCode | 0x001,NMask); END END static void AddImm16(char *NName1, char *NName2, LongWord NCode, Byte NMask) BEGIN if (InstrZ>=Imm16OrderCount) exit(255); Imm16Orders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; Imm16Orders[InstrZ].Code=NCode; Imm16Orders[InstrZ++].CPUMask=NMask; END static void AddImm16Swap(char *NName1, char *NName2, LongWord NCode, Byte NMask) BEGIN if (InstrZ>=Imm16SwapOrderCount) exit(255); Imm16SwapOrders[InstrZ].Name=(MomCPU==CPU6000)?NName2:NName1; Imm16SwapOrders[InstrZ].Code=NCode; Imm16SwapOrders[InstrZ++].CPUMask=NMask; END #ifdef __STDC__ #define T1 1lu #define T3 3lu #define T4 4lu #define T7 7lu #define T8 8lu #define T9 9lu #define T10 10lu #define T11 11lu #define T12 12lu #define T13 13lu #define T14 14lu #define T15 15lu #define T16 16lu #define T17 17lu #define T18 18lu #define T19 19lu #define T20 20lu #define T21 21lu #define T22 22lu #define T23 23lu #define T24 24lu #define T25 25lu #define T26 26lu #define T27 27lu #define T28 28lu #define T29 29lu #define T31 31lu #define T32 32lu #define T33 33lu #define T34 34lu #define T35 35lu #define T36 36lu #define T37 37lu #define T38 38lu #define T39 39lu #define T40 40lu #define T41 41lu #define T42 42lu #define T43 43lu #define T44 44lu #define T45 45lu #define T46 46lu #define T47 47lu #define T48 48lu #define T49 49lu #define T50 50lu #define T51 51lu #define T52 52lu #define T53 53lu #define T54 54lu #define T55 55lu #define T59 59lu #define T63 63lu #else #define T1 1l #define T3 3l #define T4 4l #define T7 7l #define T8 8l #define T9 9l #define T10 10l #define T11 11l #define T12 12l #define T13 13l #define T14 14l #define T15 15l #define T16 16l #define T17 17l #define T18 18l #define T19 19l #define T20 20l #define T21 21l #define T22 22l #define T23 23l #define T24 24l #define T25 25l #define T26 26l #define T27 27l #define T28 28l #define T29 29l #define T31 31l #define T32 32l #define T33 33l #define T34 34l #define T35 35l #define T36 36l #define T37 37l #define T38 38l #define T39 39l #define T40 40l #define T41 41l #define T42 42l #define T43 43l #define T44 44l #define T45 45l #define T46 46l #define T47 47l #define T48 48l #define T49 49l #define T50 50l #define T51 51l #define T52 52l #define T53 53l #define T54 54l #define T55 55l #define T59 59l #define T63 63l #endif static void InitFields(void) BEGIN /* --> 0 0 0 */ FixedOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*FixedOrderCount); InstrZ=0; AddFixed("EIEIO" ,"EIEIO" ,(T31 << 26)+(854 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddFixed("ISYNC" ,"ICS" ,(T19 << 26)+(150 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddFixed("RFI" ,"RFI" ,(T19 << 26)+( 50 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddFixed("SC" ,"SVCA" ,(T17 << 26)+( 1 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddFixed("SYNC" ,"DCS" ,(T31 << 26)+(598 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddFixed("RFCI" ,"RFCI" ,(T19 << 26)+( 51 << 1), M_403 | M_403C ); AddFixed("TLBIA" ,"TLBIA" ,(T31 << 26)+(370 << 1), M_403C ); AddFixed("TLBSYNC","TLBSYNC",(T31 << 26)+(566 << 1), M_403C ); /* D --> D 0 0 */ Reg1Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*Reg1OrderCount); InstrZ=0; AddReg1("MFCR" ,"MFCR" ,(T31 << 26)+( 19 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddReg1("MFMSR" ,"MFMSR" ,(T31 << 26)+( 83 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddReg1("MTMSR" ,"MTMSR" ,(T31 << 26)+(146 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddReg1("WRTEE" ,"WRTEE" ,(T31 << 26)+(131 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); /* crD --> D 0 0 */ CReg1Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*CReg1OrderCount); InstrZ=0; AddCReg1("MCRXR" ,"MCRXR" ,(T31 << 26)+(512 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); /* crbD --> D 0 0 */ CBit1Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*CBit1OrderCount); InstrZ=0; AddCBit1("MTFSB0" ,"MTFSB0" ,(T63 << 26)+( 70 << 1) , M_601 | M_6000); AddCBit1("MTFSB0.","MTFSB0.",(T63 << 26)+( 70 << 1)+1, M_601 | M_6000); AddCBit1("MTFSB1" ,"MTFSB1" ,(T63 << 26)+( 38 << 1) , M_601 | M_6000); AddCBit1("MTFSB1.","MTFSB1.",(T63 << 26)+( 38 << 1)+1, M_601 | M_6000); /* frD --> D 0 0 */ FReg1Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*FReg1OrderCount); InstrZ=0; AddFReg1("MFFS" ,"MFFS" ,(T63 << 26)+(583 << 1) , M_601 | M_6000); AddFReg1("MFFS." ,"MFFS." ,(T63 << 26)+(583 << 1)+1, M_601 | M_6000); /* D,A --> D A 0 */ Reg2Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*Reg2OrderCount); InstrZ=0; AddReg2("ABS" ,"ABS" ,(T31 << 26)+(360 << 1), M_6000,True ,True ); AddReg2("ADDME" ,"AME" ,(T31 << 26)+(234 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg2("ADDZE" ,"AZE" ,(T31 << 26)+(202 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg2("CLCS" ,"CLCS" ,(T31 << 26)+(531 << 1), M_6000,False,False); AddReg2("NABS" ,"NABS" ,(T31 << 26)+(488 << 1), M_6000,True ,True ); AddReg2("NEG" ,"NEG" ,(T31 << 26)+(104 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg2("SUBFME","SFME" ,(T31 << 26)+(232 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg2("SUBFZE","SFZE" ,(T31 << 26)+(200 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); /* cD,cS --> D S 0 */ CReg2Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*CReg2OrderCount); InstrZ=0; AddCReg2("MCRF" ,"MCRF" ,(T19 << 26)+( 0 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddCReg2("MCRFS" ,"MCRFS" ,(T63 << 26)+( 64 << 1), M_601 | M_6000); /* fD,fB --> D 0 B */ FReg2Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*FReg2OrderCount); InstrZ=0; AddFReg2("FABS" ,"FABS" ,(T63 << 26)+(264 << 1), M_601 | M_6000,True ); AddFReg2("FCTIW" ,"FCTIW" ,(T63 << 26)+( 14 << 1), M_601 | M_6000,True ); AddFReg2("FCTIWZ","FCTIWZ",(T63 << 26)+( 15 << 1), M_601 | M_6000,True ); AddFReg2("FMR" ,"FMR" ,(T63 << 26)+( 72 << 1), M_601 | M_6000,True ); AddFReg2("FNABS" ,"FNABS" ,(T63 << 26)+(136 << 1), M_601 | M_6000,True ); AddFReg2("FNEG" ,"FNEG" ,(T63 << 26)+( 40 << 1), M_601 | M_6000,True ); AddFReg2("FRSP" ,"FRSP" ,(T63 << 26)+( 12 << 1), M_601 | M_6000,True ); /* D,B --> D 0 B */ Reg2BOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*Reg2BOrderCount); InstrZ=0; AddReg2B("MFSRIN","MFSRIN",(T31 << 26)+(659 << 1), M_601 | M_6000); AddReg2B("MTSRIN","MTSRI" ,(T31 << 26)+(242 << 1), M_601 | M_6000); /* A,S --> S A 0 */ Reg2SwapOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*Reg2SwapOrderCount); InstrZ=0; AddReg2Swap("CNTLZW","CNTLZ" ,(T31 << 26)+( 26 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,True ); AddReg2Swap("EXTSB ","EXTSB" ,(T31 << 26)+(954 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,True ); AddReg2Swap("EXTSH ","EXTS" ,(T31 << 26)+(922 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,True ); /* A,B --> 0 A B */ NoDestOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*NoDestOrderCount); InstrZ=0; AddNoDest("DCBF" ,"DCBF" ,(T31 << 26)+( 86 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddNoDest("DCBI" ,"DCBI" ,(T31 << 26)+( 470 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddNoDest("DCBST" ,"DCBST" ,(T31 << 26)+( 54 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddNoDest("DCBT" ,"DCBT" ,(T31 << 26)+( 278 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddNoDest("DCBTST","DCBTST",(T31 << 26)+( 246 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddNoDest("DCBZ" ,"DCLZ" ,(T31 << 26)+(1014 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddNoDest("DCCCI" ,"DCCCI" ,(T31 << 26)+( 454 << 1), M_403 | M_403C ); AddNoDest("ICBI" ,"ICBI" ,(T31 << 26)+( 982 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddNoDest("ICBT" ,"ICBT" ,(T31 << 26)+( 262 << 1), M_403 | M_403C ); AddNoDest("ICCCI" ,"ICCCI" ,(T31 << 26)+( 966 << 1), M_403 | M_403C ); /* D,A,B --> D A B */ Reg3Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*Reg3OrderCount); InstrZ=0; AddReg3("ADD" ,"CAX" ,(T31 << 26)+(266 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True, True ); AddReg3("ADDC" ,"A" ,(T31 << 26)+( 10 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("ADDE" ,"AE" ,(T31 << 26)+(138 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("DIV" ,"DIV" ,(T31 << 26)+(331 << 1), M_6000,True ,True ); AddReg3("DIVS" ,"DIVS" ,(T31 << 26)+(363 << 1), M_6000,True ,True ); AddReg3("DIVW" ,"DIVW" ,(T31 << 26)+(491 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("DIVWU" ,"DIVWU" ,(T31 << 26)+(459 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("DOZ" ,"DOZ" ,(T31 << 26)+(264 << 1), M_6000,True ,True ); AddReg3("ECIWX" ,"ECIWX" ,(T31 << 26)+(310 << 1), M_6000,False,False); AddReg3("LBZUX" ,"LBZUX" ,(T31 << 26)+(119 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LBZX" ,"LBZX" ,(T31 << 26)+( 87 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LHAUX" ,"LHAUX" ,(T31 << 26)+(375 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LHAX" ,"LHAX" ,(T31 << 26)+(343 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LHBRX" ,"LHBRX" ,(T31 << 26)+(790 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LHZUX" ,"LHZUX" ,(T31 << 26)+(311 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LHZX" ,"LHZX" ,(T31 << 26)+(279 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LSCBX" ,"LSCBX" ,(T31 << 26)+(277 << 1), M_6000,False,True ); AddReg3("LSWX" ,"LSX" ,(T31 << 26)+(533 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LWARX" ,"LWARX" ,(T31 << 26)+( 20 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LWBRX" ,"LBRX" ,(T31 << 26)+(534 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LWZUX" ,"LUX" ,(T31 << 26)+( 55 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("LWZX" ,"LX" ,(T31 << 26)+( 23 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("MUL" ,"MUL" ,(T31 << 26)+(107 << 1), M_6000,True ,True ); AddReg3("MULHW" ,"MULHW" ,(T31 << 26)+( 75 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,True ); AddReg3("MULHWU","MULHWU",(T31 << 26)+( 11 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,True ); AddReg3("MULLW" ,"MULS" ,(T31 << 26)+(235 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("STBUX" ,"STBUX" ,(T31 << 26)+(247 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("STBX" ,"STBX" ,(T31 << 26)+(215 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("STHBRX","STHBRX",(T31 << 26)+(918 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("STHUX" ,"STHUX" ,(T31 << 26)+(439 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("STHX" ,"STHX" ,(T31 << 26)+(407 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("STSWX" ,"STSX" ,(T31 << 26)+(661 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("STWBRX","STBRX" ,(T31 << 26)+(662 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("STWCX.","STWCX.",(T31 << 26)+(150 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("STWUX" ,"STUX" ,(T31 << 26)+(183 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("STWX" ,"STX" ,(T31 << 26)+(151 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,False,False); AddReg3("SUBF" ,"SUBF" ,(T31 << 26)+( 40 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("SUB" ,"SUB" ,(T31 << 26)+( 40 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("SUBFC" ,"SF" ,(T31 << 26)+( 8 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("SUBC" ,"SUBC" ,(T31 << 26)+( 8 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("SUBFE" ,"SFE" ,(T31 << 26)+(136 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ,True ); AddReg3("TLBSX" ,"TLBSX" ,(T31 << 26)+(914 << 1), M_403C ,False,True ); /* cD,cA,cB --> D A B */ CReg3Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*CReg3OrderCount); InstrZ=0; AddCReg3("CRAND" ,(T19 << 26)+(257 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddCReg3("CRANDC" ,(T19 << 26)+(129 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddCReg3("CREQV" ,(T19 << 26)+(289 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddCReg3("CRNAND" ,(T19 << 26)+(225 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddCReg3("CRNOR" ,(T19 << 26)+( 33 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddCReg3("CROR" ,(T19 << 26)+(449 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddCReg3("CRORC" ,(T19 << 26)+(417 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); AddCReg3("CRXOR" ,(T19 << 26)+(193 << 1), M_403 | M_403C | M_505 | M_601 | M_6000); /* fD,fA,fB --> D A B */ FReg3Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*FReg3OrderCount); InstrZ=0; AddFReg3("FADD" ,"FA" ,(T63 << 26)+(21 << 1), M_601 | M_6000,True ); AddFReg3("FADDS" ,"FADDS" ,(T59 << 26)+(21 << 1), M_601 | M_6000,True ); AddFReg3("FDIV" ,"FD" ,(T63 << 26)+(18 << 1), M_601 | M_6000,True ); AddFReg3("FDIVS" ,"FDIVS" ,(T59 << 26)+(18 << 1), M_601 | M_6000,True ); AddFReg3("FSUB" ,"FS" ,(T63 << 26)+(20 << 1), M_601 | M_6000,True ); /* A,S,B --> S A B */ Reg3SwapOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*Reg3SwapOrderCount); InstrZ=0; AddReg3Swap("AND" ,"AND" ,(T31 << 26)+( 28 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("ANDC" ,"ANDC" ,(T31 << 26)+( 60 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("ECOWX" ,"ECOWX" ,(T31 << 26)+( 438 << 1), M_601 | M_6000,False); AddReg3Swap("EQV" ,"EQV" ,(T31 << 26)+( 284 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("MASKG" ,"MASKG" ,(T31 << 26)+( 29 << 1), M_6000,True ); AddReg3Swap("MASKIR","MASKIR",(T31 << 26)+( 541 << 1), M_6000,True ); AddReg3Swap("NAND" ,"NAND" ,(T31 << 26)+( 476 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("NOR" ,"NOR" ,(T31 << 26)+( 124 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("OR" ,"OR" ,(T31 << 26)+( 444 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("ORC" ,"ORC" ,(T31 << 26)+( 412 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("RRIB" ,"RRIB" ,(T31 << 26)+( 537 << 1), M_6000,True ); AddReg3Swap("SLE" ,"SLE" ,(T31 << 26)+( 153 << 1), M_6000,True ); AddReg3Swap("SLEQ" ,"SLEQ" ,(T31 << 26)+( 217 << 1), M_6000,True ); AddReg3Swap("SLLQ" ,"SLLQ" ,(T31 << 26)+( 216 << 1), M_6000,True ); AddReg3Swap("SLQ" ,"SLQ" ,(T31 << 26)+( 152 << 1), M_6000,True ); AddReg3Swap("SLW" ,"SL" ,(T31 << 26)+( 24 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("SRAQ" ,"SRAQ" ,(T31 << 26)+( 920 << 1), M_6000,True ); AddReg3Swap("SRAW" ,"SRA" ,(T31 << 26)+( 792 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("SRE" ,"SRE" ,(T31 << 26)+( 665 << 1), M_6000,True ); AddReg3Swap("SREA" ,"SREA" ,(T31 << 26)+( 921 << 1), M_6000,True ); AddReg3Swap("SREQ" ,"SREQ" ,(T31 << 26)+( 729 << 1), M_6000,True ); AddReg3Swap("SRLQ" ,"SRLQ" ,(T31 << 26)+( 728 << 1), M_6000,True ); AddReg3Swap("SRQ" ,"SRQ" ,(T31 << 26)+( 664 << 1), M_6000,True ); AddReg3Swap("SRW" ,"SR" ,(T31 << 26)+( 536 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); AddReg3Swap("XOR" ,"XOR" ,(T31 << 26)+( 316 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True ); /* fD,A,B --> D A B */ MixedOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*MixedOrderCount); InstrZ=0; AddMixed("LFDUX" ,"LFDUX" ,(T31 << 26)+(631 << 1), M_601 | M_6000); AddMixed("LFDX" ,"LFDX" ,(T31 << 26)+(599 << 1), M_601 | M_6000); AddMixed("LFSUX" ,"LFSUX" ,(T31 << 26)+(567 << 1), M_601 | M_6000); AddMixed("LFSX" ,"LFSX" ,(T31 << 26)+(535 << 1), M_601 | M_6000); AddMixed("STFDUX","STFDUX",(T31 << 26)+(759 << 1), M_601 | M_6000); AddMixed("STFDX" ,"STFDX" ,(T31 << 26)+(727 << 1), M_601 | M_6000); AddMixed("STFSUX","STFSUX",(T31 << 26)+(695 << 1), M_601 | M_6000); AddMixed("STFSX" ,"STFSX" ,(T31 << 26)+(663 << 1), M_601 | M_6000); /* fD,fA,fC,fB --> D A B C */ FReg4Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*FReg4OrderCount); InstrZ=0; AddFReg4("FMADD" ,"FMA" ,(T63 << 26)+(29 << 1), M_601 | M_6000,True ); AddFReg4("FMADDS" ,"FMADDS" ,(T59 << 26)+(29 << 1), M_601 | M_6000,True ); AddFReg4("FMSUB" ,"FMS" ,(T63 << 26)+(28 << 1), M_601 | M_6000,True ); AddFReg4("FMSUBS" ,"FMSUBS" ,(T59 << 26)+(28 << 1), M_601 | M_6000,True ); AddFReg4("FNMADD" ,"FNMA" ,(T63 << 26)+(31 << 1), M_601 | M_6000,True ); AddFReg4("FNMADDS","FNMADDS",(T59 << 26)+(31 << 1), M_601 | M_6000,True ); AddFReg4("FNMSUB" ,"FNMS" ,(T63 << 26)+(30 << 1), M_601 | M_6000,True ); AddFReg4("FNMSUBS","FNMSUBS",(T59 << 26)+(30 << 1), M_601 | M_6000,True ); /* D,d(A) --> D A d */ RegDispOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*RegDispOrderCount); InstrZ=0; AddRegDisp("LBZ" ,"LBZ" ,(T34 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("LBZU" ,"LBZU" ,(T35 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("LHA" ,"LHA" ,(T42 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("LHAU" ,"LHAU" ,(T43 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("LHZ" ,"LHZ" ,(T40 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("LHZU" ,"LHZU" ,(T41 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("LMW" ,"LM" ,(T46 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("LWZ" ,"L" ,(T32 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("LWZU" ,"LU" ,(T33 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("STB" ,"STB" ,(T38 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("STBU" ,"STBU" ,(T39 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("STH" ,"STH" ,(T44 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("STHU" ,"STHU" ,(T45 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("STMW" ,"STM" ,(T47 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("STW" ,"ST" ,(T36 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); AddRegDisp("STWU" ,"STU" ,(T37 << 26), M_403 | M_403C | M_505 | M_601 | M_6000); /* fD,d(A) --> D A d */ FRegDispOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*FRegDispOrderCount); InstrZ=0; AddFRegDisp("LFD" ,"LFD" ,(T50 << 26), M_601 | M_6000); AddFRegDisp("LFDU" ,"LFDU" ,(T51 << 26), M_601 | M_6000); AddFRegDisp("LFS" ,"LFS" ,(T48 << 26), M_601 | M_6000); AddFRegDisp("LFSU" ,"LFSU" ,(T49 << 26), M_601 | M_6000); AddFRegDisp("STFD" ,"STFD" ,(T54 << 26), M_601 | M_6000); AddFRegDisp("STFDU" ,"STFDU" ,(T55 << 26), M_601 | M_6000); AddFRegDisp("STFS" ,"STFS" ,(T52 << 26), M_601 | M_6000); AddFRegDisp("STFSU" ,"STFSU" ,(T53 << 26), M_601 | M_6000); /* A,S,Imm5 --> S A Imm */ Reg2ImmOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*Reg2ImmOrderCount); InstrZ=0; AddReg2Imm("SLIQ" ,"SLIQ" ,(T31 << 26)+(184 << 1), M_6000,True); AddReg2Imm("SLLIQ" ,"SLLIQ" ,(T31 << 26)+(248 << 1), M_6000,True); AddReg2Imm("SRAIQ" ,"SRAIQ" ,(T31 << 26)+(952 << 1), M_6000,True); AddReg2Imm("SRAWI" ,"SRAI" ,(T31 << 26)+(824 << 1), M_403 | M_403C | M_505 | M_601 | M_6000,True); AddReg2Imm("SRIQ" ,"SRIQ" ,(T31 << 26)+(696 << 1), M_6000,True); AddReg2Imm("SRLIQ" ,"SRLIQ" ,(T31 << 26)+(760 << 1), M_6000,True); /* D,A,Imm --> D A Imm */ Imm16Orders=(BaseOrder *) malloc(sizeof(BaseOrder)*Imm16OrderCount); InstrZ=0; AddImm16("ADDI" ,"CAL" ,T14 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16("ADDIC" ,"AI" ,T12 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16("ADDIC." ,"AI." ,T13 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16("ADDIS" ,"CAU" ,T15 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16("DOZI" ,"DOZI" , T9 << 26, M_6000); AddImm16("MULLI" ,"MULI" , T7 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16("SUBFIC" ,"SFI" , T8 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); /* A,S,Imm --> S A Imm */ Imm16SwapOrders=(BaseOrder *) malloc(sizeof(BaseOrder)*Imm16SwapOrderCount); InstrZ=0; AddImm16Swap("ANDI." ,"ANDIL." ,T28 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16Swap("ANDIS." ,"ANDIU." ,T29 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16Swap("ORI" ,"ORIL" ,T24 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16Swap("ORIS" ,"ORIU" ,T25 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16Swap("XORI" ,"XORIL" ,T26 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); AddImm16Swap("XORIS" ,"XORIU" ,T27 << 26, M_403 | M_403C | M_505 | M_601 | M_6000); END static void DeinitNames(BaseOrder *Orders, int OrderCount) BEGIN int z; for (z=0; z> 24) & 0xff; BAsmCode[1]+=(Code >> 16) & 0xff; BAsmCode[2]+=(Code >> 8) & 0xff; BAsmCode[3]+=(Code ) & 0xff; #endif DAsmCode[0]+=Code; END /*-------------------------------------------------------------------------*/ static Boolean DecodeGenReg(char *Asc, LongWord *Erg) BEGIN Boolean io; char *s; if (FindRegDef(Asc, &s)) Asc = s; if ((strlen(Asc) < 2) OR (toupper(*Asc) != 'R')) return False; else BEGIN *Erg = ConstLongInt(Asc+1,&io); return ((io) AND (*Erg <= 31)); END END static Boolean DecodeFPReg(char *Asc, LongWord *Erg) BEGIN Boolean io; char *s; if (FindRegDef(Asc, &s)) Asc = s; if ((strlen(Asc)<3) OR (toupper(*Asc)!='F') OR (toupper(Asc[1])!='R')) return False; else BEGIN *Erg=ConstLongInt(Asc+2,&io); return ((io) AND (*Erg<=31)); END END static Boolean DecodeCondReg(char *Asc, LongWord *Erg) BEGIN Boolean OK; *Erg=EvalIntExpression(Asc,UInt3,&OK) << 2; return ((OK) AND (*Erg<=31)); END static Boolean DecodeCondBit(char *Asc, LongWord *Erg) BEGIN Boolean OK; *Erg=EvalIntExpression(Asc,UInt5,&OK); return ((OK) AND (*Erg<=31)); END static Boolean DecodeRegDisp(char *Asc, LongWord *Erg) BEGIN char *p; int l=strlen(Asc); LongInt Disp; Boolean OK; if (Asc[l-1]!=')') return False; Asc[l-1]='\0'; l--; p=Asc+l-1; while ((p>=Asc) AND (*p!='(')) p--; if (p> (MomCPU-CPU403))&1)==1); END /*-------------------------------------------------------------------------*/ static Boolean DecodePseudo(void) BEGIN if (Memo("REG")) BEGIN if (ArgCnt!=1) WrError(1110); else AddRegDef(LabPart,ArgStr[1]); return True; END return False; END static void SwapCode(LongWord *Code) BEGIN *Code=((*Code & 0x1f) << 5) | ((*Code >> 5) & 0x1f); END static void MakeCode_601(void) BEGIN int z; Integer Imm; LongWord Dest,Src1,Src2,Src3; LongInt Dist; Boolean OK; CodeLen=0; DontPrint=False; /* Nullanweisung */ if ((Memo("")) AND (*AttrPart=='\0') AND (ArgCnt==0)) return; /* Pseudoanweisungen */ if (DecodePseudo()) return; if (DecodeIntelPseudo(BigEnd)) return; /* ohne Argument */ for (z=0; z=CPU505) WrXError(1500,OpPart); else if (NOT DecodeGenReg(ArgStr[1],&Dest)) WrError(1350); else BEGIN Src1=EvalIntExpression(ArgStr[2],UInt10,&OK); if (OK) BEGIN SwapCode(&Src1); PutCode((T31 << 26)+(Dest << 21)+(Src1 << 11)); IncCode((Memo("MFDCR") ? 323 : 451) << 1); CodeLen=4; END END return; END if ((Memo("MFSR")) OR (Memo("MTSR"))) BEGIN if (Memo("MTSR")) BEGIN strcpy(ArgStr[3],ArgStr[1]); strcpy(ArgStr[1],ArgStr[2]); strcpy(ArgStr[2],ArgStr[3]); END if (ArgCnt!=2) WrError(1110); else if (NOT DecodeGenReg(ArgStr[1],&Dest)) WrError(1350); else BEGIN Src1=EvalIntExpression(ArgStr[2],UInt4,&OK); if (OK) BEGIN PutCode((T31 << 26)+(Dest << 21)+(Src1 << 16)); IncCode((Memo("MFSR") ? 595 : 210) << 1); CodeLen=4; ChkSup(); END END return; END if (Memo("MTCRF")) BEGIN if ((ArgCnt<1) OR (ArgCnt>2)) WrError(1110); else if (NOT DecodeGenReg(ArgStr[ArgCnt],&Src1)) WrError(1350); else BEGIN OK=True; if (ArgCnt==1) Dest=0xff; else Dest=EvalIntExpression(ArgStr[1],UInt8,&OK); if (OK) BEGIN PutCode((T31 << 26)+(Src1 << 21)+(Dest << 12)+(144 << 1)); CodeLen=4; END END return; END if (PMemo("MTFSF")) BEGIN if (ArgCnt!=2) WrError(1110); else if (NOT DecodeFPReg(ArgStr[2],&Src1)) WrError(1350); else BEGIN Dest=EvalIntExpression(ArgStr[1],UInt8,&OK); if (OK) BEGIN PutCode((T63 << 26)+(Dest << 17)+(Src1 << 11)+(711 << 1)); IncPoint(); CodeLen=4; END END return; END if (PMemo("MTFSFI")) BEGIN if (ArgCnt!=2) WrError(1110); else if (NOT DecodeCondReg(ArgStr[1],&Dest)) WrError(1350); else if ((Dest & 3)!=0) WrError(1351); else BEGIN Src1=EvalIntExpression(ArgStr[2],UInt4,&OK); if (OK) BEGIN PutCode((T63 << 26)+(Dest << 21)+(Src1 << 12)+(134 << 1)); IncPoint(); CodeLen=4; END END return; END if (PMemo("RLMI")) BEGIN if (ArgCnt!=5) WrError(1110); else if (MomCPU=CPU505) WrXError(1500,OpPart); else BEGIN Src1=EvalIntExpression(ArgStr[1],UInt1,&OK) << 15; if (OK) BEGIN PutCode((T31 << 26)+Src1+(163 << 1)); CodeLen=4; END END return; END /* Vergleiche */ if ((Memo("CMP")) OR (Memo("CMPL"))) BEGIN if (ArgCnt==3) BEGIN strcpy(ArgStr[4],ArgStr[3]); strcpy(ArgStr[3],ArgStr[2]); strmaxcpy(ArgStr[2],"0",255); ArgCnt=4; END if (ArgCnt!=4) WrError(1110); else if (NOT DecodeGenReg(ArgStr[4],&Src2)) WrError(1350); else if (NOT DecodeGenReg(ArgStr[3],&Src1)) WrError(1350); else if (NOT DecodeCondReg(ArgStr[1],&Dest)) WrError(1350); else if ((Dest & 3)!=0) WrError(1351); else BEGIN Src3=EvalIntExpression(ArgStr[2],UInt1,&OK); if (OK) BEGIN PutCode((T31 << 26)+(Dest << 21)+(Src3 << 21)+(Src1 << 16) +(Src2 << 11)); if (Memo("CMPL")) IncCode(32 << 1); CodeLen=4; END END return; END if ((Memo("FCMPO")) OR (Memo("FCMPU"))) BEGIN if (ArgCnt!=3) WrError(1110); else if (NOT DecodeFPReg(ArgStr[3],&Src2)) WrError(1350); else if (NOT DecodeFPReg(ArgStr[2],&Src1)) WrError(1350); else if (NOT DecodeCondReg(ArgStr[1],&Dest)) WrError(1350); else if ((Dest & 3)!=0) WrError(1351); else BEGIN PutCode((T63 << 26)+(Dest << 21)+(Src1 << 16)+(Src2 << 11)); if (Memo("FCMPO")) IncCode(32 << 1); CodeLen=4; END return; END if ((Memo("CMPI")) OR (Memo("CMPLI"))) BEGIN if (ArgCnt==3) BEGIN strcpy(ArgStr[4],ArgStr[3]); strcpy(ArgStr[3],ArgStr[2]); strmaxcpy(ArgStr[2],"0",255); ArgCnt=4; END if (ArgCnt!=4) WrError(1110); else BEGIN Src2=EvalIntExpression(ArgStr[4],Int16,&OK); if (OK) if (NOT DecodeGenReg(ArgStr[3],&Src1)) WrError(1350); else if (NOT DecodeCondReg(ArgStr[1],&Dest)) WrError(1350); else if ((Dest & 3)!=0) WrError(1351); else BEGIN Src3=EvalIntExpression(ArgStr[2],UInt1,&OK); if (OK) BEGIN PutCode((T10 << 26)+(Dest << 21)+(Src3 << 21) +(Src1 << 16)+(Src2 & 0xffff)); if (Memo("CMPI")) IncCode(T1 << 26); CodeLen=4; END END END return; END /* Spruenge */ if ((Memo("B")) OR (Memo("BL")) OR (Memo("BA")) OR (Memo("BLA"))) BEGIN if (ArgCnt!=1) WrError(1110); else BEGIN Dist=EvalIntExpression(ArgStr[1],Int32,&OK); if (OK) BEGIN if ((Memo("B")) OR (Memo("BL"))) Dist-=EProgCounter(); if ((NOT SymbolQuestionable) AND (Dist>0x1ffffff)) WrError(1320); else if ((NOT SymbolQuestionable) AND (Dist<-0x2000000l)) WrError(1315); else if ((Dist & 3)!=0) WrError(1375); else BEGIN PutCode((T18 << 26)+(Dist & 0x03fffffc)); if ((Memo("BA")) OR (Memo("BLA"))) IncCode(2); if ((Memo("BL")) OR (Memo("BLA"))) IncCode(1); CodeLen=4; END END END return; END if ((Memo("BC")) OR (Memo("BCL")) OR (Memo("BCA")) OR (Memo("BCLA"))) BEGIN if (ArgCnt!=3) WrError(1110); else BEGIN Src1=EvalIntExpression(ArgStr[1],UInt5,&OK); /* BO */ if (OK) BEGIN Src2=EvalIntExpression(ArgStr[2],UInt5,&OK); /* BI */ if (OK) BEGIN Dist=EvalIntExpression(ArgStr[3],Int32,&OK); /* ADR */ if (OK) BEGIN if ((Memo("BC")) OR (Memo("BCL"))) Dist-=EProgCounter(); if ((NOT SymbolQuestionable) AND (Dist>0x7fff)) WrError(1320); else if ((NOT SymbolQuestionable) AND (Dist<-0x8000l)) WrError(1315); else if ((Dist & 3)!=0) WrError(1375); else BEGIN PutCode((T16 << 26)+(Src1 << 21)+(Src2 << 16)+(Dist & 0xfffc)); if ((Memo("BCA")) OR (Memo("BCLA"))) IncCode(2); if ((Memo("BCL")) OR (Memo("BCLA"))) IncCode(1); CodeLen=4; END END END END END return; END if (NOT Convert6000("BCC","BCCTR")) return; if (NOT Convert6000("BCCL","BCCTRL")) return; if (NOT Convert6000("BCR","BCLR")) return; if (NOT Convert6000("BCRL","BCLRL")) return; if ((Memo("BCCTR")) OR (Memo("BCCTRL")) OR (Memo("BCLR")) OR (Memo("BCLRL"))) BEGIN if (ArgCnt!=2) WrError(1110); else BEGIN Src1=EvalIntExpression(ArgStr[1],UInt5,&OK); if (OK) BEGIN Src2=EvalIntExpression(ArgStr[2],UInt5,&OK); if (OK) BEGIN PutCode((T19 << 26)+(Src1 << 21)+(Src2 << 16)); if ((Memo("BCCTR")) OR (Memo("BCCTRL"))) IncCode(528 << 1); else IncCode(16 << 1); if ((Memo("BCCTRL")) OR (Memo("BCLRL"))) IncCode(1); CodeLen=4; END END END return; END if ((Memo("TLBRE")) OR (Memo("TLBWE"))) BEGIN if (ArgCnt!=3) WrError(1110); else if (MomCPU != CPU403C) WrError(1500); else if (NOT DecodeGenReg(ArgStr[1], &Src1)) WrError(1350); else if (NOT DecodeGenReg(ArgStr[2], &Src2)) WrError(1350); else BEGIN Src3 = EvalIntExpression(ArgStr[3], UInt1, &OK); if (OK) BEGIN PutCode((T31 << 26) + (Src1 << 21) + (Src2 << 16) + (Src3 << 11) + (946 << 1)); if (Memo("TLBWE")) IncCode(32 << 1); CodeLen = 4; END END return; END /* unbekannter Befehl */ WrXError(1200,OpPart); END static Boolean IsDef_601(void) BEGIN return Memo("REG"); END static void InitPass_601(void) BEGIN SaveInitProc(); SetFlag(&BigEnd,BigEndianName,False); END static void InternSymbol_601(char *Asc, TempResult *Erg) BEGIN int l=strlen(Asc); Erg->Typ=TempNone; if ((l==3) OR (l==4)) if ((toupper(*Asc)=='C') AND (toupper(Asc[1])=='R')) if ((Asc[l-1]>='0') AND (Asc[l-1]<='7')) if ((l==3) != ((toupper(Asc[2])=='F') OR (toupper(Asc[3])=='B'))) BEGIN Erg->Typ=TempInt; Erg->Contents.Int=Asc[l-1]-'0'; END END static void SwitchFrom_601(void) BEGIN DeinitFields(); ClearONOFF(); END static void SwitchTo_601(void) BEGIN PFamilyDescr FoundDscr; TurnWords=True; ConstMode=ConstModeC; SetIsOccupied=False; FoundDscr=FindFamilyByName("MPC601"); if (FoundDscr==Nil) exit(255); PCSymbol="*"; HeaderID=FoundDscr->Id; NOPCode=0x000000000; DivideChars=","; HasAttrs=False; ValidSegs=(1<