Timur Iskhodzhanov | 4a83bf1 | 2014-01-30 17:53:45 +0000 | [diff] [blame] | 1 | ; RUN: llc -mcpu=core2 -mtriple=i686-pc-win32 -O0 < %s | FileCheck --check-prefix=X86 %s |
Reid Kleckner | 83ebad3 | 2015-12-16 18:28:12 +0000 | [diff] [blame] | 2 | ; RUN: llc -mcpu=core2 -mtriple=i686-pc-win32 -o - -O0 < %s | llvm-mc -triple=i686-pc-win32 -filetype=obj | llvm-readobj -s -sr -codeview | FileCheck --check-prefix=OBJ32 %s |
Timur Iskhodzhanov | 4a83bf1 | 2014-01-30 17:53:45 +0000 | [diff] [blame] | 3 | ; RUN: llc -mcpu=core2 -mtriple=x86_64-pc-win32 -O0 < %s | FileCheck --check-prefix=X64 %s |
Reid Kleckner | 83ebad3 | 2015-12-16 18:28:12 +0000 | [diff] [blame] | 4 | ; RUN: llc -mcpu=core2 -mtriple=x86_64-pc-win32 -o - -O0 < %s | llvm-mc -triple=x86_64-pc-win32 -filetype=obj | llvm-readobj -s -sr -codeview | FileCheck --check-prefix=OBJ64 %s |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 5 | |
| 6 | ; This LL file was generated by running clang on the following code: |
| 7 | ; D:\asm.c: |
| 8 | ; 1 void g(void); |
| 9 | ; 2 |
| 10 | ; 3 void f(void) { |
| 11 | ; 4 __asm align 4; |
| 12 | ; 5 g(); |
| 13 | ; 6 } |
| 14 | |
Timur Iskhodzhanov | e32ef93 | 2014-03-26 08:45:02 +0000 | [diff] [blame] | 15 | ; X86-LABEL: _f: |
Reid Kleckner | 2214ed8 | 2016-01-29 00:49:42 +0000 | [diff] [blame] | 16 | ; X86: .cv_file 1 "D:\\asm.c" |
| 17 | ; X86: .cv_loc 0 1 4 0 is_stmt 0 |
| 18 | ; X86: .cv_loc 0 1 5 0 |
David Majnemer | b925715 | 2014-11-04 08:03:31 +0000 | [diff] [blame] | 19 | ; X86: calll _g |
Reid Kleckner | 2214ed8 | 2016-01-29 00:49:42 +0000 | [diff] [blame] | 20 | ; X86: .cv_loc 0 1 6 0 |
David Majnemer | b925715 | 2014-11-04 08:03:31 +0000 | [diff] [blame] | 21 | ; X86: ret |
Reid Kleckner | f9c275f | 2016-02-10 20:55:49 +0000 | [diff] [blame] | 22 | ; X86: [[END_OF_F:.?Lfunc_end.*]]: |
Adrian McCarthy | 4333daa | 2016-11-02 21:30:35 +0000 | [diff] [blame] | 23 | |
Timur Iskhodzhanov | 2bc90fd | 2014-10-24 01:27:45 +0000 | [diff] [blame] | 24 | ; Line table |
Adrian McCarthy | 4333daa | 2016-11-02 21:30:35 +0000 | [diff] [blame] | 25 | ; X86: .cv_linetable 0, _f, [[END_OF_F]] |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 26 | ; File index to string table offset subsection |
Reid Kleckner | e8a236f | 2016-06-06 23:41:38 +0000 | [diff] [blame] | 27 | ; X86-NEXT: .cv_filechecksums |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 28 | ; String table |
Reid Kleckner | e8a236f | 2016-06-06 23:41:38 +0000 | [diff] [blame] | 29 | ; X86-NEXT: .cv_stringtable |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 30 | |
| 31 | ; OBJ32: Section { |
| 32 | ; OBJ32: Name: .debug$S (2E 64 65 62 75 67 24 53) |
Reid Kleckner | 2214ed8 | 2016-01-29 00:49:42 +0000 | [diff] [blame] | 33 | ; OBJ32: Characteristics [ (0x42300040) |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 34 | ; OBJ32: ] |
Reid Kleckner | 83ebad3 | 2015-12-16 18:28:12 +0000 | [diff] [blame] | 35 | ; OBJ32: CodeViewDebugInfo [ |
Timur Iskhodzhanov | 2bc90fd | 2014-10-24 01:27:45 +0000 | [diff] [blame] | 36 | ; OBJ32: Subsection [ |
Reid Kleckner | 72e2ba7 | 2016-01-13 19:32:35 +0000 | [diff] [blame] | 37 | ; OBJ32-NEXT: SubSectionType: Symbols (0xF1) |
Timur Iskhodzhanov | 2bc90fd | 2014-10-24 01:27:45 +0000 | [diff] [blame] | 38 | ; OBJ32: ProcStart { |
Reid Kleckner | 72e2ba7 | 2016-01-13 19:32:35 +0000 | [diff] [blame] | 39 | ; OBJ32: CodeSize: 0x6 |
| 40 | ; OBJ32: DisplayName: f |
| 41 | ; OBJ32: LinkageName: _f |
| 42 | ; OBJ32: } |
Zachary Turner | cac29ae | 2016-05-24 17:30:25 +0000 | [diff] [blame] | 43 | ; OBJ32: ProcEnd { |
| 44 | ; OBJ32: } |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 45 | ; OBJ32-NEXT: ] |
| 46 | ; OBJ32: FunctionLineTable [ |
| 47 | ; OBJ32-NEXT: Name: _f |
Reid Kleckner | 2214ed8 | 2016-01-29 00:49:42 +0000 | [diff] [blame] | 48 | ; OBJ32-NEXT: Flags: 0x0 |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 49 | ; OBJ32-NEXT: CodeSize: 0x6 |
| 50 | ; OBJ32-NEXT: FilenameSegment [ |
David Majnemer | 0494836 | 2016-01-13 01:05:16 +0000 | [diff] [blame] | 51 | ; OBJ32-NEXT: Filename: D:\asm.c |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 52 | ; FIXME: An empty __asm stmt creates an extra entry. |
| 53 | ; We seem to know that these offsets are the same statically during the |
Timur Iskhodzhanov | f33d8b9 | 2014-01-30 23:14:38 +0000 | [diff] [blame] | 54 | ; execution of endModule(). See PR18679 for the details. |
David Majnemer | 0494836 | 2016-01-13 01:05:16 +0000 | [diff] [blame] | 55 | ; OBJ32-NEXT: +0x0 [ |
| 56 | ; OBJ32-NEXT: LineNumberStart: 4 |
| 57 | ; OBJ32-NEXT: LineNumberEndDelta: 0 |
Reid Kleckner | 828883b | 2016-01-29 16:39:04 +0000 | [diff] [blame] | 58 | ; OBJ32-NEXT: IsStatement: No |
David Majnemer | 0494836 | 2016-01-13 01:05:16 +0000 | [diff] [blame] | 59 | ; OBJ32-NEXT: ] |
| 60 | ; OBJ32-NEXT: +0x0 [ |
| 61 | ; OBJ32-NEXT: LineNumberStart: 5 |
| 62 | ; OBJ32-NEXT: LineNumberEndDelta: 0 |
Reid Kleckner | 828883b | 2016-01-29 16:39:04 +0000 | [diff] [blame] | 63 | ; OBJ32-NEXT: IsStatement: No |
David Majnemer | 0494836 | 2016-01-13 01:05:16 +0000 | [diff] [blame] | 64 | ; OBJ32-NEXT: ] |
| 65 | ; OBJ32-NEXT: +0x5 [ |
| 66 | ; OBJ32-NEXT: LineNumberStart: 6 |
| 67 | ; OBJ32-NEXT: LineNumberEndDelta: 0 |
Reid Kleckner | 828883b | 2016-01-29 16:39:04 +0000 | [diff] [blame] | 68 | ; OBJ32-NEXT: IsStatement: No |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 69 | ; OBJ32-NEXT: ] |
| 70 | ; OBJ32-NEXT: ] |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 71 | |
Timur Iskhodzhanov | e32ef93 | 2014-03-26 08:45:02 +0000 | [diff] [blame] | 72 | ; X64-LABEL: f: |
Reid Kleckner | 2214ed8 | 2016-01-29 00:49:42 +0000 | [diff] [blame] | 73 | ; X64: .cv_file 1 "D:\\asm.c" |
| 74 | ; X64: .cv_loc 0 1 3 0 is_stmt 0 |
David Majnemer | 011980c | 2016-01-01 06:50:01 +0000 | [diff] [blame] | 75 | ; X64: subq $40, %rsp |
Reid Kleckner | 2214ed8 | 2016-01-29 00:49:42 +0000 | [diff] [blame] | 76 | ; X64: .cv_loc 0 1 4 0 |
| 77 | ; X64: .cv_loc 0 1 5 0 |
David Majnemer | b925715 | 2014-11-04 08:03:31 +0000 | [diff] [blame] | 78 | ; X64: callq g |
Reid Kleckner | 2214ed8 | 2016-01-29 00:49:42 +0000 | [diff] [blame] | 79 | ; X64: .cv_loc 0 1 6 0 |
David Majnemer | 011980c | 2016-01-01 06:50:01 +0000 | [diff] [blame] | 80 | ; X64: addq $40, %rsp |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 81 | ; X64-NEXT: ret |
Reid Kleckner | f9c275f | 2016-02-10 20:55:49 +0000 | [diff] [blame] | 82 | ; X64: [[END_OF_F:.?Lfunc_end.*]]: |
Adrian McCarthy | 4333daa | 2016-11-02 21:30:35 +0000 | [diff] [blame] | 83 | |
Timur Iskhodzhanov | 2bc90fd | 2014-10-24 01:27:45 +0000 | [diff] [blame] | 84 | ; Line table |
Adrian McCarthy | 4333daa | 2016-11-02 21:30:35 +0000 | [diff] [blame] | 85 | ; X64: .cv_linetable 0, f, [[END_OF_F]] |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 86 | ; File index to string table offset subsection |
Reid Kleckner | e8a236f | 2016-06-06 23:41:38 +0000 | [diff] [blame] | 87 | ; X64-NEXT: .cv_filechecksums |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 88 | ; String table |
Reid Kleckner | e8a236f | 2016-06-06 23:41:38 +0000 | [diff] [blame] | 89 | ; X64-NEXT: .cv_stringtable |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 90 | |
| 91 | ; OBJ64: Section { |
| 92 | ; OBJ64: Name: .debug$S (2E 64 65 62 75 67 24 53) |
Reid Kleckner | 2214ed8 | 2016-01-29 00:49:42 +0000 | [diff] [blame] | 93 | ; OBJ64: Characteristics [ (0x42300040) |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 94 | ; OBJ64: ] |
Timur Iskhodzhanov | 2bc90fd | 2014-10-24 01:27:45 +0000 | [diff] [blame] | 95 | ; OBJ64: Subsection [ |
Reid Kleckner | 72e2ba7 | 2016-01-13 19:32:35 +0000 | [diff] [blame] | 96 | ; OBJ64-NEXT: SubSectionType: Symbols (0xF1) |
Timur Iskhodzhanov | 2bc90fd | 2014-10-24 01:27:45 +0000 | [diff] [blame] | 97 | ; OBJ64: ProcStart { |
Reid Kleckner | 72e2ba7 | 2016-01-13 19:32:35 +0000 | [diff] [blame] | 98 | ; OBJ64: CodeSize: 0xE |
| 99 | ; OBJ64: DisplayName: f |
| 100 | ; OBJ64: LinkageName: f |
| 101 | ; OBJ64: } |
Zachary Turner | cac29ae | 2016-05-24 17:30:25 +0000 | [diff] [blame] | 102 | ; OBJ64-NEXT: ProcEnd { |
| 103 | ; OBJ64-NEXT: } |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 104 | ; OBJ64-NEXT: ] |
| 105 | ; OBJ64: FunctionLineTable [ |
| 106 | ; OBJ64-NEXT: Name: f |
Reid Kleckner | 2214ed8 | 2016-01-29 00:49:42 +0000 | [diff] [blame] | 107 | ; OBJ64-NEXT: Flags: 0x0 |
David Majnemer | 011980c | 2016-01-01 06:50:01 +0000 | [diff] [blame] | 108 | ; OBJ64-NEXT: CodeSize: 0xE |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 109 | ; OBJ64-NEXT: FilenameSegment [ |
| 110 | ; OBJ64-NEXT: Filename: D:\asm.c |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 111 | ; FIXME: An empty __asm stmt creates an extra entry. |
Timur Iskhodzhanov | f33d8b9 | 2014-01-30 23:14:38 +0000 | [diff] [blame] | 112 | ; See PR18679 for the details. |
David Majnemer | 0494836 | 2016-01-13 01:05:16 +0000 | [diff] [blame] | 113 | ; OBJ64-NEXT: +0x0 [ |
| 114 | ; OBJ64-NEXT: LineNumberStart: 3 |
| 115 | ; OBJ64-NEXT: LineNumberEndDelta: 0 |
Reid Kleckner | 828883b | 2016-01-29 16:39:04 +0000 | [diff] [blame] | 116 | ; OBJ64-NEXT: IsStatement: No |
David Majnemer | 0494836 | 2016-01-13 01:05:16 +0000 | [diff] [blame] | 117 | ; OBJ64-NEXT: ] |
| 118 | ; OBJ64-NEXT: +0x4 [ |
| 119 | ; OBJ64-NEXT: LineNumberStart: 4 |
| 120 | ; OBJ64-NEXT: LineNumberEndDelta: 0 |
Reid Kleckner | 828883b | 2016-01-29 16:39:04 +0000 | [diff] [blame] | 121 | ; OBJ64-NEXT: IsStatement: No |
David Majnemer | 0494836 | 2016-01-13 01:05:16 +0000 | [diff] [blame] | 122 | ; OBJ64-NEXT: ] |
| 123 | ; OBJ64-NEXT: +0x4 [ |
| 124 | ; OBJ64-NEXT: LineNumberStart: 5 |
| 125 | ; OBJ64-NEXT: LineNumberEndDelta: 0 |
Reid Kleckner | 828883b | 2016-01-29 16:39:04 +0000 | [diff] [blame] | 126 | ; OBJ64-NEXT: IsStatement: No |
David Majnemer | 0494836 | 2016-01-13 01:05:16 +0000 | [diff] [blame] | 127 | ; OBJ64-NEXT: ] |
| 128 | ; OBJ64-NEXT: +0x9 [ |
| 129 | ; OBJ64-NEXT: LineNumberStart: 6 |
| 130 | ; OBJ64-NEXT: LineNumberEndDelta: 0 |
Reid Kleckner | 828883b | 2016-01-29 16:39:04 +0000 | [diff] [blame] | 131 | ; OBJ64-NEXT: IsStatement: No |
David Majnemer | 0494836 | 2016-01-13 01:05:16 +0000 | [diff] [blame] | 132 | ; OBJ64-NEXT: ] |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 133 | ; OBJ64-NEXT: ] |
| 134 | ; OBJ64-NEXT: ] |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 135 | |
| 136 | ; Function Attrs: nounwind |
Peter Collingbourne | d4bff30 | 2015-11-05 22:03:56 +0000 | [diff] [blame] | 137 | define void @f() #0 !dbg !4 { |
Timur Iskhodzhanov | f166f6c | 2014-01-30 01:39:17 +0000 | [diff] [blame] | 138 | entry: |
| 139 | call void asm sideeffect inteldialect ".align 4", "~{dirflag},~{fpsr},~{flags}"() #2, !dbg !12 |
| 140 | call void @g(), !dbg !13 |
| 141 | ret void, !dbg !14 |
| 142 | } |
| 143 | |
| 144 | declare void @g() #1 |
| 145 | |
| 146 | attributes #0 = { nounwind "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "no-realign-stack" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" } |
| 147 | attributes #1 = { "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "no-realign-stack" "stack-protector-buffer-size"="8" "unsafe-fp-math"="false" "use-soft-float"="false" } |
| 148 | attributes #2 = { nounwind } |
| 149 | |
| 150 | !llvm.dbg.cu = !{!0} |
| 151 | !llvm.module.flags = !{!9, !10} |
| 152 | !llvm.ident = !{!11} |
| 153 | |
Adrian Prantl | 75819ae | 2016-04-15 15:57:41 +0000 | [diff] [blame] | 154 | !0 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.5 ", isOptimized: false, emissionKind: FullDebug, file: !1, enums: !2, retainedTypes: !2, globals: !2, imports: !2) |
Duncan P. N. Exon Smith | a9308c4 | 2015-04-29 16:38:44 +0000 | [diff] [blame] | 155 | !1 = !DIFile(filename: "<unknown>", directory: "D:\5C") |
Duncan P. N. Exon Smith | be7ea19 | 2014-12-15 19:07:53 +0000 | [diff] [blame] | 156 | !2 = !{} |
Adrian Prantl | 75819ae | 2016-04-15 15:57:41 +0000 | [diff] [blame] | 157 | !4 = distinct !DISubprogram(name: "f", line: 3, isLocal: false, isDefinition: true, virtualIndex: 6, flags: DIFlagPrototyped, isOptimized: false, unit: !0, scopeLine: 3, file: !5, scope: !6, type: !7, variables: !2) |
Duncan P. N. Exon Smith | a9308c4 | 2015-04-29 16:38:44 +0000 | [diff] [blame] | 158 | !5 = !DIFile(filename: "asm.c", directory: "D:\5C") |
| 159 | !6 = !DIFile(filename: "asm.c", directory: "D:C") |
| 160 | !7 = !DISubroutineType(types: !8) |
Duncan P. N. Exon Smith | be7ea19 | 2014-12-15 19:07:53 +0000 | [diff] [blame] | 161 | !8 = !{null} |
Reid Kleckner | 12d2c12 | 2015-08-05 22:26:20 +0000 | [diff] [blame] | 162 | !9 = !{i32 2, !"CodeView", i32 1} |
Duncan P. N. Exon Smith | e274180 | 2015-03-03 17:24:31 +0000 | [diff] [blame] | 163 | !10 = !{i32 1, !"Debug Info Version", i32 3} |
Duncan P. N. Exon Smith | be7ea19 | 2014-12-15 19:07:53 +0000 | [diff] [blame] | 164 | !11 = !{!"clang version 3.5 "} |
Duncan P. N. Exon Smith | a9308c4 | 2015-04-29 16:38:44 +0000 | [diff] [blame] | 165 | !12 = !DILocation(line: 4, scope: !4) |
| 166 | !13 = !DILocation(line: 5, scope: !4) |
| 167 | !14 = !DILocation(line: 6, scope: !4) |