| ; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx700 -filetype=obj -o - < %s | llvm-readobj -elf-output-style=GNU -notes | FileCheck --check-prefix=CHECK --check-prefix=GFX700 --check-prefix=NOTES %s | 
 | ; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx803 -filetype=obj -o - < %s | llvm-readobj -elf-output-style=GNU -notes | FileCheck --check-prefix=CHECK --check-prefix=GFX803 --check-prefix=NOTES %s | 
 | ; RUN: llc -mtriple=amdgcn-amd-amdhsa -mcpu=gfx900 -filetype=obj -o - < %s | llvm-readobj -elf-output-style=GNU -notes | FileCheck --check-prefix=CHECK --check-prefix=GFX900 --check-prefix=NOTES %s | 
 |  | 
 | ; CHECK: --- | 
 | ; CHECK:  Version: [ 1, 0 ] | 
 | ; CHECK:  Kernels: | 
 |  | 
 | ; CHECK:      - Name:       test0 | 
 | ; CHECK:        SymbolName: 'test0@kd' | 
 | ; CHECK:        Args: | 
 | ; CHECK-NEXT:     - Name:            r | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            a | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            b | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:   CodeProps: | 
 | define amdgpu_kernel void @test0( | 
 |     half addrspace(1)* %r, | 
 |     half addrspace(1)* %a, | 
 |     half addrspace(1)* %b) { | 
 | entry: | 
 |   %a.val = load half, half addrspace(1)* %a | 
 |   %b.val = load half, half addrspace(1)* %b | 
 |   %r.val = fadd half %a.val, %b.val | 
 |   store half %r.val, half addrspace(1)* %r | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK:      - Name:       test8 | 
 | ; CHECK:        SymbolName: 'test8@kd' | 
 | ; CHECK:        Args: | 
 | ; CHECK-NEXT:     - Name:            r | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            a | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            b | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetX | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:   CodeProps: | 
 | define amdgpu_kernel void @test8( | 
 |     half addrspace(1)* %r, | 
 |     half addrspace(1)* %a, | 
 |     half addrspace(1)* %b) #0 { | 
 | entry: | 
 |   %a.val = load half, half addrspace(1)* %a | 
 |   %b.val = load half, half addrspace(1)* %b | 
 |   %r.val = fadd half %a.val, %b.val | 
 |   store half %r.val, half addrspace(1)* %r | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK:      - Name:       test16 | 
 | ; CHECK:        SymbolName: 'test16@kd' | 
 | ; CHECK:        Args: | 
 | ; CHECK-NEXT:     - Name:            r | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            a | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            b | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetX | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetY | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:   CodeProps: | 
 | define amdgpu_kernel void @test16( | 
 |     half addrspace(1)* %r, | 
 |     half addrspace(1)* %a, | 
 |     half addrspace(1)* %b) #1 { | 
 | entry: | 
 |   %a.val = load half, half addrspace(1)* %a | 
 |   %b.val = load half, half addrspace(1)* %b | 
 |   %r.val = fadd half %a.val, %b.val | 
 |   store half %r.val, half addrspace(1)* %r | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK:      - Name:       test24 | 
 | ; CHECK:        SymbolName: 'test24@kd' | 
 | ; CHECK:        Args: | 
 | ; CHECK-NEXT:     - Name:            r | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            a | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            b | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetX | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetY | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetZ | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:   CodeProps: | 
 | define amdgpu_kernel void @test24( | 
 |     half addrspace(1)* %r, | 
 |     half addrspace(1)* %a, | 
 |     half addrspace(1)* %b) #2 { | 
 | entry: | 
 |   %a.val = load half, half addrspace(1)* %a | 
 |   %b.val = load half, half addrspace(1)* %b | 
 |   %r.val = fadd half %a.val, %b.val | 
 |   store half %r.val, half addrspace(1)* %r | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK:      - Name:       test32 | 
 | ; CHECK:        SymbolName: 'test32@kd' | 
 | ; CHECK:        Args: | 
 | ; CHECK-NEXT:     - Name:            r | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            a | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            b | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetX | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetY | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetZ | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenNone | 
 | ; CHECK-NEXT:       ValueType:       I8 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:   CodeProps: | 
 | define amdgpu_kernel void @test32( | 
 |     half addrspace(1)* %r, | 
 |     half addrspace(1)* %a, | 
 |     half addrspace(1)* %b) #3 { | 
 | entry: | 
 |   %a.val = load half, half addrspace(1)* %a | 
 |   %b.val = load half, half addrspace(1)* %b | 
 |   %r.val = fadd half %a.val, %b.val | 
 |   store half %r.val, half addrspace(1)* %r | 
 |   ret void | 
 | } | 
 |  | 
 | ; CHECK:      - Name:       test48 | 
 | ; CHECK:        SymbolName: 'test48@kd' | 
 | ; CHECK:        Args: | 
 | ; CHECK-NEXT:     - Name:            r | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            a | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Name:            b | 
 | ; CHECK-NEXT:       Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       GlobalBuffer | 
 | ; CHECK-NEXT:       ValueType:       F16 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetX | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetY | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenGlobalOffsetZ | 
 | ; CHECK-NEXT:       ValueType:       I64 | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenNone | 
 | ; CHECK-NEXT:       ValueType:       I8 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenNone | 
 | ; CHECK-NEXT:       ValueType:       I8 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:     - Size:            8 | 
 | ; CHECK-NEXT:       Align:           8 | 
 | ; CHECK-NEXT:       ValueKind:       HiddenNone | 
 | ; CHECK-NEXT:       ValueType:       I8 | 
 | ; CHECK-NEXT:       AddrSpaceQual:   Global | 
 | ; CHECK-NEXT:   CodeProps: | 
 | define amdgpu_kernel void @test48( | 
 |     half addrspace(1)* %r, | 
 |     half addrspace(1)* %a, | 
 |     half addrspace(1)* %b) #4 { | 
 | entry: | 
 |   %a.val = load half, half addrspace(1)* %a | 
 |   %b.val = load half, half addrspace(1)* %b | 
 |   %r.val = fadd half %a.val, %b.val | 
 |   store half %r.val, half addrspace(1)* %r | 
 |   ret void | 
 | } | 
 |  | 
 | attributes #0 = { "amdgpu-implicitarg-num-bytes"="8" } | 
 | attributes #1 = { "amdgpu-implicitarg-num-bytes"="16" } | 
 | attributes #2 = { "amdgpu-implicitarg-num-bytes"="24" } | 
 | attributes #3 = { "amdgpu-implicitarg-num-bytes"="32" } | 
 | attributes #4 = { "amdgpu-implicitarg-num-bytes"="48" } |