aboutsummaryrefslogtreecommitdiffstats
path: root/ortho/mcode/ortho_code-x86.ads
diff options
context:
space:
mode:
Diffstat (limited to 'ortho/mcode/ortho_code-x86.ads')
-rw-r--r--ortho/mcode/ortho_code-x86.ads160
1 files changed, 0 insertions, 160 deletions
diff --git a/ortho/mcode/ortho_code-x86.ads b/ortho/mcode/ortho_code-x86.ads
deleted file mode 100644
index 24be1eb6c..000000000
--- a/ortho/mcode/ortho_code-x86.ads
+++ /dev/null
@@ -1,160 +0,0 @@
--- Mcode back-end for ortho - X86 common definitions.
--- Copyright (C) 2006 Tristan Gingold
---
--- GHDL 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 2, or (at your option) any later
--- version.
---
--- GHDL 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 GCC; see the file COPYING. If not, write to the Free
--- Software Foundation, 59 Temple Place - Suite 330, Boston, MA
--- 02111-1307, USA.
-with Ortho_Code.Exprs; use Ortho_Code.Exprs;
-
-package Ortho_Code.X86 is
- -- Registers.
- R_Nil : constant O_Reg := 0;
-
- -- Not a value. Used for statements.
- R_None : constant O_Reg := 1;
-
- -- Memory.
- R_Mem : constant O_Reg := 2;
-
- -- Spilled out.
- R_Spill : constant O_Reg := 3;
-
- -- Register or memory.
- -- THis can only be requested.
- R_Rm : constant O_Reg := 48;
-
- -- Immediat
- R_Imm : constant O_Reg := 49;
-
- -- Immediat, register or memory.
- -- This can be requested.
- R_Irm : constant O_Reg := 50;
-
- -- Immediat or register.
- -- This can be requested.
- R_Ir : constant O_Reg := 51;
-
- -- BASE + OFFSET
- R_B_Off : constant O_Reg := 52;
-
- -- BASE+INDEX*SCALE+OFFSET
- -- This can be requested.
- R_Sib : constant O_Reg := 53;
-
- -- INDEX*SCALE + OFFSET
- -- This can be requested.
- R_I_Off : constant O_Reg := 54;
-
- -- BASE + INDEX*SCALE
- R_B_I : constant O_Reg := 55;
-
- -- INDEX*SCALE
- R_I : constant O_Reg := 56;
-
- subtype Regs_Imm32 is O_Reg range R_Irm .. R_I_Off;
-
- R_Any8 : constant O_Reg := 6;
- R_Any32 : constant O_Reg := 7;
- R_Ax : constant O_Reg := 8;
- R_Cx : constant O_Reg := 9;
- R_Dx : constant O_Reg := 10;
- R_Bx : constant O_Reg := 11;
- R_Sp : constant O_Reg := 12;
- R_Bp : constant O_Reg := 13;
- R_Si : constant O_Reg := 14;
- R_Di : constant O_Reg := 15;
-
- subtype Regs_R8 is O_Reg range R_Ax .. R_Bx;
- subtype Regs_R32 is O_Reg range R_Ax .. R_Di;
-
- R_St0 : constant O_Reg := 16;
- R_St1 : constant O_Reg := 17;
- R_St2 : constant O_Reg := 18;
- R_St3 : constant O_Reg := 19;
- R_St4 : constant O_Reg := 20;
- R_St5 : constant O_Reg := 21;
- R_St6 : constant O_Reg := 22;
- R_St7 : constant O_Reg := 23;
- --R_Any_Fp : constant O_Reg := 24;
-
- subtype Regs_Fp is O_Reg range R_St0 .. R_St7;
-
- -- Any condition register.
- R_Any_Cc : constant O_Reg := 32;
- R_Ov : constant O_Reg := 32;
- R_Ult : constant O_Reg := 34;
- R_Uge : constant O_Reg := 35;
- R_Eq : constant O_Reg := 36;
- R_Ne : constant O_Reg := 37;
- R_Ule : constant O_Reg := 38;
- R_Ugt : constant O_Reg := 39;
- R_Slt : constant O_Reg := 44;
- R_Sge : constant O_Reg := 45;
- R_Sle : constant O_Reg := 46;
- R_Sgt : constant O_Reg := 47;
-
- subtype Regs_Cc is O_Reg range R_Ov .. R_Sgt;
-
- R_Edx_Eax : constant O_Reg := 64;
- R_Ebx_Ecx : constant O_Reg := 65;
- R_Esi_Edi : constant O_Reg := 66;
- R_Any64 : constant O_Reg := 67;
-
- subtype Regs_R64 is O_Reg range R_Edx_Eax .. R_Esi_Edi;
-
- R_Any_Xmm : constant O_Reg := 79;
-
- R_Xmm0 : constant O_Reg := 80;
- R_Xmm1 : constant O_Reg := R_Xmm0 + 1;
- R_Xmm2 : constant O_Reg := R_Xmm0 + 2;
- R_Xmm3 : constant O_Reg := R_Xmm0 + 3;
- R_Xmm4 : constant O_Reg := R_Xmm0 + 4;
- R_Xmm5 : constant O_Reg := R_Xmm0 + 5;
- R_Xmm6 : constant O_Reg := R_Xmm0 + 6;
- R_Xmm7 : constant O_Reg := R_Xmm0 + 7;
- R_Xmm8 : constant O_Reg := R_Xmm0 + 8;
- R_Xmm9 : constant O_Reg := R_Xmm0 + 9;
- R_Xmm10 : constant O_Reg := R_Xmm0 + 10;
- R_Xmm11 : constant O_Reg := R_Xmm0 + 11;
- R_Xmm12 : constant O_Reg := R_Xmm0 + 12;
- R_Xmm13 : constant O_Reg := R_Xmm0 + 13;
- R_Xmm14 : constant O_Reg := R_Xmm0 + 14;
- R_Xmm15 : constant O_Reg := R_Xmm0 + 15;
-
- subtype Regs_X86_64_Xmm is O_Reg range R_Xmm0 .. R_Xmm15;
- subtype Regs_X86_Xmm is O_Reg range R_Xmm0 .. R_Xmm7;
- subtype Regs_Xmm is O_Reg range R_Xmm0 .. R_Xmm15;
-
- function Get_R64_High (Reg : Regs_R64) return Regs_R32;
- function Get_R64_Low (Reg : Regs_R64) return Regs_R32;
-
- function Inverse_Cc (R : O_Reg) return O_Reg;
-
- -- Intrinsic subprograms.
- Intrinsic_Mul_Ov_U64 : constant Int32 := 1;
- Intrinsic_Div_Ov_U64 : constant Int32 := 2;
- Intrinsic_Mod_Ov_U64 : constant Int32 := 3;
- Intrinsic_Mul_Ov_I64 : constant Int32 := 4;
- Intrinsic_Div_Ov_I64 : constant Int32 := 5;
- Intrinsic_Mod_Ov_I64 : constant Int32 := 6;
- Intrinsic_Rem_Ov_I64 : constant Int32 := 7;
-
- subtype Intrinsics_X86 is Int32
- range Intrinsic_Mul_Ov_U64 .. Intrinsic_Rem_Ov_I64;
-
- -- Convert a KIND to a reg.
- function Ekind_Unsigned_To_Cc (Kind : OE_Kind_Cmp) return O_Reg;
- function Ekind_Signed_To_Cc (Kind : OE_Kind_Cmp) return O_Reg;
-
-end Ortho_Code.X86;