summaryrefslogtreecommitdiff
path: root/test/lit/exec/negative-zero.wast
blob: 2c45dbdfb9cee694f2c69a6b32854db4da1b1145 (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
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
;; NOTE: Assertions have been generated by update_lit_checks.py --output=fuzz-exec and should not be edited.

;; RUN: wasm-opt %s -all --fuzz-exec -o /dev/null 2>&1 | filecheck %s

(module
 ;; CHECK:      [fuzz-exec] calling min1
 ;; CHECK-NEXT: [fuzz-exec] note result: min1 => -0
 (func $min1 (export "min1") (result f64)
  ;; This should return -0.
  (f64.min
   (f64.const 0)
   (f64.const -0)
  )
 )

 ;; CHECK:      [fuzz-exec] calling min2
 ;; CHECK-NEXT: [fuzz-exec] note result: min2 => -0
 (func $min2 (export "min2") (result f64)
  ;; Flipped arms; still -0.
  (f64.min
   (f64.const -0)
   (f64.const 0)
  )
 )

 ;; CHECK:      [fuzz-exec] calling min1-f32
 ;; CHECK-NEXT: [fuzz-exec] note result: min1-f32 => -0
 (func $min1-f32 (export "min1-f32") (result f32)
  ;; As above, but f32 and not f64
  (f32.min
   (f32.const 0)
   (f32.const -0)
  )
 )

 ;; CHECK:      [fuzz-exec] calling min2-f32
 ;; CHECK-NEXT: [fuzz-exec] note result: min2-f32 => -0
 (func $min2-f32 (export "min2-f32") (result f32)
  ;; Flipped arms; still -0.
  (f32.min
   (f32.const -0)
   (f32.const 0)
  )
 )

 ;; CHECK:      [fuzz-exec] calling max1
 ;; CHECK-NEXT: [fuzz-exec] note result: max1 => 0
 (func $max1 (export "max1") (result f64)
  ;; This should return 0.
  (f64.max
   (f64.const 0)
   (f64.const -0)
  )
 )

 ;; CHECK:      [fuzz-exec] calling max2
 ;; CHECK-NEXT: [fuzz-exec] note result: max2 => 0
 (func $max2 (export "max2") (result f64)
  ;; Flipped arms; still 0.
  (f64.max
   (f64.const -0)
   (f64.const 0)
  )
 )

 ;; CHECK:      [fuzz-exec] calling max1-f32
 ;; CHECK-NEXT: [fuzz-exec] note result: max1-f32 => 0
 (func $max1-f32 (export "max1-f32") (result f32)
  ;; As above, but f32 and not f64
  (f32.max
   (f32.const 0)
   (f32.const -0)
  )
 )

 ;; CHECK:      [fuzz-exec] calling max2-f32
 ;; CHECK-NEXT: [fuzz-exec] note result: max2-f32 => 0
 ;; CHECK-NEXT: warning: no passes specified, not doing any work
 (func $max2-f32 (export "max2-f32") (result f32)
  ;; Flipped arms; still 0.
  (f32.max
   (f32.const -0)
   (f32.const 0)
  )
 )
)
;; CHECK:      [fuzz-exec] calling min1
;; CHECK-NEXT: [fuzz-exec] note result: min1 => -0

;; CHECK:      [fuzz-exec] calling min2
;; CHECK-NEXT: [fuzz-exec] note result: min2 => -0

;; CHECK:      [fuzz-exec] calling min1-f32
;; CHECK-NEXT: [fuzz-exec] note result: min1-f32 => -0

;; CHECK:      [fuzz-exec] calling min2-f32
;; CHECK-NEXT: [fuzz-exec] note result: min2-f32 => -0

;; CHECK:      [fuzz-exec] calling max1
;; CHECK-NEXT: [fuzz-exec] note result: max1 => 0

;; CHECK:      [fuzz-exec] calling max2
;; CHECK-NEXT: [fuzz-exec] note result: max2 => 0

;; CHECK:      [fuzz-exec] calling max1-f32
;; CHECK-NEXT: [fuzz-exec] note result: max1-f32 => 0

;; CHECK:      [fuzz-exec] calling max2-f32
;; CHECK-NEXT: [fuzz-exec] note result: max2-f32 => 0
;; CHECK-NEXT: [fuzz-exec] comparing max1
;; CHECK-NEXT: [fuzz-exec] comparing max1-f32
;; CHECK-NEXT: [fuzz-exec] comparing max2
;; CHECK-NEXT: [fuzz-exec] comparing max2-f32
;; CHECK-NEXT: [fuzz-exec] comparing min1
;; CHECK-NEXT: [fuzz-exec] comparing min1-f32
;; CHECK-NEXT: [fuzz-exec] comparing min2
;; CHECK-NEXT: [fuzz-exec] comparing min2-f32