[Bitcode] Replace hand-coded little endian handling with Endian.h functions.

No functional change intended.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@239944 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Benjamin Kramer 2015-06-17 20:55:30 +00:00
parent dd8f10201c
commit 3cab8a1193
3 changed files with 8 additions and 22 deletions

View File

@ -63,10 +63,7 @@ class BitstreamWriter {
// BackpatchWord - Backpatch a 32-bit word in the output with the specified // BackpatchWord - Backpatch a 32-bit word in the output with the specified
// value. // value.
void BackpatchWord(unsigned ByteNo, unsigned NewWord) { void BackpatchWord(unsigned ByteNo, unsigned NewWord) {
Out[ByteNo++] = (unsigned char)(NewWord >> 0); support::endian::write32le(&Out[ByteNo], NewWord);
Out[ByteNo++] = (unsigned char)(NewWord >> 8);
Out[ByteNo++] = (unsigned char)(NewWord >> 16);
Out[ByteNo ] = (unsigned char)(NewWord >> 24);
} }
void WriteByte(unsigned char Value) { void WriteByte(unsigned char Value) {
@ -74,12 +71,9 @@ class BitstreamWriter {
} }
void WriteWord(unsigned Value) { void WriteWord(unsigned Value) {
unsigned char Bytes[4] = { Value = support::endian::byte_swap<uint32_t, support::little>(Value);
(unsigned char)(Value >> 0), Out.append(reinterpret_cast<const char *>(&Value),
(unsigned char)(Value >> 8), reinterpret_cast<const char *>(&Value + 1));
(unsigned char)(Value >> 16),
(unsigned char)(Value >> 24) };
Out.append(&Bytes[0], &Bytes[4]);
} }
unsigned GetBufferOffset() const { unsigned GetBufferOffset() const {

View File

@ -15,6 +15,7 @@
#define LLVM_BITCODE_READERWRITER_H #define LLVM_BITCODE_READERWRITER_H
#include "llvm/IR/DiagnosticInfo.h" #include "llvm/IR/DiagnosticInfo.h"
#include "llvm/Support/Endian.h"
#include "llvm/Support/ErrorOr.h" #include "llvm/Support/ErrorOr.h"
#include "llvm/Support/MemoryBuffer.h" #include "llvm/Support/MemoryBuffer.h"
#include <memory> #include <memory>
@ -133,14 +134,8 @@ namespace llvm {
// Must contain the header! // Must contain the header!
if (BufEnd-BufPtr < KnownHeaderSize) return true; if (BufEnd-BufPtr < KnownHeaderSize) return true;
unsigned Offset = ( BufPtr[OffsetField ] | unsigned Offset = support::endian::read32le(&BufPtr[OffsetField]);
(BufPtr[OffsetField+1] << 8) | unsigned Size = support::endian::read32le(&BufPtr[SizeField]);
(BufPtr[OffsetField+2] << 16) |
(BufPtr[OffsetField+3] << 24));
unsigned Size = ( BufPtr[SizeField ] |
(BufPtr[SizeField +1] << 8) |
(BufPtr[SizeField +2] << 16) |
(BufPtr[SizeField +3] << 24));
// Verify that Offset+Size fits in the file. // Verify that Offset+Size fits in the file.
if (VerifyBufferSize && Offset+Size > unsigned(BufEnd-BufPtr)) if (VerifyBufferSize && Offset+Size > unsigned(BufEnd-BufPtr))

View File

@ -2406,10 +2406,7 @@ enum {
static void WriteInt32ToBuffer(uint32_t Value, SmallVectorImpl<char> &Buffer, static void WriteInt32ToBuffer(uint32_t Value, SmallVectorImpl<char> &Buffer,
uint32_t &Position) { uint32_t &Position) {
Buffer[Position + 0] = (unsigned char) (Value >> 0); support::endian::write32le(&Buffer[Position], Value);
Buffer[Position + 1] = (unsigned char) (Value >> 8);
Buffer[Position + 2] = (unsigned char) (Value >> 16);
Buffer[Position + 3] = (unsigned char) (Value >> 24);
Position += 4; Position += 4;
} }