forked from OSchip/llvm-project
				
			TLI: Microoptimize calls to strlen+memcmp to strncmp.
The strlen+memcmp was hidden in a call to StringRef::operator==. We check if there are any null bytes in the string upfront so we can simplify the comparison Small speedup when compiling code with many function calls. llvm-svn: 176766
This commit is contained in:
		
							parent
							
								
									2ef36b633b
								
							
						
					
					
						commit
						160f72dc8e
					
				| 
						 | 
				
			
			@ -597,15 +597,37 @@ TargetLibraryInfo::TargetLibraryInfo(const TargetLibraryInfo &TLI)
 | 
			
		|||
  CustomNames = TLI.CustomNames;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
namespace {
 | 
			
		||||
struct StringComparator {
 | 
			
		||||
  /// Compare two strings and return true if LHS is lexicographically less than
 | 
			
		||||
  /// RHS. Requires that RHS doesn't contain any zero bytes.
 | 
			
		||||
  bool operator()(const char *LHS, StringRef RHS) const {
 | 
			
		||||
    // Compare prefixes with strncmp. If prefixes match we know that LHS is
 | 
			
		||||
    // greater or equal to RHS as RHS can't contain any '\0'.
 | 
			
		||||
    return std::strncmp(LHS, RHS.data(), RHS.size()) < 0;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  // Provided for compatibility with MSVC's debug mode.
 | 
			
		||||
  bool operator()(StringRef LHS, const char *RHS) const { return LHS < RHS; }
 | 
			
		||||
  bool operator()(StringRef LHS, StringRef RHS) const { return LHS < RHS; }
 | 
			
		||||
};
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool TargetLibraryInfo::getLibFunc(StringRef funcName,
 | 
			
		||||
                                   LibFunc::Func &F) const {
 | 
			
		||||
  const char **Start = &StandardNames[0];
 | 
			
		||||
  const char **End = &StandardNames[LibFunc::NumLibFuncs];
 | 
			
		||||
 | 
			
		||||
  // Filter out empty names and names containing null bytes, those can't be in
 | 
			
		||||
  // our table.
 | 
			
		||||
  if (funcName.empty() || funcName.find('\0') != StringRef::npos)
 | 
			
		||||
    return false;
 | 
			
		||||
 | 
			
		||||
  // Check for \01 prefix that is used to mangle __asm declarations and
 | 
			
		||||
  // strip it if present.
 | 
			
		||||
  if (!funcName.empty() && funcName.front() == '\01')
 | 
			
		||||
  if (funcName.front() == '\01')
 | 
			
		||||
    funcName = funcName.substr(1);
 | 
			
		||||
  const char **I = std::lower_bound(Start, End, funcName);
 | 
			
		||||
  const char **I = std::lower_bound(Start, End, funcName, StringComparator());
 | 
			
		||||
  if (I != End && *I == funcName) {
 | 
			
		||||
    F = (LibFunc::Func)(I - Start);
 | 
			
		||||
    return true;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue