2016-12-29 17:31:51 +01:00
|
|
|
// Copyright 2016 Dolphin Emulator Project
|
|
|
|
// Licensed under GPLv2+
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "Common/BitField.h"
|
|
|
|
|
|
|
|
#include "VideoCommon/BPMemory.h"
|
|
|
|
#include "VideoCommon/BPStructs.h"
|
|
|
|
|
2019-02-15 11:59:50 +10:00
|
|
|
enum class AbstractTextureFormat : u32;
|
|
|
|
|
2017-04-30 18:07:57 +10:00
|
|
|
enum class PrimitiveType : u32
|
|
|
|
{
|
|
|
|
Points,
|
|
|
|
Lines,
|
|
|
|
Triangles,
|
|
|
|
TriangleStrip,
|
|
|
|
};
|
|
|
|
|
|
|
|
union RasterizationState
|
|
|
|
{
|
|
|
|
void Generate(const BPMemory& bp, PrimitiveType primitive_type);
|
|
|
|
|
2017-09-09 18:30:15 +10:00
|
|
|
RasterizationState& operator=(const RasterizationState& rhs);
|
|
|
|
|
|
|
|
bool operator==(const RasterizationState& rhs) const { return hex == rhs.hex; }
|
|
|
|
bool operator!=(const RasterizationState& rhs) const { return hex != rhs.hex; }
|
|
|
|
bool operator<(const RasterizationState& rhs) const { return hex < rhs.hex; }
|
2021-02-10 18:11:31 -08:00
|
|
|
BitField<0, 2, CullMode> cullmode;
|
2017-04-30 18:07:57 +10:00
|
|
|
BitField<3, 2, PrimitiveType> primitive;
|
|
|
|
|
|
|
|
u32 hex;
|
|
|
|
};
|
|
|
|
|
2019-02-15 11:59:50 +10:00
|
|
|
union FramebufferState
|
|
|
|
{
|
|
|
|
BitField<0, 8, AbstractTextureFormat> color_texture_format;
|
|
|
|
BitField<8, 8, AbstractTextureFormat> depth_texture_format;
|
|
|
|
BitField<16, 8, u32> samples;
|
|
|
|
BitField<24, 1, u32> per_sample_shading;
|
|
|
|
|
|
|
|
bool operator==(const FramebufferState& rhs) const { return hex == rhs.hex; }
|
|
|
|
bool operator!=(const FramebufferState& rhs) const { return hex != rhs.hex; }
|
|
|
|
FramebufferState& operator=(const FramebufferState& rhs);
|
|
|
|
|
|
|
|
u32 hex;
|
|
|
|
};
|
|
|
|
|
2017-04-30 15:54:45 +10:00
|
|
|
union DepthState
|
|
|
|
{
|
|
|
|
void Generate(const BPMemory& bp);
|
|
|
|
|
2017-09-09 18:30:15 +10:00
|
|
|
DepthState& operator=(const DepthState& rhs);
|
|
|
|
|
|
|
|
bool operator==(const DepthState& rhs) const { return hex == rhs.hex; }
|
|
|
|
bool operator!=(const DepthState& rhs) const { return hex != rhs.hex; }
|
|
|
|
bool operator<(const DepthState& rhs) const { return hex < rhs.hex; }
|
2017-04-30 15:54:45 +10:00
|
|
|
BitField<0, 1, u32> testenable;
|
|
|
|
BitField<1, 1, u32> updateenable;
|
2021-02-10 18:11:31 -08:00
|
|
|
BitField<2, 3, CompareMode> func;
|
2017-04-30 15:54:45 +10:00
|
|
|
|
|
|
|
u32 hex;
|
|
|
|
};
|
|
|
|
|
2016-12-29 17:31:51 +01:00
|
|
|
union BlendingState
|
|
|
|
{
|
|
|
|
void Generate(const BPMemory& bp);
|
|
|
|
|
2019-08-02 19:20:36 +10:00
|
|
|
// HACK: Replaces logical operations with blend operations.
|
|
|
|
// Will not be bit-correct, and in some cases not even remotely in the same ballpark.
|
|
|
|
void ApproximateLogicOpWithBlending();
|
|
|
|
|
2017-09-09 18:30:15 +10:00
|
|
|
BlendingState& operator=(const BlendingState& rhs);
|
|
|
|
|
|
|
|
bool operator==(const BlendingState& rhs) const { return hex == rhs.hex; }
|
|
|
|
bool operator!=(const BlendingState& rhs) const { return hex != rhs.hex; }
|
|
|
|
bool operator<(const BlendingState& rhs) const { return hex < rhs.hex; }
|
2016-12-29 17:31:51 +01:00
|
|
|
BitField<0, 1, u32> blendenable;
|
|
|
|
BitField<1, 1, u32> logicopenable;
|
|
|
|
BitField<2, 1, u32> dstalpha;
|
2017-04-18 21:45:03 +10:00
|
|
|
BitField<3, 1, u32> colorupdate;
|
|
|
|
BitField<4, 1, u32> alphaupdate;
|
|
|
|
BitField<5, 1, u32> subtract;
|
|
|
|
BitField<6, 1, u32> subtractAlpha;
|
|
|
|
BitField<7, 1, u32> usedualsrc;
|
2021-02-10 18:11:31 -08:00
|
|
|
BitField<8, 3, DstBlendFactor> dstfactor;
|
|
|
|
BitField<11, 3, SrcBlendFactor> srcfactor;
|
|
|
|
BitField<14, 3, DstBlendFactor> dstfactoralpha;
|
|
|
|
BitField<17, 3, SrcBlendFactor> srcfactoralpha;
|
|
|
|
BitField<20, 4, LogicOp> logicmode;
|
2016-12-29 17:31:51 +01:00
|
|
|
|
|
|
|
u32 hex;
|
|
|
|
};
|
2017-09-09 00:10:40 +10:00
|
|
|
|
2017-09-09 18:30:15 +10:00
|
|
|
union SamplerState
|
|
|
|
{
|
2017-10-18 02:02:56 -07:00
|
|
|
using StorageType = u64;
|
|
|
|
|
|
|
|
enum class Filter : StorageType
|
2017-09-09 18:30:15 +10:00
|
|
|
{
|
|
|
|
Point,
|
|
|
|
Linear
|
|
|
|
};
|
|
|
|
|
2017-10-18 02:02:56 -07:00
|
|
|
enum class AddressMode : StorageType
|
2017-09-09 18:30:15 +10:00
|
|
|
{
|
|
|
|
Clamp,
|
|
|
|
Repeat,
|
|
|
|
MirroredRepeat
|
|
|
|
};
|
|
|
|
|
|
|
|
void Generate(const BPMemory& bp, u32 index);
|
|
|
|
|
|
|
|
SamplerState& operator=(const SamplerState& rhs);
|
|
|
|
|
|
|
|
bool operator==(const SamplerState& rhs) const { return hex == rhs.hex; }
|
|
|
|
bool operator!=(const SamplerState& rhs) const { return hex != rhs.hex; }
|
|
|
|
bool operator<(const SamplerState& rhs) const { return hex < rhs.hex; }
|
|
|
|
BitField<0, 1, Filter> min_filter;
|
|
|
|
BitField<1, 1, Filter> mag_filter;
|
|
|
|
BitField<2, 1, Filter> mipmap_filter;
|
|
|
|
BitField<3, 2, AddressMode> wrap_u;
|
|
|
|
BitField<5, 2, AddressMode> wrap_v;
|
2017-10-18 02:02:56 -07:00
|
|
|
BitField<7, 16, s64> lod_bias; // multiplied by 256
|
|
|
|
BitField<23, 8, u64> min_lod; // multiplied by 16
|
|
|
|
BitField<31, 8, u64> max_lod; // multiplied by 16
|
|
|
|
BitField<39, 1, u64> anisotropic_filtering;
|
2017-09-09 18:30:15 +10:00
|
|
|
|
2017-10-18 02:02:56 -07:00
|
|
|
StorageType hex;
|
2017-09-09 18:30:15 +10:00
|
|
|
};
|
|
|
|
|
2017-09-09 00:10:40 +10:00
|
|
|
namespace RenderState
|
|
|
|
{
|
2019-01-19 23:54:35 +10:00
|
|
|
RasterizationState GetInvalidRasterizationState();
|
2019-02-15 11:59:50 +10:00
|
|
|
RasterizationState GetNoCullRasterizationState(PrimitiveType primitive);
|
|
|
|
RasterizationState GetCullBackFaceRasterizationState(PrimitiveType primitive);
|
2019-01-19 23:54:35 +10:00
|
|
|
DepthState GetInvalidDepthState();
|
2019-02-15 11:59:50 +10:00
|
|
|
DepthState GetNoDepthTestingDepthState();
|
|
|
|
DepthState GetAlwaysWriteDepthState();
|
2019-01-19 23:54:35 +10:00
|
|
|
BlendingState GetInvalidBlendingState();
|
2017-09-09 00:10:40 +10:00
|
|
|
BlendingState GetNoBlendingBlendState();
|
2019-02-15 11:59:50 +10:00
|
|
|
BlendingState GetNoColorWriteBlendState();
|
2019-01-19 23:54:35 +10:00
|
|
|
SamplerState GetInvalidSamplerState();
|
2017-09-09 18:30:15 +10:00
|
|
|
SamplerState GetPointSamplerState();
|
|
|
|
SamplerState GetLinearSamplerState();
|
2019-02-15 11:59:50 +10:00
|
|
|
FramebufferState GetColorFramebufferState(AbstractTextureFormat format);
|
|
|
|
FramebufferState GetRGBA8FramebufferState();
|
|
|
|
} // namespace RenderState
|