|  | ; 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) |