glsl: SSBO access fixes and wip SampleExplicitLod implementation.
This commit is contained in:
		| @@ -46,7 +46,20 @@ void EmitImageSampleExplicitLod([[maybe_unused]] EmitContext& ctx, [[maybe_unuse | |||||||
|                                 [[maybe_unused]] std::string_view coords, |                                 [[maybe_unused]] std::string_view coords, | ||||||
|                                 [[maybe_unused]] std::string_view lod_lc, |                                 [[maybe_unused]] std::string_view lod_lc, | ||||||
|                                 [[maybe_unused]] const IR::Value& offset) { |                                 [[maybe_unused]] const IR::Value& offset) { | ||||||
|     throw NotImplementedException("GLSL Instruction"); |     const auto info{inst.Flags<IR::TextureInstInfo>()}; | ||||||
|  |     if (info.has_bias) { | ||||||
|  |         throw NotImplementedException("Bias texture samples"); | ||||||
|  |     } | ||||||
|  |     if (info.has_lod_clamp) { | ||||||
|  |         throw NotImplementedException("Lod clamp samples"); | ||||||
|  |     } | ||||||
|  |     const auto texture{Texture(ctx, info, index)}; | ||||||
|  |     if (!offset.IsEmpty()) { | ||||||
|  |         ctx.AddF32x4("{}=textureLodOffset({},{},{},ivec2({}));", inst, texture, coords, lod_lc, | ||||||
|  |                      ctx.reg_alloc.Consume(offset)); | ||||||
|  |     } else { | ||||||
|  |         ctx.AddF32x4("{}=textureLod({},{},{});", inst, texture, coords, lod_lc); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| void EmitImageSampleDrefImplicitLod([[maybe_unused]] EmitContext& ctx, | void EmitImageSampleDrefImplicitLod([[maybe_unused]] EmitContext& ctx, | ||||||
|   | |||||||
| @@ -81,13 +81,15 @@ void EmitWriteStorageS16([[maybe_unused]] EmitContext& ctx, | |||||||
|  |  | ||||||
| void EmitWriteStorage32(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | void EmitWriteStorage32(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||||
|                         std::string_view value) { |                         std::string_view value) { | ||||||
|     ctx.Add("ssbo{}[{}]={};", binding.U32(), offset.U32(), value); |     const auto offset_var{ctx.reg_alloc.Consume(offset)}; | ||||||
|  |     ctx.Add("ssbo{}[{}]={};", binding.U32(), offset_var, value); | ||||||
| } | } | ||||||
|  |  | ||||||
| void EmitWriteStorage64(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | void EmitWriteStorage64(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset, | ||||||
|                         std::string_view value) { |                         std::string_view value) { | ||||||
|     ctx.Add("ssbo{}[{}]={}.x;", binding.U32(), offset.U32(), value); |     const auto offset_var{ctx.reg_alloc.Consume(offset)}; | ||||||
|     ctx.Add("ssbo{}[{}]={}.y;", binding.U32(), offset.U32() + 1, value); |     ctx.Add("ssbo{}[{}]={}.x;", binding.U32(), offset_var, value); | ||||||
|  |     ctx.Add("ssbo{}[{}+1]={}.y;", binding.U32(), offset_var, value); | ||||||
| } | } | ||||||
|  |  | ||||||
| void EmitWriteStorage128([[maybe_unused]] EmitContext& ctx, | void EmitWriteStorage128([[maybe_unused]] EmitContext& ctx, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user