1 ;; BB cluster sections error handling
2 ;; Error handling for version 0:
3 ; RUN: echo '!dummy1' > %t1
4 ; RUN: echo '!!1 4' >> %t1
5 ; RUN: echo '!!1' >> %t1
6 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64-pc-linux -function-sections -basic-block-sections=%t1 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR1
7 ; CHECK-ERROR1: LLVM ERROR: invalid profile {{.*}} at line 3: duplicate basic block id found '1'
8 ; RUN: echo '!dummy1' > %t3
9 ; RUN: echo '!!-1' >> %t3
10 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64-pc-linux -function-sections -basic-block-sections=%t3 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR3
11 ; CHECK-ERROR3: LLVM ERROR: invalid profile {{.*}} at line 2: unsigned integer expected: '-1'
12 ; RUN: echo '!dummy1 /path/to/filename' > %t4
13 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t4 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR4
14 ; CHECK-ERROR4: LLVM ERROR: invalid profile {{.*}} at line 1: unknown string found: '/path/to/filename'
15 ; RUN: echo '!dummy2 M=test_dir/test_file' > %t5
16 ; RUN: echo '!dummy2 M=test_dir/test_file' >> %t5
17 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t5 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR5
18 ; CHECK-ERROR5: LLVM ERROR: invalid profile {{.*}} at line 2: duplicate profile for function 'dummy2'
19 ; RUN: echo '!dummy1 M=' > %t6
20 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t6 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR6
21 ; CHECK-ERROR6: LLVM ERROR: invalid profile {{.*}} at line 1: empty module name specifier
23 ;; Error handling for version 1:
24 ; RUN: echo 'v2' > %t7
25 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t7 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR7
26 ; CHECK-ERROR7: LLVM ERROR: invalid profile {{.*}} at line 1: invalid profile version: 2
27 ; RUN: echo 'v1' > %t8
28 ; RUN: echo '!dummy1' >> %t8
29 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t8 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR8
30 ; CHECK-ERROR8: LLVM ERROR: invalid profile {{.*}} at line 2: invalid specifier: '!'
31 ; RUN: echo 'v1' > %t9
32 ; RUN: echo 'm dummy1/module1 dummy1/module2' >> %t9
33 ; RUN: echo 'f dummy1' >> %t9
34 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t9 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR9
35 ; CHECK-ERROR9: LLVM ERROR: invalid profile {{.*}} at line 2: invalid module name value: 'dummy1/module1 dummy1/module2'
37 ;; Error handling for version 1, cloning paths.
38 ; RUN: echo 'v1' > %t10
39 ; RUN: echo 'f dummy1' >> %t10
40 ; RUN: echo 'c 0 1.1.1' >> %t10
41 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t10 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR10
42 ; CHECK-ERROR10: LLVM ERROR: invalid profile {{.*}} at line 3: unable to parse basic block id: '1.1.1'
43 ; RUN: echo 'v1' > %t11
44 ; RUN: echo 'f dummy1' >> %t11
45 ; RUN: echo 'c 0 1.a' >> %t11
46 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t11 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR11
47 ; CHECK-ERROR11: LLVM ERROR: invalid profile {{.*}} at line 3: unable to parse clone id: 'a'
48 ; RUN: echo 'v1' > %t12
49 ; RUN: echo 'f dummy1' >> %t12
50 ; RUN: echo 'c 0 1' >> %t12
51 ; RUN: echo 'p 1 2.1' >> %t12
52 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t12 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR12
53 ; CHECK-ERROR12: LLVM ERROR: invalid profile {{.*}} at line 4: unsigned integer expected: '2.1'
54 ; RUN: echo 'v1' > %t13
55 ; RUN: echo 'f dummy1' >> %t13
56 ; RUN: echo 'c 0 1' >> %t13
57 ; RUN: echo 'p 1 2 3 2' >> %t13
58 ; RUN: not --crash llc < %s -O0 -mtriple=x86_64 -function-sections -basic-block-sections=%t13 2>&1 | FileCheck %s --check-prefix=CHECK-ERROR13
59 ; CHECK-ERROR13: LLVM ERROR: invalid profile {{.*}} at line 4: duplicate cloned block in path: '2'
61 define i32 @dummy1(i32 %x, i32 %y, i32 %z) {
64 %tmp2 = add i32 %tmp, %z
68 define i32 @dummy2(i32 %x, i32 %y, i32 %z) !dbg !4 {
71 %tmp2 = add i32 %tmp, %z
76 !llvm.module.flags = !{!2, !3}
78 !0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1)
79 !1 = !DIFile(filename: "test_dir/test_file", directory: "test_dir")
80 !2 = !{i32 7, !"Dwarf Version", i32 5}
81 !3 = !{i32 2, !"Debug Info Version", i32 3}
82 !4 = distinct !DISubprogram(name: "dummy1", scope: !1, unit: !0)