Skip to content

Commit

Permalink
Remove support for border colors (thatcosmonaut#50)
Browse files Browse the repository at this point in the history
  • Loading branch information
TheSpydog authored and flibitijibibo committed Aug 16, 2024
1 parent 36d9cc6 commit 77e3f56
Show file tree
Hide file tree
Showing 4 changed files with 7 additions and 78 deletions.
15 changes: 1 addition & 14 deletions include/SDL3/SDL_gpu.h
Original file line number Diff line number Diff line change
Expand Up @@ -319,21 +319,9 @@ typedef enum SDL_GpuSamplerAddressMode
{
SDL_GPU_SAMPLERADDRESSMODE_REPEAT,
SDL_GPU_SAMPLERADDRESSMODE_MIRRORED_REPEAT,
SDL_GPU_SAMPLERADDRESSMODE_CLAMP_TO_EDGE,
SDL_GPU_SAMPLERADDRESSMODE_CLAMP_TO_BORDER
SDL_GPU_SAMPLERADDRESSMODE_CLAMP_TO_EDGE
} SDL_GpuSamplerAddressMode;

/* FIXME: we should probably make a library-level decision about color types */
typedef enum SDL_GpuBorderColor
{
SDL_GPU_BORDERCOLOR_FLOAT_TRANSPARENT_BLACK,
SDL_GPU_BORDERCOLOR_INT_TRANSPARENT_BLACK,
SDL_GPU_BORDERCOLOR_FLOAT_OPAQUE_BLACK,
SDL_GPU_BORDERCOLOR_INT_OPAQUE_BLACK,
SDL_GPU_BORDERCOLOR_FLOAT_OPAQUE_WHITE,
SDL_GPU_BORDERCOLOR_INT_OPAQUE_WHITE
} SDL_GpuBorderColor;

/*
* VSYNC:
* Waits for vblank before presenting.
Expand Down Expand Up @@ -486,7 +474,6 @@ typedef struct SDL_GpuSamplerCreateInfo
SDL_GpuCompareOp compareOp;
float minLod;
float maxLod;
SDL_GpuBorderColor borderColor;
} SDL_GpuSamplerCreateInfo;

typedef struct SDL_GpuVertexBinding
Expand Down
41 changes: 2 additions & 39 deletions src/gpu/d3d11/SDL_gpu_d3d11.c
Original file line number Diff line number Diff line change
Expand Up @@ -374,41 +374,9 @@ static D3D11_INPUT_CLASSIFICATION SDLToD3D11_VertexInputRate[] = {
static D3D11_TEXTURE_ADDRESS_MODE SDLToD3D11_SamplerAddressMode[] = {
D3D11_TEXTURE_ADDRESS_WRAP, /* REPEAT */
D3D11_TEXTURE_ADDRESS_MIRROR, /* MIRRORED_REPEAT */
D3D11_TEXTURE_ADDRESS_CLAMP, /* CLAMP_TO_EDGE */
D3D11_TEXTURE_ADDRESS_BORDER /* CLAMP_TO_BORDER */
D3D11_TEXTURE_ADDRESS_CLAMP /* CLAMP_TO_EDGE */
};

static void SDLToD3D11_BorderColor(
SDL_GpuSamplerCreateInfo *createInfo,
D3D11_SAMPLER_DESC *desc)
{
switch (createInfo->borderColor) {
case SDL_GPU_BORDERCOLOR_FLOAT_OPAQUE_BLACK:
case SDL_GPU_BORDERCOLOR_INT_OPAQUE_BLACK:
desc->BorderColor[0] = 0.0f;
desc->BorderColor[1] = 0.0f;
desc->BorderColor[2] = 0.0f;
desc->BorderColor[3] = 1.0f;
break;

case SDL_GPU_BORDERCOLOR_FLOAT_OPAQUE_WHITE:
case SDL_GPU_BORDERCOLOR_INT_OPAQUE_WHITE:
desc->BorderColor[0] = 1.0f;
desc->BorderColor[1] = 1.0f;
desc->BorderColor[2] = 1.0f;
desc->BorderColor[3] = 1.0f;
break;

case SDL_GPU_BORDERCOLOR_FLOAT_TRANSPARENT_BLACK:
case SDL_GPU_BORDERCOLOR_INT_TRANSPARENT_BLACK:
desc->BorderColor[0] = 0.0f;
desc->BorderColor[1] = 0.0f;
desc->BorderColor[2] = 0.0f;
desc->BorderColor[3] = 0.0f;
break;
}
}

