diff --git a/pxr/imaging/hgiMetal/blitCmds.mm b/pxr/imaging/hgiMetal/blitCmds.mm index b03dc94aca..48486bbc86 100644 --- a/pxr/imaging/hgiMetal/blitCmds.mm +++ b/pxr/imaging/hgiMetal/blitCmds.mm @@ -444,29 +444,46 @@ } static bool -_HgiCanBeFiltered(HgiFormat format) +_HgiTextureCanBeFiltered(HgiTextureDesc const &descriptor) { - HgiFormat const componentFormat = HgiGetComponentBaseFormat(format); + HgiFormat const componentFormat = + HgiGetComponentBaseFormat(descriptor.format); - switch(componentFormat) { - case HgiFormatInt16: - case HgiFormatUInt16: - case HgiFormatInt32: + if (componentFormat == HgiFormatInt16 || + componentFormat == HgiFormatUInt16 || + componentFormat == HgiFormatInt32) { return false; - default: - return true; } + + GfVec3i const dims = descriptor.dimensions; + switch (descriptor.type) { + case HgiTextureType1D: + case HgiTextureType1DArray: + return (dims[0] > 1); + + case HgiTextureType2D: + case HgiTextureType2DArray: + return (dims[0] > 1 || dims[1] > 1); + + case HgiTextureType3D: + return (dims[0] > 1 || dims[1] > 1 || dims[2] > 1); + + default: + TF_CODING_ERROR("Unsupported HgiTextureType enum value"); + return false; + } + + return false; } void HgiMetalBlitCmds::GenerateMipMaps(HgiTextureHandle const& texture) { HgiMetalTexture* metalTex = static_cast(texture.Get()); + if (metalTex) { - HgiFormat const format = metalTex->GetDescriptor().format; - if (_HgiCanBeFiltered(format)) { + if (_HgiTextureCanBeFiltered(metalTex->GetDescriptor())) { _CreateEncoder(); - // Can fail if the texture format is not filterable. [_blitEncoder generateMipmapsForTexture:metalTex->GetTextureId()]; } }