[Mesa-dev] [PATCH 18.0] swr/rast: Fix index buffer overfetch issue for non-indexed draws
Cherniak, Bruce
bruce.cherniak at intel.com
Wed Feb 28 20:55:59 UTC 2018
Reviewed-by: Bruce Cherniak <bruce.cherniak at intel.com>
> On Feb 28, 2018, at 1:16 PM, George Kyriazis <george.kyriazis at intel.com> wrote:
>
> Populate pLastIndex, even for the non-indexed case. An zero pLastIndex
> can cause the index offsets inside the fetcher to have non-sensical values
> that can be either very large positive or very large negative numbers.
>
> Cherry-pick of 539de78633 for 18.0. Surrounding context is different for
> 18.0 branch, hence the need for a separate patch.
>
> cc: "18.0" <mesa-stable at lists.freedesktop.org>
> ---
> src/gallium/drivers/swr/rasterizer/core/frontend.cpp | 15 +++++++++++++++
> 1 file changed, 15 insertions(+)
>
> diff --git a/src/gallium/drivers/swr/rasterizer/core/frontend.cpp b/src/gallium/drivers/swr/rasterizer/core/frontend.cpp
> index 9600f78..ce6cb68 100644
> --- a/src/gallium/drivers/swr/rasterizer/core/frontend.cpp
> +++ b/src/gallium/drivers/swr/rasterizer/core/frontend.cpp
> @@ -1724,6 +1724,21 @@ void ProcessDraw(
>
> if (i < endVertex)
> {
> + if (!IsIndexedT::value)
> + {
> + fetchInfo_lo.pLastIndex = fetchInfo_lo.pIndices;
> + uint32_t offset;
> + offset = std::min(endVertex-i, (uint32_t) KNOB_SIMD16_WIDTH);
> +#if USE_SIMD16_SHADERS
> + fetchInfo_lo.pLastIndex += offset;
> +#else
> + fetchInfo_lo.pLastIndex += std::min(offset, (uint32_t) KNOB_SIMD_WIDTH);
> + uint32_t offset2 = std::min(offset, (uint32_t) KNOB_SIMD16_WIDTH)-KNOB_SIMD_WIDTH;
> + assert(offset >= 0);
> + fetchInfo_hi.pLastIndex = fetchInfo_hi.pIndices;
> + fetchInfo_hi.pLastIndex += offset2;
> +#endif
> + }
> // 1. Execute FS/VS for a single SIMD.
> AR_BEGIN(FEFetchShader, pDC->drawId);
> #if USE_SIMD16_SHADERS
> --
> 2.7.4
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/mesa-dev
More information about the mesa-dev
mailing list