#[cfg(target_arch = "spirv")]
use core::arch::asm;
use core::marker::PhantomData;
#[spirv(runtime_array)]
#[repr(C)]
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 {
let mut result_slot = core::mem::MaybeUninit::uninit();
asm! {
"%result = OpAccessChain _ {arr} {index}",
"OpStore {result_slot} %result",
arr = in(reg) self,
index = in(reg) index,
result_slot = in(reg) result_slot.as_mut_ptr(),
}
result_slot.assume_init()
}
#[spirv_std_macros::gpu_only]
pub unsafe fn index_mut(&mut self, index: usize) -> &mut T {
let mut result_slot = core::mem::MaybeUninit::uninit();
asm! {
"%result = OpAccessChain _ {arr} {index}",
"OpStore {result_slot} %result",
arr = in(reg) self,
index = in(reg) index,
result_slot = in(reg) result_slot.as_mut_ptr(),
}
result_slot.assume_init()
}
}