From e831f3c3996624d4f2b1445fc32408ea1edf28d5 Mon Sep 17 00:00:00 2001 From: James Benton Date: Wed, 8 Jun 2016 00:15:43 +0100 Subject: [PATCH] Add gx2/enum.h and move all GX2 enums to it. --- include/gx2/clear.h | 7 +- include/gx2/display.h | 27 +-- include/gx2/draw.h | 17 +- include/gx2/enum.h | 502 ++++++++++++++++++++++++++++++++++++++++ include/gx2/event.h | 9 +- include/gx2/registers.h | 213 +++++++---------- include/gx2/sampler.h | 59 +---- include/gx2/state.h | 10 +- include/gx2/surface.h | 158 +------------ include/gx2/swap.h | 7 +- 10 files changed, 588 insertions(+), 421 deletions(-) create mode 100644 include/gx2/enum.h diff --git a/include/gx2/clear.h b/include/gx2/clear.h index cbe9b34..4d02358 100644 --- a/include/gx2/clear.h +++ b/include/gx2/clear.h @@ -1,5 +1,6 @@ #pragma once #include +#include "enum.h" /** * \defgroup gx2_clear Clear @@ -14,12 +15,6 @@ extern "C" { typedef struct GX2ColorBuffer GX2ColorBuffer; typedef struct GX2DepthBuffer GX2DepthBuffer; -typedef enum GX2ClearFlags -{ - GX2_CLEAR_FLAGS_DEPTH = 1, - GX2_CLEAR_FLAGS_STENCIL = 2, -} GX2ClearFlags; - void GX2ClearColor(GX2ColorBuffer *colorBuffer, float red, diff --git a/include/gx2/display.h b/include/gx2/display.h index fb355b8..f3b07fb 100644 --- a/include/gx2/display.h +++ b/include/gx2/display.h @@ -1,5 +1,6 @@ #pragma once #include +#include "enum.h" #include "surface.h" /** @@ -12,32 +13,6 @@ extern "C" { #endif -typedef enum GX2TVRenderMode -{ - GX2_TV_RENDER_MODE_STANDARD_480P = 1, - GX2_TV_RENDER_MODE_WIDE_480P = 2, - GX2_TV_RENDER_MODE_WIDE_720P = 3, - GX2_TV_RENDER_MODE_WIDE_1080P = 5, -} GX2TVRenderMode; - -typedef enum GX2DrcRenderMode -{ - GX2_DRC_RENDER_MODE_DISABLED = 0, - GX2_DRC_RENDER_MODE_SINGLE = 1, -} GX2DrcRenderMode; - -typedef enum GX2BufferingMode -{ - GX2_BUFFERING_MODE_SINGLE = 1, - GX2_BUFFERING_MODE_DOUBLE = 2, - GX2_BUFFERING_MODE_TRIPLE = 3, -} GX2BufferingMode; - -typedef enum GX2TVScanMode -{ - GX2_TV_SCAN_MODE_NONE = 0, -} GX2TVScanMode; - void GX2SetTVEnable(BOOL enable); diff --git a/include/gx2/draw.h b/include/gx2/draw.h index c2659a0..c47a354 100644 --- a/include/gx2/draw.h +++ b/include/gx2/draw.h @@ -1,5 +1,6 @@ #pragma once #include +#include "enum.h" /** * \defgroup gx2_draw Draw @@ -11,22 +12,6 @@ extern "C" { #endif -typedef enum GX2PrimitiveMode -{ - GX2_PRIMITIVE_MODE_TRIANGLES = 4, - GX2_PRIMITIVE_MODE_TRIANGLE_STRIP = 6, - GX2_PRIMITIVE_MODE_QUADS = 19, - GX2_PRIMITIVE_MODE_QUAD_STRIP = 20, -} GX2PrimitiveMode; - -typedef enum GX2IndexType -{ - GX2_INDEX_TYPE_U16_LE = 0, - GX2_INDEX_TYPE_U32_LE = 1, - GX2_INDEX_TYPE_U16 = 4, - GX2_INDEX_TYPE_U32 = 9, -} GX2IndexType; - void GX2SetAttribBuffer(uint32_t index, uint32_t size, diff --git a/include/gx2/enum.h b/include/gx2/enum.h new file mode 100644 index 0000000..203afa8 --- /dev/null +++ b/include/gx2/enum.h @@ -0,0 +1,502 @@ +#pragma once +#include + +/** + * \defgroup gx2_enum Enums + * \ingroup gx2 + * @{ + */ + +#ifdef __cplusplus +extern "C" { +#endif + +typedef enum GX2AAMode +{ + GX2_AA_MODE1X = 0, +} GX2AAMode; + +typedef enum GX2AlphaToMaskMode +{ + GX2_ALPHA_TO_MASK_MODE_NON_DITHERED = 0, + GX2_ALPHA_TO_MASK_MODE_DITHER_0 = 1, + GX2_ALPHA_TO_MASK_MODE_DITHER_90 = 2, + GX2_ALPHA_TO_MASK_MODE_DITHER_180 = 3, + GX2_ALPHA_TO_MASK_MODE_DITHER_270 = 4, +} GX2AlphaToMaskMode; + +typedef enum GX2AttribFormat +{ + GX2_ATTRIB_FORMAT_UNORM_8 = 0x0, + GX2_ATTRIB_FORMAT_UNORM_8_8 = 0x04, + GX2_ATTRIB_FORMAT_UNORM_8_8_8_8 = 0x0A, + + GX2_ATTRIB_FORMAT_UINT_8 = 0x100, + GX2_ATTRIB_FORMAT_UINT_8_8 = 0x104, + GX2_ATTRIB_FORMAT_UINT_8_8_8_8 = 0x10A, + + GX2_ATTRIB_FORMAT_SNORM_8 = 0x200, + GX2_ATTRIB_FORMAT_SNORM_8_8 = 0x204, + GX2_ATTRIB_FORMAT_SNORM_8_8_8_8 = 0x20A, + + GX2_ATTRIB_FORMAT_SINT_8 = 0x300, + GX2_ATTRIB_FORMAT_SINT_8_8 = 0x304, + GX2_ATTRIB_FORMAT_SINT_8_8_8_8 = 0x30A, + + GX2_ATTRIB_FORMAT_FLOAT_32 = 0x806, + GX2_ATTRIB_FORMAT_FLOAT_32_32 = 0x80d, + GX2_ATTRIB_FORMAT_FLOAT_32_32_32 = 0x811, + GX2_ATTRIB_FORMAT_FLOAT_32_32_32_32 = 0x813, +} GX2AttribFormat; + +typedef enum GX2AttribIndexType +{ + GX2_ATTRIB_INDEX_PER_VERTEX = 0, + GX2_ATTRIB_INDEX_PER_INSTANCE = 1, +} GX2AttribIndexType; + +typedef enum GX2BlendMode +{ + GX2_BLEND_MODE_ZERO = 0, + GX2_BLEND_MODE_ONE = 1, + GX2_BLEND_MODE_SRC_COLOR = 2, + GX2_BLEND_MODE_INV_SRC_COLOR = 3, + GX2_BLEND_MODE_SRC_ALPHA = 4, + GX2_BLEND_MODE_INV_SRC_ALPHA = 5, + GX2_BLEND_MODE_DST_ALPHA = 6, + GX2_BLEND_MODE_INV_DST_ALPHA = 7, + GX2_BLEND_MODE_DST_COLOR = 8, + GX2_BLEND_MODE_INV_DST_COLOR = 9, + GX2_BLEND_MODE_SRC_ALPHA_SAT = 10, + GX2_BLEND_MODE_BOTH_SRC_ALPHA = 11, + GX2_BLEND_MODE_BOTH_INV_SRC_ALPHA = 12, + GX2_BLEND_MODE_BLEND_FACTOR = 13, + GX2_BLEND_MODE_INV_BLEND_FACTOR = 14, + GX2_BLEND_MODE_SRC1_COLOR = 15, + GX2_BLEND_MODE_INV_SRC1_COLOR = 16, + GX2_BLEND_MODE_SRC1_ALPHA = 17, + GX2_BLEND_MODE_INV_SRC1_ALPHA = 18, +} GX2BlendMode; + +typedef enum GX2BlendCombineMode +{ + GX2_BLEND_COMBINE_MODE_ADD = 0, + GX2_BLEND_COMBINE_MODE_SUB = 1, + GX2_BLEND_COMBINE_MODE_MIN = 2, + GX2_BLEND_COMBINE_MODE_MAX = 3, + GX2_BLEND_COMBINE_MODE_REV_SUB = 4, +} GX2BlendCombineMode; + +typedef enum GX2BufferingMode +{ + GX2_BUFFERING_MODE_SINGLE = 1, + GX2_BUFFERING_MODE_DOUBLE = 2, + GX2_BUFFERING_MODE_TRIPLE = 3, +} GX2BufferingMode; + +typedef enum GX2ChannelMask +{ + GX2_CHANNEL_MASK_R = 1, + GX2_CHANNEL_MASK_G = 2, + GX2_CHANNEL_MASK_RG = 3, + GX2_CHANNEL_MASK_B = 4, + GX2_CHANNEL_MASK_RB = 5, + GX2_CHANNEL_MASK_GB = 6, + GX2_CHANNEL_MASK_RGB = 7, + GX2_CHANNEL_MASK_A = 8, + GX2_CHANNEL_MASK_RA = 9, + GX2_CHANNEL_MASK_GA = 10, + GX2_CHANNEL_MASK_RGA = 11, + GX2_CHANNEL_MASK_BA = 12, + GX2_CHANNEL_MASK_RBA = 13, + GX2_CHANNEL_MASK_GBA = 14, + GX2_CHANNEL_MASK_RGBA = 15, +} GX2ChannelMask; + +typedef enum GX2ClearFlags +{ + GX2_CLEAR_FLAGS_DEPTH = 1, + GX2_CLEAR_FLAGS_STENCIL = 2, +} GX2ClearFlags; + +typedef enum GX2CompareFunction +{ + GX2_COMPARE_FUNC_NEVER = 0, + GX2_COMPARE_FUNC_LESS = 1, + GX2_COMPARE_FUNC_EQUAL = 2, + GX2_COMPARE_FUNC_LEQUAL = 3, + GX2_COMPARE_FUNC_GREATER = 4, + GX2_COMPARE_FUNC_NOT_EQUAL = 5, + GX2_COMPARE_FUNC_GEQUAL = 6, + GX2_COMPARE_FUNC_ALWAYS = 7, +} GX2CompareFunction; + +typedef enum GX2DrcRenderMode +{ + GX2_DRC_RENDER_MODE_DISABLED = 0, + GX2_DRC_RENDER_MODE_SINGLE = 1, +} GX2DrcRenderMode; + +typedef enum GX2EventType +{ + GX2_EVENT_TYPE_VSYNC = 2, + GX2_EVENT_TYPE_FLIP = 3, + GX2_EVENT_TYPE_DISPLAY_LIST_OVERRUN = 4, +} GX2EventType; + +typedef enum GX2EndianSwapMode +{ + GX2_ENDIAN_SWAP_NONE = 0, + GX2_ENDIAN_SWAP_8_IN_16 = 1, + GX2_ENDIAN_SWAP_8_IN_32 = 2, + GX2_ENDIAN_SWAP_DEFAULT = 3, +} GX2EndianSwapMode; + +typedef enum GX2FetchShaderType +{ + GX2_FETCH_SHADER_TESSELLATION_NONE = 0, + GX2_FETCH_SHADER_TESSELLATION_LINE = 1, + GX2_FETCH_SHADER_TESSELLATION_TRIANGLE = 2, + GX2_FETCH_SHADER_TESSELLATION_QUAD = 3, +} GX2FetchShaderType; + +typedef enum GX2FrontFace +{ + GX2_FRONT_FACE_CCW = 0, + GX2_FRONT_FACE_CW = 1, +} GX2FrontFace; + +typedef enum GX2IndexType +{ + GX2_INDEX_TYPE_U16_LE = 0, + GX2_INDEX_TYPE_U32_LE = 1, + GX2_INDEX_TYPE_U16 = 4, + GX2_INDEX_TYPE_U32 = 9, +} GX2IndexType; + +typedef enum GX2InitAttributes +{ + GX2_INIT_END = 0, + GX2_INIT_CMD_BUF_BASE = 1, + GX2_INIT_CMD_BUF_POOL_SIZE = 2, + GX2_INIT_ARGC = 7, + GX2_INIT_ARGV = 8, +} GX2InitAttributes; + +typedef enum GX2LogicOp +{ + GX2_LOGIC_OP_CLEAR = 0x00, + GX2_LOGIC_OP_NOR = 0x11, + GX2_LOGIC_OP_INV_AND = 0x22, + GX2_LOGIC_OP_INV_COPY = 0x33, + GX2_LOGIC_OP_REV_AND = 0x44, + GX2_LOGIC_OP_INV = 0x55, + GX2_LOGIC_OP_XOR = 0x66, + GX2_LOGIC_OP_NOT_AND = 0x77, + GX2_LOGIC_OP_AND = 0x88, + GX2_LOGIC_OP_EQUIV = 0x99, + GX2_LOGIC_OP_NOP = 0xAA, + GX2_LOGIC_OP_INV_OR = 0xBB, + GX2_LOGIC_OP_COPY = 0xCC, + GX2_LOGIC_OP_REV_OR = 0xDD, + GX2_LOGIC_OP_OR = 0xEE, + GX2_LOGIC_OP_SET = 0xFF, +} GX2LogicOp; + +typedef enum GX2PrimitiveMode +{ + GX2_PRIMITIVE_MODE_TRIANGLES = 4, + GX2_PRIMITIVE_MODE_TRIANGLE_STRIP = 6, + GX2_PRIMITIVE_MODE_QUADS = 19, + GX2_PRIMITIVE_MODE_QUAD_STRIP = 20, +} GX2PrimitiveMode; + +typedef enum GX2PolygonMode +{ + GX2_POLYGON_MODE_POINT = 0, + GX2_POLYGON_MODE_LINE = 1, + GX2_POLYGON_MODE_TRIANGLE = 2, +} GX2PolygonMode; + +typedef enum GX2RenderTarget +{ + GX2_RENDER_TARGET_0 = 0, + GX2_RENDER_TARGET_1 = 1, + GX2_RENDER_TARGET_2 = 2, + GX2_RENDER_TARGET_3 = 3, + GX2_RENDER_TARGET_4 = 4, + GX2_RENDER_TARGET_5 = 5, + GX2_RENDER_TARGET_6 = 6, +} GX2RenderTarget; + +typedef enum GX2RoundingMode +{ + GX2_ROUNDING_MODE_ROUND_TO_EVEN = 0, + GX2_ROUNDING_MODE_TRUNCATE = 1, +} GX2RoundingMode; + +typedef enum GX2RResourceFlags +{ + GX2R_RESOURCE_FLAGS_BIND_TEXTURE = 1 << 0, + GX2R_RESOURCE_FLAGS_BIND_COLOR_BUFFER = 1 << 1, + GX2R_RESOURCE_FLAGS_BIND_DEPTH_BUFFER = 1 << 2, + GX2R_RESOURCE_FLAGS_BIND_SCAN_BUFFER = 1 << 3, + GX2R_RESOURCE_FLAGS_BIND_VERTEX_BUFFER = 1 << 4, + GX2R_RESOURCE_FLAGS_BIND_INDEX_BUFFER = 1 << 5, + GX2R_RESOURCE_FLAGS_BIND_UNIFORM_BLOCK = 1 << 6, + GX2R_RESOURCE_FLAGS_BIND_SHADER_PROGRAM = 1 << 7, + GX2R_RESOURCE_FLAGS_BIND_STREAM_OUTPUT = 1 << 8, + GX2R_RESOURCE_FLAGS_BIND_DISPLAY_LIST = 1 << 9, + GX2R_RESOURCE_FLAGS_BIND_GS_RING = 1 << 10, + GX2R_RESOURCE_FLAGS_USAGE_CPU_READ = 1 << 11, + GX2R_RESOURCE_FLAGS_USAGE_CPU_WRITE = 1 << 12, + GX2R_RESOURCE_FLAGS_USAGE_GPU_READ = 1 << 13, + GX2R_RESOURCE_FLAGS_USAGE_GPU_WRITE = 1 << 14, + GX2R_RESOURCE_FLAGS_USAGE_DMA_READ = 1 << 15, + GX2R_RESOURCE_FLAGS_USAGE_DMA_WRITE = 1 << 16, + GX2R_RESOURCE_FLAGS_USAGE_FORCE_MEM1 = 1 << 17, + GX2R_RESOURCE_FLAGS_USAGE_FORCE_MEM2 = 1 << 18, + GX2R_RESOURCE_FLAGS_USER_MEMORY = 1 << 29, + GX2R_RESOURCE_FLAGS_LOCKED = 1 << 30, +} GX2RResourceFlags; + +typedef enum GX2SamplerVarType +{ + GX2_SAMPLER_VAR_TYPE_SAMPLER_1D = 0, + GX2_SAMPLER_VAR_TYPE_SAMPLER_2D = 1, + GX2_SAMPLER_VAR_TYPE_SAMPLER_3D = 3, + GX2_SAMPLER_VAR_TYPE_SAMPLER_CUBE = 4, +} GX2SamplerVarType; + +typedef enum GX2ScanTarget +{ + GX2_SCAN_TARGET_TV = 1, + GX2_SCAN_TARGET_DRC = 4, +} GX2ScanTarget; + +typedef enum GX2ShaderMode +{ + GX2_SHADER_MODE_UNIFORM_REGISTER = 0, + GX2_SHADER_MODE_UNIFORM_BLOCK = 1, + GX2_SHADER_MODE_GEOMETRY_SHADER = 2, + GX2_SHADER_MODE_COMPUTE_SHADER = 3, +} GX2ShaderMode; + +typedef enum GX2ShaderVarType +{ + GX2_SHADER_VAR_TYPE_INT = 2, + GX2_SHADER_VAR_TYPE_FLOAT = 4, + GX2_SHADER_VAR_TYPE_FLOAT2 = 9, + GX2_SHADER_VAR_TYPE_FLOAT3 = 10, + GX2_SHADER_VAR_TYPE_FLOAT4 = 11, + GX2_SHADER_VAR_TYPE_INT2 = 15, + GX2_SHADER_VAR_TYPE_INT3 = 16, + GX2_SHADER_VAR_TYPE_INT4 = 17, + GX2_SHADER_VAR_TYPE_MATRIX4X4 = 29, +} GX2ShaderVarType; + +typedef enum GX2StencilFunction +{ + GX2_STENCIL_FUNCTION_KEEP = 0, + GX2_STENCIL_FUNCTION_ZERO = 1, + GX2_STENCIL_FUNCTION_REPLACE = 2, + GX2_STENCIL_FUNCTION_INCR_CLAMP = 3, + GX2_STENCIL_FUNCTION_DECR_CLAMP = 4, + GX2_STENCIL_FUNCTION_INV = 5, + GX2_STENCIL_FUNCTION_INCR_WRAP = 6, + GX2_STENCIL_FUNCTION_DECR_WRAP = 7, +} GX2StencilFunction; + +typedef enum +{ + GX2_SURFACE_DIM_TEXTURE_1D = 0, + GX2_SURFACE_DIM_TEXTURE_2D = 1, + GX2_SURFACE_DIM_TEXTURE_3D = 2, + GX2_SURFACE_DIM_TEXTURE_CUBE = 3, + GX2_SURFACE_DIM_TEXTURE_1D_ARRAY = 4, + GX2_SURFACE_DIM_TEXTURE_2D_ARRAY = 5, + GX2_SURFACE_DIM_TEXTURE_2D_MSAA = 6, + GX2_SURFACE_DIM_TEXTURE_2D_MSAA_ARRAY = 7, +} GX2SurfaceDim; + +typedef enum +{ + GX2_SURFACE_FORMAT_INVALID = 0x00, + GX2_SURFACE_FORMAT_UNORM_R4_G4 = 0x02, + GX2_SURFACE_FORMAT_UNORM_R4_G4_B4_A4 = 0x0b, + GX2_SURFACE_FORMAT_UNORM_R8 = 0x01, + GX2_SURFACE_FORMAT_UNORM_R8_G8 = 0x07, + GX2_SURFACE_FORMAT_UNORM_R8_G8_B8_A8 = 0x01a, + GX2_SURFACE_FORMAT_UNORM_R16 = 0x05, + GX2_SURFACE_FORMAT_UNORM_R16_G16 = 0x0f, + GX2_SURFACE_FORMAT_UNORM_R16_G16_B16_A16 = 0x01f, + GX2_SURFACE_FORMAT_UNORM_R5_G6_B5 = 0x08, + GX2_SURFACE_FORMAT_UNORM_R5_G5_B5_A1 = 0x0a, + GX2_SURFACE_FORMAT_UNORM_A1_B5_G5_R5 = 0x0c, + GX2_SURFACE_FORMAT_UNORM_R24_X8 = 0x011, + GX2_SURFACE_FORMAT_UNORM_A2_B10_G10_R10 = 0x01b, + GX2_SURFACE_FORMAT_UNORM_R10_G10_B10_A2 = 0x019, + GX2_SURFACE_FORMAT_UNORM_BC1 = 0x031, + GX2_SURFACE_FORMAT_UNORM_BC2 = 0x032, + GX2_SURFACE_FORMAT_UNORM_BC3 = 0x033, + GX2_SURFACE_FORMAT_UNORM_BC4 = 0x034, + GX2_SURFACE_FORMAT_UNORM_BC5 = 0x035, + GX2_SURFACE_FORMAT_UNORM_NV12 = 0x081, + + GX2_SURFACE_FORMAT_UINT_R8 = 0x101, + GX2_SURFACE_FORMAT_UINT_R8_G8 = 0x107, + GX2_SURFACE_FORMAT_UINT_R8_G8_B8_A8 = 0x11a, + GX2_SURFACE_FORMAT_UINT_R16 = 0x105, + GX2_SURFACE_FORMAT_UINT_R16_G16 = 0x10f, + GX2_SURFACE_FORMAT_UINT_R16_G16_B16_A16 = 0x11f, + GX2_SURFACE_FORMAT_UINT_R32 = 0x10d, + GX2_SURFACE_FORMAT_UINT_R32_G32 = 0x11d, + GX2_SURFACE_FORMAT_UINT_R32_G32_B32_A32 = 0x122, + GX2_SURFACE_FORMAT_UINT_A2_B10_G10_R10 = 0x11b, + GX2_SURFACE_FORMAT_UINT_R10_G10_B10_A2 = 0x119, + GX2_SURFACE_FORMAT_UINT_X24_G8 = 0x111, + GX2_SURFACE_FORMAT_UINT_G8_X24 = 0x11c, + + GX2_SURFACE_FORMAT_SNORM_R8 = 0x201, + GX2_SURFACE_FORMAT_SNORM_R8_G8 = 0x207, + GX2_SURFACE_FORMAT_SNORM_R8_G8_B8_A8 = 0x21a, + GX2_SURFACE_FORMAT_SNORM_R16 = 0x205, + GX2_SURFACE_FORMAT_SNORM_R16_G16 = 0x20f, + GX2_SURFACE_FORMAT_SNORM_R16_G16_B16_A16 = 0x21f, + GX2_SURFACE_FORMAT_SNORM_R10_G10_B10_A2 = 0x219, + GX2_SURFACE_FORMAT_SNORM_BC4 = 0x234, + GX2_SURFACE_FORMAT_SNORM_BC5 = 0x235, + + GX2_SURFACE_FORMAT_SINT_R8 = 0x301, + GX2_SURFACE_FORMAT_SINT_R8_G8 = 0x307, + GX2_SURFACE_FORMAT_SINT_R8_G8_B8_A8 = 0x31a, + GX2_SURFACE_FORMAT_SINT_R16 = 0x305, + GX2_SURFACE_FORMAT_SINT_R16_G16 = 0x30f, + GX2_SURFACE_FORMAT_SINT_R16_G16_B16_A16 = 0x31f, + GX2_SURFACE_FORMAT_SINT_R32 = 0x30d, + GX2_SURFACE_FORMAT_SINT_R32_G32 = 0x31d, + GX2_SURFACE_FORMAT_SINT_R32_G32_B32_A32 = 0x322, + GX2_SURFACE_FORMAT_SINT_R10_G10_B10_A2 = 0x319, + + GX2_SURFACE_FORMAT_SRGB_R8_G8_B8_A8 = 0x41a, + GX2_SURFACE_FORMAT_SRGB_BC1 = 0x431, + GX2_SURFACE_FORMAT_SRGB_BC2 = 0x432, + GX2_SURFACE_FORMAT_SRGB_BC3 = 0x433, + + GX2_SURFACE_FORMAT_FLOAT_R32 = 0x80e, + GX2_SURFACE_FORMAT_FLOAT_R32_G32 = 0x81e, + GX2_SURFACE_FORMAT_FLOAT_R32_G32_B32_A32 = 0x823, + GX2_SURFACE_FORMAT_FLOAT_R16 = 0x806, + GX2_SURFACE_FORMAT_FLOAT_R16_G16 = 0x810, + GX2_SURFACE_FORMAT_FLOAT_R16_G16_B16_A16 = 0x820, + GX2_SURFACE_FORMAT_FLOAT_R11_G11_B10 = 0x816, + GX2_SURFACE_FORMAT_FLOAT_D24_S8 = 0x811, + GX2_SURFACE_FORMAT_FLOAT_X8_X24 = 0x81c, +} GX2SurfaceFormat; + +typedef enum GX2SurfaceUse +{ + GX2_SURFACE_USE_TEXTURE = 1 << 0, + GX2_SURFACE_USE_COLOR_BUFFER = 1 << 1, + GX2_SURFACE_USE_DEPTH_BUFFER = 1 << 2, + GX2_SURFACE_USE_SCAN_BUFFER = 1 << 3, +} GX2SurfaceUse; + +typedef enum GX2TessellationMode +{ + GX2_TESSELLATION_MODE_DISCRETE = 0, + GX2_TESSELLATION_MODE_CONTINUOUS = 1, + GX2_TESSELLATION_MODE_ADAPTIVE = 2, +} GX2TessellationMode; + +typedef enum GX2TexBorderType +{ + GX2_TEX_BORDER_TYPE_TRANSPARENT_BLACK = 0, + GX2_TEX_BORDER_TYPE_BLACK = 1, + GX2_TEX_BORDER_TYPE_WHITE = 2, + GX2_TEX_BORDER_TYPE_VARIABLE = 3, +} GX2TexBorderType; + +typedef enum GX2TexClampMode +{ + GX2_TEX_CLAMP_MODE_WRAP = 0, + GX2_TEX_CLAMP_MODE_MIRROR = 1, + GX2_TEX_CLAMP_MODE_CLAMP = 2, + GX2_TEX_CLAMP_MODE_MIRROR_ONCE = 3, + GX2_TEX_CLAMP_MODE_CLAMP_BORDER = 6, +} GX2TexClampMode; + +typedef enum GX2TexMipFilterMode +{ + GX2_TEX_MIP_FILTER_MODE_NONE = 0, + GX2_TEX_MIP_FILTER_MODE_POINT = 1, + GX2_TEX_MIP_FILTER_MODE_LINEAR = 2, +} GX2TexMipFilterMode; + +typedef enum GX2TexMipPerfMode +{ + GX2_TEX_MIP_PERF_MODE_DISABLE = 0, +} GX2TexMipPerfMode; + +typedef enum GX2TexXYFilterMode +{ + GX2_TEX_XY_FILLTER_MODE_POINT = 0, + GX2_TEX_XY_FILLTER_MODE_LINEAR = 1, +} GX2TexXYFilterMode; + +typedef enum GX2TexAnisoRatio +{ + GX2_TEX_ANISO_RATIO_NONE = 0, +} GX2TexAnisoRatio; + +typedef enum GX2TexZFilterMode +{ + GX2_TEX_Z_FILTER_MODE_NONE = 0, + GX2_TEX_Z_FILTER_MODE_POINT = 1, + GX2_TEX_Z_FILTER_MODE_LINEAR = 2, +} GX2TexZFilterMode; + +typedef enum GX2TexZPerfMode +{ + GX2_TEX_Z_PERF_MODE_DISABLED = 0, +} GX2TexZPerfMode; + +typedef enum GX2TileMode +{ + GX2_TILE_MODE_DEFAULT = 0, + GX2_TILE_MODE_LINEAR_ALIGNED = 1, + GX2_TILE_MODE_TILED_1D_THIN1 = 2, + GX2_TILE_MODE_TILED_1D_THICK = 3, + GX2_TILE_MODE_TILED_2D_THIN1 = 4, + GX2_TILE_MODE_TILED_2D_THIN2 = 5, + GX2_TILE_MODE_TILED_2D_THIN4 = 6, + GX2_TILE_MODE_TILED_2D_THICK = 7, + GX2_TILE_MODE_TILED_2B_THIN1 = 8, + GX2_TILE_MODE_TILED_2B_THIN2 = 9, + GX2_TILE_MODE_TILED_2B_THIN4 = 10, + GX2_TILE_MODE_TILED_2B_THICK = 11, + GX2_TILE_MODE_TILED_3D_THIN1 = 12, + GX2_TILE_MODE_TILED_3D_THICK = 13, + GX2_TILE_MODE_TILED_3B_THIN1 = 14, + GX2_TILE_MODE_TILED_3B_THICK = 15, + GX2_TILE_MODE_LINEAR_SPECIAL = 16, +} GX2TileMode; + +typedef enum GX2TVRenderMode +{ + GX2_TV_RENDER_MODE_STANDARD_480P = 1, + GX2_TV_RENDER_MODE_WIDE_480P = 2, + GX2_TV_RENDER_MODE_WIDE_720P = 3, + GX2_TV_RENDER_MODE_WIDE_1080P = 5, +} GX2TVRenderMode; + +typedef enum GX2TVScanMode +{ + GX2_TV_SCAN_MODE_NONE = 0, +} GX2TVScanMode; + +#ifdef __cplusplus +} +#endif + +/** @} */ diff --git a/include/gx2/event.h b/include/gx2/event.h index 48ad136..0acc761 100644 --- a/include/gx2/event.h +++ b/include/gx2/event.h @@ -1,6 +1,7 @@ #pragma once #include #include +#include "enum.h" /** * \defgroup gx2_event Event @@ -13,14 +14,6 @@ extern "C" { #endif typedef struct GX2DisplayListOverrunData GX2DisplayListOverrunData; - -typedef enum GX2EventType -{ - GX2_EVENT_TYPE_VSYNC = 2, - GX2_EVENT_TYPE_FLIP = 3, - GX2_EVENT_TYPE_DISPLAY_LIST_OVERRUN = 4, -} GX2EventType; - typedef void (*GX2EventCallbackFunction)(GX2EventType, void *); struct GX2DisplayListOverrunData diff --git a/include/gx2/registers.h b/include/gx2/registers.h index e4fb563..6181335 100644 --- a/include/gx2/registers.h +++ b/include/gx2/registers.h @@ -1,5 +1,6 @@ #pragma once #include +#include "enum.h" #include "surface.h" /** @@ -29,218 +30,160 @@ typedef struct GX2ScissorReg GX2ScissorReg; typedef struct GX2TargetChannelMaskReg GX2TargetChannelMaskReg; typedef struct GX2ViewportReg GX2ViewportReg; -typedef enum GX2CompareFunction -{ - GX2_COMPARE_FUNC_NEVER = 0, - GX2_COMPARE_FUNC_LESS = 1, - GX2_COMPARE_FUNC_EQUAL = 2, - GX2_COMPARE_FUNC_LEQUAL = 3, - GX2_COMPARE_FUNC_GREATER = 4, - GX2_COMPARE_FUNC_NOT_EQUAL = 5, - GX2_COMPARE_FUNC_GEQUAL = 6, - GX2_COMPARE_FUNC_ALWAYS = 7, -} GX2CompareFunction; - -typedef enum GX2AlphaToMaskMode -{ - GX2_ALPHA_TO_MASK_MODE_NON_DITHERED = 0, - GX2_ALPHA_TO_MASK_MODE_DITHER_0 = 1, - GX2_ALPHA_TO_MASK_MODE_DITHER_90 = 2, - GX2_ALPHA_TO_MASK_MODE_DITHER_180 = 3, - GX2_ALPHA_TO_MASK_MODE_DITHER_270 = 4, -} GX2AlphaToMaskMode; - -typedef enum GX2BlendMode -{ - GX2_BLEND_MODE_ZERO = 0, - GX2_BLEND_MODE_ONE = 1, - GX2_BLEND_MODE_SRC_COLOR = 2, - GX2_BLEND_MODE_INV_SRC_COLOR = 3, - GX2_BLEND_MODE_SRC_ALPHA = 4, - GX2_BLEND_MODE_INV_SRC_ALPHA = 5, - GX2_BLEND_MODE_DST_ALPHA = 6, - GX2_BLEND_MODE_INV_DST_ALPHA = 7, - GX2_BLEND_MODE_DST_COLOR = 8, - GX2_BLEND_MODE_INV_DST_COLOR = 9, - GX2_BLEND_MODE_SRC_ALPHA_SAT = 10, - GX2_BLEND_MODE_BOTH_SRC_ALPHA = 11, - GX2_BLEND_MODE_BOTH_INV_SRC_ALPHA = 12, - GX2_BLEND_MODE_BLEND_FACTOR = 13, - GX2_BLEND_MODE_INV_BLEND_FACTOR = 14, - GX2_BLEND_MODE_SRC1_COLOR = 15, - GX2_BLEND_MODE_INV_SRC1_COLOR = 16, - GX2_BLEND_MODE_SRC1_ALPHA = 17, - GX2_BLEND_MODE_INV_SRC1_ALPHA = 18, -} GX2BlendMode; - -typedef enum GX2BlendCombineMode -{ - GX2_BLEND_COMBINE_MODE_ADD = 0, - GX2_BLEND_COMBINE_MODE_SUB = 1, - GX2_BLEND_COMBINE_MODE_MIN = 2, - GX2_BLEND_COMBINE_MODE_MAX = 3, - GX2_BLEND_COMBINE_MODE_REV_SUB = 4, -} GX2BlendCombineMode; - -typedef enum GX2FrontFace -{ - GX2_FRONT_FACE_CCW = 0, - GX2_FRONT_FACE_CW = 1, -} GX2FrontFace; - -typedef enum GX2LogicOp -{ - GX2_LOGIC_OP_CLEAR = 0x00, - GX2_LOGIC_OP_NOR = 0x11, - GX2_LOGIC_OP_INV_AND = 0x22, - GX2_LOGIC_OP_INV_COPY = 0x33, - GX2_LOGIC_OP_REV_AND = 0x44, - GX2_LOGIC_OP_INV = 0x55, - GX2_LOGIC_OP_XOR = 0x66, - GX2_LOGIC_OP_NOT_AND = 0x77, - GX2_LOGIC_OP_AND = 0x88, - GX2_LOGIC_OP_EQUIV = 0x99, - GX2_LOGIC_OP_NOP = 0xAA, - GX2_LOGIC_OP_INV_OR = 0xBB, - GX2_LOGIC_OP_COPY = 0xCC, - GX2_LOGIC_OP_REV_OR = 0xDD, - GX2_LOGIC_OP_OR = 0xEE, - GX2_LOGIC_OP_SET = 0xFF, -} GX2LogicOp; - -typedef enum GX2StencilFunction -{ - GX2_STENCIL_FUNCTION_KEEP = 0, - GX2_STENCIL_FUNCTION_ZERO = 1, - GX2_STENCIL_FUNCTION_REPLACE = 2, - GX2_STENCIL_FUNCTION_INCR_CLAMP = 3, - GX2_STENCIL_FUNCTION_DECR_CLAMP = 4, - GX2_STENCIL_FUNCTION_INV = 5, - GX2_STENCIL_FUNCTION_INCR_WRAP = 6, - GX2_STENCIL_FUNCTION_DECR_WRAP = 7, -} GX2StencilFunction; - -typedef enum GX2PolygonMode -{ - GX2_POLYGON_MODE_POINT = 0, - GX2_POLYGON_MODE_LINE = 1, - GX2_POLYGON_MODE_TRIANGLE = 2, -} GX2PolygonMode; - - -typedef enum GX2ChannelMask -{ - GX2_CHANNEL_MASK_R = 1, - GX2_CHANNEL_MASK_G = 2, - GX2_CHANNEL_MASK_RG = 3, - GX2_CHANNEL_MASK_B = 4, - GX2_CHANNEL_MASK_RB = 5, - GX2_CHANNEL_MASK_GB = 6, - GX2_CHANNEL_MASK_RGB = 7, - GX2_CHANNEL_MASK_A = 8, - GX2_CHANNEL_MASK_RA = 9, - GX2_CHANNEL_MASK_GA = 10, - GX2_CHANNEL_MASK_RGA = 11, - GX2_CHANNEL_MASK_BA = 12, - GX2_CHANNEL_MASK_RBA = 13, - GX2_CHANNEL_MASK_GBA = 14, - GX2_CHANNEL_MASK_RGBA = 15, -} GX2ChannelMask; - struct GX2AAMaskReg { - uint32_t regs[1]; + uint32_t pa_sc_aa_mask; }; +CHECK_OFFSET(GX2AAMaskReg, 0, pa_sc_aa_mask); CHECK_SIZE(GX2AAMaskReg, 4); struct GX2AlphaTestReg { - uint32_t regs[2]; + uint32_t sx_alpha_test_control; + uint32_t sx_alpha_ref; }; +CHECK_OFFSET(GX2AlphaTestReg, 0, sx_alpha_test_control); +CHECK_OFFSET(GX2AlphaTestReg, 4, sx_alpha_ref); CHECK_SIZE(GX2AlphaTestReg, 8); struct GX2AlphaToMaskReg { - uint32_t regs[1]; + uint32_t db_alpha_to_mask; }; +CHECK_OFFSET(GX2AlphaToMaskReg, 0, db_alpha_to_mask); CHECK_SIZE(GX2AlphaToMaskReg, 4); struct GX2BlendControlReg { - uint32_t regs[2]; + GX2RenderTarget target; + uint32_t cb_blend_control; }; +CHECK_OFFSET(GX2BlendControlReg, 0, target); +CHECK_OFFSET(GX2BlendControlReg, 4, cb_blend_control); CHECK_SIZE(GX2BlendControlReg, 8); struct GX2BlendConstantColorReg { - uint32_t regs[4]; + float red; + float green; + float blue; + float alpha; }; -CHECK_SIZE(GX2BlendConstantColorReg, 16); +CHECK_OFFSET(GX2BlendConstantColorReg, 0x00, red); +CHECK_OFFSET(GX2BlendConstantColorReg, 0x04, green); +CHECK_OFFSET(GX2BlendConstantColorReg, 0x08, blue); +CHECK_OFFSET(GX2BlendConstantColorReg, 0x0c, alpha); +CHECK_SIZE(GX2BlendConstantColorReg, 0x10); struct GX2ColorControlReg { - uint32_t regs[1]; + uint32_t cb_color_control; }; +CHECK_OFFSET(GX2ColorControlReg, 0x00, cb_color_control); CHECK_SIZE(GX2ColorControlReg, 4); struct GX2DepthStencilControlReg { - uint32_t regs[1]; + uint32_t db_depth_control; }; +CHECK_OFFSET(GX2DepthStencilControlReg, 0, db_depth_control); CHECK_SIZE(GX2DepthStencilControlReg, 4); struct GX2StencilMaskReg { - uint32_t regs[2]; + uint32_t db_stencilrefmask; + uint32_t db_stencilrefmask_bf; }; +CHECK_OFFSET(GX2StencilMaskReg, 0, db_stencilrefmask); +CHECK_OFFSET(GX2StencilMaskReg, 4, db_stencilrefmask_bf); CHECK_SIZE(GX2StencilMaskReg, 8); struct GX2LineWidthReg { - uint32_t regs[1]; + uint32_t pa_su_line_cntl; }; +CHECK_OFFSET(GX2LineWidthReg, 0, pa_su_line_cntl); CHECK_SIZE(GX2LineWidthReg, 4); struct GX2PointSizeReg { - uint32_t regs[1]; + uint32_t pa_su_point_size; }; +CHECK_OFFSET(GX2PointSizeReg, 0, pa_su_point_size); CHECK_SIZE(GX2PointSizeReg, 4); struct GX2PointLimitsReg { - uint32_t regs[1]; + uint32_t pa_su_point_minmax; }; +CHECK_OFFSET(GX2PointLimitsReg, 0, pa_su_point_minmax); CHECK_SIZE(GX2PointLimitsReg, 4); struct GX2PolygonControlReg { - uint32_t regs[1]; + uint32_t pa_su_sc_mode_cntl; }; +CHECK_OFFSET(GX2PolygonControlReg, 0, pa_su_sc_mode_cntl); CHECK_SIZE(GX2PolygonControlReg, 4); struct GX2PolygonOffsetReg { - uint32_t regs[5]; + uint32_t pa_su_poly_offset_front_scale; + uint32_t pa_su_poly_offset_front_offset; + uint32_t pa_su_poly_offset_back_scale; + uint32_t pa_su_poly_offset_back_offset; + uint32_t pa_su_poly_offset_clamp; }; +CHECK_OFFSET(GX2PolygonOffsetReg, 0x00, pa_su_poly_offset_front_scale); +CHECK_OFFSET(GX2PolygonOffsetReg, 0x04, pa_su_poly_offset_front_offset); +CHECK_OFFSET(GX2PolygonOffsetReg, 0x08, pa_su_poly_offset_back_scale); +CHECK_OFFSET(GX2PolygonOffsetReg, 0x0C, pa_su_poly_offset_back_offset); +CHECK_OFFSET(GX2PolygonOffsetReg, 0x10, pa_su_poly_offset_clamp); CHECK_SIZE(GX2PolygonOffsetReg, 20); struct GX2ScissorReg { - uint32_t regs[2]; + uint32_t pa_sc_generic_scissor_tl; + uint32_t pa_sc_generic_scissor_br; }; +CHECK_OFFSET(GX2ScissorReg, 0x00, pa_sc_generic_scissor_tl); +CHECK_OFFSET(GX2ScissorReg, 0x04, pa_sc_generic_scissor_br); CHECK_SIZE(GX2ScissorReg, 8); struct GX2TargetChannelMaskReg { - uint32_t regs[1]; + uint32_t cb_target_mask; }; +CHECK_OFFSET(GX2TargetChannelMaskReg, 0x00, cb_target_mask); CHECK_SIZE(GX2TargetChannelMaskReg, 4); struct GX2ViewportReg { - uint32_t regs[12]; + uint32_t pa_cl_vport_xscale; + uint32_t pa_cl_vport_xoffset; + uint32_t pa_cl_vport_yscale; + uint32_t pa_cl_vport_yoffset; + uint32_t pa_cl_vport_zscale; + uint32_t pa_cl_vport_zoffset; + uint32_t pa_cl_gb_vert_clip_adj; + uint32_t pa_cl_gb_vert_disc_adj; + uint32_t pa_cl_gb_horz_clip_adj; + uint32_t pa_cl_gb_horz_disc_adj; + uint32_t pa_sc_vport_zmin; + uint32_t pa_sc_vport_zmax; }; +CHECK_OFFSET(GX2ViewportReg, 0x00, pa_cl_vport_xscale); +CHECK_OFFSET(GX2ViewportReg, 0x04, pa_cl_vport_xoffset); +CHECK_OFFSET(GX2ViewportReg, 0x08, pa_cl_vport_yscale); +CHECK_OFFSET(GX2ViewportReg, 0x0C, pa_cl_vport_yoffset); +CHECK_OFFSET(GX2ViewportReg, 0x10, pa_cl_vport_zscale); +CHECK_OFFSET(GX2ViewportReg, 0x14, pa_cl_vport_zoffset); +CHECK_OFFSET(GX2ViewportReg, 0x18, pa_cl_gb_vert_clip_adj); +CHECK_OFFSET(GX2ViewportReg, 0x1C, pa_cl_gb_vert_disc_adj); +CHECK_OFFSET(GX2ViewportReg, 0x20, pa_cl_gb_horz_clip_adj); +CHECK_OFFSET(GX2ViewportReg, 0x24, pa_cl_gb_horz_disc_adj); +CHECK_OFFSET(GX2ViewportReg, 0x28, pa_sc_vport_zmin); +CHECK_OFFSET(GX2ViewportReg, 0x2C, pa_sc_vport_zmax); CHECK_SIZE(GX2ViewportReg, 48); void diff --git a/include/gx2/sampler.h b/include/gx2/sampler.h index 3819d54..cdb1a1d 100644 --- a/include/gx2/sampler.h +++ b/include/gx2/sampler.h @@ -1,5 +1,6 @@ #pragma once #include +#include "enum.h" /** * \defgroup gx2_sampler Sampler @@ -19,64 +20,6 @@ struct GX2Sampler }; CHECK_SIZE(GX2Sampler, 12); -typedef enum GX2TexBorderType -{ - GX2_TEX_BORDER_TYPE_TRANSPARENT_BLACK = 0, - GX2_TEX_BORDER_TYPE_BLACK = 1, - GX2_TEX_BORDER_TYPE_WHITE = 2, - GX2_TEX_BORDER_TYPE_VARIABLE = 3, -} GX2TexBorderType; - -typedef enum GX2TexClampMode -{ - GX2_TEX_CLAMP_MODE_WRAP = 0, - GX2_TEX_CLAMP_MODE_MIRROR = 1, - GX2_TEX_CLAMP_MODE_CLAMP = 2, - GX2_TEX_CLAMP_MODE_MIRROR_ONCE = 3, - GX2_TEX_CLAMP_MODE_CLAMP_BORDER = 6, -} GX2TexClampMode; - -typedef enum GX2TexMipFilterMode -{ - GX2_TEX_MIP_FILTER_MODE_NONE = 0, - GX2_TEX_MIP_FILTER_MODE_POINT = 1, - GX2_TEX_MIP_FILTER_MODE_LINEAR = 2, -} GX2TexMipFilterMode; - -typedef enum GX2TexMipPerfMode -{ - GX2_TEX_MIP_PERF_MODE_DISABLE = 0, -} GX2TexMipPerfMode; - -typedef enum GX2TexXYFilterMode -{ - GX2_TEX_XY_FILLTER_MODE_POINT = 0, - GX2_TEX_XY_FILLTER_MODE_LINEAR = 1, -} GX2TexXYFilterMode; - -typedef enum GX2TexAnisoRatio -{ - GX2_TEX_ANISO_RATIO_NONE = 0, -} GX2TexAnisoRatio; - -typedef enum GX2TexZFilterMode -{ - GX2_TEX_Z_FILTER_MODE_NONE = 0, - GX2_TEX_Z_FILTER_MODE_POINT = 1, - GX2_TEX_Z_FILTER_MODE_LINEAR = 2, -} GX2TexZFilterMode; - -typedef enum GX2TexZPerfMode -{ - GX2_TEX_Z_PERF_MODE_DISABLED = 0, -} GX2TexZPerfMode; - -typedef enum GX2RoundingMode -{ - GX2_ROUNDING_MODE_ROUND_TO_EVEN = 0, - GX2_ROUNDING_MODE_TRUNCATE = 1, -} GX2RoundingMode; - void GX2InitSampler(GX2Sampler *sampler, GX2TexClampMode clampMode, diff --git a/include/gx2/state.h b/include/gx2/state.h index 8aefb99..7fc6b4e 100644 --- a/include/gx2/state.h +++ b/include/gx2/state.h @@ -1,5 +1,6 @@ #pragma once #include +#include "enum.h" /** * \defgroup gx2_state State @@ -11,15 +12,6 @@ extern "C" { #endif -typedef enum GX2InitAttributes -{ - GX2_INIT_END = 0, - GX2_INIT_CMD_BUF_BASE = 1, - GX2_INIT_CMD_BUF_POOL_SIZE = 2, - GX2_INIT_ARGC = 7, - GX2_INIT_ARGV = 8, -} GX2InitAttributes; - void GX2Init(uint32_t *attributes); diff --git a/include/gx2/surface.h b/include/gx2/surface.h index d1ef52d..75199b8 100644 --- a/include/gx2/surface.h +++ b/include/gx2/surface.h @@ -1,5 +1,6 @@ #pragma once #include +#include "enum.h" /** * \defgroup gx2_surface Surface @@ -15,163 +16,6 @@ typedef struct GX2Surface GX2Surface; typedef struct GX2DepthBuffer GX2DepthBuffer; typedef struct GX2ColorBuffer GX2ColorBuffer; -typedef enum -{ - GX2_SURFACE_DIM_TEXTURE_1D = 0, - GX2_SURFACE_DIM_TEXTURE_2D = 1, - GX2_SURFACE_DIM_TEXTURE_3D = 2, - GX2_SURFACE_DIM_TEXTURE_CUBE = 3, - GX2_SURFACE_DIM_TEXTURE_1D_ARRAY = 4, - GX2_SURFACE_DIM_TEXTURE_2D_ARRAY = 5, - GX2_SURFACE_DIM_TEXTURE_2D_MSAA = 6, - GX2_SURFACE_DIM_TEXTURE_2D_MSAA_ARRAY = 7, -} GX2SurfaceDim; - -typedef enum -{ - GX2_SURFACE_FORMAT_INVALID = 0x00, - GX2_SURFACE_FORMAT_UNORM_R4_G4 = 0x02, - GX2_SURFACE_FORMAT_UNORM_R4_G4_B4_A4 = 0x0b, - GX2_SURFACE_FORMAT_UNORM_R8 = 0x01, - GX2_SURFACE_FORMAT_UNORM_R8_G8 = 0x07, - GX2_SURFACE_FORMAT_UNORM_R8_G8_B8_A8 = 0x01a, - GX2_SURFACE_FORMAT_UNORM_R16 = 0x05, - GX2_SURFACE_FORMAT_UNORM_R16_G16 = 0x0f, - GX2_SURFACE_FORMAT_UNORM_R16_G16_B16_A16 = 0x01f, - GX2_SURFACE_FORMAT_UNORM_R5_G6_B5 = 0x08, - GX2_SURFACE_FORMAT_UNORM_R5_G5_B5_A1 = 0x0a, - GX2_SURFACE_FORMAT_UNORM_A1_B5_G5_R5 = 0x0c, - GX2_SURFACE_FORMAT_UNORM_R24_X8 = 0x011, - GX2_SURFACE_FORMAT_UNORM_A2_B10_G10_R10 = 0x01b, - GX2_SURFACE_FORMAT_UNORM_R10_G10_B10_A2 = 0x019, - GX2_SURFACE_FORMAT_UNORM_BC1 = 0x031, - GX2_SURFACE_FORMAT_UNORM_BC2 = 0x032, - GX2_SURFACE_FORMAT_UNORM_BC3 = 0x033, - GX2_SURFACE_FORMAT_UNORM_BC4 = 0x034, - GX2_SURFACE_FORMAT_UNORM_BC5 = 0x035, - GX2_SURFACE_FORMAT_UNORM_NV12 = 0x081, - - GX2_SURFACE_FORMAT_UINT_R8 = 0x101, - GX2_SURFACE_FORMAT_UINT_R8_G8 = 0x107, - GX2_SURFACE_FORMAT_UINT_R8_G8_B8_A8 = 0x11a, - GX2_SURFACE_FORMAT_UINT_R16 = 0x105, - GX2_SURFACE_FORMAT_UINT_R16_G16 = 0x10f, - GX2_SURFACE_FORMAT_UINT_R16_G16_B16_A16 = 0x11f, - GX2_SURFACE_FORMAT_UINT_R32 = 0x10d, - GX2_SURFACE_FORMAT_UINT_R32_G32 = 0x11d, - GX2_SURFACE_FORMAT_UINT_R32_G32_B32_A32 = 0x122, - GX2_SURFACE_FORMAT_UINT_A2_B10_G10_R10 = 0x11b, - GX2_SURFACE_FORMAT_UINT_R10_G10_B10_A2 = 0x119, - GX2_SURFACE_FORMAT_UINT_X24_G8 = 0x111, - GX2_SURFACE_FORMAT_UINT_G8_X24 = 0x11c, - - GX2_SURFACE_FORMAT_SNORM_R8 = 0x201, - GX2_SURFACE_FORMAT_SNORM_R8_G8 = 0x207, - GX2_SURFACE_FORMAT_SNORM_R8_G8_B8_A8 = 0x21a, - GX2_SURFACE_FORMAT_SNORM_R16 = 0x205, - GX2_SURFACE_FORMAT_SNORM_R16_G16 = 0x20f, - GX2_SURFACE_FORMAT_SNORM_R16_G16_B16_A16 = 0x21f, - GX2_SURFACE_FORMAT_SNORM_R10_G10_B10_A2 = 0x219, - GX2_SURFACE_FORMAT_SNORM_BC4 = 0x234, - GX2_SURFACE_FORMAT_SNORM_BC5 = 0x235, - - GX2_SURFACE_FORMAT_SINT_R8 = 0x301, - GX2_SURFACE_FORMAT_SINT_R8_G8 = 0x307, - GX2_SURFACE_FORMAT_SINT_R8_G8_B8_A8 = 0x31a, - GX2_SURFACE_FORMAT_SINT_R16 = 0x305, - GX2_SURFACE_FORMAT_SINT_R16_G16 = 0x30f, - GX2_SURFACE_FORMAT_SINT_R16_G16_B16_A16 = 0x31f, - GX2_SURFACE_FORMAT_SINT_R32 = 0x30d, - GX2_SURFACE_FORMAT_SINT_R32_G32 = 0x31d, - GX2_SURFACE_FORMAT_SINT_R32_G32_B32_A32 = 0x322, - GX2_SURFACE_FORMAT_SINT_R10_G10_B10_A2 = 0x319, - - GX2_SURFACE_FORMAT_SRGB_R8_G8_B8_A8 = 0x41a, - GX2_SURFACE_FORMAT_SRGB_BC1 = 0x431, - GX2_SURFACE_FORMAT_SRGB_BC2 = 0x432, - GX2_SURFACE_FORMAT_SRGB_BC3 = 0x433, - - GX2_SURFACE_FORMAT_FLOAT_R32 = 0x80e, - GX2_SURFACE_FORMAT_FLOAT_R32_G32 = 0x81e, - GX2_SURFACE_FORMAT_FLOAT_R32_G32_B32_A32 = 0x823, - GX2_SURFACE_FORMAT_FLOAT_R16 = 0x806, - GX2_SURFACE_FORMAT_FLOAT_R16_G16 = 0x810, - GX2_SURFACE_FORMAT_FLOAT_R16_G16_B16_A16 = 0x820, - GX2_SURFACE_FORMAT_FLOAT_R11_G11_B10 = 0x816, - GX2_SURFACE_FORMAT_FLOAT_D24_S8 = 0x811, - GX2_SURFACE_FORMAT_FLOAT_X8_X24 = 0x81c, -} GX2SurfaceFormat; - -typedef enum GX2AAMode -{ - GX2_AA_MODE1X = 0, -} GX2AAMode; - -typedef enum GX2SurfaceUse -{ - GX2_SURFACE_USE_TEXTURE = 1 << 0, - GX2_SURFACE_USE_COLOR_BUFFER = 1 << 1, - GX2_SURFACE_USE_DEPTH_BUFFER = 1 << 2, - GX2_SURFACE_USE_SCAN_BUFFER = 1 << 3, -} GX2SurfaceUse; - -typedef enum GX2RResourceFlags -{ - GX2R_RESOURCE_FLAGS_BIND_TEXTURE = 1 << 0, - GX2R_RESOURCE_FLAGS_BIND_COLOR_BUFFER = 1 << 1, - GX2R_RESOURCE_FLAGS_BIND_DEPTH_BUFFER = 1 << 2, - GX2R_RESOURCE_FLAGS_BIND_SCAN_BUFFER = 1 << 3, - GX2R_RESOURCE_FLAGS_BIND_VERTEX_BUFFER = 1 << 4, - GX2R_RESOURCE_FLAGS_BIND_INDEX_BUFFER = 1 << 5, - GX2R_RESOURCE_FLAGS_BIND_UNIFORM_BLOCK = 1 << 6, - GX2R_RESOURCE_FLAGS_BIND_SHADER_PROGRAM = 1 << 7, - GX2R_RESOURCE_FLAGS_BIND_STREAM_OUTPUT = 1 << 8, - GX2R_RESOURCE_FLAGS_BIND_DISPLAY_LIST = 1 << 9, - GX2R_RESOURCE_FLAGS_BIND_GS_RING = 1 << 10, - GX2R_RESOURCE_FLAGS_USAGE_CPU_READ = 1 << 11, - GX2R_RESOURCE_FLAGS_USAGE_CPU_WRITE = 1 << 12, - GX2R_RESOURCE_FLAGS_USAGE_GPU_READ = 1 << 13, - GX2R_RESOURCE_FLAGS_USAGE_GPU_WRITE = 1 << 14, - GX2R_RESOURCE_FLAGS_USAGE_DMA_READ = 1 << 15, - GX2R_RESOURCE_FLAGS_USAGE_DMA_WRITE = 1 << 16, - GX2R_RESOURCE_FLAGS_USAGE_FORCE_MEM1 = 1 << 17, - GX2R_RESOURCE_FLAGS_USAGE_FORCE_MEM2 = 1 << 18, - GX2R_RESOURCE_FLAGS_USER_MEMORY = 1 << 29, - GX2R_RESOURCE_FLAGS_LOCKED = 1 << 30, -} GX2RResourceFlags; - -typedef enum GX2TileMode -{ - GX2_TILE_MODE_DEFAULT = 0, - GX2_TILE_MODE_LINEAR_ALIGNED = 1, - GX2_TILE_MODE_TILED_1D_THIN1 = 2, - GX2_TILE_MODE_TILED_1D_THICK = 3, - GX2_TILE_MODE_TILED_2D_THIN1 = 4, - GX2_TILE_MODE_TILED_2D_THIN2 = 5, - GX2_TILE_MODE_TILED_2D_THIN4 = 6, - GX2_TILE_MODE_TILED_2D_THICK = 7, - GX2_TILE_MODE_TILED_2B_THIN1 = 8, - GX2_TILE_MODE_TILED_2B_THIN2 = 9, - GX2_TILE_MODE_TILED_2B_THIN4 = 10, - GX2_TILE_MODE_TILED_2B_THICK = 11, - GX2_TILE_MODE_TILED_3D_THIN1 = 12, - GX2_TILE_MODE_TILED_3D_THICK = 13, - GX2_TILE_MODE_TILED_3B_THIN1 = 14, - GX2_TILE_MODE_TILED_3B_THICK = 15, - GX2_TILE_MODE_LINEAR_SPECIAL = 16, -} GX2TileMode; - -typedef enum GX2RenderTarget -{ - GX2_RENDER_TARGET_0 = 0, - GX2_RENDER_TARGET_1 = 1, - GX2_RENDER_TARGET_2 = 2, - GX2_RENDER_TARGET_3 = 3, - GX2_RENDER_TARGET_4 = 4, - GX2_RENDER_TARGET_5 = 5, - GX2_RENDER_TARGET_6 = 6, -} GX2RenderTarget; - struct GX2Surface { GX2SurfaceDim dim; diff --git a/include/gx2/swap.h b/include/gx2/swap.h index b1f8d87..194ebbf 100644 --- a/include/gx2/swap.h +++ b/include/gx2/swap.h @@ -1,5 +1,6 @@ #pragma once #include +#include "enum.h" /** * \defgroup gx2_swap Swap @@ -11,12 +12,6 @@ extern "C" { #endif -typedef enum GX2ScanTarget -{ - GX2_SCAN_TARGET_TV = 1, - GX2_SCAN_TARGET_DRC = 4, -} GX2ScanTarget; - typedef struct GX2ColorBuffer GX2ColorBuffer; typedef struct GX2Texture GX2Texture;