aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/Hexagon/Hexagon.h
diff options
context:
space:
mode:
authorEvandro Menezes <emenezes@codeaurora.org>2012-04-12 17:55:53 +0000
committerEvandro Menezes <emenezes@codeaurora.org>2012-04-12 17:55:53 +0000
commite5041e6fa8fa74a26e031b7487be1912257c87f1 (patch)
treec3d38ea8b2d34abb1b41a47552b0c7b3e338f352 /lib/Target/Hexagon/Hexagon.h
parent4b4795563c4b724fa56c428d9d18160ee5cd429a (diff)
downloadexternal_llvm-e5041e6fa8fa74a26e031b7487be1912257c87f1.zip
external_llvm-e5041e6fa8fa74a26e031b7487be1912257c87f1.tar.gz
external_llvm-e5041e6fa8fa74a26e031b7487be1912257c87f1.tar.bz2
Hexagon: enable assembler output through the MC layer.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@154597 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/Hexagon/Hexagon.h')
-rw-r--r--lib/Target/Hexagon/Hexagon.h24
1 files changed, 22 insertions, 2 deletions
diff --git a/lib/Target/Hexagon/Hexagon.h b/lib/Target/Hexagon/Hexagon.h
index 270c7a7..0808323 100644
--- a/lib/Target/Hexagon/Hexagon.h
+++ b/lib/Target/Hexagon/Hexagon.h
@@ -17,10 +17,14 @@
#include "MCTargetDesc/HexagonMCTargetDesc.h"
#include "llvm/Target/TargetLowering.h"
+#include "llvm/Target/TargetMachine.h"
namespace llvm {
class FunctionPass;
class TargetMachine;
+ class MachineInstr;
+ class MCInst;
+ class HexagonAsmPrinter;
class HexagonTargetMachine;
class raw_ostream;
@@ -30,13 +34,23 @@ namespace llvm {
FunctionPass *createHexagonRemoveExtendOps(HexagonTargetMachine &TM);
FunctionPass *createHexagonCFGOptimizer(HexagonTargetMachine &TM);
- FunctionPass* createHexagonSplitTFRCondSets(HexagonTargetMachine &TM);
- FunctionPass* createHexagonExpandPredSpillCode(HexagonTargetMachine &TM);
+ FunctionPass *createHexagonSplitTFRCondSets(HexagonTargetMachine &TM);
+ FunctionPass *createHexagonExpandPredSpillCode(HexagonTargetMachine &TM);
FunctionPass *createHexagonHardwareLoops();
FunctionPass *createHexagonPeephole();
FunctionPass *createHexagonFixupHwLoops();
+/* TODO: object output.
+ MCCodeEmitter *createHexagonMCCodeEmitter(const Target &,
+ TargetMachine &TM,
+ MCContext &Ctx);
+*/
+/* TODO: assembler input.
+ TargetAsmBackend *createHexagonAsmBackend(const Target &, const std::string &);
+*/
+ void HexagonLowerToMC(const MachineInstr *MI, MCInst &MCI,
+ HexagonAsmPrinter &AP);
} // end namespace llvm;
#define Hexagon_POINTER_SIZE 4
@@ -50,4 +64,10 @@ namespace llvm {
// a new stack frame. This takes 8 bytes.
#define HEXAGON_LRFP_SIZE 8
+// Normal instruction size (in bytes).
+#define HEXAGON_INSTR_SIZE 4
+
+// Maximum number of words in a packet (in instructions).
+#define HEXAGON_PACKET_SIZE 4
+
#endif