mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-02 07:32:52 +00:00
4a6fa1390a
This updates the instrumentation based profiling format so that when we have multiple functions with the same name (but different function hashes) we keep all of them instead of rejecting the later ones. There are a number of scenarios where this can come up where it's more useful to keep multiple function profiles: * Name collisions in unrelated libraries that are profiled together. * Multiple "main" functions from multiple tools built against a common library. * Combining profiles from different build configurations (ie, asserts and no-asserts) The profile format now stores the number of counters between the hash and the counts themselves, so that multiple sets of counts can be stored. Since this is backwards incompatible, I've bumped the format version and added some trivial logic to skip this when reading the old format. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@214585 91177308-0d34-0410-b5e6-96231b3b80d8
56 lines
1.5 KiB
C++
56 lines
1.5 KiB
C++
//=-- InstrProfIndexed.h - Indexed profiling format support -------*- C++ -*-=//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Shared header for the instrumented profile data reader and writer.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_PROFILEDATA_INSTRPROF_INDEXED_H_
|
|
#define LLVM_PROFILEDATA_INSTRPROF_INDEXED_H_
|
|
|
|
#include "llvm/Support/ErrorHandling.h"
|
|
#include "llvm/Support/MD5.h"
|
|
|
|
namespace llvm {
|
|
|
|
namespace IndexedInstrProf {
|
|
enum class HashT : uint32_t {
|
|
MD5,
|
|
|
|
Last = MD5
|
|
};
|
|
|
|
static inline uint64_t MD5Hash(StringRef Str) {
|
|
MD5 Hash;
|
|
Hash.update(Str);
|
|
llvm::MD5::MD5Result Result;
|
|
Hash.final(Result);
|
|
// Return the least significant 8 bytes. Our MD5 implementation returns the
|
|
// result in little endian, so we may need to swap bytes.
|
|
using namespace llvm::support;
|
|
return endian::read<uint64_t, little, unaligned>(Result);
|
|
}
|
|
|
|
static inline uint64_t ComputeHash(HashT Type, StringRef K) {
|
|
switch (Type) {
|
|
case HashT::MD5:
|
|
return IndexedInstrProf::MD5Hash(K);
|
|
}
|
|
llvm_unreachable("Unhandled hash type");
|
|
}
|
|
|
|
const uint64_t Magic = 0x8169666f72706cff; // "\xfflprofi\x81"
|
|
const uint64_t Version = 2;
|
|
const HashT HashType = HashT::MD5;
|
|
}
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif // LLVM_PROFILEDATA_INSTRPROF_INDEXED_H_
|