diff options
author | Krzysztof Parzyszek <kparzysz@codeaurora.org> | 2016-04-25 12:49:47 +0000 |
---|---|---|
committer | Krzysztof Parzyszek <kparzysz@codeaurora.org> | 2016-04-25 12:49:47 +0000 |
commit | e6ee481bdfec4776cdbb795511adafd2869ef62a (patch) | |
tree | d697fcc8eb6b674dc4519b2ac67b01ee90811bb0 /llvm/lib | |
parent | d79073dc2a7187b39200461216c74010bb4e14b6 (diff) | |
download | bcm5719-llvm-e6ee481bdfec4776cdbb795511adafd2869ef62a.tar.gz bcm5719-llvm-e6ee481bdfec4776cdbb795511adafd2869ef62a.zip |
[Hexagon] Correctly set "Flags" in ELF header
llvm-svn: 267397
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Target/Hexagon/MCTargetDesc/HexagonMCTargetDesc.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/llvm/lib/Target/Hexagon/MCTargetDesc/HexagonMCTargetDesc.cpp b/llvm/lib/Target/Hexagon/MCTargetDesc/HexagonMCTargetDesc.cpp index 7997198c7ac..86d0f77d343 100644 --- a/llvm/lib/Target/Hexagon/MCTargetDesc/HexagonMCTargetDesc.cpp +++ b/llvm/lib/Target/Hexagon/MCTargetDesc/HexagonMCTargetDesc.cpp @@ -157,10 +157,14 @@ public: HexagonTargetELFStreamer(MCStreamer &S, MCSubtargetInfo const &STI) : HexagonTargetStreamer(S) { auto Bits = STI.getFeatureBits(); - unsigned Flags; - if (Bits.to_ullong() & llvm::Hexagon::ArchV5) + unsigned Flags = 0; + if (Bits[Hexagon::ArchV60]) + Flags = ELF::EF_HEXAGON_MACH_V60; + else if (Bits[Hexagon::ArchV55]) + Flags = ELF::EF_HEXAGON_MACH_V55; + else if (Bits[Hexagon::ArchV5]) Flags = ELF::EF_HEXAGON_MACH_V5; - else + else if (Bits[Hexagon::ArchV4]) Flags = ELF::EF_HEXAGON_MACH_V4; getStreamer().getAssembler().setELFHeaderEFlags(Flags); } |