From 83d3ddd0ec49efd02bdbfeb2b44ae9206c087d34 Mon Sep 17 00:00:00 2001 From: Alok Hota Date: Mon, 25 Jun 2018 09:52:17 -0500 Subject: [PATCH] swr/rast: Adding SCATTERPS functionality to BuilderGfxMem Reviewed-by: Bruce Cherniak --- .../swr/rasterizer/jitter/builder_gfx_mem.cpp | 13 +++++++++++++ .../drivers/swr/rasterizer/jitter/builder_gfx_mem.h | 6 ++++++ 2 files changed, 19 insertions(+) diff --git a/src/gallium/drivers/swr/rasterizer/jitter/builder_gfx_mem.cpp b/src/gallium/drivers/swr/rasterizer/jitter/builder_gfx_mem.cpp index 8706bfa66bf..df11914db13 100644 --- a/src/gallium/drivers/swr/rasterizer/jitter/builder_gfx_mem.cpp +++ b/src/gallium/drivers/swr/rasterizer/jitter/builder_gfx_mem.cpp @@ -108,6 +108,19 @@ namespace SwrJit return vGather; } + void BuilderGfxMem::SCATTERPS( + Value* pDst, Value* vSrc, Value* vOffsets, Value* vMask, JIT_MEM_CLIENT usage) + { + + // address may be coming in as 64bit int now so get the pointer + if (pDst->getType() == mInt64Ty) + { + pDst = INT_TO_PTR(pDst, PointerType::get(mInt8Ty, 0)); + } + + Builder::SCATTERPS(pDst, vSrc, vOffsets, vMask, usage); + } + Value *BuilderGfxMem::OFFSET_TO_NEXT_COMPONENT(Value *base, Constant *offset) { diff --git a/src/gallium/drivers/swr/rasterizer/jitter/builder_gfx_mem.h b/src/gallium/drivers/swr/rasterizer/jitter/builder_gfx_mem.h index a552ff9b260..dd20c06afef 100644 --- a/src/gallium/drivers/swr/rasterizer/jitter/builder_gfx_mem.h +++ b/src/gallium/drivers/swr/rasterizer/jitter/builder_gfx_mem.h @@ -88,6 +88,12 @@ namespace SwrJit uint8_t scale = 1, JIT_MEM_CLIENT usage = MEM_CLIENT_INTERNAL); + virtual void SCATTERPS(Value* pDst, + Value* vSrc, + Value* vOffsets, + Value* vMask, + JIT_MEM_CLIENT usage = MEM_CLIENT_INTERNAL); + Value *TranslateGfxAddressForRead(Value * xpGfxAddress, Type * PtrTy = nullptr, -- 2.30.2