125 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
| ;; The test fails on Windows. Fix it before removing the following requirement.
 | |
| ; REQUIRES: x86_64-linux
 | |
| ; RUN: llvm-profgen --format=text --perfscript=%S/Inputs/noinline-cs-noprobe.perfscript --binary=%S/Inputs/noinline-cs-noprobe.perfbin --output=%t --skip-symbolization --profile-summary-cold-count=0
 | |
| ; RUN: FileCheck %s --input-file %t --check-prefix=CHECK-UNWINDER
 | |
| ; RUN: llvm-profgen --format=text --unsymbolized-profile=%t --binary=%S/Inputs/noinline-cs-noprobe.perfbin --output=%t1 --profile-summary-cold-count=0 --csspgo-preinliner=0 --gen-cs-nested-profile=0
 | |
| ; RUN: FileCheck %s --input-file %t1
 | |
| ; RUN: llvm-profgen --format=text --perfscript=%S/Inputs/noinline-cs-noprobe.perfscript --binary=%S/Inputs/noinline-cs-noprobe.perfbin --output=%t --profile-summary-cold-count=0 --ignore-stack-samples --csspgo-preinliner=0 --gen-cs-nested-profile=0
 | |
| ; RUN: FileCheck %s --input-file %t --check-prefix=CHECK-STRIP-CTX
 | |
| ; RUN: llvm-profgen --format=text --perfscript=%S/Inputs/noinline-cs-noprobe.aggperfscript --binary=%S/Inputs/noinline-cs-noprobe.perfbin --output=%t --skip-symbolization --profile-summary-cold-count=0
 | |
| ; RUN: FileCheck %s --input-file %t --check-prefix=CHECK-AGG-UNWINDER
 | |
| ; RUN: llvm-profgen --format=text --perfscript=%S/Inputs/noinline-cs-noprobe.aggperfscript --binary=%S/Inputs/noinline-cs-noprobe.perfbin --output=%t --profile-summary-cold-count=0 --csspgo-preinliner=0 --gen-cs-nested-profile=0
 | |
| ; RUN: FileCheck %s --input-file %t --check-prefix=CHECK-AGG
 | |
| 
 | |
| ; RUN: llvm-profgen --format=text --perfscript=%S/Inputs/noinline-cs-noprobe.perfscript --binary=%S/Inputs/noinline-cs-noprobe.perfbin --output=%t1 --profile-summary-cold-count=0
 | |
| ; RUN: llvm-profgen --format=extbinary --perfscript=%S/Inputs/noinline-cs-noprobe.perfscript --binary=%S/Inputs/noinline-cs-noprobe.perfbin --output=%t2 --profile-summary-cold-count=0 -use-md5
 | |
| ; RUN: llvm-profdata show --sample -show-sec-info-only %t2 | FileCheck %s --check-prefix=CHECK-MD5
 | |
| ; RUN: llvm-profdata show --sample -detailed-summary --function=dummy %t1 > %t.summary
 | |
| ; RUN: llvm-profdata show --sample -detailed-summary --function=dummy %t2 > %t2.summary
 | |
| ; RUN: diff -b %t.summary %t2.summary
 | |
| 
 | |
| 
 | |
| ; CHECK-AGG:[main:1 @ foo]:108:0
 | |
| ; CHECK-AGG: 2: 6
 | |
| ; CHECK-AGG: 3: 6 bar:6
 | |
| ; CHECK-AGG:[main:1 @ foo:3 @ bar]:100:6
 | |
| ; CHECK-AGG: 0: 6
 | |
| ; CHECK-AGG: 1: 6
 | |
| ; CHECK-AGG: 2: 4
 | |
| ; CHECK-AGG: 4: 2
 | |
| ; CHECK-AGG: 5: 6
 | |
| 
 | |
| ; CHECK-AGG-UNWINDER:      [main:1 @ foo]
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   3
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   5ff-62f:6
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   634-637:6
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   645-645:6
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   3
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   62f->5b0:6
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   637->645:6
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   645->5ff:6
 | |
| ; CHECK-AGG-UNWINDER-NEXT: [main:1 @ foo:3 @ bar]
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   4
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   5b0-5c8:2
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   5b0-5d7:4
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   5dc-5e9:2
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   5e5-5e9:4
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   3
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   5c8->5dc:4
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   5d7->5e5:4
 | |
| ; CHECK-AGG-UNWINDER-NEXT:   5e9->634:6
 | |
| 
 | |
| 
 | |
| ; CHECK:[main:1 @ foo]:54:0
 | |
| ; CHECK: 2: 3
 | |
| ; CHECK: 3: 3 bar:3
 | |
| ; CHECK:[main:1 @ foo:3 @ bar]:50:3
 | |
| ; CHECK: 0: 3
 | |
| ; CHECK: 1: 3
 | |
| ; CHECK: 2: 2
 | |
| ; CHECK: 4: 1
 | |
| ; CHECK: 5: 3
 | |
| 
 | |
| ; CHECK-STRIP-CTX: foo:198:0
 | |
| ; CHECK-STRIP-CTX:  0: 0
 | |
| ; CHECK-STRIP-CTX:  1: 0
 | |
| ; CHECK-STRIP-CTX:  2: 3
 | |
| ; CHECK-STRIP-CTX:  3: 3 bar:3
 | |
| ; CHECK-STRIP-CTX:  4: 0
 | |
| ; CHECK-STRIP-CTX:  5: 0
 | |
| ; CHECK-STRIP-CTX: bar:142:3
 | |
| ; CHECK-STRIP-CTX:  0: 3
 | |
| ; CHECK-STRIP-CTX:  1: 3
 | |
| ; CHECK-STRIP-CTX:  2: 2
 | |
| ; CHECK-STRIP-CTX:  4: 1
 | |
| ; CHECK-STRIP-CTX:  5: 3
 | |
| 
 | |
| ; CHECK-UNWINDER:      [main:1 @ foo]
 | |
| ; CHECK-UNWINDER-NEXT:   3
 | |
| ; CHECK-UNWINDER-NEXT:   5ff-62f:3
 | |
| ; CHECK-UNWINDER-NEXT:   634-637:3
 | |
| ; CHECK-UNWINDER-NEXT:   645-645:3
 | |
| ; CHECK-UNWINDER-NEXT:   3
 | |
| ; CHECK-UNWINDER-NEXT:   62f->5b0:3
 | |
| ; CHECK-UNWINDER-NEXT:   637->645:3
 | |
| ; CHECK-UNWINDER-NEXT:   645->5ff:3
 | |
| ; CHECK-UNWINDER-NEXT: [main:1 @ foo:3 @ bar]
 | |
| ; CHECK-UNWINDER-NEXT:   4
 | |
| ; CHECK-UNWINDER-NEXT:   5b0-5c8:1
 | |
| ; CHECK-UNWINDER-NEXT:   5b0-5d7:2
 | |
| ; CHECK-UNWINDER-NEXT:   5dc-5e9:1
 | |
| ; CHECK-UNWINDER-NEXT:   5e5-5e9:2
 | |
| ; CHECK-UNWINDER-NEXT:   3
 | |
| ; CHECK-UNWINDER-NEXT:   5c8->5dc:2
 | |
| ; CHECK-UNWINDER-NEXT:   5d7->5e5:2
 | |
| ; CHECK-UNWINDER-NEXT:   5e9->634:3
 | |
| 
 | |
| ; CHECK-MD5: NameTableSection {{.*}} {fixlenmd5}
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| ; original code:
 | |
| ; clang -O0 -g test.c -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;
 | |
| }
 |