llvm-project/llvm/test/tools/llvm-profgen/update-samples.test
Hongtao Yu acfd0a3456 [llvm-profgen] Update callsite body samples by summing up all call target samples.
Current profile generation caculcates callsite body samples and call target samples separately. The former is done based on LBR range samples while the latter is done based on branch samples. Note that there's a subtle difference. LBR ranges is formed from two consecutive branch samples. Therefore the last entry in a LBR record will not be counted towards body samples while there's still a chance for it to be counted towards call targets if it is a function call. I'm making sense of the call body samples by updating it to the aggregation of call targets.

Reviewed By: wenlei

Differential Revision: https://reviews.llvm.org/D122609
2022-05-16 09:13:37 -07:00

46 lines
996 B
Plaintext

; RUN: llvm-profgen --format=text --perfscript=%S/Inputs/noprobe.perfscript --binary=%S/Inputs/noprobe.perfbin --output=%t1
; RUN: FileCheck %s --input-file %t1 --check-prefix=CALLSITE
; RUN: llvm-profgen --format=text --perfscript=%S/Inputs/noprobe.perfscript --binary=%S/Inputs/noprobe.perfbin --output=%t2 --update-total-samples=1
; RUN: FileCheck %s --input-file %t2 --check-prefix=TOTAL
;CALLSITE: foo:1241:0
;CALLSITE: 0: 0
;CALLSITE: 1: 0
;CALLSITE: 2: 19
;CALLSITE: 3: 21 bar:21
;CALLSITE: 4: 0
;CALLSITE: 5: 0
;TOTAL: foo:40:0
;TOTAL: 0: 0
;TOTAL: 1: 0
;TOTAL: 2: 19
;TOTAL: 3: 21 bar:21
;TOTAL: 4: 0
;TOTAL: 5: 0
; original code:
; clang -O3 -g -fdebug-info-for-profiling test.c -fno-inline -o a.out
#include <stdio.h>
int bar(int x, int y) {
if (x % 3) {
return x - y;
}
return x + y;
}
void foo() {
int s, i = 0;
while (i++ < 4000 * 4000)
if (i % 91) s = bar(i, s); else s += 30;
printf("sum is %d\n", s);
}
int main() {
foo();
return 0;
}