#[cfg(target_arch = "spirv")]
use core::arch::asm;
use core::marker::PhantomData;
#[spirv(runtime_array)]
#[repr(C)]
#[allow(dead_code)]
pub struct RuntimeArray<T> {
_anti_zst_padding: core::mem::MaybeUninit<u32>,
_phantom: PhantomData<T>,
}
impl<T> RuntimeArray<T> {
#[spirv_std_macros::gpu_only]
pub unsafe fn index(&self, index: usize) -> &T {
unsafe {
let mut result = core::mem::MaybeUninit::uninit();
asm! {
"OpDecorate %index NonUniform",
"OpDecorate %result NonUniform",
"%index = OpLoad _ {index}",
"%result = OpAccessChain typeof*{result} {this} %index",
"OpStore {result} %result",
result = in(reg) result.as_mut_ptr(),
this = in(reg) self,
index = in(reg) &index,
}
result.assume_init()
}
}
#[spirv_std_macros::gpu_only]
pub unsafe fn index_mut(&mut self, index: usize) -> &mut T {
unsafe {
let mut result = core::mem::MaybeUninit::uninit();
asm! {
"OpDecorate %index NonUniform",
"OpDecorate %result NonUniform",
"%index = OpLoad _ {index}",
"%result = OpAccessChain typeof*{result} {this} %index",
"OpStore {result} %result",
result = in(reg) result.as_mut_ptr(),
this = in(reg) self,
index = in(reg) &index,
}
result.assume_init()
}
}
}