summaryrefslogtreecommitdiff
path: root/lib/Target/PowerPC/PPCInstrBuilder.h
diff options
context:
space:
mode:
authorMisha Brukman <brukman+llvm@gmail.com>2004-06-21 16:55:25 +0000
committerMisha Brukman <brukman+llvm@gmail.com>2004-06-21 16:55:25 +0000
commit5dfe3a9c3bd9091f9adecc909665d52bdd4edd8c (patch)
tree212bdacc535069a5718dbc33375cb3e1f69ce363 /lib/Target/PowerPC/PPCInstrBuilder.h
parent31b24322edc0bcfb8c77277fc5eeebfe98267118 (diff)
downloadllvm-5dfe3a9c3bd9091f9adecc909665d52bdd4edd8c.tar.gz
llvm-5dfe3a9c3bd9091f9adecc909665d52bdd4edd8c.tar.bz2
llvm-5dfe3a9c3bd9091f9adecc909665d52bdd4edd8c.tar.xz
Initial revision
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14283 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/PowerPC/PPCInstrBuilder.h')
-rw-r--r--lib/Target/PowerPC/PPCInstrBuilder.h53
1 files changed, 53 insertions, 0 deletions
diff --git a/lib/Target/PowerPC/PPCInstrBuilder.h b/lib/Target/PowerPC/PPCInstrBuilder.h
new file mode 100644
index 0000000000..704e17c49b
--- /dev/null
+++ b/lib/Target/PowerPC/PPCInstrBuilder.h
@@ -0,0 +1,53 @@
+//===-- PowerPCInstrBuilder.h - Functions to aid building PPC insts -*- C++ -*-===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file was developed by the LLVM research group and is distributed under
+// the University of Illinois Open Source License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file exposes functions that may be used with BuildMI from the
+// MachineInstrBuilder.h file to simplify generating frame and constant pool
+// references.
+//
+// For reference, the order of operands for memory references is:
+// (Operand), Dest Reg, Base Reg, and either Reg Index or Immediate Displacement.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef PPCINSTRBUILDER_H
+#define PPCINSTRBUILDER_H
+
+#include "llvm/CodeGen/MachineInstrBuilder.h"
+
+namespace llvm {
+
+/// addFrameReference - This function is used to add a reference to the base of
+/// an abstract object on the stack frame of the current function. This
+/// reference has base register as the FrameIndex offset until it is resolved.
+/// This allows a constant offset to be specified as well...
+///
+inline const MachineInstrBuilder &
+addFrameReference(const MachineInstrBuilder &MIB, int FI, int Offset = 0, bool mem = true) {
+ if (mem)
+ return MIB.addSImm(Offset).addFrameIndex(FI);
+ else
+ return MIB.addFrameIndex(FI).addSImm(Offset);
+}
+
+/// addConstantPoolReference - This function is used to add a reference to the
+/// base of a constant value spilled to the per-function constant pool. The
+/// reference has base register ConstantPoolIndex offset which is retained until
+/// either machine code emission or assembly output. This allows an optional
+/// offset to be added as well.
+///
+inline const MachineInstrBuilder &
+addConstantPoolReference(const MachineInstrBuilder &MIB, unsigned CPI,
+ int Offset = 0) {
+ return MIB.addSImm(Offset).addConstantPoolIndex(CPI);
+}
+
+} // End llvm namespace
+
+#endif