aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/SparcV9/SparcV9InstrSelectionSupport.h
diff options
context:
space:
mode:
authorVikram S. Adve <vadve@cs.uiuc.edu>2001-10-18 00:03:20 +0000
committerVikram S. Adve <vadve@cs.uiuc.edu>2001-10-18 00:03:20 +0000
commitfee93865d687dc176e748698c58c87674c5c8af7 (patch)
treea42dab2d71d05ddc0cf15bac0a41487d0b64013a /lib/Target/SparcV9/SparcV9InstrSelectionSupport.h
parent4df35a2ce3507b85a4d0966f2ce0a92abe3f5aab (diff)
downloadexternal_llvm-fee93865d687dc176e748698c58c87674c5c8af7.zip
external_llvm-fee93865d687dc176e748698c58c87674c5c8af7.tar.gz
external_llvm-fee93865d687dc176e748698c58c87674c5c8af7.tar.bz2
Sparc-specific code shared between local files.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@864 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/SparcV9/SparcV9InstrSelectionSupport.h')
-rw-r--r--lib/Target/SparcV9/SparcV9InstrSelectionSupport.h61
1 files changed, 61 insertions, 0 deletions
diff --git a/lib/Target/SparcV9/SparcV9InstrSelectionSupport.h b/lib/Target/SparcV9/SparcV9InstrSelectionSupport.h
new file mode 100644
index 0000000..f62457c
--- /dev/null
+++ b/lib/Target/SparcV9/SparcV9InstrSelectionSupport.h
@@ -0,0 +1,61 @@
+// $Id$ -*-c++-*-
+//***************************************************************************
+// File:
+// SparcInstrSelectionSupport.h
+//
+// Purpose:
+//
+// History:
+// 10/17/01 - Vikram Adve - Created
+//**************************************************************************/
+
+#ifndef SPARC_INSTR_SELECTION_SUPPORT_h
+#define SPARC_INSTR_SELECTION_SUPPORT_h
+
+
+inline MachineOpCode
+ChooseLoadInstruction(const Type *DestTy)
+{
+ switch (DestTy->getPrimitiveID()) {
+ case Type::BoolTyID:
+ case Type::UByteTyID: return LDUB;
+ case Type::SByteTyID: return LDSB;
+ case Type::UShortTyID: return LDUH;
+ case Type::ShortTyID: return LDSH;
+ case Type::UIntTyID: return LDUW;
+ case Type::IntTyID: return LDSW;
+ case Type::PointerTyID:
+ case Type::ULongTyID:
+ case Type::LongTyID: return LDX;
+ case Type::FloatTyID: return LD;
+ case Type::DoubleTyID: return LDD;
+ default: assert(0 && "Invalid type for Load instruction");
+ }
+
+ return 0;
+}
+
+
+inline MachineOpCode
+ChooseStoreInstruction(const Type *DestTy)
+{
+ switch (DestTy->getPrimitiveID()) {
+ case Type::BoolTyID:
+ case Type::UByteTyID:
+ case Type::SByteTyID: return STB;
+ case Type::UShortTyID:
+ case Type::ShortTyID: return STH;
+ case Type::UIntTyID:
+ case Type::IntTyID: return STW;
+ case Type::PointerTyID:
+ case Type::ULongTyID:
+ case Type::LongTyID: return STX;
+ case Type::FloatTyID: return ST;
+ case Type::DoubleTyID: return STD;
+ default: assert(0 && "Invalid type for Store instruction");
+ }
+
+ return 0;
+}
+
+#endif SPARC_INSTR_SELECTION_SUPPORT_h