diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-08-18 22:24:00 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-08-18 22:24:00 +0000 |
commit | 4514ae4f34d61ff30c18ce5a9dc734768471a02a (patch) | |
tree | 6d159ed8a1c8672ec7eb828470a004982c92ebb9 /lib/Support/raw_ostream.cpp | |
parent | a793115a75b24b6b59de79d12b331a4829c6b9e2 (diff) | |
download | external_llvm-4514ae4f34d61ff30c18ce5a9dc734768471a02a.zip external_llvm-4514ae4f34d61ff30c18ce5a9dc734768471a02a.tar.gz external_llvm-4514ae4f34d61ff30c18ce5a9dc734768471a02a.tar.bz2 |
Speed up raw_ostream::<<(unsigned long long) for 32-bit systems by doing most
div/mods in 32-bits.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79375 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Support/raw_ostream.cpp')
-rw-r--r-- | lib/Support/raw_ostream.cpp | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/lib/Support/raw_ostream.cpp b/lib/Support/raw_ostream.cpp index 0c1843c..ac9bc64 100644 --- a/lib/Support/raw_ostream.cpp +++ b/lib/Support/raw_ostream.cpp @@ -125,19 +125,24 @@ raw_ostream &raw_ostream::operator<<(long N) { } raw_ostream &raw_ostream::operator<<(unsigned long long N) { - // Output using 32-bit div/mod when possible. + // Handle simple case when value fits in long already. if (N == static_cast<unsigned long>(N)) return this->operator<<(static_cast<unsigned long>(N)); - char NumberBuffer[20]; - char *EndPtr = NumberBuffer+sizeof(NumberBuffer); - char *CurPtr = EndPtr; - - while (N) { - *--CurPtr = '0' + char(N % 10); - N /= 10; - } - return write(CurPtr, EndPtr-CurPtr); + // Otherwise divide into at two or three 10**9 chunks and write out using + // long div/mod, this is substantially faster on a 32-bit system. + unsigned long Top = 0, Mid = 0, Bot = N % 1000000000; + N /= 1000000000; + if (N > 1000000000) { + Mid = N % 1000000000; + Top = N / 1000000000; + } else + Mid = N; + + if (Top) + this->operator<<(static_cast<unsigned long>(Top)); + this->operator<<(static_cast<unsigned long>(Mid)); + return this->operator<<(static_cast<unsigned long>(Bot)); } raw_ostream &raw_ostream::operator<<(long long N) { |