@@ -1838,11 +1838,11 @@ define <3 x half> @v_maximumnum_v3f16(<3 x half> %x, <3 x half> %y) {
1838
1838
; GFX8-NEXT: v_max_f16_e32 v2, v2, v2
1839
1839
; GFX8-NEXT: v_max_f16_e32 v0, v0, v0
1840
1840
; GFX8-NEXT: v_max_f16_sdwa v4, v5, v4 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
1841
- ; GFX8-NEXT: v_max_f16_e32 v0, v0, v2
1842
- ; GFX8-NEXT: v_max_f16_e32 v2, v3, v3
1841
+ ; GFX8-NEXT: v_max_f16_e32 v3, v3, v3
1843
1842
; GFX8-NEXT: v_max_f16_e32 v1, v1, v1
1843
+ ; GFX8-NEXT: v_max_f16_e32 v0, v0, v2
1844
+ ; GFX8-NEXT: v_max_f16_e32 v1, v1, v3
1844
1845
; GFX8-NEXT: v_or_b32_e32 v0, v0, v4
1845
- ; GFX8-NEXT: v_max_f16_e32 v1, v1, v2
1846
1846
; GFX8-NEXT: s_setpc_b64 s[30:31]
1847
1847
;
1848
1848
; GFX9-LABEL: v_maximumnum_v3f16:
@@ -1904,8 +1904,8 @@ define <3 x half> @v_maximumnum_v3f16_nnan(<3 x half> %x, <3 x half> %y) {
1904
1904
; GFX8-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1905
1905
; GFX8-NEXT: v_max_f16_sdwa v4, v0, v2 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
1906
1906
; GFX8-NEXT: v_max_f16_e32 v0, v0, v2
1907
- ; GFX8-NEXT: v_or_b32_e32 v0, v0, v4
1908
1907
; GFX8-NEXT: v_max_f16_e32 v1, v1, v3
1908
+ ; GFX8-NEXT: v_or_b32_e32 v0, v0, v4
1909
1909
; GFX8-NEXT: s_setpc_b64 s[30:31]
1910
1910
;
1911
1911
; GFX9-LABEL: v_maximumnum_v3f16_nnan:
@@ -1947,20 +1947,20 @@ define <4 x half> @v_maximumnum_v4f16(<4 x half> %x, <4 x half> %y) {
1947
1947
; GFX8-LABEL: v_maximumnum_v4f16:
1948
1948
; GFX8: ; %bb.0:
1949
1949
; GFX8-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
1950
- ; GFX8-NEXT: v_max_f16_sdwa v4, v2, v2 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
1951
- ; GFX8-NEXT: v_max_f16_sdwa v5, v0, v0 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
1952
- ; GFX8-NEXT: v_max_f16_e32 v2, v2, v2
1953
- ; GFX8-NEXT: v_max_f16_e32 v0, v0, v0
1950
+ ; GFX8-NEXT: v_max_f16_sdwa v4, v3, v3 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
1951
+ ; GFX8-NEXT: v_max_f16_sdwa v5, v1, v1 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
1954
1952
; GFX8-NEXT: v_max_f16_sdwa v4, v5, v4 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
1955
- ; GFX8-NEXT: v_max_f16_e32 v0, v0, v2
1956
- ; GFX8-NEXT: v_or_b32_e32 v0, v0, v4
1957
- ; GFX8-NEXT: v_max_f16_sdwa v2, v3, v3 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
1958
- ; GFX8-NEXT: v_max_f16_sdwa v4, v1, v1 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
1953
+ ; GFX8-NEXT: v_max_f16_sdwa v5, v2, v2 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
1954
+ ; GFX8-NEXT: v_max_f16_sdwa v6, v0, v0 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
1959
1955
; GFX8-NEXT: v_max_f16_e32 v3, v3, v3
1960
1956
; GFX8-NEXT: v_max_f16_e32 v1, v1, v1
1961
- ; GFX8-NEXT: v_max_f16_sdwa v2, v4, v2 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
1957
+ ; GFX8-NEXT: v_max_f16_e32 v2, v2, v2
1958
+ ; GFX8-NEXT: v_max_f16_e32 v0, v0, v0
1959
+ ; GFX8-NEXT: v_max_f16_sdwa v5, v6, v5 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
1962
1960
; GFX8-NEXT: v_max_f16_e32 v1, v1, v3
1963
- ; GFX8-NEXT: v_or_b32_e32 v1, v1, v2
1961
+ ; GFX8-NEXT: v_max_f16_e32 v0, v0, v2
1962
+ ; GFX8-NEXT: v_or_b32_e32 v0, v0, v5
1963
+ ; GFX8-NEXT: v_or_b32_e32 v1, v1, v4
1964
1964
; GFX8-NEXT: s_setpc_b64 s[30:31]
1965
1965
;
1966
1966
; GFX9-LABEL: v_maximumnum_v4f16:
@@ -2020,12 +2020,12 @@ define <4 x half> @v_maximumnum_v4f16_nnan(<4 x half> %x, <4 x half> %y) {
2020
2020
; GFX8-LABEL: v_maximumnum_v4f16_nnan:
2021
2021
; GFX8: ; %bb.0:
2022
2022
; GFX8-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2023
- ; GFX8-NEXT: v_max_f16_sdwa v4, v0, v2 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2024
- ; GFX8-NEXT: v_max_f16_e32 v0, v0, v2
2025
- ; GFX8-NEXT: v_max_f16_sdwa v2, v1, v3 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2023
+ ; GFX8-NEXT: v_max_f16_sdwa v4, v1, v3 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2024
+ ; GFX8-NEXT: v_max_f16_sdwa v5, v0, v2 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2026
2025
; GFX8-NEXT: v_max_f16_e32 v1, v1, v3
2027
- ; GFX8-NEXT: v_or_b32_e32 v0, v0, v4
2028
- ; GFX8-NEXT: v_or_b32_e32 v1, v1, v2
2026
+ ; GFX8-NEXT: v_max_f16_e32 v0, v0, v2
2027
+ ; GFX8-NEXT: v_or_b32_e32 v0, v0, v5
2028
+ ; GFX8-NEXT: v_or_b32_e32 v1, v1, v4
2029
2029
; GFX8-NEXT: s_setpc_b64 s[30:31]
2030
2030
;
2031
2031
; GFX9-LABEL: v_maximumnum_v4f16_nnan:
@@ -2067,27 +2067,27 @@ define <6 x half> @v_maximumnum_v6f16(<6 x half> %x, <6 x half> %y) {
2067
2067
; GFX8-LABEL: v_maximumnum_v6f16:
2068
2068
; GFX8: ; %bb.0:
2069
2069
; GFX8-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2070
- ; GFX8-NEXT: v_max_f16_sdwa v6, v3, v3 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2071
- ; GFX8-NEXT: v_max_f16_sdwa v7, v0, v0 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2072
- ; GFX8-NEXT: v_max_f16_e32 v3, v3, v3
2073
- ; GFX8-NEXT: v_max_f16_e32 v0, v0, v0
2070
+ ; GFX8-NEXT: v_max_f16_sdwa v6, v5, v5 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2071
+ ; GFX8-NEXT: v_max_f16_sdwa v7, v2, v2 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2074
2072
; GFX8-NEXT: v_max_f16_sdwa v6, v7, v6 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2075
- ; GFX8-NEXT: v_max_f16_e32 v0, v0, v3
2076
- ; GFX8-NEXT: v_or_b32_e32 v0, v0, v6
2077
- ; GFX8-NEXT: v_max_f16_sdwa v3, v4, v4 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2078
- ; GFX8-NEXT: v_max_f16_sdwa v6, v1, v1 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2073
+ ; GFX8-NEXT: v_max_f16_sdwa v7, v4, v4 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2074
+ ; GFX8-NEXT: v_max_f16_sdwa v8, v1, v1 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2075
+ ; GFX8-NEXT: v_max_f16_sdwa v7, v8, v7 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2076
+ ; GFX8-NEXT: v_max_f16_sdwa v8, v3, v3 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2077
+ ; GFX8-NEXT: v_max_f16_sdwa v9, v0, v0 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2078
+ ; GFX8-NEXT: v_max_f16_e32 v5, v5, v5
2079
+ ; GFX8-NEXT: v_max_f16_e32 v2, v2, v2
2079
2080
; GFX8-NEXT: v_max_f16_e32 v4, v4, v4
2080
2081
; GFX8-NEXT: v_max_f16_e32 v1, v1, v1
2081
- ; GFX8-NEXT: v_max_f16_sdwa v3, v6, v3 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2082
+ ; GFX8-NEXT: v_max_f16_e32 v3, v3, v3
2083
+ ; GFX8-NEXT: v_max_f16_e32 v0, v0, v0
2084
+ ; GFX8-NEXT: v_max_f16_sdwa v8, v9, v8 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2085
+ ; GFX8-NEXT: v_max_f16_e32 v2, v2, v5
2082
2086
; GFX8-NEXT: v_max_f16_e32 v1, v1, v4
2083
- ; GFX8-NEXT: v_or_b32_e32 v1, v1, v3
2084
- ; GFX8-NEXT: v_max_f16_sdwa v3, v5, v5 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2085
- ; GFX8-NEXT: v_max_f16_sdwa v4, v2, v2 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2086
- ; GFX8-NEXT: v_max_f16_sdwa v3, v4, v3 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2087
- ; GFX8-NEXT: v_max_f16_e32 v4, v5, v5
2088
- ; GFX8-NEXT: v_max_f16_e32 v2, v2, v2
2089
- ; GFX8-NEXT: v_max_f16_e32 v2, v2, v4
2090
- ; GFX8-NEXT: v_or_b32_e32 v2, v2, v3
2087
+ ; GFX8-NEXT: v_max_f16_e32 v0, v0, v3
2088
+ ; GFX8-NEXT: v_or_b32_e32 v0, v0, v8
2089
+ ; GFX8-NEXT: v_or_b32_e32 v1, v1, v7
2090
+ ; GFX8-NEXT: v_or_b32_e32 v2, v2, v6
2091
2091
; GFX8-NEXT: s_setpc_b64 s[30:31]
2092
2092
;
2093
2093
; GFX9-LABEL: v_maximumnum_v6f16:
@@ -2159,34 +2159,34 @@ define <8 x half> @v_maximumnum_v8f16(<8 x half> %x, <8 x half> %y) {
2159
2159
; GFX8-LABEL: v_maximumnum_v8f16:
2160
2160
; GFX8: ; %bb.0:
2161
2161
; GFX8-NEXT: s_waitcnt vmcnt(0) expcnt(0) lgkmcnt(0)
2162
- ; GFX8-NEXT: v_max_f16_sdwa v8, v4, v4 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2163
- ; GFX8-NEXT: v_max_f16_sdwa v9, v0, v0 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2164
- ; GFX8-NEXT: v_max_f16_e32 v4, v4, v4
2165
- ; GFX8-NEXT: v_max_f16_e32 v0, v0, v0
2162
+ ; GFX8-NEXT: v_max_f16_sdwa v8, v7, v7 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2163
+ ; GFX8-NEXT: v_max_f16_sdwa v9, v3, v3 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2166
2164
; GFX8-NEXT: v_max_f16_sdwa v8, v9, v8 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2167
- ; GFX8-NEXT: v_max_f16_e32 v0, v0, v4
2168
- ; GFX8-NEXT: v_or_b32_e32 v0, v0, v8
2169
- ; GFX8-NEXT: v_max_f16_sdwa v4, v5, v5 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2170
- ; GFX8-NEXT: v_max_f16_sdwa v8, v1, v1 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2165
+ ; GFX8-NEXT: v_max_f16_sdwa v9, v6, v6 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2166
+ ; GFX8-NEXT: v_max_f16_sdwa v10, v2, v2 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2167
+ ; GFX8-NEXT: v_max_f16_sdwa v9, v10, v9 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2168
+ ; GFX8-NEXT: v_max_f16_sdwa v10, v5, v5 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2169
+ ; GFX8-NEXT: v_max_f16_sdwa v11, v1, v1 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2170
+ ; GFX8-NEXT: v_max_f16_sdwa v10, v11, v10 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2171
+ ; GFX8-NEXT: v_max_f16_sdwa v11, v4, v4 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2172
+ ; GFX8-NEXT: v_max_f16_sdwa v12, v0, v0 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2173
+ ; GFX8-NEXT: v_max_f16_e32 v7, v7, v7
2174
+ ; GFX8-NEXT: v_max_f16_e32 v3, v3, v3
2175
+ ; GFX8-NEXT: v_max_f16_e32 v6, v6, v6
2176
+ ; GFX8-NEXT: v_max_f16_e32 v2, v2, v2
2171
2177
; GFX8-NEXT: v_max_f16_e32 v5, v5, v5
2172
2178
; GFX8-NEXT: v_max_f16_e32 v1, v1, v1
2173
- ; GFX8-NEXT: v_max_f16_sdwa v4, v8, v4 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2179
+ ; GFX8-NEXT: v_max_f16_e32 v4, v4, v4
2180
+ ; GFX8-NEXT: v_max_f16_e32 v0, v0, v0
2181
+ ; GFX8-NEXT: v_max_f16_sdwa v11, v12, v11 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2182
+ ; GFX8-NEXT: v_max_f16_e32 v3, v3, v7
2183
+ ; GFX8-NEXT: v_max_f16_e32 v2, v2, v6
2174
2184
; GFX8-NEXT: v_max_f16_e32 v1, v1, v5
2175
- ; GFX8-NEXT: v_or_b32_e32 v1, v1, v4
2176
- ; GFX8-NEXT: v_max_f16_sdwa v4, v6, v6 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2177
- ; GFX8-NEXT: v_max_f16_sdwa v5, v2, v2 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2178
- ; GFX8-NEXT: v_max_f16_sdwa v4, v5, v4 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2179
- ; GFX8-NEXT: v_max_f16_e32 v5, v6, v6
2180
- ; GFX8-NEXT: v_max_f16_e32 v2, v2, v2
2181
- ; GFX8-NEXT: v_max_f16_e32 v2, v2, v5
2182
- ; GFX8-NEXT: v_or_b32_e32 v2, v2, v4
2183
- ; GFX8-NEXT: v_max_f16_sdwa v4, v7, v7 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2184
- ; GFX8-NEXT: v_max_f16_sdwa v5, v3, v3 dst_sel:DWORD dst_unused:UNUSED_PAD src0_sel:WORD_1 src1_sel:WORD_1
2185
- ; GFX8-NEXT: v_max_f16_sdwa v4, v5, v4 dst_sel:WORD_1 dst_unused:UNUSED_PAD src0_sel:DWORD src1_sel:DWORD
2186
- ; GFX8-NEXT: v_max_f16_e32 v5, v7, v7
2187
- ; GFX8-NEXT: v_max_f16_e32 v3, v3, v3
2188
- ; GFX8-NEXT: v_max_f16_e32 v3, v3, v5
2189
- ; GFX8-NEXT: v_or_b32_e32 v3, v3, v4
2185
+ ; GFX8-NEXT: v_max_f16_e32 v0, v0, v4
2186
+ ; GFX8-NEXT: v_or_b32_e32 v0, v0, v11
2187
+ ; GFX8-NEXT: v_or_b32_e32 v1, v1, v10
2188
+ ; GFX8-NEXT: v_or_b32_e32 v2, v2, v9
2189
+ ; GFX8-NEXT: v_or_b32_e32 v3, v3, v8
2190
2190
; GFX8-NEXT: s_setpc_b64 s[30:31]
2191
2191
;
2192
2192
; GFX9-LABEL: v_maximumnum_v8f16:
0 commit comments