From 3c288fc8e72b8541a599c8396104988fe907499c Mon Sep 17 00:00:00 2001 From: Logan Chien Date: Sat, 22 Feb 2014 15:39:39 +0000 Subject: [PATCH] Don't inline get[S|U]LEB128Size() until they are proved to be hot. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@201939 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Support/LEB128.h | 23 ++---------------- lib/Support/CMakeLists.txt | 1 + lib/Support/LEB128.cpp | 44 +++++++++++++++++++++++++++++++++++ 3 files changed, 47 insertions(+), 21 deletions(-) create mode 100644 lib/Support/LEB128.cpp diff --git a/include/llvm/Support/LEB128.h b/include/llvm/Support/LEB128.h index 6eb34eec8a6c..9ef5fe6bef8f 100644 --- a/include/llvm/Support/LEB128.h +++ b/include/llvm/Support/LEB128.h @@ -91,29 +91,10 @@ inline uint64_t decodeULEB128(const uint8_t *p, unsigned *n = 0) { } /// Utility function to get the size of the ULEB128-encoded value. -inline unsigned getULEB128Size(uint64_t Value) { - unsigned Size = 0; - do { - Value >>= 7; - Size += sizeof(int8_t); - } while (Value); - return Size; -} +extern unsigned getULEB128Size(uint64_t Value); /// Utility function to get the size of the SLEB128-encoded value. -inline unsigned getSLEB128Size(int64_t Value) { - unsigned Size = 0; - int Sign = Value >> (8 * sizeof(Value) - 1); - bool IsMore; - - do { - unsigned Byte = Value & 0x7f; - Value >>= 7; - IsMore = Value != Sign || ((Byte ^ Sign) & 0x40) != 0; - Size += sizeof(int8_t); - } while (IsMore); - return Size; -} +extern unsigned getSLEB128Size(int64_t Value); } // namespace llvm diff --git a/lib/Support/CMakeLists.txt b/lib/Support/CMakeLists.txt index 5d533dea6589..1ba1c76f71f2 100644 --- a/lib/Support/CMakeLists.txt +++ b/lib/Support/CMakeLists.txt @@ -31,6 +31,7 @@ add_llvm_library(LLVMSupport IntrusiveRefCntPtr.cpp IsInf.cpp IsNAN.cpp + LEB128.cpp LineIterator.cpp Locale.cpp LockFileManager.cpp diff --git a/lib/Support/LEB128.cpp b/lib/Support/LEB128.cpp new file mode 100644 index 000000000000..449626f2d451 --- /dev/null +++ b/lib/Support/LEB128.cpp @@ -0,0 +1,44 @@ +//===- LEB128.cpp - LEB128 utility functions implementation -----*- C++ -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file implements some utility functions for encoding SLEB128 and +// ULEB128 values. +// +//===----------------------------------------------------------------------===// + +#include "llvm/Support/LEB128.h" + +namespace llvm { + +/// Utility function to get the size of the ULEB128-encoded value. +unsigned getULEB128Size(uint64_t Value) { + unsigned Size = 0; + do { + Value >>= 7; + Size += sizeof(int8_t); + } while (Value); + return Size; +} + +/// Utility function to get the size of the SLEB128-encoded value. +unsigned getSLEB128Size(int64_t Value) { + unsigned Size = 0; + int Sign = Value >> (8 * sizeof(Value) - 1); + bool IsMore; + + do { + unsigned Byte = Value & 0x7f; + Value >>= 7; + IsMore = Value != Sign || ((Byte ^ Sign) & 0x40) != 0; + Size += sizeof(int8_t); + } while (IsMore); + return Size; +} + +} // namespace llvm