77 lines
2.6 KiB
TableGen
77 lines
2.6 KiB
TableGen
//==- SPIRVCanonicalization.td - Canonicalization Patterns ---*- tablegen -*==//
|
|
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines SPIR-V canonicalization patterns.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
include "mlir/IR/PatternBase.td"
|
|
include "mlir/Dialect/SPIRV/IR/SPIRVOps.td"
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// spirv.LogicalNot
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
def ConvertLogicalNotOfIEqual : Pat<
|
|
(SPIRV_LogicalNotOp (SPIRV_IEqualOp $lhs, $rhs)),
|
|
(SPIRV_INotEqualOp $lhs, $rhs)>;
|
|
|
|
def ConvertLogicalNotOfINotEqual : Pat<
|
|
(SPIRV_LogicalNotOp (SPIRV_INotEqualOp $lhs, $rhs)),
|
|
(SPIRV_IEqualOp $lhs, $rhs)>;
|
|
|
|
def ConvertLogicalNotOfLogicalEqual : Pat<
|
|
(SPIRV_LogicalNotOp (SPIRV_LogicalEqualOp $lhs, $rhs)),
|
|
(SPIRV_LogicalNotEqualOp $lhs, $rhs)>;
|
|
|
|
def ConvertLogicalNotOfLogicalNotEqual : Pat<
|
|
(SPIRV_LogicalNotOp (SPIRV_LogicalNotEqualOp $lhs, $rhs)),
|
|
(SPIRV_LogicalEqualOp $lhs, $rhs)>;
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// spirv.Select -> spirv.GL.*Clamp
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
def ValuesAreEqual : Constraint<CPred<"$0 == $1">>;
|
|
|
|
foreach CmpClampPair = [
|
|
[SPIRV_FOrdLessThanOp, SPIRV_GLFClampOp],
|
|
[SPIRV_FOrdLessThanEqualOp, SPIRV_GLFClampOp],
|
|
[SPIRV_SLessThanOp, SPIRV_GLSClampOp],
|
|
[SPIRV_SLessThanEqualOp, SPIRV_GLSClampOp],
|
|
[SPIRV_ULessThanOp, SPIRV_GLUClampOp],
|
|
[SPIRV_ULessThanEqualOp, SPIRV_GLUClampOp]] in {
|
|
|
|
// Detect: $min < $input, $input < $max
|
|
def ConvertComparisonIntoClamp1_#CmpClampPair[0] : Pat<
|
|
(SPIRV_SelectOp
|
|
(CmpClampPair[0]
|
|
(SPIRV_SelectOp:$middle0
|
|
(CmpClampPair[0] $min, $input),
|
|
$input,
|
|
$min
|
|
),
|
|
$max
|
|
),
|
|
$middle1,
|
|
$max),
|
|
(CmpClampPair[1] $input, $min, $max),
|
|
[(ValuesAreEqual $middle0, $middle1)]>;
|
|
|
|
// Detect: $input < $min, $max < $input
|
|
def ConvertComparisonIntoClamp2_#CmpClampPair[0] : Pat<
|
|
(SPIRV_SelectOp
|
|
(CmpClampPair[0] $max, $input),
|
|
$max,
|
|
(SPIRV_SelectOp
|
|
(CmpClampPair[0] $input, $min),
|
|
$min,
|
|
$input
|
|
)),
|
|
(CmpClampPair[1] $input, $min, $max)>;
|
|
}
|