9#include <spirv/unified1/spirv.h>
11#define wrd_caps h_ctx->m_section.m_capability
12#define wrd_caps_count h_ctx->m_count.m_capability
14#define wrd_ext h_ctx->m_section.m_ext
15#define wrd_ext_count h_ctx->m_count.m_ext
18 const h_util_ctx_t h_ctx
24 h_ctx
->m_id = ID_DEFAULT_END;
26 h_ctx->m_count.m_capability = 0;
27 h_ctx->m_count.m_ext = 0;
28 h_ctx->m_count.m_memmodel = 0;
29 h_ctx->m_count.m_entp = 0;
30 h_ctx->m_count.m_execmode = 0;
31 h_ctx->m_count.m_name = 0;
32 h_ctx->m_count.m_decorate = 0;
33 h_ctx->m_count.m_types = 0;
34 h_ctx->m_count.m_vars = 0;
35 h_ctx->m_count.m_fndef = 0;
43 , SpvCapabilityShader))
44 return ACLSPV_COMPILE_ALLOC_FAILED;
47 h_ctx->m_is_for_gl = 1;
54 , SpvCapabilityAddresses))
55 return ACLSPV_COMPILE_ALLOC_FAILED;
58 unless(h_ctx->m_is_for_gl) {
63 , SpvCapabilityVulkanMemoryModel))
64 return ACLSPV_COMPILE_ALLOC_FAILED;
68 return ACLSPV_COMPILE_ALLOC_FAILED;
70 ,
"SPV_KHR_vulkan_memory_model"))
71 return ACLSPV_COMPILE_ALLOC_FAILED;
78 return ACLSPV_COMPILE_ALLOC_FAILED;
80 return ACLSPV_COMPILE_ALLOC_FAILED;
85 &h_ctx->m_section.m_memmodel
88 ? SpvAddressingModelLogical
89 : h_ctx->m_is_buffer_64 ? SpvAddressingModelPhysical64 : SpvAddressingModelPhysical32
90 , h_ctx->m_is_for_gl ? SpvMemoryModelGLSL450 : SpvMemoryModelVulkan))
91 return ACLSPV_COMPILE_ALLOC_FAILED;
93 return ACLSPV_COMPILE_OK;
#define ae2f_WhenCXX(a)
Appears when the current language is C.
#define ae2f_WhenC(a)
Appears when the current language is C++.
#define unless(a)
Invokes when condition is false.
#define ae2f_extern
Suggests the existence of external variable or function, in naming of C. [non-mangling].
#define ACLSPV_ABI_DECL
Declaration as ABI.
#define ae2f_assume(a)
tells the compiler that value if a is false, below this keyword is not expected to be reached.
#define ae2f_unexpected_but_if(a)
#define ae2f_ccpure
Keyword as [[pure]] on C23.
#define ae2f_expected_but_else(a)
#define ae2f_expected_if(a)
#define ae2f_ccconst
Keyword as [[const]] on C23..
#define ae2f_noexcept
marker that this function does not throw something.
#define ae2f_restrict
Keyword as restrict on C99.
#define ae2f_expected_not(a)
expectes a as false.
#define ae2f_unreachable()
tells the compiler that below this keyword is not expected to be reached.
#define ae2f_inline
inline
#define ae2f_expected(a)
expectes a as true.
#define util_emitx_type_pointer(h_wrds, c_wrdcount, c_retid, c_storage_class, c_elm_type_id)
#define get_buf_from_scale(h_alloc, c_scale)
#define aclspv_opcode_t
integer as operation code
aclspv_wrd_t aclspv_wrdcount_t
the integer type represents the number of word.
#define ACLSPV_MASK_OPCODE
mask for opcode
#define aclspv_wrd_t
integer as word
#define ACLSPV_MASK_NOPRNDS
mask for number of operands
x_aclspv_vec m_scale_vars
aclspv_wrdcount_t m_num_type_uniques
x_aclspv_vec m_cursors
cache for cursors for parsing one function for its use see util/cursor.h
x_aclspv_vec m_constant_cache
x_aclspv_vec m_ret
word count for m_ret
aclspv_wrd_t m_is_logical
when on, ignores m_is_buffer_64.
aclspv_wrdcount_t m_num_cursor
number of m_cursors. for its use see util/cursor.h
x_aclspv_vec m_type_uniques
cache for complex types which needs to be stored somewhere for its use see util/type_unique....
util_bind_unified m_unified
#define mk_noprnds(c_num_opprm)
#define emit_opcode(h_wrds, c_wrdcount, c_opcode, c_num_opprm_opt)
try emit opcode with num_opprm
#define sz_to_count(c_sz)
byte size to word count
#define get_wrd_of_vec(vec)
get word buffer from vector
aclspv_wrdcount_t spvsz_t
#define count_to_sz(c_count)
word count to byte size
#define set_oprnd_count_for_opcode(cr_wrd, c_num_opprm)
#define opcode_to_wrd(c_opcode, c_num_opprm)