2021-02-05 20:11:23 -06:00
|
|
|
// Copyright 2021 yuzu Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2021-02-07 23:54:35 -06:00
|
|
|
#include <sirit/sirit.h>
|
|
|
|
|
|
|
|
#include "common/common_types.h"
|
2021-02-16 01:10:22 -06:00
|
|
|
#include "shader_recompiler/backend/spirv/emit_context.h"
|
2021-02-16 21:59:28 -06:00
|
|
|
#include "shader_recompiler/environment.h"
|
2021-02-05 20:11:23 -06:00
|
|
|
#include "shader_recompiler/frontend/ir/microinstruction.h"
|
|
|
|
#include "shader_recompiler/frontend/ir/program.h"
|
2021-02-20 00:30:13 -06:00
|
|
|
#include "shader_recompiler/profile.h"
|
2021-02-05 20:11:23 -06:00
|
|
|
|
|
|
|
namespace Shader::Backend::SPIRV {
|
|
|
|
|
2021-02-20 00:30:13 -06:00
|
|
|
[[nodiscard]] std::vector<u32> EmitSPIRV(const Profile& profile, Environment& env,
|
|
|
|
IR::Program& program);
|
2021-02-07 23:54:35 -06:00
|
|
|
|
2021-02-16 21:59:28 -06:00
|
|
|
// Microinstruction emitters
|
|
|
|
Id EmitPhi(EmitContext& ctx, IR::Inst* inst);
|
|
|
|
void EmitVoid(EmitContext& ctx);
|
|
|
|
Id EmitIdentity(EmitContext& ctx, const IR::Value& value);
|
|
|
|
void EmitBranch(EmitContext& ctx, IR::Block* label);
|
|
|
|
void EmitBranchConditional(EmitContext& ctx, Id condition, IR::Block* true_label,
|
|
|
|
IR::Block* false_label);
|
|
|
|
void EmitLoopMerge(EmitContext& ctx, IR::Block* merge_label, IR::Block* continue_label);
|
|
|
|
void EmitSelectionMerge(EmitContext& ctx, IR::Block* merge_label);
|
|
|
|
void EmitReturn(EmitContext& ctx);
|
|
|
|
void EmitGetRegister(EmitContext& ctx);
|
|
|
|
void EmitSetRegister(EmitContext& ctx);
|
|
|
|
void EmitGetPred(EmitContext& ctx);
|
|
|
|
void EmitSetPred(EmitContext& ctx);
|
|
|
|
void EmitSetGotoVariable(EmitContext& ctx);
|
|
|
|
void EmitGetGotoVariable(EmitContext& ctx);
|
|
|
|
Id EmitGetCbuf(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset);
|
|
|
|
void EmitGetAttribute(EmitContext& ctx);
|
|
|
|
void EmitSetAttribute(EmitContext& ctx);
|
|
|
|
void EmitGetAttributeIndexed(EmitContext& ctx);
|
|
|
|
void EmitSetAttributeIndexed(EmitContext& ctx);
|
|
|
|
void EmitGetZFlag(EmitContext& ctx);
|
|
|
|
void EmitGetSFlag(EmitContext& ctx);
|
|
|
|
void EmitGetCFlag(EmitContext& ctx);
|
|
|
|
void EmitGetOFlag(EmitContext& ctx);
|
|
|
|
void EmitSetZFlag(EmitContext& ctx);
|
|
|
|
void EmitSetSFlag(EmitContext& ctx);
|
|
|
|
void EmitSetCFlag(EmitContext& ctx);
|
|
|
|
void EmitSetOFlag(EmitContext& ctx);
|
|
|
|
Id EmitWorkgroupId(EmitContext& ctx);
|
|
|
|
Id EmitLocalInvocationId(EmitContext& ctx);
|
|
|
|
Id EmitUndefU1(EmitContext& ctx);
|
|
|
|
Id EmitUndefU8(EmitContext& ctx);
|
|
|
|
Id EmitUndefU16(EmitContext& ctx);
|
|
|
|
Id EmitUndefU32(EmitContext& ctx);
|
|
|
|
Id EmitUndefU64(EmitContext& ctx);
|
|
|
|
void EmitLoadGlobalU8(EmitContext& ctx);
|
|
|
|
void EmitLoadGlobalS8(EmitContext& ctx);
|
|
|
|
void EmitLoadGlobalU16(EmitContext& ctx);
|
|
|
|
void EmitLoadGlobalS16(EmitContext& ctx);
|
|
|
|
void EmitLoadGlobal32(EmitContext& ctx);
|
|
|
|
void EmitLoadGlobal64(EmitContext& ctx);
|
|
|
|
void EmitLoadGlobal128(EmitContext& ctx);
|
|
|
|
void EmitWriteGlobalU8(EmitContext& ctx);
|
|
|
|
void EmitWriteGlobalS8(EmitContext& ctx);
|
|
|
|
void EmitWriteGlobalU16(EmitContext& ctx);
|
|
|
|
void EmitWriteGlobalS16(EmitContext& ctx);
|
|
|
|
void EmitWriteGlobal32(EmitContext& ctx);
|
|
|
|
void EmitWriteGlobal64(EmitContext& ctx);
|
|
|
|
void EmitWriteGlobal128(EmitContext& ctx);
|
|
|
|
void EmitLoadStorageU8(EmitContext& ctx);
|
|
|
|
void EmitLoadStorageS8(EmitContext& ctx);
|
|
|
|
void EmitLoadStorageU16(EmitContext& ctx);
|
|
|
|
void EmitLoadStorageS16(EmitContext& ctx);
|
|
|
|
Id EmitLoadStorage32(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset);
|
|
|
|
void EmitLoadStorage64(EmitContext& ctx);
|
|
|
|
void EmitLoadStorage128(EmitContext& ctx);
|
|
|
|
void EmitWriteStorageU8(EmitContext& ctx);
|
|
|
|
void EmitWriteStorageS8(EmitContext& ctx);
|
|
|
|
void EmitWriteStorageU16(EmitContext& ctx);
|
|
|
|
void EmitWriteStorageS16(EmitContext& ctx);
|
|
|
|
void EmitWriteStorage32(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset,
|
|
|
|
Id value);
|
2021-02-19 15:10:18 -06:00
|
|
|
void EmitWriteStorage64(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset,
|
|
|
|
Id value);
|
2021-02-16 21:59:28 -06:00
|
|
|
void EmitWriteStorage128(EmitContext& ctx);
|
2021-02-19 15:10:18 -06:00
|
|
|
Id EmitCompositeConstructU32x2(EmitContext& ctx, Id e1, Id e2);
|
|
|
|
Id EmitCompositeConstructU32x3(EmitContext& ctx, Id e1, Id e2, Id e3);
|
|
|
|
Id EmitCompositeConstructU32x4(EmitContext& ctx, Id e1, Id e2, Id e3, Id e4);
|
|
|
|
Id EmitCompositeExtractU32x2(EmitContext& ctx, Id composite, u32 index);
|
|
|
|
Id EmitCompositeExtractU32x3(EmitContext& ctx, Id composite, u32 index);
|
|
|
|
Id EmitCompositeExtractU32x4(EmitContext& ctx, Id composite, u32 index);
|
2021-02-16 21:59:28 -06:00
|
|
|
void EmitCompositeConstructF16x2(EmitContext& ctx);
|
|
|
|
void EmitCompositeConstructF16x3(EmitContext& ctx);
|
|
|
|
void EmitCompositeConstructF16x4(EmitContext& ctx);
|
2021-02-19 15:10:18 -06:00
|
|
|
Id EmitCompositeExtractF16x2(EmitContext& ctx, Id composite, u32 index);
|
|
|
|
Id EmitCompositeExtractF16x3(EmitContext& ctx, Id composite, u32 index);
|
|
|
|
Id EmitCompositeExtractF16x4(EmitContext& ctx, Id composite, u32 index);
|
2021-02-16 21:59:28 -06:00
|
|
|
void EmitCompositeConstructF32x2(EmitContext& ctx);
|
|
|
|
void EmitCompositeConstructF32x3(EmitContext& ctx);
|
|
|
|
void EmitCompositeConstructF32x4(EmitContext& ctx);
|
2021-02-19 15:10:18 -06:00
|
|
|
Id EmitCompositeExtractF32x2(EmitContext& ctx, Id composite, u32 index);
|
|
|
|
Id EmitCompositeExtractF32x3(EmitContext& ctx, Id composite, u32 index);
|
|
|
|
Id EmitCompositeExtractF32x4(EmitContext& ctx, Id composite, u32 index);
|
2021-02-16 21:59:28 -06:00
|
|
|
void EmitCompositeConstructF64x2(EmitContext& ctx);
|
|
|
|
void EmitCompositeConstructF64x3(EmitContext& ctx);
|
|
|
|
void EmitCompositeConstructF64x4(EmitContext& ctx);
|
|
|
|
void EmitCompositeExtractF64x2(EmitContext& ctx);
|
|
|
|
void EmitCompositeExtractF64x3(EmitContext& ctx);
|
|
|
|
void EmitCompositeExtractF64x4(EmitContext& ctx);
|
|
|
|
void EmitSelect8(EmitContext& ctx);
|
|
|
|
void EmitSelect16(EmitContext& ctx);
|
2021-02-21 14:50:14 -06:00
|
|
|
Id EmitSelect32(EmitContext& ctx, Id cond, Id true_value, Id false_value);
|
2021-02-16 21:59:28 -06:00
|
|
|
void EmitSelect64(EmitContext& ctx);
|
|
|
|
void EmitBitCastU16F16(EmitContext& ctx);
|
|
|
|
Id EmitBitCastU32F32(EmitContext& ctx, Id value);
|
|
|
|
void EmitBitCastU64F64(EmitContext& ctx);
|
|
|
|
void EmitBitCastF16U16(EmitContext& ctx);
|
|
|
|
Id EmitBitCastF32U32(EmitContext& ctx, Id value);
|
|
|
|
void EmitBitCastF64U64(EmitContext& ctx);
|
|
|
|
void EmitPackUint2x32(EmitContext& ctx);
|
2021-02-19 15:10:18 -06:00
|
|
|
Id EmitUnpackUint2x32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitPackFloat2x16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitUnpackFloat2x16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitPackHalf2x16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitUnpackHalf2x16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitPackDouble2x32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitUnpackDouble2x32(EmitContext& ctx, Id value);
|
2021-02-16 21:59:28 -06:00
|
|
|
void EmitGetZeroFromOp(EmitContext& ctx);
|
|
|
|
void EmitGetSignFromOp(EmitContext& ctx);
|
|
|
|
void EmitGetCarryFromOp(EmitContext& ctx);
|
|
|
|
void EmitGetOverflowFromOp(EmitContext& ctx);
|
2021-02-21 14:50:14 -06:00
|
|
|
Id EmitFPAbs16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPAbs32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPAbs64(EmitContext& ctx, Id value);
|
2021-02-16 21:59:28 -06:00
|
|
|
Id EmitFPAdd16(EmitContext& ctx, IR::Inst* inst, Id a, Id b);
|
|
|
|
Id EmitFPAdd32(EmitContext& ctx, IR::Inst* inst, Id a, Id b);
|
|
|
|
Id EmitFPAdd64(EmitContext& ctx, IR::Inst* inst, Id a, Id b);
|
|
|
|
Id EmitFPFma16(EmitContext& ctx, IR::Inst* inst, Id a, Id b, Id c);
|
|
|
|
Id EmitFPFma32(EmitContext& ctx, IR::Inst* inst, Id a, Id b, Id c);
|
|
|
|
Id EmitFPFma64(EmitContext& ctx, IR::Inst* inst, Id a, Id b, Id c);
|
|
|
|
void EmitFPMax32(EmitContext& ctx);
|
|
|
|
void EmitFPMax64(EmitContext& ctx);
|
|
|
|
void EmitFPMin32(EmitContext& ctx);
|
|
|
|
void EmitFPMin64(EmitContext& ctx);
|
|
|
|
Id EmitFPMul16(EmitContext& ctx, IR::Inst* inst, Id a, Id b);
|
|
|
|
Id EmitFPMul32(EmitContext& ctx, IR::Inst* inst, Id a, Id b);
|
|
|
|
Id EmitFPMul64(EmitContext& ctx, IR::Inst* inst, Id a, Id b);
|
2021-02-21 14:50:14 -06:00
|
|
|
Id EmitFPNeg16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPNeg32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPNeg64(EmitContext& ctx, Id value);
|
2021-02-16 21:59:28 -06:00
|
|
|
void EmitFPRecip32(EmitContext& ctx);
|
|
|
|
void EmitFPRecip64(EmitContext& ctx);
|
|
|
|
void EmitFPRecipSqrt32(EmitContext& ctx);
|
|
|
|
void EmitFPRecipSqrt64(EmitContext& ctx);
|
|
|
|
void EmitFPSqrt(EmitContext& ctx);
|
|
|
|
void EmitFPSin(EmitContext& ctx);
|
|
|
|
void EmitFPSinNotReduced(EmitContext& ctx);
|
|
|
|
void EmitFPExp2(EmitContext& ctx);
|
|
|
|
void EmitFPExp2NotReduced(EmitContext& ctx);
|
|
|
|
void EmitFPCos(EmitContext& ctx);
|
|
|
|
void EmitFPCosNotReduced(EmitContext& ctx);
|
|
|
|
void EmitFPLog2(EmitContext& ctx);
|
2021-02-21 14:50:14 -06:00
|
|
|
Id EmitFPSaturate16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPSaturate32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPSaturate64(EmitContext& ctx, Id value);
|
2021-02-19 15:10:18 -06:00
|
|
|
Id EmitFPRoundEven16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPRoundEven32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPRoundEven64(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPFloor16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPFloor32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPFloor64(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPCeil16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPCeil32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPCeil64(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPTrunc16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPTrunc32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitFPTrunc64(EmitContext& ctx, Id value);
|
2021-02-16 21:59:28 -06:00
|
|
|
Id EmitIAdd32(EmitContext& ctx, IR::Inst* inst, Id a, Id b);
|
|
|
|
void EmitIAdd64(EmitContext& ctx);
|
|
|
|
Id EmitISub32(EmitContext& ctx, Id a, Id b);
|
|
|
|
void EmitISub64(EmitContext& ctx);
|
|
|
|
Id EmitIMul32(EmitContext& ctx, Id a, Id b);
|
|
|
|
void EmitINeg32(EmitContext& ctx);
|
|
|
|
void EmitIAbs32(EmitContext& ctx);
|
|
|
|
Id EmitShiftLeftLogical32(EmitContext& ctx, Id base, Id shift);
|
|
|
|
void EmitShiftRightLogical32(EmitContext& ctx);
|
|
|
|
void EmitShiftRightArithmetic32(EmitContext& ctx);
|
2021-02-21 14:50:14 -06:00
|
|
|
Id EmitBitwiseAnd32(EmitContext& ctx, Id a, Id b);
|
|
|
|
Id EmitBitwiseOr32(EmitContext& ctx, Id a, Id b);
|
|
|
|
Id EmitBitwiseXor32(EmitContext& ctx, Id a, Id b);
|
2021-02-16 21:59:28 -06:00
|
|
|
void EmitBitFieldInsert(EmitContext& ctx);
|
|
|
|
void EmitBitFieldSExtract(EmitContext& ctx);
|
|
|
|
Id EmitBitFieldUExtract(EmitContext& ctx, Id base, Id offset, Id count);
|
|
|
|
Id EmitSLessThan(EmitContext& ctx, Id lhs, Id rhs);
|
2021-02-21 14:50:14 -06:00
|
|
|
Id EmitULessThan(EmitContext& ctx, Id lhs, Id rhs);
|
|
|
|
Id EmitIEqual(EmitContext& ctx, Id lhs, Id rhs);
|
|
|
|
Id EmitSLessThanEqual(EmitContext& ctx, Id lhs, Id rhs);
|
|
|
|
Id EmitULessThanEqual(EmitContext& ctx, Id lhs, Id rhs);
|
2021-02-16 21:59:28 -06:00
|
|
|
Id EmitSGreaterThan(EmitContext& ctx, Id lhs, Id rhs);
|
2021-02-21 14:50:14 -06:00
|
|
|
Id EmitUGreaterThan(EmitContext& ctx, Id lhs, Id rhs);
|
|
|
|
Id EmitINotEqual(EmitContext& ctx, Id lhs, Id rhs);
|
|
|
|
Id EmitSGreaterThanEqual(EmitContext& ctx, Id lhs, Id rhs);
|
2021-02-16 21:59:28 -06:00
|
|
|
Id EmitUGreaterThanEqual(EmitContext& ctx, Id lhs, Id rhs);
|
2021-02-21 20:42:38 -06:00
|
|
|
Id EmitLogicalOr(EmitContext& ctx, Id a, Id b);
|
|
|
|
Id EmitLogicalAnd(EmitContext& ctx, Id a, Id b);
|
|
|
|
Id EmitLogicalXor(EmitContext& ctx, Id a, Id b);
|
|
|
|
Id EmitLogicalNot(EmitContext& ctx, Id value);
|
2021-02-19 15:10:18 -06:00
|
|
|
Id EmitConvertS16F16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertS16F32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertS16F64(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertS32F16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertS32F32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertS32F64(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertS64F16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertS64F32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertS64F64(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU16F16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU16F32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU16F64(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU32F16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU32F32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU32F64(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU64F16(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU64F32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU64F64(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU64U32(EmitContext& ctx, Id value);
|
|
|
|
Id EmitConvertU32U64(EmitContext& ctx, Id value);
|
2021-02-05 20:11:23 -06:00
|
|
|
|
|
|
|
} // namespace Shader::Backend::SPIRV
|