diff options
author | Roman Divacky <rdivacky@freebsd.org> | 2011-06-07 17:31:02 +0000 |
---|---|---|
committer | Roman Divacky <rdivacky@freebsd.org> | 2011-06-07 17:31:02 +0000 |
commit | 384ffa9a0edcf573e4cf3353a1285069e630c395 (patch) | |
tree | 33c3aaae1f5e0ee80be78ae516175c5e1f456713 /llvm/lib/MC/MCStreamer.cpp | |
parent | 7ae360f2e1c28a174f0f4583ca20fed7772a4a05 (diff) | |
download | bcm5719-llvm-384ffa9a0edcf573e4cf3353a1285069e630c395.tar.gz bcm5719-llvm-384ffa9a0edcf573e4cf3353a1285069e630c395.zip |
Make EmitIntValue() work properly on big-endian targets.
llvm-svn: 132715
Diffstat (limited to 'llvm/lib/MC/MCStreamer.cpp')
-rw-r--r-- | llvm/lib/MC/MCStreamer.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/llvm/lib/MC/MCStreamer.cpp b/llvm/lib/MC/MCStreamer.cpp index 974e885aacd..ae3ed0f3f61 100644 --- a/llvm/lib/MC/MCStreamer.cpp +++ b/llvm/lib/MC/MCStreamer.cpp @@ -15,6 +15,7 @@ #include "llvm/MC/MCSymbol.h" #include "llvm/Support/ErrorHandling.h" #include "llvm/Support/raw_ostream.h" +#include "llvm/Target/TargetAsmInfo.h" #include "llvm/ADT/SmallString.h" #include "llvm/ADT/Twine.h" #include <cstdlib> @@ -80,9 +81,11 @@ void MCStreamer::EmitIntValue(uint64_t Value, unsigned Size, assert((isUIntN(8 * Size, Value) || isIntN(8 * Size, Value)) && "Invalid size"); char buf[8]; - // FIXME: Endianness assumption. - for (unsigned i = 0; i != Size; ++i) - buf[i] = uint8_t(Value >> (i * 8)); + const bool isLittleEndian = Context.getTargetAsmInfo().isLittleEndian(); + for (unsigned i = 0; i != Size; ++i) { + unsigned index = isLittleEndian ? i : (Size - i - 1); + buf[i] = uint8_t(Value >> (index * 8)); + } EmitBytes(StringRef(buf, Size), AddrSpace); } |