File: bitcast-bfloat-half-mixing.ll

package info (click to toggle)
llvm-toolchain-19 1%3A19.1.7-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,998,520 kB
  • sloc: cpp: 6,951,680; ansic: 1,486,157; asm: 913,598; python: 232,024; f90: 80,126; objc: 75,281; lisp: 37,276; pascal: 16,990; sh: 10,009; ml: 5,058; perl: 4,724; awk: 3,523; makefile: 3,167; javascript: 2,504; xml: 892; fortran: 664; cs: 573
file content (87 lines) | stat: -rw-r--r-- 2,407 bytes parent folder | download | duplicates (7)
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 4
; RUN: opt -passes=instcombine -S %s | FileCheck %s

define double @F0(bfloat %P0) {
; CHECK-LABEL: define double @F0(
; CHECK-SAME: bfloat [[P0:%.*]]) {
; CHECK-NEXT:  entry:
; CHECK-NEXT:    [[CONV0:%.*]] = bitcast bfloat [[P0]] to half
; CHECK-NEXT:    [[TMP0:%.*]] = fpext half [[CONV0]] to double
; CHECK-NEXT:    ret double [[TMP0]]
;
entry:
  %conv0 = bitcast bfloat %P0 to half
  %0 = fpext half %conv0 to double
  ret double %0
}

define double @F1(half %P1) {
; CHECK-LABEL: define double @F1(
; CHECK-SAME: half [[P1:%.*]]) {
; CHECK-NEXT:  entry:
; CHECK-NEXT:    [[CONV1:%.*]] = bitcast half [[P1]] to bfloat
; CHECK-NEXT:    [[TMP0:%.*]] = fpext bfloat [[CONV1]] to double
; CHECK-NEXT:    ret double [[TMP0]]
;
entry:
  %conv1 = bitcast half %P1 to bfloat
  %0 = fpext bfloat %conv1 to double
  ret double %0
}

define i32 @F2(bfloat %P2) {
; CHECK-LABEL: define i32 @F2(
; CHECK-SAME: bfloat [[P2:%.*]]) {
; CHECK-NEXT:  entry:
; CHECK-NEXT:    [[CONV2:%.*]] = bitcast bfloat [[P2]] to half
; CHECK-NEXT:    [[TMP0:%.*]] = fptoui half [[CONV2]] to i32
; CHECK-NEXT:    ret i32 [[TMP0]]
;
entry:
  %conv2 = bitcast bfloat %P2 to half
  %0 = fptoui half %conv2 to i32
  ret i32 %0
}

define i32 @F3(half %P3) {
; CHECK-LABEL: define i32 @F3(
; CHECK-SAME: half [[P3:%.*]]) {
; CHECK-NEXT:  entry:
; CHECK-NEXT:    [[CONV3:%.*]] = bitcast half [[P3]] to bfloat
; CHECK-NEXT:    [[TMP0:%.*]] = fptoui bfloat [[CONV3]] to i32
; CHECK-NEXT:    ret i32 [[TMP0]]
;
entry:
  %conv3 = bitcast half %P3 to bfloat
  %0 = fptoui bfloat %conv3 to i32
  ret i32 %0
}

define i32 @F4(bfloat %P4) {
; CHECK-LABEL: define i32 @F4(
; CHECK-SAME: bfloat [[P4:%.*]]) {
; CHECK-NEXT:  entry:
; CHECK-NEXT:    [[CONV4:%.*]] = bitcast bfloat [[P4]] to half
; CHECK-NEXT:    [[TMP0:%.*]] = fptosi half [[CONV4]] to i32
; CHECK-NEXT:    ret i32 [[TMP0]]
;
entry:
  %conv4 = bitcast bfloat %P4 to half
  %0 = fptosi half %conv4 to i32
  ret i32 %0
}

define i32 @F5(half %P5) {
; CHECK-LABEL: define i32 @F5(
; CHECK-SAME: half [[P5:%.*]]) {
; CHECK-NEXT:  entry:
; CHECK-NEXT:    [[CONV5:%.*]] = bitcast half [[P5]] to bfloat
; CHECK-NEXT:    [[TMP0:%.*]] = fptosi bfloat [[CONV5]] to i32
; CHECK-NEXT:    ret i32 [[TMP0]]
;
entry:
  %conv5 = bitcast half %P5 to bfloat
  %0 = fptosi bfloat %conv5 to i32
  ret i32 %0
}