Index: lib/profile/InstrProfiling.h =================================================================== --- lib/profile/InstrProfiling.h +++ lib/profile/InstrProfiling.h @@ -33,11 +33,12 @@ #endif /* defined(__FreeBSD__) && defined(__i386__) */ -typedef enum ValueKind { - VK_IndirectCallTarget = 0, - VK_FIRST = VK_IndirectCallTarget, - VK_LAST = VK_IndirectCallTarget -} __llvm_profile_value_kind; +enum ValueKind { + IPVK_IndirectCallTarget = 0, + IPVK_First = IPVK_IndirectCallTarget, + IPVK_Last = IPVK_IndirectCallTarget + +}; typedef struct __llvm_profile_value_data { uint64_t TargetValue; @@ -49,15 +50,16 @@ struct __llvm_profile_value_node *Next; } __llvm_profile_value_node; +typedef void *IntPtrT; typedef struct LLVM_ALIGNAS(8) __llvm_profile_data { const uint32_t NameSize; const uint32_t NumCounters; const uint64_t FuncHash; - const char *const NamePtr; - uint64_t *const CounterPtr; - const uint8_t *FunctionPointer; - __llvm_profile_value_node **ValueCounters; - const uint16_t NumValueSites[VK_LAST + 1]; + const IntPtrT NamePtr; + const IntPtrT CounterPtr; + const IntPtrT FunctionPointer; + IntPtrT Values; + const uint16_t NumValueSites[IPVK_Last + 1]; } __llvm_profile_data; typedef struct __llvm_profile_header { @@ -111,8 +113,8 @@ * Records the target value for the CounterIndex if not seen before. Otherwise, * increments the counter associated w/ the target value. */ -void __llvm_profile_instrument_target(uint64_t TargetValue, - void *Data_, uint32_t CounterIndex); +void __llvm_profile_instrument_target(uint64_t TargetValue, void *Data, + uint32_t CounterIndex); /*! * \brief Prepares the value profiling data for output. Index: lib/profile/InstrProfiling.c =================================================================== --- lib/profile/InstrProfiling.c +++ lib/profile/InstrProfiling.c @@ -12,6 +12,11 @@ #include #include +typedef struct ValueProfNode { + __llvm_profile_value_data VData; + struct ValueProfNode *Next; +} ValueProfNode; + __attribute__((visibility("hidden"))) uint64_t __llvm_profile_get_magic(void) { /* Magic number to detect file format and endianness. * @@ -54,14 +59,16 @@ for (DI = DataBegin; DI != DataEnd; ++DI) { uint64_t CurrentVSiteCount = 0; uint32_t VKI, i; - if (!DI->ValueCounters) + if (!DI->Values) continue; - for (VKI = VK_FIRST; VKI <= VK_LAST; ++VKI) + ValueProfNode **ValueCounters = (ValueProfNode **)DI->Values; + + for (VKI = IPVK_First; VKI <= IPVK_Last; ++VKI) CurrentVSiteCount += DI->NumValueSites[VKI]; for (i = 0; i < CurrentVSiteCount; ++i) { - __llvm_profile_value_node *CurrentVNode = DI->ValueCounters[i]; + ValueProfNode *CurrentVNode = ValueCounters[i]; while (CurrentVNode) { CurrentVNode->VData.NumTaken = 0; @@ -83,14 +90,14 @@ static int allocateValueProfileCounters(__llvm_profile_data *Data) { uint64_t NumVSites = 0; uint32_t VKI; - for (VKI = VK_FIRST; VKI <= VK_LAST; ++VKI) + for (VKI = IPVK_First; VKI <= IPVK_Last; ++VKI) NumVSites += Data->NumValueSites[VKI]; - __llvm_profile_value_node **Mem = (__llvm_profile_value_node **)calloc( - NumVSites, sizeof(__llvm_profile_value_node *)); + ValueProfNode **Mem = + (ValueProfNode **)calloc(NumVSites, sizeof(ValueProfNode *)); if (!Mem) return 0; - if (!__sync_bool_compare_and_swap(&Data->ValueCounters, 0, Mem)) { + if (!__sync_bool_compare_and_swap(&Data->Values, 0, Mem)) { free(Mem); return 0; } @@ -105,20 +112,21 @@ } __attribute__((visibility("hidden"))) void -__llvm_profile_instrument_target(uint64_t TargetValue, void *Data_, +__llvm_profile_instrument_target(uint64_t TargetValue, void *Data, uint32_t CounterIndex) { - __llvm_profile_data *Data = (__llvm_profile_data *)Data_; - if (!Data) + __llvm_profile_data *VData = (__llvm_profile_data *)Data; + if (!VData) return; - if (!Data->ValueCounters) { - if (!allocateValueProfileCounters(Data)) + if (!VData->Values) { + if (!allocateValueProfileCounters(VData)) return; } - __llvm_profile_value_node *PrevVNode = NULL; - __llvm_profile_value_node *CurrentVNode = Data->ValueCounters[CounterIndex]; + ValueProfNode **ValueCounters = (ValueProfNode **)VData->Values; + ValueProfNode *PrevVNode = NULL; + ValueProfNode *CurrentVNode = ValueCounters[CounterIndex]; uint8_t VDataCount = 0; while (CurrentVNode) { @@ -134,8 +142,7 @@ if (VDataCount >= UCHAR_MAX) return; - CurrentVNode = - (__llvm_profile_value_node *)calloc(1, sizeof(__llvm_profile_value_node)); + CurrentVNode = (ValueProfNode *)calloc(1, sizeof(ValueProfNode)); if (!CurrentVNode) return; @@ -143,9 +150,9 @@ CurrentVNode->VData.NumTaken++; uint32_t Success = 0; - if (!Data->ValueCounters[CounterIndex]) - Success = __sync_bool_compare_and_swap(&(Data->ValueCounters[CounterIndex]), - 0, CurrentVNode); + if (!ValueCounters[CounterIndex]) + Success = __sync_bool_compare_and_swap(&ValueCounters[CounterIndex], 0, + CurrentVNode); else if (PrevVNode && !PrevVNode->Next) Success = __sync_bool_compare_and_swap(&(PrevVNode->Next), 0, CurrentVNode); @@ -153,8 +160,7 @@ free(CurrentVNode); return; } - __sync_fetch_and_add(&TotalValueDataSize, - Success * sizeof(__llvm_profile_value_data)); + __sync_fetch_and_add(&TotalValueDataSize, Success * sizeof(ValueProfNode)); } __attribute__((visibility("hidden"))) uint64_t @@ -178,10 +184,12 @@ uint64_t NumVSites = 0; uint32_t VKI, i; - if (!I->ValueCounters) + if (!I->Values) continue; - for (VKI = VK_FIRST; VKI <= VK_LAST; ++VKI) + ValueProfNode **ValueCounters = (ValueProfNode **)I->Values; + + for (VKI = IPVK_First; VKI <= IPVK_Last; ++VKI) NumVSites += I->NumValueSites[VKI]; uint8_t Padding = __llvm_profile_get_num_padding_bytes(NumVSites); @@ -191,7 +199,7 @@ for (i = 0; i < NumVSites; ++i) { - __llvm_profile_value_node *VNode = I->ValueCounters[i]; + ValueProfNode *VNode = ValueCounters[i]; uint8_t VDataCount = 0; while (VNode && ((uint8_t *)(VDataPtr + 1) <= VDataEnd)) { @@ -204,7 +212,7 @@ *PerSiteCountPtr = VDataCount; ++PerSiteCountPtr; } - I->ValueCounters = (void *)PerSiteCountsHead; + I->Values = (void *)PerSiteCountsHead; PerSiteCountsHead = (uint8_t *)VDataPtr; } return PerSiteCountsHead - *VDataArray; Index: lib/profile/InstrProfilingWriter.c =================================================================== --- lib/profile/InstrProfilingWriter.c +++ lib/profile/InstrProfilingWriter.c @@ -54,7 +54,7 @@ Header.NamesSize = NamesSize; Header.CountersDelta = (uintptr_t)CountersBegin; Header.NamesDelta = (uintptr_t)NamesBegin; - Header.ValueKindLast = VK_LAST; + Header.ValueKindLast = IPVK_Last; Header.ValueDataSize = ValueDataSize; Header.ValueDataDelta = (uintptr_t)ValueDataBegin;