mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 03:02:36 +01:00
eb7eabd7be
Replace the clang builtin function and LLVM intrinsic for f32x4.demote_zero_f64x2 with combines from normal SDNodes. Also add missing combines for i32x4.trunc_sat_zero_f64x2_{s,u}, which share the same pattern. Differential Revision: https://reviews.llvm.org/D105755
53 lines
1.6 KiB
C++
53 lines
1.6 KiB
C++
//- WebAssemblyISD.def - WebAssembly ISD ---------------------------*- C++ -*-//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
///
|
|
/// \file
|
|
/// This file describes the various WebAssembly ISD node types.
|
|
///
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// NOTE: NO INCLUDE GUARD DESIRED!
|
|
|
|
HANDLE_NODETYPE(CALL)
|
|
HANDLE_NODETYPE(RET_CALL)
|
|
HANDLE_NODETYPE(RETURN)
|
|
HANDLE_NODETYPE(ARGUMENT)
|
|
HANDLE_NODETYPE(LOCAL_GET)
|
|
HANDLE_NODETYPE(LOCAL_SET)
|
|
// A wrapper node for TargetExternalSymbol, TargetGlobalAddress, and MCSymbol
|
|
HANDLE_NODETYPE(Wrapper)
|
|
// A special wapper used in PIC code for __memory_base/__table_base relative
|
|
// access.
|
|
HANDLE_NODETYPE(WrapperPIC)
|
|
HANDLE_NODETYPE(BR_IF)
|
|
HANDLE_NODETYPE(BR_TABLE)
|
|
HANDLE_NODETYPE(SHUFFLE)
|
|
HANDLE_NODETYPE(SWIZZLE)
|
|
HANDLE_NODETYPE(VEC_SHL)
|
|
HANDLE_NODETYPE(VEC_SHR_S)
|
|
HANDLE_NODETYPE(VEC_SHR_U)
|
|
HANDLE_NODETYPE(EXTEND_LOW_S)
|
|
HANDLE_NODETYPE(EXTEND_LOW_U)
|
|
HANDLE_NODETYPE(EXTEND_HIGH_S)
|
|
HANDLE_NODETYPE(EXTEND_HIGH_U)
|
|
HANDLE_NODETYPE(CONVERT_LOW_S)
|
|
HANDLE_NODETYPE(CONVERT_LOW_U)
|
|
HANDLE_NODETYPE(PROMOTE_LOW)
|
|
HANDLE_NODETYPE(TRUNC_SAT_ZERO_S)
|
|
HANDLE_NODETYPE(TRUNC_SAT_ZERO_U)
|
|
HANDLE_NODETYPE(DEMOTE_ZERO)
|
|
HANDLE_NODETYPE(THROW)
|
|
HANDLE_NODETYPE(CATCH)
|
|
HANDLE_NODETYPE(MEMORY_COPY)
|
|
HANDLE_NODETYPE(MEMORY_FILL)
|
|
|
|
// Memory intrinsics
|
|
HANDLE_MEM_NODETYPE(LOAD_SPLAT)
|
|
HANDLE_MEM_NODETYPE(GLOBAL_GET)
|
|
HANDLE_MEM_NODETYPE(GLOBAL_SET)
|