summaryrefslogtreecommitdiffstats
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
parentd79073dc2a7187b39200461216c74010bb4e14b6 (diff)
downloadbcm5719-llvm-e6ee481bdfec4776cdbb795511adafd2869ef62a.tar.gz
bcm5719-llvm-e6ee481bdfec4776cdbb795511adafd2869ef62a.zip
[Hexagon] Correctly set "Flags" in ELF header
llvm-svn: 267397
-rw-r--r--llvm/lib/Target/Hexagon/MCTargetDesc/HexagonMCTargetDesc.cpp10
-rw-r--r--llvm/test/MC/Hexagon/elf-flags.ll9
2 files changed, 16 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);
}
diff --git a/llvm/test/MC/Hexagon/elf-flags.ll b/llvm/test/MC/Hexagon/elf-flags.ll
new file mode 100644
index 00000000000..ec1d22b38d7
--- /dev/null
+++ b/llvm/test/MC/Hexagon/elf-flags.ll
@@ -0,0 +1,9 @@
+; RUN: llc -march=hexagon -mcpu=hexagonv4 --filetype=obj %s -o - | llvm-readobj -file-headers -elf-output-style=GNU | FileCheck --check-prefix=CHECK-V4 %s
+; RUN: llc -march=hexagon -mcpu=hexagonv5 --filetype=obj %s -o - | llvm-readobj -file-headers -elf-output-style=GNU | FileCheck --check-prefix=CHECK-V5 %s
+; RUN: llc -march=hexagon -mcpu=hexagonv55 --filetype=obj %s -o - | llvm-readobj -file-headers -elf-output-style=GNU | FileCheck --check-prefix=CHECK-V55 %s
+; RUN: llc -march=hexagon -mcpu=hexagonv60 --filetype=obj %s -o - | llvm-readobj -file-headers -elf-output-style=GNU | FileCheck --check-prefix=CHECK-V60 %s
+
+; CHECK-V4: Flags: 0x3
+; CHECK-V5: Flags: 0x4
+; CHECK-V55: Flags: 0x5
+; CHECK-V60: Flags: 0x60
OpenPOWER on IntegriCloud