//===- unittests/SPIRV/CodeGenSPIRVTest.cpp ---- Run CodeGenSPIRV tests ---===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include "FileTestFixture.h" #include "WholeFileTestFixture.h" namespace { using clang::spirv::FileTest; using clang::spirv::WholeFileTest; // === Whole output tests === TEST_F(WholeFileTest, EmptyVoidMain) { runWholeFileTest("empty-void-main.hlsl2spv", /*generateHeader*/ true); } TEST_F(WholeFileTest, PassThruPixelShader) { runWholeFileTest("passthru-ps.hlsl2spv", /*generateHeader*/ true); } TEST_F(WholeFileTest, PassThruVertexShader) { runWholeFileTest("passthru-vs.hlsl2spv", /*generateHeader*/ true); } TEST_F(WholeFileTest, ConstantPixelShader) { runWholeFileTest("constant-ps.hlsl2spv", /*generateHeader*/ true); } // === Partial output tests === // For types TEST_F(FileTest, ScalarTypes) { runFileTest("type.scalar.hlsl"); } TEST_F(FileTest, VectorTypes) { runFileTest("type.vector.hlsl"); } TEST_F(FileTest, MatrixTypes) { runFileTest("type.matrix.hlsl"); } TEST_F(FileTest, TypedefTypes) { runFileTest("type.typedef.hlsl"); } // For constants TEST_F(FileTest, ScalarConstants) { runFileTest("constant.scalar.hlsl"); } TEST_F(FileTest, VectorConstants) { runFileTest("constant.vector.hlsl"); } // For variables TEST_F(FileTest, VarInit) { runFileTest("var.init.hlsl"); } TEST_F(FileTest, VarInitMatrixMxN) { runFileTest("var.init.matrix.mxn.hlsl"); } TEST_F(FileTest, VarInitMatrixMx1) { runFileTest("var.init.matrix.mx1.hlsl"); } TEST_F(FileTest, VarInitMatrix1xN) { runFileTest("var.init.matrix.1xn.hlsl"); } TEST_F(FileTest, VarInitMatrix1x1) { runFileTest("var.init.matrix.1x1.hlsl"); } TEST_F(FileTest, StaticVar) { runFileTest("var.static.hlsl"); } // For prefix/postfix increment/decrement TEST_F(FileTest, UnaryOpPrefixIncrement) { runFileTest("unary-op.prefix-inc.hlsl"); } TEST_F(FileTest, UnaryOpPrefixIncrementMatrix) { runFileTest("unary-op.prefix-inc.matrix.hlsl"); } TEST_F(FileTest, UnaryOpPrefixDecrement) { runFileTest("unary-op.prefix-dec.hlsl"); } TEST_F(FileTest, UnaryOpPrefixDecrementMatrix) { runFileTest("unary-op.prefix-dec.matrix.hlsl"); } TEST_F(FileTest, UnaryOpPostfixIncrement) { runFileTest("unary-op.postfix-inc.hlsl"); } TEST_F(FileTest, UnaryOpPostfixIncrementMatrix) { runFileTest("unary-op.postfix-inc.matrix.hlsl"); } TEST_F(FileTest, UnaryOpPostfixDecrement) { runFileTest("unary-op.postfix-dec.hlsl"); } TEST_F(FileTest, UnaryOpPostfixDecrementMatrix) { runFileTest("unary-op.postfix-dec.matrix.hlsl"); } // For unary operators TEST_F(FileTest, UnaryOpPlus) { runFileTest("unary-op.plus.hlsl"); } TEST_F(FileTest, UnaryOpMinus) { runFileTest("unary-op.minus.hlsl"); } TEST_F(FileTest, UnaryOpLogicalNot) { runFileTest("unary-op.logical-not.hlsl"); } // For assignments TEST_F(FileTest, BinaryOpAssign) { runFileTest("binary-op.assign.hlsl"); } // For arithmetic binary operators TEST_F(FileTest, BinaryOpScalarArithmetic) { runFileTest("binary-op.arithmetic.scalar.hlsl"); } TEST_F(FileTest, BinaryOpVectorArithmetic) { runFileTest("binary-op.arithmetic.vector.hlsl"); } TEST_F(FileTest, BinaryOpMatrixArithmetic) { runFileTest("binary-op.arithmetic.matrix.hlsl"); } TEST_F(FileTest, BinaryOpMixedArithmetic) { runFileTest("binary-op.arithmetic.mixed.hlsl"); } // For arithmetic assignments TEST_F(FileTest, BinaryOpScalarArithAssign) { runFileTest("binary-op.arith-assign.scalar.hlsl"); } TEST_F(FileTest, BinaryOpVectorArithAssign) { runFileTest("binary-op.arith-assign.vector.hlsl"); } TEST_F(FileTest, BinaryOpMatrixArithAssign) { runFileTest("binary-op.arith-assign.matrix.hlsl"); } TEST_F(FileTest, BinaryOpMixedArithAssign) { runFileTest("binary-op.arith-assign.mixed.hlsl"); } // For bitwise binary operators TEST_F(FileTest, BinaryOpScalarBitwise) { runFileTest("binary-op.bitwise.scalar.hlsl"); } TEST_F(FileTest, BinaryOpVectorBitwise) { runFileTest("binary-op.bitwise.vector.hlsl"); } // For bitwise assignments TEST_F(FileTest, BinaryOpScalarBitwiseAssign) { runFileTest("binary-op.bitwise-assign.scalar.hlsl"); } TEST_F(FileTest, BinaryOpVectorBitwiseAssign) { runFileTest("binary-op.bitwise-assign.vector.hlsl"); } // For comparison operators TEST_F(FileTest, BinaryOpScalarComparison) { runFileTest("binary-op.comparison.scalar.hlsl"); } TEST_F(FileTest, BinaryOpVectorComparison) { runFileTest("binary-op.comparison.vector.hlsl"); } // For logical binary operators TEST_F(FileTest, BinaryOpLogicalAnd) { runFileTest("binary-op.logical-and.hlsl"); } TEST_F(FileTest, BinaryOpLogicalOr) { runFileTest("binary-op.logical-or.hlsl"); } // For ternary operators TEST_F(FileTest, TernaryOpConditionalOp) { runFileTest("ternary-op.cond-op.hlsl"); } // For vector accessing/swizzling operators TEST_F(FileTest, OpVectorSwizzle) { runFileTest("op.vector.swizzle.hlsl"); } TEST_F(FileTest, OpVectorSize1Swizzle) { runFileTest("op.vector.swizzle.size1.hlsl"); } TEST_F(FileTest, OpVectorAccess) { runFileTest("op.vector.access.hlsl"); } // For matrix accessing/swizzling operators TEST_F(FileTest, OpMatrixAccessMxN) { runFileTest("op.matrix.access.mxn.hlsl"); } TEST_F(FileTest, OpMatrixAccessMx1) { runFileTest("op.matrix.access.mx1.hlsl"); } TEST_F(FileTest, OpMatrixAccess1xN) { runFileTest("op.matrix.access.1xn.hlsl"); } TEST_F(FileTest, OpMatrixAccess1x1) { runFileTest("op.matrix.access.1x1.hlsl"); } // For casting TEST_F(FileTest, CastNoOp) { runFileTest("cast.no-op.hlsl"); } TEST_F(FileTest, CastImplicit2Bool) { runFileTest("cast.2bool.implicit.hlsl"); } TEST_F(FileTest, CastExplicit2Bool) { runFileTest("cast.2bool.explicit.hlsl"); } TEST_F(FileTest, CastImplicit2SInt) { runFileTest("cast.2sint.implicit.hlsl"); } TEST_F(FileTest, CastExplicit2SInt) { runFileTest("cast.2sint.explicit.hlsl"); } TEST_F(FileTest, CastImplicit2UInt) { runFileTest("cast.2uint.implicit.hlsl"); } TEST_F(FileTest, CastExplicit2UInt) { runFileTest("cast.2uint.explicit.hlsl"); } TEST_F(FileTest, CastImplicit2FP) { runFileTest("cast.2fp.implicit.hlsl"); } TEST_F(FileTest, CastExplicit2FP) { runFileTest("cast.2fp.explicit.hlsl"); } // For vector/matrix splatting and trunction TEST_F(FileTest, CastTruncateVector) { runFileTest("cast.vector.trunc.hlsl"); } TEST_F(FileTest, CastSplatVector) { runFileTest("cast.vector.splat.hlsl"); } TEST_F(FileTest, CastSplatMatrix) { runFileTest("cast.matrix.splat.hlsl"); } // For if statements TEST_F(FileTest, IfStmtPlainAssign) { runFileTest("if-stmt.plain.hlsl"); } TEST_F(FileTest, IfStmtNestedIfStmt) { runFileTest("if-stmt.nested.hlsl"); } // For switch statements TEST_F(FileTest, SwitchStmtUsingOpSwitch) { runFileTest("switch-stmt.opswitch.hlsl"); } TEST_F(FileTest, SwitchStmtUsingIfStmt) { runFileTest("switch-stmt.ifstmt.hlsl"); } // For for statements TEST_F(FileTest, ForStmtPlainAssign) { runFileTest("for-stmt.plain.hlsl"); } TEST_F(FileTest, ForStmtNestedForStmt) { runFileTest("for-stmt.nested.hlsl"); } // For while statements TEST_F(FileTest, WhileStmtPlain) { runFileTest("while-stmt.plain.hlsl"); } TEST_F(FileTest, WhileStmtNested) { runFileTest("while-stmt.nested.hlsl"); } // For do statements TEST_F(FileTest, DoStmtPlain) { runFileTest("do-stmt.plain.hlsl"); } TEST_F(FileTest, DoStmtNested) { runFileTest("do-stmt.nested.hlsl"); } // For control flows TEST_F(FileTest, ControlFlowNestedIfForStmt) { runFileTest("cf.if.for.hlsl"); } TEST_F(FileTest, ControlFlowLogicalAnd) { runFileTest("cf.logical-and.hlsl"); } TEST_F(FileTest, ControlFlowLogicalOr) { runFileTest("cf.logical-or.hlsl"); } TEST_F(FileTest, ControlFlowConditionalOp) { runFileTest("cf.cond-op.hlsl"); } // For function calls TEST_F(FileTest, FunctionCall) { runFileTest("fn.call.hlsl"); } // For semantics TEST_F(FileTest, SemanticPositionVS) { runFileTest("semantic.position.vs.hlsl"); } TEST_F(FileTest, SemanticPositionPS) { runFileTest("semantic.position.ps.hlsl"); } TEST_F(FileTest, SemanticVertexIDVS) { runFileTest("semantic.vertex-id.vs.hlsl"); } TEST_F(FileTest, SemanticInstanceIDVS) { runFileTest("semantic.instance-id.vs.hlsl"); } TEST_F(FileTest, SemanticInstanceIDPS) { runFileTest("semantic.instance-id.ps.hlsl"); } TEST_F(FileTest, SemanticTargetPS) { runFileTest("semantic.target.ps.hlsl"); } TEST_F(FileTest, SemanticDepthPS) { runFileTest("semantic.depth.ps.hlsl"); } TEST_F(FileTest, SemanticArbitrary) { runFileTest("semantic.arbitrary.hlsl"); } // For intrinsic functions TEST_F(FileTest, IntrinsicsDot) { runFileTest("intrinsics.dot.hlsl"); } TEST_F(FileTest, IntrinsicsAll) { runFileTest("intrinsics.all.hlsl"); } TEST_F(FileTest, IntrinsicsAny) { runFileTest("intrinsics.any.hlsl"); } TEST_F(FileTest, IntrinsicsAsfloat) { runFileTest("intrinsics.asfloat.hlsl"); } TEST_F(FileTest, IntrinsicsAsint) { runFileTest("intrinsics.asint.hlsl"); } TEST_F(FileTest, IntrinsicsAsuint) { runFileTest("intrinsics.asuint.hlsl"); } TEST_F(FileTest, IntrinsicsRound) { runFileTest("intrinsics.round.hlsl"); } TEST_F(FileTest, IntrinsicsAbs) { runFileTest("intrinsics.abs.hlsl"); } TEST_F(FileTest, IntrinsicsCeil) { runFileTest("intrinsics.ceil.hlsl"); } TEST_F(FileTest, IntrinsicsDegrees) { runFileTest("intrinsics.degrees.hlsl"); } TEST_F(FileTest, IntrinsicsRadians) { runFileTest("intrinsics.radians.hlsl"); } TEST_F(FileTest, IntrinsicsDeterminant) { runFileTest("intrinsics.determinant.hlsl"); } TEST_F(FileTest, IntrinsicsExp) { runFileTest("intrinsics.exp.hlsl"); } TEST_F(FileTest, IntrinsicsExp2) { runFileTest("intrinsics.exp2.hlsl"); } TEST_F(FileTest, IntrinsicsFloor) { runFileTest("intrinsics.floor.hlsl"); } TEST_F(FileTest, IntrinsicsLength) { runFileTest("intrinsics.length.hlsl"); } TEST_F(FileTest, IntrinsicsLog) { runFileTest("intrinsics.log.hlsl"); } TEST_F(FileTest, IntrinsicsLog2) { runFileTest("intrinsics.log2.hlsl"); } TEST_F(FileTest, IntrinsicsNormalize) { runFileTest("intrinsics.normalize.hlsl"); } TEST_F(FileTest, IntrinsicsRsqrt) { runFileTest("intrinsics.rsqrt.hlsl"); } TEST_F(FileTest, IntrinsicsFloatSign) { runFileTest("intrinsics.floatsign.hlsl"); } TEST_F(FileTest, IntrinsicsIntSign) { runFileTest("intrinsics.intsign.hlsl"); } TEST_F(FileTest, IntrinsicsSqrt) { runFileTest("intrinsics.sqrt.hlsl"); } TEST_F(FileTest, IntrinsicsTrunc) { runFileTest("intrinsics.trunc.hlsl"); } // For intrinsic trigonometric functions TEST_F(FileTest, IntrinsicsSin) { runFileTest("intrinsics.sin.hlsl"); } TEST_F(FileTest, IntrinsicsCos) { runFileTest("intrinsics.cos.hlsl"); } TEST_F(FileTest, IntrinsicsTan) { runFileTest("intrinsics.tan.hlsl"); } TEST_F(FileTest, IntrinsicsSinh) { runFileTest("intrinsics.sinh.hlsl"); } TEST_F(FileTest, IntrinsicsCosh) { runFileTest("intrinsics.cosh.hlsl"); } TEST_F(FileTest, IntrinsicsTanh) { runFileTest("intrinsics.tanh.hlsl"); } TEST_F(FileTest, IntrinsicsAsin) { runFileTest("intrinsics.asin.hlsl"); } TEST_F(FileTest, IntrinsicsAcos) { runFileTest("intrinsics.acos.hlsl"); } TEST_F(FileTest, IntrinsicsAtan) { runFileTest("intrinsics.atan.hlsl"); } // SPIR-V specific TEST_F(FileTest, SpirvStorageClass) { runFileTest("spirv.storage-class.hlsl"); } } // namespace