| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 3 |
| ; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx908 < %s | FileCheck %s |
| |
| define amdgpu_kernel void @_Z3fooPiiii(ptr addrspace(1) nocapture noundef writeonly %c.coerce, i32 noundef %a, i32 noundef %b, i32 noundef %d) !dbg !9 { |
| ; CHECK-LABEL: _Z3fooPiiii: |
| ; CHECK: .Lfunc_begin0: |
| ; CHECK-NEXT: .file 0 "test" "a.hip" md5 0x004a28df8cfd98cdd2c71d5d814d9c6b |
| ; CHECK-NEXT: .cfi_sections .debug_frame |
| ; CHECK-NEXT: .cfi_startproc |
| ; CHECK-NEXT: ; %bb.0: ; %entry |
| ; CHECK-NEXT: .file 1 "." "a.h" |
| ; CHECK-NEXT: .loc 1 5 12 prologue_end ; ./a.h:5:12 @[ a.hip:12:8 ] |
| ; CHECK-NEXT: s_load_dwordx4 s[0:3], s[8:9], 0x8 |
| ; CHECK-NEXT: s_load_dwordx2 s[4:5], s[8:9], 0x0 |
| ; CHECK-NEXT: v_mov_b32_e32 v0, 0 |
| ; CHECK-NEXT: s_waitcnt lgkmcnt(0) |
| ; CHECK-NEXT: s_add_i32 s1, s1, s0 |
| ; CHECK-NEXT: .Ltmp0: |
| ; CHECK-NEXT: .loc 1 5 12 is_stmt 0 ; ./a.h:5:12 @[ a.hip:13:9 ] |
| ; CHECK-NEXT: s_add_i32 s0, s2, s0 |
| ; CHECK-NEXT: .Ltmp1: |
| ; CHECK-NEXT: .file 2 "a.hip" |
| ; CHECK-NEXT: .loc 2 13 6 is_stmt 1 ; a.hip:13:6 |
| ; CHECK-NEXT: s_mul_i32 s0, s0, s1 |
| ; CHECK-NEXT: v_mov_b32_e32 v1, s0 |
| ; CHECK-NEXT: global_store_dword v0, v1, s[4:5] |
| ; CHECK-NEXT: .loc 2 14 1 ; a.hip:14:1 |
| ; CHECK-NEXT: s_endpgm |
| ; CHECK-NEXT: .Ltmp2: |
| entry: |
| %add.i = add nsw i32 %b, %a, !dbg !13 |
| %add.i3 = add nsw i32 %d, %a, !dbg !17 |
| %mul = mul nsw i32 %add.i3, %add.i, !dbg !19 |
| store i32 %mul, ptr addrspace(1) %c.coerce, align 4, !dbg !19, !tbaa !20 |
| ret void, !dbg !24 |
| } |
| |
| !llvm.dbg.cu = !{!0} |
| !llvm.module.flags = !{!2, !3, !4, !5, !6, !7} |
| !llvm.ident = !{!8} |
| |
| !0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus_14, file: !1, producer: "clang version 20.0.0", isOptimized: true, runtimeVersion: 0, emissionKind: LineTablesOnly, splitDebugInlining: false, nameTableKind: None) |
| !1 = !DIFile(filename: "a.hip", directory: "test", checksumkind: CSK_MD5, checksum: "004a28df8cfd98cdd2c71d5d814d9c6b") |
| !2 = !{i32 1, !"amdhsa_code_object_version", i32 500} |
| !3 = !{i32 1, !"amdgpu_printf_kind", !"hostcall"} |
| !4 = !{i32 7, !"Dwarf Version", i32 5} |
| !5 = !{i32 2, !"Debug Info Version", i32 3} |
| !6 = !{i32 1, !"wchar_size", i32 4} |
| !7 = !{i32 8, !"PIC Level", i32 2} |
| !8 = !{!"clang version 20.0.0"} |
| !9 = distinct !DISubprogram(name: "foo", scope: !10, file: !10, line: 11, type: !11, scopeLine: 11, flags: DIFlagPrototyped | DIFlagAllCallsDescribed, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !0) |
| !10 = !DIFile(filename: "a.hip", directory: "test") |
| !11 = !DISubroutineType(types: !12) |
| !12 = !{} |
| !13 = !DILocation(line: 5, column: 12, scope: !14, inlinedAt: !16) |
| !14 = distinct !DISubprogram(name: "bar", scope: !15, file: !15, line: 4, type: !11, scopeLine: 4, flags: DIFlagPrototyped | DIFlagAllCallsDescribed, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !0) |
| !15 = !DIFile(filename: "./a.h", directory: "test") |
| !16 = distinct !DILocation(line: 12, column: 8, scope: !9) |
| !17 = !DILocation(line: 5, column: 12, scope: !14, inlinedAt: !18) |
| !18 = distinct !DILocation(line: 13, column: 9, scope: !9) |
| !19 = !DILocation(line: 13, column: 6, scope: !9) |
| !20 = !{!21, !21, i64 0} |
| !21 = !{!"int", !22, i64 0} |
| !22 = !{!"omnipotent char", !23, i64 0} |
| !23 = !{!"Simple C++ TBAA"} |
| !24 = !DILocation(line: 14, column: 1, scope: !9) |