2017-12-13 15:32:54 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "dxbc_enums.h"
|
|
|
|
|
|
|
|
namespace dxvk {
|
|
|
|
|
|
|
|
constexpr size_t DxbcMaxInterfaceRegs = 32;
|
|
|
|
constexpr size_t DxbcMaxOperandCount = 8;
|
|
|
|
|
2017-12-14 12:53:53 +01:00
|
|
|
/**
|
|
|
|
* \brief Operand kind
|
|
|
|
*
|
|
|
|
* In the instruction format definition, this specified
|
|
|
|
* whether an operand uses an actual operand token, or
|
|
|
|
* whether it is stored as an immediate value.
|
|
|
|
*/
|
2017-12-13 15:32:54 +01:00
|
|
|
enum class DxbcOperandKind {
|
|
|
|
DstReg, ///< Destination register
|
|
|
|
SrcReg, ///< Source register
|
|
|
|
Imm32, ///< Constant number
|
|
|
|
};
|
|
|
|
|
2017-12-14 12:53:53 +01:00
|
|
|
/**
|
|
|
|
* \brief Instruction class
|
|
|
|
*
|
|
|
|
* Instructions with a similar format are grouped into
|
|
|
|
* instruction classes in order to make implementing
|
|
|
|
* new instructions easier.
|
|
|
|
*/
|
2017-12-13 15:32:54 +01:00
|
|
|
enum class DxbcInstClass {
|
2018-03-01 12:08:06 +01:00
|
|
|
Declaration, ///< Interface or resource declaration
|
|
|
|
CustomData, ///< Immediate constant buffer
|
|
|
|
ControlFlow, ///< Control flow instructions
|
|
|
|
GeometryEmit, ///< Special geometry shader instructions
|
|
|
|
Atomic, ///< Atomic operations
|
|
|
|
AtomicCounter, ///< Atomic counter operations
|
|
|
|
Barrier, ///< Execution or memory barrier
|
|
|
|
BitExtract, ///< Bit field extract operations
|
|
|
|
BitInsert, ///< Bit field insert operations
|
2018-05-12 01:39:23 +02:00
|
|
|
BitScan, ///< Bit scan operations
|
2018-03-01 12:08:06 +01:00
|
|
|
BufferQuery, ///< Buffer query instruction
|
|
|
|
BufferLoad, ///< Structured or raw buffer load
|
|
|
|
BufferStore, ///< Structured or raw buffer store
|
|
|
|
ConvertFloat16, ///< 16-bit float packing/unpacking
|
2018-06-07 14:32:56 +02:00
|
|
|
ConvertFloat64, ///< 64-bit float conversion
|
2018-03-01 12:08:06 +01:00
|
|
|
HullShaderPhase, ///< Hull shader phase declaration
|
|
|
|
HullShaderInstCnt, ///< Hull shader phase instance count
|
|
|
|
Interpolate, ///< Input attribute interpolation
|
2018-04-11 01:49:39 +02:00
|
|
|
NoOperation, ///< The most useful instruction class
|
2018-03-01 12:08:06 +01:00
|
|
|
TextureQuery, ///< Texture query instruction
|
|
|
|
TextureQueryLod, ///< Texture LOD query instruction
|
|
|
|
TextureQueryMs, ///< Multisample texture query
|
2018-03-12 12:25:10 +01:00
|
|
|
TextureQueryMsPos, ///< Sample position query
|
2018-03-01 12:08:06 +01:00
|
|
|
TextureFetch, ///< Texture fetch instruction
|
|
|
|
TextureGather, ///< Texture gather instruction
|
|
|
|
TextureSample, ///< Texture sampling instruction
|
|
|
|
TypedUavLoad, ///< Typed UAV load
|
|
|
|
TypedUavStore, ///< Typed UAV store
|
|
|
|
VectorAlu, ///< Component-wise vector instructions
|
|
|
|
VectorCmov, ///< Component-wise conditional move
|
|
|
|
VectorCmp, ///< Component-wise vector comparison
|
|
|
|
VectorDeriv, ///< Vector derivatives
|
|
|
|
VectorDot, ///< Dot product instruction
|
|
|
|
VectorIdiv, ///< Component-wise integer division
|
|
|
|
VectorImul, ///< Component-wise integer multiplication
|
|
|
|
VectorShift, ///< Bit shift operations on vectors
|
|
|
|
VectorSinCos, ///< Sine and Cosine instruction
|
|
|
|
Undefined, ///< Instruction code not defined
|
2017-12-13 15:32:54 +01:00
|
|
|
};
|
|
|
|
|
2017-12-14 12:53:53 +01:00
|
|
|
/**
|
|
|
|
* \brief Instruction operand format
|
|
|
|
*
|
|
|
|
* Stores the kind and the expected data type
|
|
|
|
* of an operand. Used when parsing instructions.
|
|
|
|
*/
|
2017-12-13 15:32:54 +01:00
|
|
|
struct DxbcInstOperandFormat {
|
|
|
|
DxbcOperandKind kind;
|
|
|
|
DxbcScalarType type;
|
|
|
|
};
|
|
|
|
|
2017-12-14 12:53:53 +01:00
|
|
|
/**
|
|
|
|
* \brief Instruction format
|
|
|
|
*
|
|
|
|
* Defines the instruction class as well as
|
|
|
|
* the format of the insttruction operands.
|
|
|
|
*/
|
2017-12-13 15:32:54 +01:00
|
|
|
struct DxbcInstFormat {
|
|
|
|
uint32_t operandCount = 0;
|
|
|
|
DxbcInstClass instructionClass = DxbcInstClass::Undefined;
|
|
|
|
DxbcInstOperandFormat operands[DxbcMaxOperandCount];
|
|
|
|
};
|
|
|
|
|
2017-12-14 12:53:53 +01:00
|
|
|
/**
|
|
|
|
* \brief Retrieves instruction format info
|
|
|
|
*
|
|
|
|
* \param [in] opcode The opcode to retrieve
|
|
|
|
* \returns Instruction format info
|
|
|
|
*/
|
2017-12-13 15:32:54 +01:00
|
|
|
DxbcInstFormat dxbcInstructionFormat(DxbcOpcode opcode);
|
|
|
|
|
|
|
|
}
|