//===- AArch64CA53Erratum843419Stub.h -------------------------------------===// // // The MCLinker Project // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef TARGET_AARCH64_AARCH64CA53ERRATUM843419STUB_H_ #define TARGET_AARCH64_AARCH64CA53ERRATUM843419STUB_H_ #include "AArch64CA53ErratumStub.h" #include "mcld/Support/Compiler.h" #include #include #include namespace mcld { class FragmentRef; class AArch64CA53Erratum843419Stub : public AArch64CA53ErratumStub { public: static constexpr unsigned ErratumInsnOffset = 8; struct ErratumSequence { unsigned insns[3]; }; public: static bool isErratum843419Sequence(unsigned insn1, unsigned insn2, unsigned insn3); public: AArch64CA53Erratum843419Stub(); ~AArch64CA53Erratum843419Stub(); bool isMyDuty(const FragmentRef& pFragRef) const; unsigned getErratumInsnOffset() const { return ErratumInsnOffset; } unsigned getErratumSequenceSize() const { return sizeof(ErratumSequence); } private: /// for doClone AArch64CA53Erratum843419Stub(const uint32_t* pData, size_t pSize, const char* pName, const_fixup_iterator pBegin, const_fixup_iterator pEnd); /// doClone Stub* doClone(); private: DISALLOW_COPY_AND_ASSIGN(AArch64CA53Erratum843419Stub); }; } // namespace mcld #endif // TARGET_AARCH64_AARCH64CA53ERRATUM843419STUB_H_