summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorKrzysztof Parzyszek <kparzysz@codeaurora.org>2016-04-25 12:49:47 +0000
committerKrzysztof Parzyszek <kparzysz@codeaurora.org>2016-04-25 12:49:47 +0000
commite6ee481bdfec4776cdbb795511adafd2869ef62a (patch)
treed697fcc8eb6b674dc4519b2ac67b01ee90811bb0 /llvm/lib
parentd79073dc2a7187b39200461216c74010bb4e14b6 (diff)
downloadbcm5719-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.cpp10
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);
}
OpenPOWER on IntegriCloud