diff options
author | Hans Wennborg <hans@hanshq.net> | 2019-10-09 09:06:30 +0000 |
---|---|---|
committer | Hans Wennborg <hans@hanshq.net> | 2019-10-09 09:06:30 +0000 |
commit | 1e1e3ba2526ecab1ad3c18c97abef36df00b3813 (patch) | |
tree | 58e8e645b1d85f51ab432d8ab7e279df0b3caf17 /llvm/lib/MC/WinCOFFObjectWriter.cpp | |
parent | f8d482c07be46b2ed0c280dfda1bb86cab5de386 (diff) | |
download | llvm-1e1e3ba2526ecab1ad3c18c97abef36df00b3813.zip llvm-1e1e3ba2526ecab1ad3c18c97abef36df00b3813.tar.gz llvm-1e1e3ba2526ecab1ad3c18c97abef36df00b3813.tar.bz2 |
Unify the two CRC implementations
David added the JamCRC implementation in r246590. More recently, Eugene
added a CRC-32 implementation in r357901, which falls back to zlib's
crc32 function if present.
These checksums are essentially the same, so having multiple
implementations seems unnecessary. This replaces the CRC-32
implementation with the simpler one from JamCRC, and implements the
JamCRC interface in terms of CRC-32 since this means it can use zlib's
implementation when available, saving a few bytes and potentially making
it faster.
JamCRC took an ArrayRef<char> argument, and CRC-32 took a StringRef.
This patch changes it to ArrayRef<uint8_t> which I think is the best
choice, and simplifies a few of the callers nicely.
Differential revision: https://reviews.llvm.org/D68570
llvm-svn: 374148
Diffstat (limited to 'llvm/lib/MC/WinCOFFObjectWriter.cpp')
-rw-r--r-- | llvm/lib/MC/WinCOFFObjectWriter.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/llvm/lib/MC/WinCOFFObjectWriter.cpp b/llvm/lib/MC/WinCOFFObjectWriter.cpp index fa97227..749ed8b 100644 --- a/llvm/lib/MC/WinCOFFObjectWriter.cpp +++ b/llvm/lib/MC/WinCOFFObjectWriter.cpp @@ -31,10 +31,10 @@ #include "llvm/MC/MCValue.h" #include "llvm/MC/MCWinCOFFObjectWriter.h" #include "llvm/MC/StringTableBuilder.h" +#include "llvm/Support/CRC.h" #include "llvm/Support/Casting.h" #include "llvm/Support/Endian.h" #include "llvm/Support/ErrorHandling.h" -#include "llvm/Support/JamCRC.h" #include "llvm/Support/LEB128.h" #include "llvm/Support/MathExtras.h" #include "llvm/Support/raw_ostream.h" @@ -605,7 +605,7 @@ uint32_t WinCOFFObjectWriter::writeSectionContents(MCAssembler &Asm, // Calculate our CRC with an initial value of '0', this is not how // JamCRC is specified but it aligns with the expected output. JamCRC JC(/*Init=*/0); - JC.update(Buf); + JC.update(makeArrayRef(reinterpret_cast<uint8_t*>(Buf.data()), Buf.size())); return JC.getCRC(); } |