diff options
Diffstat (limited to 'llvm/lib/Target/Hexagon/HexagonSubtarget.h')
| -rw-r--r-- | llvm/lib/Target/Hexagon/HexagonSubtarget.h | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/llvm/lib/Target/Hexagon/HexagonSubtarget.h b/llvm/lib/Target/Hexagon/HexagonSubtarget.h index 753dca00006..542929d94a7 100644 --- a/llvm/lib/Target/Hexagon/HexagonSubtarget.h +++ b/llvm/lib/Target/Hexagon/HexagonSubtarget.h @@ -56,10 +56,18 @@ public: /// default for V60. bool UseBSBScheduling; - class HexagonDAGMutation : public ScheduleDAGMutation { - public: + struct UsrOverflowMutation : public ScheduleDAGMutation { void apply(ScheduleDAGInstrs *DAG) override; }; + struct HVXMemLatencyMutation : public ScheduleDAGMutation { + void apply(ScheduleDAGInstrs *DAG) override; + }; + struct CallMutation : public ScheduleDAGMutation { + void apply(ScheduleDAGInstrs *DAG) override; + private: + bool shouldTFRICallBind(const HexagonInstrInfo &HII, + const SUnit &Inst1, const SUnit &Inst2) const; + }; private: std::string CPUString; |

