123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392 |
- {****************************************************************}
- { CODE GENERATOR TEST PROGRAM }
- {****************************************************************}
- { NODE TESTED : secondin() }
- {****************************************************************}
- { PRE-REQUISITES: secondload() }
- { secondassign() }
- { secondtypeconv() }
- { secondadd() for sets }
- { secondsetelement() }
- { secondcalln() }
- { secondfuncret() }
- {****************************************************************}
- { DEFINES: }
- { FPC = Target is FreePascal compiler }
- {****************************************************************}
- { REMARKS: }
- { }
- { }
- { }
- {****************************************************************}
- type
- { DO NOT CHANGE THE VALUES OF THESE ENUMERATIONS! }
- { This will fit into a 32-bit small set }
- tsmallenum = (dA,dB,dC,dd,de,df,dg,dh,di,dj,dk,dl,dm,dn,dop,dp,dq,dr);
- { This will fit into a normal 32-byte set }
- tbigenum = (A_ABCD,
- A_ADD,A_ADDA,A_ADDI,A_ADDQ,A_ADDX,A_AND,A_ANDI,
- A_ASL,A_ASR,A_BCC,A_BCS,A_BEQ,A_BGE,A_BGT,A_BHI,
- A_BLE,A_BLS,A_BLT,A_BMI,A_BNE,A_BPL,A_BVC,A_BVS,
- A_BCHG,A_BCLR,A_BRA,A_BSET,A_BSR,A_BTST,A_CHK,
- A_CLR,A_CMP,A_CMPA,A_CMPI,A_CMPM,A_DBCC,A_DBCS,A_DBEQ,A_DBGE,
- A_DBGT,A_DBHI,A_DBLE,A_DBLS,A_DBLT,A_DBMI,A_DBNE,A_DBRA,
- A_DBPL,A_DBT,A_DBVC,A_DBVS,A_DBF,A_DIVS,A_DIVU,
- A_EOR,A_EORI,A_EXG,A_ILLEGAL,A_EXT,A_JMP,A_JSR,
- A_LEA,A_LINK,A_LSL,A_LSR,A_MOVE,A_MOVEA,A_MOVEI,A_MOVEQ,
- A_MOVEM,A_MOVEP,A_MULS,A_MULU,A_NBCD,A_NEG,A_NEGX,
- A_NOP,A_NOT,A_OR,A_ORI,A_PEA,A_ROL,A_ROR,A_ROXL,
- A_ROXR,A_RTR,A_RTS,A_SBCD,A_SCC,A_SCS,A_SEQ,A_SGE,
- A_SGT,A_SHI,A_SLE,A_SLS,A_SLT,A_SMI,A_SNE,
- A_SPL,A_ST,A_SVC,A_SVS,A_SF,A_SUB,A_SUBA,A_SUBI,A_SUBQ,
- A_SUBX,A_SWAP,A_TAS,A_TRAP,A_TRAPV,A_TST,A_UNLK,
- A_RTE,A_RESET,A_STOP,
- A_BKPT,A_MOVEC,A_MOVES,A_RTD,
- A_BFCHG,A_BFCLR,A_BFEXTS,A_BFEXTU,A_BFFFO,
- A_BFINS,A_BFSET,A_BFTST,A_CALLM,A_CAS,A_CAS2,
- A_CHK2,A_CMP2,A_DIVSL,A_DIVUL,A_EXTB,A_PACK,A_RTM,
- A_TRAPCC,A_TRACS,A_TRAPEQ,A_TRAPF,A_TRAPGE,A_TRAPGT,
- A_TRAPHI,A_TRAPLE,A_TRAPLS,A_TRAPLT,A_TRAPMI,A_TRAPNE,
- A_TRAPPL,A_TRAPT,A_TRAPVC,A_TRAPVS,A_UNPK,
- { FPU Processor instructions - directly supported only. }
- { IEEE aware and misc. condition codes not supported }
- A_FABS,A_FADD,
- A_FBEQ,A_FBNE,A_FBNGT,A_FBGT,A_FBGE,A_FBNGE,
- A_FBLT,A_FBNLT,A_FBLE,A_FBGL,A_FBNGL,A_FBGLE,A_FBNGLE,
- A_FDBEQ,A_FDBNE,A_FDBGT,A_FDBNGT,A_FDBGE,A_FDBNGE,
- A_FDBLT,A_FDBNLT,A_FDBLE,A_FDBGL,A_FDBNGL,A_FDBGLE,A_FBDNGLE,
- A_FSEQ,A_FSNE,A_FSGT,A_FSNGT,A_FSGE,A_FSNGE,
- A_FSLT,A_FSNLT,A_FSLE,A_FSGL,A_FSNGL,A_FSGLE,A_FSNGLE,
- A_FCMP,A_FDIV,A_FMOVE,A_FMOVEM,
- A_FMUL,A_FNEG,A_FNOP,A_FSQRT,A_FSUB,A_FSGLDIV,
- A_FSFLMUL,A_FTST,
- A_FTRAPEQ,A_FTRAPNE,A_FTRAPGT,A_FTRAPNGT,A_FTRAPGE,A_FTRAPNGE,
- A_FTRAPLT,A_FTRAPNLT,A_FTRAPLE,A_FTRAPGL,A_FTRAPNGL,A_FTRAPGLE,A_FTRAPNGLE,
- A_CPRESTORE,A_CPSAVE,
- A_FRESTORE,A_FSAVE,A_PFLUSH,A_PFLUSHA,A_PLOAD,A_PMOVE,A_PTEST,
- A_LABEL,A_NONE);
- { this is also a normal set }
- tregister = (R_NO,
- R_EAX,R_ECX,R_EDX,R_EBX,R_ESP,R_EBP,R_ESI,R_EDI,
- R_AX,R_CX,R_DX,R_BX,R_SP,R_BP,R_SI,R_DI,
- R_AL,R_CL,R_DL,R_BL,R_AH,R_CH,R_BH,R_DH,
- R_CS,R_DS,R_ES,R_SS,R_FS,R_GS,
- R_ST,R_ST0,R_ST1,R_ST2,R_ST3,R_ST4,R_ST5,R_ST6,R_ST7,
- R_DR0,R_DR1,R_DR2,R_DR3,R_DR6,R_DR7,
- R_CR0,R_CR2,R_CR3,R_CR4,
- R_TR3,R_TR4,R_TR5,R_TR6,R_TR7,
- R_MM0,R_MM1,R_MM2,R_MM3,R_MM4,R_MM5,R_MM6,R_MM7,
- R_XMM0,R_XMM1,R_XMM2,R_XMM3,R_XMM4,R_XMM5,R_XMM6,R_XMM7
- );
- const
- LoReg = R_EAX;
- HiReg = R_DH;
- type
- tnormalset = set of tbigenum;
- tsmallset = set of tsmallenum;
- tregset = set of LoReg..HiReg;
- procedure checkpassed(passed : boolean);
- begin
- if passed then
- WriteLn('Passed!')
- else
- begin
- WriteLn('Failure.');
- Halt(1);
- end;
- end;
- var
- NewRegsEncountered : TRegSet;
- function Reg32 : tregister;
- begin
- Reg32:=R_EAX;
- end;
- {*******************************************************************}
- { The following cases are possible }
- { jump table usage }
- { small set or normal set }
- { source location : REFERENCE,MEMORY,CONSTANT or REGISTER }
- {*******************************************************************}
- { NO GENERATION OF JUMP TABLE }
- { SMALL SET }
- procedure smallsettestone;
- var
- op1 : tsmallset;
- op2 : tsmallset;
- op3 : tsmallset;
- op : tsmallenum;
- passed : boolean;
- begin
- passed := true;
- Write('Small set in operator test (without case table)...');
- { LEFT : LOC_REFERENCE (not a constant node) }
- { RIGHT : LOC_REFERENCE }
- op1 := [DI];
- op2 := [DI];
- op := DI;
- if not (op in op1) then
- passed := false;
- { LEFT : LOC_REFERENCE (a constant node) }
- { RIGHT: LOC_REFERENCE }
- op1 := [DL];
- op := DI;
- if not (DL in op1) then
- passed := false;
- { LEFT : LOC_REFERENCE (a constant node) }
- { THIS CAN NEVER HAPPEN - EVALUATED AT COMPILE TIME BY COMPILER }
- op1 := [DB];
- op := DB;
- if not (DB in [DA..DL]) then
- passed := false;
- { LEFT : LOC_REFERENCE (not a constant node) }
- { RIGHT : LOC_REGISTER,LOC_CREGISTER }
- op := DF;
- op2 := [DB];
- op3 := [DF];
- if not (op in (op2+op3)) then
- passed := false;
- { LEFT : LOC_REGISTER (a constant node) }
- { RIGHT : LOC_REGISTER,LOC_CREGISTER }
- op2 := [DB];
- op3 := [DF];
- if not (DB in (op2+op3)) then
- passed := false;
- checkpassed(passed);
- end;
- { returns result in register }
- function getsmallop : tsmallenum;
- begin
- getsmallop := DQ;
- end;
- { NO GENERATION OF JUMP TABLE }
- { SMALL SET }
- procedure smallsettestthree;
- var
- op1 : tsmallset;
- op2 : tsmallset;
- op3 : tsmallset;
- op : tsmallenum;
- passed : boolean;
- begin
- passed := true;
- Write('Small set in operator test (without case table)...');
- { LEFT : LOC_REGISTER (not a constant node) }
- { RIGHT : LOC_REFERENCE }
- op1 := [DQ];
- op2 := [DQ];
- if not (getsmallop in op1) then
- passed := false;
- { LEFT : LOC_REGISTER (not a constant node) }
- { RIGHT : LOC_REGISTER }
- op := DF;
- op2 := [DB,DQ];
- op3 := [DF];
- if not (getsmallop in (op2+op3)) then
- passed := false;
- checkpassed(passed);
- end;
- { GENERATION OF JUMP TABLE }
- { SMALL SET }
- procedure smallsettesttwo;
- var
- op1 : tsmallset;
- op2 : tsmallset;
- op : tsmallenum;
- passed : boolean;
- begin
- Write('Small set in operator test (with case table)...');
- passed := true;
- op := DN;
- { LEFT : LOC_REFERENCE }
- { RIGHT: range constant set (carry flag) }
- if not (op in [DB..DN]) then
- passed := false;
- { LEFT : LOC_REFERENCE }
- { RIGHT: NOT range constant set (zero flag) }
- op := DH;
- if not (op in [DB,DH,DP]) then
- passed := false;
- { LEFT : LOC_REFERENCE }
- { RIGHT : range constant set with full set }
- op:=DK;
- if not (op in [dA,dB,dC,dd,de,df,dg,dh,di,dj,dk,dl,dm,dn,dop,dp,dq,dr]) then
- passed := false;
- { LEFT : LOC_REGISTER }
- { RIGHT : NOT range constant set (zero flag) }
- op := DH;
- if not (getsmallop in [DA,DB..DN,DQ]) then
- passed := false;
- { LEFT : LOC_REGISTER }
- { RIGHT : range constant set with full set }
- if not (getsmallop in [dA,dB,dC,dd,de,df,dg,dh,di,dj,dk,dl,dm,dn,dop,dp,dq,dr]) then
- passed := false;
- checkpassed(passed);
- end;
- { returns result in register }
- function getop : tbigenum;
- begin
- getop := A_BFSET;
- end;
- { NO JUMP TABLE }
- { NORMAL SETS }
- procedure settestone;
- var
- op1 : tnormalset;
- op2 : tnormalset;
- op : tbigenum;
- passed : boolean;
- begin
- Write('Normal set in operator test (without case table)...');
- passed := true;
- { RIGHT NODE = immediate value in reference field ?? }
- { RIGHT node = ordconstn (how is this possible?) - it goes through }
- { analizeset! }
- { Left : LOC_REGISTER }
- { right : LOC_REFERENCE (call to sys) }
- if not (getop in [A_BFSET,A_MOVE,A_TRAP,A_CMP,A_CMPI,A_FADD,A_LABEL,A_ASL,A_ADDX]) then
- passed := false;
- op := A_MOVE;
- { Left : LOC_REFERENCE }
- { right : LOC_REFERENCE }
- if not (op in [A_BFSET,A_MOVE,A_TRAP,A_CMP,A_CMPI,A_FADD,A_LABEL,A_ASL,A_ADDX]) then
- passed := false;
- { Left : ordinal constant }
- { right : LOC_REFERENCE }
- op1 := [A_MOVE,A_TRAP];
- if not (A_MOVE in op1) then
- passed := false;
- checkpassed(passed);
- end;
- { WITH JUMP TABLE }
- { NORMAL SETS }
- procedure settesttwo;
- var
- op1 : tnormalset;
- op2 : tnormalset;
- bs : set of boolean;
- op : tbigenum;
- passed : boolean;
- begin
- Write('Normal set in operator test (with case table)...');
- passed := true;
- { Left : LOC_REGISTER }
- { right : LOC_REFERENCE with ranges }
- if not (getop in [A_BFSET,A_MOVE,A_ASL..A_BCC]) then
- passed := false;
- { Left : LOC_REGISTER }
- { right : LOC_REFERENCE no ranges }
- if not (getop in [A_BFSET,A_MOVE]) then
- passed := false;
- { Left : LOC_REGISTER }
- { right : no set at all }
- if getop in [] then
- passed:=false;
- { Left : LOC_REGISTER }
- { right : complete set definition }
- if not (getop in [A_ABCD..A_NONE]) then
- passed:=false;
- op := A_MOVE;
- { Left : LOC_REFERENCE }
- { right : LOC_REFERENCE with ranges }
- if not (getop in [A_BFSET,A_MOVE,A_ASL..A_BCC]) then
- passed := false;
- op:= A_MOVE;
- if not (getop in [A_BFSET,A_MOVE]) then
- passed := false;
- { Left : LOC_REFERENCE }
- { right : no set at all }
- op := A_MOVE;
- if op in [] then
- passed:=false;
- { Left : LOC_REFERENCE }
- { right : complete set definition }
- op:=A_MOVE;
- if not (op in [A_ABCD..A_NONE]) then
- passed:=false;
- checkpassed(passed);
- { LEFT : LOC_JUMP }
- { RIGHT : LOC_REGISTER,LOC_CREGISTER }
- bs:=[false,true];
- op:=A_MOVE;
- passed:=true;
- if not(not(op in [A_BFSET,A_MOVE,A_ASL..A_BCC]) in bs) then
- passed := false;
- if not((op in [A_BFSET,A_MOVE,A_ASL..A_BCC]) in bs) then
- passed := false;
- bs:=[false];
- if ((op in [A_BFSET,A_MOVE,A_ASL..A_BCC]) in bs) then
- passed := false;
- checkpassed(passed);
- end;
- { WITH JUMP TABLE }
- { NORMAL SETS }
- procedure settestthree;
- var
- passed : boolean;
- begin
- Write('Normal set in operator test II (without case table)...');
- passed := false;
- NewRegsEncountered := [R_EAX..R_EDX];
- If (Reg32 in NewRegsEncountered) Then
- passed := true;
- checkpassed(passed);
- end;
- Begin
- smallsettestone;
- smallsettesttwo;
- smallsettestthree;
- settestone;
- settesttwo;
- settestthree;
- end.
|