forked from OSchip/llvm-project
parent
f7861b7a09
commit
ba904d4ecf
|
@ -291,6 +291,7 @@ typedef struct ValueProfData {
|
|||
*/
|
||||
void deserializeTo(InstrProfRecord &Record,
|
||||
InstrProfRecord::ValueMapType *VMap);
|
||||
void operator delete(void *ptr) { ::operator delete(ptr); }
|
||||
#endif
|
||||
} ValueProfData;
|
||||
|
||||
|
@ -537,12 +538,13 @@ int initializeValueProfRuntimeRecord(ValueProfRuntimeRecord *RuntimeRecord,
|
|||
}
|
||||
NumValueKinds++;
|
||||
RuntimeRecord->SiteCountArray[I] = (uint8_t *)calloc(N, 1);
|
||||
RuntimeRecord->NodesKind[I] = &RuntimeRecord->Nodes[S];
|
||||
if (!RuntimeRecord->NodesKind[I])
|
||||
if (!RuntimeRecord->SiteCountArray[I])
|
||||
return 1;
|
||||
RuntimeRecord->NodesKind[I] = Nodes ? &Nodes[S] : NULL;
|
||||
for (J = 0; J < N; J++) {
|
||||
/* Compute value count for each site. */
|
||||
uint32_t C = 0;
|
||||
ValueProfNode *Site = RuntimeRecord->Nodes[S + J];
|
||||
ValueProfNode *Site = Nodes ? RuntimeRecord->NodesKind[I][J] : NULL;
|
||||
while (Site) {
|
||||
C++;
|
||||
Site = Site->Next;
|
||||
|
@ -595,6 +597,8 @@ void getValueForSiteRT(const void *R, InstrProfValueData *Dst, uint32_t VK,
|
|||
unsigned I, N = 0;
|
||||
const ValueProfRuntimeRecord *Record = (const ValueProfRuntimeRecord *)R;
|
||||
N = getNumValueDataForSiteRT(R, VK, S);
|
||||
if (N == 0)
|
||||
return;
|
||||
ValueProfNode *VNode = Record->NodesKind[VK][S];
|
||||
for (I = 0; I < N; I++) {
|
||||
Dst[I] = VNode->VData;
|
||||
|
|
Loading…
Reference in New Issue