diff options
Diffstat (limited to 'src/venus/venus-protocol/vn_protocol_renderer_cs.h')
-rw-r--r-- | src/venus/venus-protocol/vn_protocol_renderer_cs.h | 143 |
1 files changed, 143 insertions, 0 deletions
diff --git a/src/venus/venus-protocol/vn_protocol_renderer_cs.h b/src/venus/venus-protocol/vn_protocol_renderer_cs.h new file mode 100644 index 00000000..d929827c --- /dev/null +++ b/src/venus/venus-protocol/vn_protocol_renderer_cs.h @@ -0,0 +1,143 @@ +/* This file is generated by venus-protocol. See vn_protocol_renderer.h. */ + +/* + * Copyright 2020 Google LLC + * SPDX-License-Identifier: MIT + */ + +#ifndef VN_PROTOCOL_RENDERER_CS_H +#define VN_PROTOCOL_RENDERER_CS_H + +#include <assert.h> + +/* + * These types/functions are expected + * + * struct vn_cs_encoder + * vn_cs_encoder_write + * + * struct vn_cs_decoder + * vn_cs_decoder_set_fatal + * vn_cs_decoder_get_fatal + * vn_cs_decoder_lookup_object + * vn_cs_decoder_reset_temp_pool + * vn_cs_decoder_alloc_temp + * vn_cs_decoder_read + * vn_cs_decoder_peek + * + * vn_object_id + * vn_cs_handle_indirect_id + * vn_cs_handle_load_id + * vn_cs_handle_store_id + * vn_cs_get_object_handle + */ +#include "vkr_cs.h" + +struct vn_cs_encoder; +struct vn_cs_decoder; + +typedef vkr_object_id vn_object_id; + +#pragma GCC diagnostic push +#pragma GCC diagnostic ignored "-Wunused-parameter" + +static inline void +vn_cs_encoder_write(struct vn_cs_encoder *enc, size_t size, const void *val, size_t val_size) +{ + struct vkr_cs_encoder *e = (struct vkr_cs_encoder *)enc; + vkr_cs_encoder_write(e, size, val, val_size); +} + +static inline void +vn_cs_decoder_set_fatal(const struct vn_cs_decoder *dec) +{ + const struct vkr_cs_decoder *d = (struct vkr_cs_decoder *)dec; + vkr_cs_decoder_set_fatal(d); +} + +static inline bool +vn_cs_decoder_get_fatal(const struct vn_cs_decoder *dec) +{ + const struct vkr_cs_decoder *d = (struct vkr_cs_decoder *)dec; + return vkr_cs_decoder_get_fatal(d); +} + +static inline void * +vn_cs_decoder_lookup_object(const struct vn_cs_decoder *dec, vn_object_id id, VkObjectType type) +{ + const struct vkr_cs_decoder *d = (const struct vkr_cs_decoder *)dec; + return vkr_cs_decoder_lookup_object(d, id, type); +} + +static inline void +vn_cs_decoder_reset_temp_pool(struct vn_cs_decoder *dec) +{ + struct vkr_cs_decoder *d = (struct vkr_cs_decoder *)dec; + vkr_cs_decoder_reset_temp_pool(d); +} + +static inline void * +vn_cs_decoder_alloc_temp(struct vn_cs_decoder *dec, size_t size) +{ + struct vkr_cs_decoder *d = (struct vkr_cs_decoder *)dec; + return vkr_cs_decoder_alloc_temp(d, size); +} + +static inline void +vn_cs_decoder_read(struct vn_cs_decoder *dec, size_t size, void *val, size_t val_size) +{ + struct vkr_cs_decoder *d = (struct vkr_cs_decoder *)dec; + vkr_cs_decoder_read(d, size, val, val_size); +} + +static inline void +vn_cs_decoder_peek(const struct vn_cs_decoder *dec, size_t size, void *val, size_t val_size) +{ + const struct vkr_cs_decoder *d = (const struct vkr_cs_decoder *)dec; + vkr_cs_decoder_peek(d, size, val, val_size); +} + +static inline bool +vn_cs_handle_indirect_id(VkObjectType type) +{ + return vkr_cs_handle_indirect_id(type); +} + +static inline vn_object_id +vn_cs_handle_load_id(const void **handle, VkObjectType type) +{ + return vkr_cs_handle_load_id(handle, type); +} + +static inline void +vn_cs_handle_store_id(void **handle, vn_object_id id, VkObjectType type) +{ + vkr_cs_handle_store_id(handle, id, type); +} + +static inline uint64_t +vn_cs_get_object_handle(const void **handle, VkObjectType type) +{ + const struct vkr_object *obj = *(const struct vkr_object **)handle; + return obj ? obj->handle.u64 : 0; +} + +static inline void +vn_encode(struct vn_cs_encoder *enc, size_t size, const void *data, size_t data_size) +{ + assert(size % 4 == 0); + /* no vn_cs_encoder_reserve; vn_cs_encoder_write must do size check */ + /* TODO check if the generated code is optimal */ + vn_cs_encoder_write(enc, size, data, data_size); +} + +static inline void +vn_decode(struct vn_cs_decoder *dec, size_t size, void *data, size_t data_size) +{ + assert(size % 4 == 0); + vn_cs_decoder_read(dec, size, data, data_size); +} + +#pragma GCC diagnostic pop + +#endif /* VN_PROTOCOL_RENDERER_CS_H */ |