2014-12-10 06:07:25 +08:00
|
|
|
/*===- InstrProfiling.h- Support library for PGO instrumentation ----------===*\
|
|
|
|
|*
|
2019-01-19 16:50:56 +08:00
|
|
|
|* Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
|* See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
|* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2014-12-10 06:07:25 +08:00
|
|
|
|*
|
|
|
|
\*===----------------------------------------------------------------------===*/
|
|
|
|
|
|
|
|
#ifndef PROFILE_INSTRPROFILING_INTERNALH_
|
|
|
|
#define PROFILE_INSTRPROFILING_INTERNALH_
|
|
|
|
|
2017-12-15 03:01:04 +08:00
|
|
|
#include <stddef.h>
|
|
|
|
|
2014-12-10 06:07:25 +08:00
|
|
|
#include "InstrProfiling.h"
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Write instrumentation data to the given buffer, given explicit
|
|
|
|
* pointers to the live data in memory. This function is probably not what you
|
|
|
|
* want. Use __llvm_profile_get_size_for_buffer instead. Use this function if
|
|
|
|
* your program has a custom memory layout.
|
|
|
|
*/
|
|
|
|
uint64_t __llvm_profile_get_size_for_buffer_internal(
|
|
|
|
const __llvm_profile_data *DataBegin, const __llvm_profile_data *DataEnd,
|
|
|
|
const uint64_t *CountersBegin, const uint64_t *CountersEnd,
|
|
|
|
const char *NamesBegin, const char *NamesEnd);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Write instrumentation data to the given buffer, given explicit
|
|
|
|
* pointers to the live data in memory. This function is probably not what you
|
|
|
|
* want. Use __llvm_profile_write_buffer instead. Use this function if your
|
|
|
|
* program has a custom memory layout.
|
|
|
|
*
|
|
|
|
* \pre \c Buffer is the start of a buffer at least as big as \a
|
|
|
|
* __llvm_profile_get_size_for_buffer_internal().
|
|
|
|
*/
|
|
|
|
int __llvm_profile_write_buffer_internal(
|
|
|
|
char *Buffer, const __llvm_profile_data *DataBegin,
|
|
|
|
const __llvm_profile_data *DataEnd, const uint64_t *CountersBegin,
|
|
|
|
const uint64_t *CountersEnd, const char *NamesBegin, const char *NamesEnd);
|
|
|
|
|
2015-11-19 05:08:03 +08:00
|
|
|
/*!
|
2015-12-30 07:54:41 +08:00
|
|
|
* The data structure describing the data to be written by the
|
|
|
|
* low level writer callback function.
|
2019-12-11 10:17:28 +08:00
|
|
|
*
|
|
|
|
* If \ref ProfDataIOVec.Data is null, and \ref ProfDataIOVec.UseZeroPadding is
|
|
|
|
* 0, the write is skipped (the writer simply advances ElmSize*NumElm bytes).
|
|
|
|
*
|
|
|
|
* If \ref ProfDataIOVec.Data is null, and \ref ProfDataIOVec.UseZeroPadding is
|
|
|
|
* nonzero, ElmSize*NumElm zero bytes are written.
|
2015-11-19 05:08:03 +08:00
|
|
|
*/
|
2015-11-21 12:16:42 +08:00
|
|
|
typedef struct ProfDataIOVec {
|
2015-11-21 15:26:46 +08:00
|
|
|
const void *Data;
|
2015-11-21 12:16:42 +08:00
|
|
|
size_t ElmSize;
|
|
|
|
size_t NumElm;
|
2019-12-11 10:17:28 +08:00
|
|
|
int UseZeroPadding;
|
2015-11-21 12:16:42 +08:00
|
|
|
} ProfDataIOVec;
|
|
|
|
|
2017-06-28 01:28:01 +08:00
|
|
|
struct ProfDataWriter;
|
|
|
|
typedef uint32_t (*WriterCallback)(struct ProfDataWriter *This, ProfDataIOVec *,
|
|
|
|
uint32_t NumIOVecs);
|
|
|
|
|
|
|
|
typedef struct ProfDataWriter {
|
|
|
|
WriterCallback Write;
|
|
|
|
void *WriterCtx;
|
|
|
|
} ProfDataWriter;
|
2015-12-30 07:54:41 +08:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* The data structure for buffered IO of profile data.
|
|
|
|
*/
|
|
|
|
typedef struct ProfBufferIO {
|
2017-06-28 01:28:01 +08:00
|
|
|
ProfDataWriter *FileWriter;
|
|
|
|
uint32_t OwnFileWriter;
|
2015-12-30 07:54:41 +08:00
|
|
|
/* The start of the buffer. */
|
|
|
|
uint8_t *BufferStart;
|
|
|
|
/* Total size of the buffer. */
|
|
|
|
uint32_t BufferSz;
|
|
|
|
/* Current byte offset from the start of the buffer. */
|
|
|
|
uint32_t CurOffset;
|
|
|
|
} ProfBufferIO;
|
|
|
|
|
|
|
|
/* The creator interface used by testing. */
|
2016-05-14 02:26:26 +08:00
|
|
|
ProfBufferIO *lprofCreateBufferIOInternal(void *File, uint32_t BufferSz);
|
|
|
|
|
2015-12-30 07:54:41 +08:00
|
|
|
/*!
|
|
|
|
* This is the interface to create a handle for buffered IO.
|
|
|
|
*/
|
2017-06-28 01:28:01 +08:00
|
|
|
ProfBufferIO *lprofCreateBufferIO(ProfDataWriter *FileWriter);
|
2016-05-14 02:26:26 +08:00
|
|
|
|
2015-12-30 07:54:41 +08:00
|
|
|
/*!
|
|
|
|
* The interface to destroy the bufferIO handle and reclaim
|
|
|
|
* the memory.
|
|
|
|
*/
|
2016-03-06 12:18:13 +08:00
|
|
|
void lprofDeleteBufferIO(ProfBufferIO *BufferIO);
|
2015-12-30 07:54:41 +08:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* This is the interface to write \c Data of \c Size bytes through
|
|
|
|
* \c BufferIO. Returns 0 if successful, otherwise return -1.
|
|
|
|
*/
|
2016-03-06 12:18:13 +08:00
|
|
|
int lprofBufferIOWrite(ProfBufferIO *BufferIO, const uint8_t *Data,
|
|
|
|
uint32_t Size);
|
2015-12-30 07:54:41 +08:00
|
|
|
/*!
|
|
|
|
* The interface to flush the remaining data in the buffer.
|
|
|
|
* through the low level writer callback.
|
|
|
|
*/
|
2016-03-06 12:18:13 +08:00
|
|
|
int lprofBufferIOFlush(ProfBufferIO *BufferIO);
|
2015-12-30 07:54:41 +08:00
|
|
|
|
|
|
|
/* The low level interface to write data into a buffer. It is used as the
|
|
|
|
* callback by other high level writer methods such as buffered IO writer
|
|
|
|
* and profile data writer. */
|
2017-06-28 01:28:01 +08:00
|
|
|
uint32_t lprofBufferWriter(ProfDataWriter *This, ProfDataIOVec *IOVecs,
|
|
|
|
uint32_t NumIOVecs);
|
|
|
|
void initBufferWriter(ProfDataWriter *BufferWriter, char *Buffer);
|
2015-12-30 07:54:41 +08:00
|
|
|
|
2016-05-15 04:12:42 +08:00
|
|
|
struct ValueProfData;
|
|
|
|
struct ValueProfRecord;
|
|
|
|
struct InstrProfValueData;
|
|
|
|
struct ValueProfNode;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* The class that defines a set of methods to read value profile
|
|
|
|
* data for streaming/serialization from the instrumentation runtime.
|
|
|
|
*/
|
|
|
|
typedef struct VPDataReaderType {
|
|
|
|
uint32_t (*InitRTRecord)(const __llvm_profile_data *Data,
|
|
|
|
uint8_t *SiteCountArray[]);
|
|
|
|
/* Function pointer to getValueProfRecordHeader method. */
|
|
|
|
uint32_t (*GetValueProfRecordHeaderSize)(uint32_t NumSites);
|
|
|
|
/* Function pointer to getFristValueProfRecord method. */
|
|
|
|
struct ValueProfRecord *(*GetFirstValueProfRecord)(struct ValueProfData *);
|
|
|
|
/* Return the number of value data for site \p Site. */
|
|
|
|
uint32_t (*GetNumValueDataForSite)(uint32_t VK, uint32_t Site);
|
|
|
|
/* Return the total size of the value profile data of the
|
|
|
|
* current function. */
|
|
|
|
uint32_t (*GetValueProfDataSize)(void);
|
|
|
|
/*!
|
|
|
|
* Read the next \p N value data for site \p Site and store the data
|
|
|
|
* in \p Dst. \p StartNode is the first value node to start with if
|
|
|
|
* it is not null. The function returns the pointer to the value
|
|
|
|
* node pointer to be used as the \p StartNode of the next batch reading.
|
|
|
|
* If there is nothing left, it returns NULL.
|
|
|
|
*/
|
|
|
|
struct ValueProfNode *(*GetValueData)(uint32_t ValueKind, uint32_t Site,
|
|
|
|
struct InstrProfValueData *Dst,
|
|
|
|
struct ValueProfNode *StartNode,
|
|
|
|
uint32_t N);
|
|
|
|
} VPDataReaderType;
|
|
|
|
|
2017-06-29 00:46:06 +08:00
|
|
|
/* Write profile data to destinitation. If SkipNameDataWrite is set to 1,
|
|
|
|
the name data is already in destintation, we just skip over it. */
|
|
|
|
int lprofWriteData(ProfDataWriter *Writer, VPDataReaderType *VPDataReader,
|
|
|
|
int SkipNameDataWrite);
|
2017-06-28 01:28:01 +08:00
|
|
|
int lprofWriteDataImpl(ProfDataWriter *Writer,
|
2016-03-06 12:18:13 +08:00
|
|
|
const __llvm_profile_data *DataBegin,
|
|
|
|
const __llvm_profile_data *DataEnd,
|
|
|
|
const uint64_t *CountersBegin,
|
|
|
|
const uint64_t *CountersEnd,
|
2016-05-15 04:12:42 +08:00
|
|
|
VPDataReaderType *VPDataReader, const char *NamesBegin,
|
2017-06-29 00:46:06 +08:00
|
|
|
const char *NamesEnd, int SkipNameDataWrite);
|
2016-05-10 08:17:31 +08:00
|
|
|
|
2016-03-04 02:54:46 +08:00
|
|
|
/* Merge value profile data pointed to by SrcValueProfData into
|
|
|
|
* in-memory profile counters pointed by to DstData. */
|
2016-03-06 12:18:13 +08:00
|
|
|
void lprofMergeValueProfData(struct ValueProfData *SrcValueProfData,
|
|
|
|
__llvm_profile_data *DstData);
|
2015-11-19 05:08:03 +08:00
|
|
|
|
2017-08-31 23:51:23 +08:00
|
|
|
VPDataReaderType *lprofGetVPDataReader();
|
2016-05-15 04:12:42 +08:00
|
|
|
|
2016-05-20 05:35:34 +08:00
|
|
|
/* Internal interface used by test to reset the max number of
|
|
|
|
* tracked values per value site to be \p MaxVals.
|
|
|
|
*/
|
|
|
|
void lprofSetMaxValsPerSite(uint32_t MaxVals);
|
2017-08-31 23:51:23 +08:00
|
|
|
void lprofSetupValueProfiler();
|
2016-05-19 06:34:05 +08:00
|
|
|
|
2016-06-09 07:43:56 +08:00
|
|
|
/* Return the profile header 'signature' value associated with the current
|
|
|
|
* executable or shared library. The signature value can be used to for
|
|
|
|
* a profile name that is unique to this load module so that it does not
|
|
|
|
* collide with profiles from other binaries. It also allows shared libraries
|
|
|
|
* to dump merged profile data into its own profile file. */
|
2017-08-31 23:51:23 +08:00
|
|
|
uint64_t lprofGetLoadModuleSignature();
|
2016-06-09 07:43:56 +08:00
|
|
|
|
2016-08-09 12:21:14 +08:00
|
|
|
/*
|
|
|
|
* Return non zero value if the profile data has already been
|
|
|
|
* dumped to the file.
|
|
|
|
*/
|
2020-03-25 11:02:44 +08:00
|
|
|
unsigned lprofProfileDumped(void);
|
|
|
|
void lprofSetProfileDumped(unsigned);
|
2016-08-09 12:21:14 +08:00
|
|
|
|
2020-03-22 07:41:00 +08:00
|
|
|
/* Return non zero value if counters are being relocated at runtime. */
|
|
|
|
unsigned lprofRuntimeCounterRelocation(void);
|
2020-03-25 11:02:44 +08:00
|
|
|
void lprofSetRuntimeCounterRelocation(unsigned);
|
2020-03-22 07:41:00 +08:00
|
|
|
|
2016-05-10 03:01:19 +08:00
|
|
|
COMPILER_RT_VISIBILITY extern void (*FreeHook)(void *);
|
2016-05-14 02:26:26 +08:00
|
|
|
COMPILER_RT_VISIBILITY extern uint8_t *DynamicBufferIOBuffer;
|
|
|
|
COMPILER_RT_VISIBILITY extern uint32_t VPBufferSize;
|
2016-05-19 06:34:05 +08:00
|
|
|
COMPILER_RT_VISIBILITY extern uint32_t VPMaxNumValsPerSite;
|
2016-05-22 06:55:45 +08:00
|
|
|
/* Pointer to the start of static value counters to be allocted. */
|
|
|
|
COMPILER_RT_VISIBILITY extern ValueProfNode *CurrentVNode;
|
|
|
|
COMPILER_RT_VISIBILITY extern ValueProfNode *EndVNode;
|
2016-03-04 02:54:46 +08:00
|
|
|
extern void (*VPMergeHook)(struct ValueProfData *, __llvm_profile_data *);
|
2015-12-11 03:50:04 +08:00
|
|
|
|
2014-12-10 06:07:25 +08:00
|
|
|
#endif
|