static D3D11_FILTER SDLToD3D11_Filter(SDL_GpuSamplerCreateInfo *createInfo)
{
if (createInfo->minFilter == SDL_GPU_FILTER_LINEAR) {
Expand Down Expand Up @@ -1875,17 +1843,13 @@ static SDL_GpuSampler *D3D11_CreateSampler(
samplerDesc.AddressU = SDLToD3D11_SamplerAddressMode[samplerCreateInfo->addressModeU];
samplerDesc.AddressV = SDLToD3D11_SamplerAddressMode[samplerCreateInfo->addressModeV];
samplerDesc.AddressW = SDLToD3D11_SamplerAddressMode[samplerCreateInfo->addressModeW];

SDLToD3D11_BorderColor(
samplerCreateInfo,
&samplerDesc);

samplerDesc.ComparisonFunc = (samplerCreateInfo->compareEnable ? SDLToD3D11_CompareOp[samplerCreateInfo->compareOp] : SDLToD3D11_CompareOp[SDL_GPU_COMPAREOP_ALWAYS]);
samplerDesc.MaxAnisotropy = (samplerCreateInfo->anisotropyEnable ? (UINT)samplerCreateInfo->maxAnisotropy : 0);
samplerDesc.Filter = SDLToD3D11_Filter(samplerCreateInfo);
samplerDesc.MaxLOD = samplerCreateInfo->maxLod;
samplerDesc.MinLOD = samplerCreateInfo->minLod;
samplerDesc.MipLODBias = samplerCreateInfo->mipLodBias;
SDL_zeroa(samplerDesc.BorderColor); /* arbitrary, unused */

res = ID3D11Device_CreateSamplerState(
renderer->device,
Expand Down Expand Up @@ -6059,7 +6023,6 @@ static void D3D11_INTERNAL_InitBlitPipelines(
samplerCreateInfo.mipLodBias = 0.0f;
samplerCreateInfo.minLod = 0;
samplerCreateInfo.maxLod = 1000;
samplerCreateInfo.borderColor = SDL_GPU_BORDERCOLOR_FLOAT_TRANSPARENT_BLACK;

renderer->blitNearestSampler = D3D11_CreateSampler(
(SDL_GpuRenderer *)renderer,
Expand Down
15 changes: 2 additions & 13 deletions src/gpu/metal/SDL_gpu_metal.m
Original file line number Diff line number Diff line change
Expand Up @@ -250,17 +250,7 @@ static void METAL_UnclaimWindow(
static MTLSamplerAddressMode SDLToMetal_SamplerAddressMode[] = {
MTLSamplerAddressModeRepeat, /* REPEAT */
MTLSamplerAddressModeMirrorRepeat, /* MIRRORED_REPEAT */
MTLSamplerAddressModeClampToEdge, /* CLAMP_TO_EDGE */
MTLSamplerAddressModeClampToBorderColor, /* CLAMP_TO_BORDER */
};

static MTLSamplerBorderColor SDLToMetal_BorderColor[] = {
MTLSamplerBorderColorTransparentBlack, /* FLOAT_TRANSPARENT_BLACK */
MTLSamplerBorderColorTransparentBlack, /* INT_TRANSPARENT_BLACK */
MTLSamplerBorderColorOpaqueBlack, /* FLOAT_OPAQUE_BLACK */
MTLSamplerBorderColorOpaqueBlack, /* INT_OPAQUE_BLACK */
MTLSamplerBorderColorOpaqueWhite, /* FLOAT_OPAQUE_WHITE */
MTLSamplerBorderColorOpaqueWhite, /* INT_OPAQUE_WHITE */
MTLSamplerAddressModeClampToEdge /* CLAMP_TO_EDGE */
};

static MTLSamplerMinMagFilter SDLToMetal_MinMagFilter[] = {
Expand Down Expand Up @@ -1163,14 +1153,14 @@ static void METAL_PopDebugGroup(
samplerDesc.rAddressMode = SDLToMetal_SamplerAddressMode[samplerCreateInfo->addressModeU];
samplerDesc.sAddressMode = SDLToMetal_SamplerAddressMode[samplerCreateInfo->addressModeV];
samplerDesc.tAddressMode = SDLToMetal_SamplerAddressMode[samplerCreateInfo->addressModeW];
samplerDesc.borderColor = SDLToMetal_BorderColor[samplerCreateInfo->borderColor];
samplerDesc.minFilter = SDLToMetal_MinMagFilter[samplerCreateInfo->minFilter];
samplerDesc.magFilter = SDLToMetal_MinMagFilter[samplerCreateInfo->magFilter];
samplerDesc.mipFilter = SDLToMetal_MipFilter[samplerCreateInfo->mipmapMode]; /* FIXME: Is this right with non-mipmapped samplers? */
samplerDesc.lodMinClamp = samplerCreateInfo->minLod;
samplerDesc.lodMaxClamp = samplerCreateInfo->maxLod;
samplerDesc.maxAnisotropy = (NSUInteger)((samplerCreateInfo->anisotropyEnable) ? samplerCreateInfo->maxAnisotropy : 1);
samplerDesc.compareFunction = (samplerCreateInfo->compareEnable) ? SDLToMetal_CompareOp[samplerCreateInfo->compareOp] : MTLCompareFunctionAlways;
samplerDesc.borderColor = MTLSamplerBorderColorTransparentBlack; /* arbitrary, unused */

sampler = [renderer->device newSamplerStateWithDescriptor:samplerDesc];
if (sampler == NULL) {
Expand Down Expand Up @@ -3619,7 +3609,6 @@ static void METAL_INTERNAL_InitBlitResources(
samplerCreateInfo.mipLodBias = 0.0f;
samplerCreateInfo.minLod = 0;
samplerCreateInfo.maxLod = 1000;
samplerCreateInfo.borderColor = SDL_GPU_BORDERCOLOR_FLOAT_TRANSPARENT_BLACK;

renderer->blitNearestSampler = METAL_CreateSampler(
(SDL_GpuRenderer *)renderer,
Expand Down
14 changes: 2 additions & 12 deletions src/gpu/vulkan/SDL_gpu_vulkan.c
Original file line number Diff line number Diff line change
Expand Up @@ -324,17 +324,7 @@ static VkSamplerMipmapMode SDLToVK_SamplerMipmapMode[] = {
static VkSamplerAddressMode SDLToVK_SamplerAddressMode[] = {
VK_SAMPLER_ADDRESS_MODE_REPEAT,
VK_SAMPLER_ADDRESS_MODE_MIRRORED_REPEAT,
VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE,
VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER
};

static VkBorderColor SDLToVK_BorderColor[] = {
VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK,
VK_BORDER_COLOR_INT_TRANSPARENT_BLACK,
VK_BORDER_COLOR_FLOAT_OPAQUE_BLACK,
VK_BORDER_COLOR_INT_OPAQUE_BLACK,
VK_BORDER_COLOR_FLOAT_OPAQUE_WHITE,
VK_BORDER_COLOR_INT_OPAQUE_WHITE
VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_EDGE
};

/* Structures */
Expand Down Expand Up @@ -6599,7 +6589,7 @@ static SDL_GpuSampler *VULKAN_CreateSampler(
vkSamplerCreateInfo.compareOp = SDLToVK_CompareOp[samplerCreateInfo->compareOp];
vkSamplerCreateInfo.minLod = samplerCreateInfo->minLod;
vkSamplerCreateInfo.maxLod = samplerCreateInfo->maxLod;
vkSamplerCreateInfo.borderColor = SDLToVK_BorderColor[samplerCreateInfo->borderColor];
vkSamplerCreateInfo.borderColor = VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK; /* arbitrary, unused */
vkSamplerCreateInfo.unnormalizedCoordinates = VK_FALSE;

vulkanResult = renderer->vkCreateSampler(
Expand Down

0 comments on commit 77e3f56

Please sign in to comment.