aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/AMDGPU/bf16-ops.ll
blob: b24983c10d3a8c0db50fbb7b2d00c6c5db3134ae (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
; RUN: not llc < %s -mtriple=amdgcn -mcpu=hawaii
; RUN: not llc < %s -mtriple=amdgcn -mcpu=tonga
; RUN: not llc < %s -mtriple=amdgcn -mcpu=gfx900
; RUN: not llc < %s -mtriple=amdgcn -mcpu=gfx1010

; TODO: Add GlobalISel tests, currently it silently miscompiles as GISel does not handle BF16 at all.

; We only have storage-only BF16 support so check codegen fails if we attempt to do operations on bfloats.

define void @test_fneg(bfloat %a, ptr addrspace(1) %out) {
  %result = fneg bfloat %a
  store bfloat %result, ptr addrspace(1) %out
  ret void
}

define void @test_fabs(bfloat %a, ptr addrspace(1) %out) {
  %result = fabs bfloat %a
  store bfloat %result, ptr addrspace(1) %out
  ret void
}

define void @test_add(bfloat %a, bfloat %b, ptr addrspace(1) %out) {
  %result = fadd bfloat %a, %b
  store bfloat %result, ptr addrspace(1) %out
  ret void
}

define void @test_mul(bfloat %a, bfloat %b, ptr addrspace(1) %out) {
  %result = fmul bfloat %a, %b
  store bfloat %result, ptr addrspace(1) %out
  ret void
}