mirror of
				https://git.suyu.dev/suyu/suyu.git
				synced 2025-10-26 20:36:48 +08:00 
			
		
		
		
	Merge pull request #12903 from liamwhite/const-offset
shader_recompiler: use only ConstOffset for OpImageFetch
This commit is contained in:
		
						commit
						f049453dd6
					
				| @ -60,10 +60,11 @@ public: | |||||||
|         Add(spv::ImageOperandsMask::ConstOffsets, offsets); |         Add(spv::ImageOperandsMask::ConstOffsets, offsets); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     explicit ImageOperands(Id lod, Id ms) { |     explicit ImageOperands(EmitContext& ctx, const IR::Value& offset, Id lod, Id ms) { | ||||||
|         if (Sirit::ValidId(lod)) { |         if (Sirit::ValidId(lod)) { | ||||||
|             Add(spv::ImageOperandsMask::Lod, lod); |             Add(spv::ImageOperandsMask::Lod, lod); | ||||||
|         } |         } | ||||||
|  |         AddOffset(ctx, offset, ImageFetchOffsetAllowed); | ||||||
|         if (Sirit::ValidId(ms)) { |         if (Sirit::ValidId(ms)) { | ||||||
|             Add(spv::ImageOperandsMask::Sample, ms); |             Add(spv::ImageOperandsMask::Sample, ms); | ||||||
|         } |         } | ||||||
| @ -311,37 +312,6 @@ Id ImageGatherSubpixelOffset(EmitContext& ctx, const IR::TextureInstInfo& info, | |||||||
|         return coords; |         return coords; | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 |  | ||||||
| void AddOffsetToCoordinates(EmitContext& ctx, const IR::TextureInstInfo& info, Id& coords, |  | ||||||
|                             Id offset) { |  | ||||||
|     if (!Sirit::ValidId(offset)) { |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     Id result_type{}; |  | ||||||
|     switch (info.type) { |  | ||||||
|     case TextureType::Buffer: |  | ||||||
|     case TextureType::Color1D: |  | ||||||
|     case TextureType::ColorArray1D: { |  | ||||||
|         result_type = ctx.U32[1]; |  | ||||||
|         break; |  | ||||||
|     } |  | ||||||
|     case TextureType::Color2D: |  | ||||||
|     case TextureType::Color2DRect: |  | ||||||
|     case TextureType::ColorArray2D: { |  | ||||||
|         result_type = ctx.U32[2]; |  | ||||||
|         break; |  | ||||||
|     } |  | ||||||
|     case TextureType::Color3D: { |  | ||||||
|         result_type = ctx.U32[3]; |  | ||||||
|         break; |  | ||||||
|     } |  | ||||||
|     case TextureType::ColorCube: |  | ||||||
|     case TextureType::ColorArrayCube: |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
|     coords = ctx.OpIAdd(result_type, coords, offset); |  | ||||||
| } |  | ||||||
| } // Anonymous namespace
 | } // Anonymous namespace
 | ||||||
| 
 | 
 | ||||||
| Id EmitBindlessImageSampleImplicitLod(EmitContext&) { | Id EmitBindlessImageSampleImplicitLod(EmitContext&) { | ||||||
| @ -524,10 +494,9 @@ Id EmitImageGatherDref(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, | |||||||
|                 operands.Span()); |                 operands.Span()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Id EmitImageFetch(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id coords, Id offset, | Id EmitImageFetch(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id coords, | ||||||
|                   Id lod, Id ms) { |                   const IR::Value& offset, Id lod, Id ms) { | ||||||
|     const auto info{inst->Flags<IR::TextureInstInfo>()}; |     const auto info{inst->Flags<IR::TextureInstInfo>()}; | ||||||
|     AddOffsetToCoordinates(ctx, info, coords, offset); |  | ||||||
|     if (info.type == TextureType::Buffer) { |     if (info.type == TextureType::Buffer) { | ||||||
|         lod = Id{}; |         lod = Id{}; | ||||||
|     } |     } | ||||||
| @ -535,7 +504,7 @@ Id EmitImageFetch(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id c | |||||||
|         // This image is multisampled, lod must be implicit
 |         // This image is multisampled, lod must be implicit
 | ||||||
|         lod = Id{}; |         lod = Id{}; | ||||||
|     } |     } | ||||||
|     const ImageOperands operands(lod, ms); |     const ImageOperands operands(ctx, offset, lod, ms); | ||||||
|     return Emit(&EmitContext::OpImageSparseFetch, &EmitContext::OpImageFetch, ctx, inst, ctx.F32[4], |     return Emit(&EmitContext::OpImageSparseFetch, &EmitContext::OpImageFetch, ctx, inst, ctx.F32[4], | ||||||
|                 TextureImage(ctx, info, index), coords, operands.MaskOptional(), operands.Span()); |                 TextureImage(ctx, info, index), coords, operands.MaskOptional(), operands.Span()); | ||||||
| } | } | ||||||
|  | |||||||
| @ -537,8 +537,8 @@ Id EmitImageGather(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id | |||||||
|                    const IR::Value& offset, const IR::Value& offset2); |                    const IR::Value& offset, const IR::Value& offset2); | ||||||
| Id EmitImageGatherDref(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id coords, | Id EmitImageGatherDref(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id coords, | ||||||
|                        const IR::Value& offset, const IR::Value& offset2, Id dref); |                        const IR::Value& offset, const IR::Value& offset2, Id dref); | ||||||
| Id EmitImageFetch(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id coords, Id offset, | Id EmitImageFetch(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id coords, | ||||||
|                   Id lod, Id ms); |                   const IR::Value& offset, Id lod, Id ms); | ||||||
| Id EmitImageQueryDimensions(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id lod, | Id EmitImageQueryDimensions(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id lod, | ||||||
|                             const IR::Value& skip_mips); |                             const IR::Value& skip_mips); | ||||||
| Id EmitImageQueryLod(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id coords); | Id EmitImageQueryLod(EmitContext& ctx, IR::Inst* inst, const IR::Value& index, Id coords); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user