forked from eden-emu/eden
		
	spirv: Handle small storage buffer loads on devices with no support
This commit is contained in:
		
							parent
							
								
									ca67077ca8
								
							
						
					
					
						commit
						b5e78607ad
					
				
					 2 changed files with 6 additions and 6 deletions
				
			
		|  | @ -952,13 +952,13 @@ void EmitContext::DefineStorageBuffers(const Info& info, u32& binding) { | ||||||
| 
 | 
 | ||||||
|     const IR::Type used_types{profile.support_descriptor_aliasing ? info.used_storage_buffer_types |     const IR::Type used_types{profile.support_descriptor_aliasing ? info.used_storage_buffer_types | ||||||
|                                                                   : IR::Type::U32}; |                                                                   : IR::Type::U32}; | ||||||
|     if (True(used_types & IR::Type::U8)) { |     if (profile.support_int8 && True(used_types & IR::Type::U8)) { | ||||||
|         DefineSsbos(*this, storage_types.U8, &StorageDefinitions::U8, info, binding, U8, |         DefineSsbos(*this, storage_types.U8, &StorageDefinitions::U8, info, binding, U8, | ||||||
|                     sizeof(u8)); |                     sizeof(u8)); | ||||||
|         DefineSsbos(*this, storage_types.S8, &StorageDefinitions::S8, info, binding, S8, |         DefineSsbos(*this, storage_types.S8, &StorageDefinitions::S8, info, binding, S8, | ||||||
|                     sizeof(u8)); |                     sizeof(u8)); | ||||||
|     } |     } | ||||||
|     if (True(used_types & IR::Type::U16)) { |     if (profile.support_int16 && True(used_types & IR::Type::U16)) { | ||||||
|         DefineSsbos(*this, storage_types.U16, &StorageDefinitions::U16, info, binding, U16, |         DefineSsbos(*this, storage_types.U16, &StorageDefinitions::U16, info, binding, U16, | ||||||
|                     sizeof(u16)); |                     sizeof(u16)); | ||||||
|         DefineSsbos(*this, storage_types.S16, &StorageDefinitions::S16, info, binding, S16, |         DefineSsbos(*this, storage_types.S16, &StorageDefinitions::S16, info, binding, S16, | ||||||
|  |  | ||||||
|  | @ -124,7 +124,7 @@ void EmitWriteGlobal128(EmitContext& ctx, Id address, Id value) { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Id EmitLoadStorageU8(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset) { | Id EmitLoadStorageU8(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset) { | ||||||
|     if (ctx.profile.support_descriptor_aliasing) { |     if (ctx.profile.support_int8 && ctx.profile.support_descriptor_aliasing) { | ||||||
|         return ctx.OpUConvert(ctx.U32[1], |         return ctx.OpUConvert(ctx.U32[1], | ||||||
|                               LoadStorage(ctx, binding, offset, ctx.U8, ctx.storage_types.U8, |                               LoadStorage(ctx, binding, offset, ctx.U8, ctx.storage_types.U8, | ||||||
|                                           sizeof(u8), &StorageDefinitions::U8)); |                                           sizeof(u8), &StorageDefinitions::U8)); | ||||||
|  | @ -135,7 +135,7 @@ Id EmitLoadStorageU8(EmitContext& ctx, const IR::Value& binding, const IR::Value | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Id EmitLoadStorageS8(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset) { | Id EmitLoadStorageS8(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset) { | ||||||
|     if (ctx.profile.support_descriptor_aliasing) { |     if (ctx.profile.support_int8 && ctx.profile.support_descriptor_aliasing) { | ||||||
|         return ctx.OpSConvert(ctx.U32[1], |         return ctx.OpSConvert(ctx.U32[1], | ||||||
|                               LoadStorage(ctx, binding, offset, ctx.S8, ctx.storage_types.S8, |                               LoadStorage(ctx, binding, offset, ctx.S8, ctx.storage_types.S8, | ||||||
|                                           sizeof(s8), &StorageDefinitions::S8)); |                                           sizeof(s8), &StorageDefinitions::S8)); | ||||||
|  | @ -146,7 +146,7 @@ Id EmitLoadStorageS8(EmitContext& ctx, const IR::Value& binding, const IR::Value | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Id EmitLoadStorageU16(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset) { | Id EmitLoadStorageU16(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset) { | ||||||
|     if (ctx.profile.support_descriptor_aliasing) { |     if (ctx.profile.support_int16 && ctx.profile.support_descriptor_aliasing) { | ||||||
|         return ctx.OpUConvert(ctx.U32[1], |         return ctx.OpUConvert(ctx.U32[1], | ||||||
|                               LoadStorage(ctx, binding, offset, ctx.U16, ctx.storage_types.U16, |                               LoadStorage(ctx, binding, offset, ctx.U16, ctx.storage_types.U16, | ||||||
|                                           sizeof(u16), &StorageDefinitions::U16)); |                                           sizeof(u16), &StorageDefinitions::U16)); | ||||||
|  | @ -157,7 +157,7 @@ Id EmitLoadStorageU16(EmitContext& ctx, const IR::Value& binding, const IR::Valu | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Id EmitLoadStorageS16(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset) { | Id EmitLoadStorageS16(EmitContext& ctx, const IR::Value& binding, const IR::Value& offset) { | ||||||
|     if (ctx.profile.support_descriptor_aliasing) { |     if (ctx.profile.support_int16 && ctx.profile.support_descriptor_aliasing) { | ||||||
|         return ctx.OpSConvert(ctx.U32[1], |         return ctx.OpSConvert(ctx.U32[1], | ||||||
|                               LoadStorage(ctx, binding, offset, ctx.S16, ctx.storage_types.S16, |                               LoadStorage(ctx, binding, offset, ctx.S16, ctx.storage_types.S16, | ||||||
|                                           sizeof(s16), &StorageDefinitions::S16)); |                                           sizeof(s16), &StorageDefinitions::S16)); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ReinUsesLisp
						ReinUsesLisp