#ifndef __VENUS_HFI_CMDS_H__
#define __VENUS_HFI_CMDS_H__
#include "hfi.h"
#define HFI_CMD_SYS_INIT …
#define HFI_CMD_SYS_PC_PREP …
#define HFI_CMD_SYS_SET_RESOURCE …
#define HFI_CMD_SYS_RELEASE_RESOURCE …
#define HFI_CMD_SYS_SET_PROPERTY …
#define HFI_CMD_SYS_GET_PROPERTY …
#define HFI_CMD_SYS_SESSION_INIT …
#define HFI_CMD_SYS_SESSION_END …
#define HFI_CMD_SYS_SET_BUFFERS …
#define HFI_CMD_SYS_TEST_SSR …
#define HFI_CMD_SESSION_SET_PROPERTY …
#define HFI_CMD_SESSION_SET_BUFFERS …
#define HFI_CMD_SESSION_GET_SEQUENCE_HEADER …
#define HFI_CMD_SYS_SESSION_ABORT …
#define HFI_CMD_SYS_PING …
#define HFI_CMD_SESSION_LOAD_RESOURCES …
#define HFI_CMD_SESSION_START …
#define HFI_CMD_SESSION_STOP …
#define HFI_CMD_SESSION_EMPTY_BUFFER …
#define HFI_CMD_SESSION_FILL_BUFFER …
#define HFI_CMD_SESSION_SUSPEND …
#define HFI_CMD_SESSION_RESUME …
#define HFI_CMD_SESSION_FLUSH …
#define HFI_CMD_SESSION_GET_PROPERTY …
#define HFI_CMD_SESSION_PARSE_SEQUENCE_HEADER …
#define HFI_CMD_SESSION_RELEASE_BUFFERS …
#define HFI_CMD_SESSION_RELEASE_RESOURCES …
#define HFI_CMD_SESSION_CONTINUE …
#define HFI_CMD_SESSION_SYNC …
struct hfi_sys_init_pkt { … };
struct hfi_sys_pc_prep_pkt { … };
struct hfi_sys_set_resource_pkt { … };
struct hfi_sys_release_resource_pkt { … };
struct hfi_sys_set_property_pkt { … };
struct hfi_sys_get_property_pkt { … };
struct hfi_sys_set_buffers_pkt { … };
struct hfi_sys_ping_pkt { … };
struct hfi_session_init_pkt { … };
struct hfi_session_end_pkt { … };
struct hfi_session_abort_pkt { … };
struct hfi_session_set_property_pkt { … };
struct hfi_session_set_buffers_pkt { … };
struct hfi_session_get_sequence_header_pkt { … };
struct hfi_session_load_resources_pkt { … };
struct hfi_session_start_pkt { … };
struct hfi_session_stop_pkt { … };
struct hfi_session_empty_buffer_compressed_pkt { … };
struct hfi_session_empty_buffer_uncompressed_plane0_pkt { … };
struct hfi_session_empty_buffer_uncompressed_plane1_pkt { … };
struct hfi_session_empty_buffer_uncompressed_plane2_pkt { … };
struct hfi_session_fill_buffer_pkt { … };
struct hfi_session_flush_pkt { … };
struct hfi_session_suspend_pkt { … };
struct hfi_session_resume_pkt { … };
struct hfi_session_get_property_pkt { … };
struct hfi_session_release_buffer_pkt { … };
struct hfi_session_release_resources_pkt { … };
struct hfi_session_parse_sequence_header_pkt { … };
struct hfi_sfr { … };
struct hfi_sys_test_ssr_pkt { … };
void pkt_set_version(enum hfi_version version);
void pkt_sys_init(struct hfi_sys_init_pkt *pkt, u32 arch_type);
void pkt_sys_pc_prep(struct hfi_sys_pc_prep_pkt *pkt);
void pkt_sys_idle_indicator(struct hfi_sys_set_property_pkt *pkt, u32 enable);
void pkt_sys_power_control(struct hfi_sys_set_property_pkt *pkt, u32 enable);
void pkt_sys_ubwc_config(struct hfi_sys_set_property_pkt *pkt, const struct hfi_ubwc_config *hfi);
int pkt_sys_set_resource(struct hfi_sys_set_resource_pkt *pkt, u32 id, u32 size,
u32 addr, void *cookie);
int pkt_sys_unset_resource(struct hfi_sys_release_resource_pkt *pkt, u32 id,
u32 size, void *cookie);
void pkt_sys_debug_config(struct hfi_sys_set_property_pkt *pkt, u32 mode,
u32 config);
void pkt_sys_coverage_config(struct hfi_sys_set_property_pkt *pkt, u32 mode);
void pkt_sys_ping(struct hfi_sys_ping_pkt *pkt, u32 cookie);
void pkt_sys_image_version(struct hfi_sys_get_property_pkt *pkt);
int pkt_sys_ssr_cmd(struct hfi_sys_test_ssr_pkt *pkt, u32 trigger_type);
int pkt_session_init(struct hfi_session_init_pkt *pkt, void *cookie,
u32 session_type, u32 codec);
void pkt_session_cmd(struct hfi_session_pkt *pkt, u32 pkt_type, void *cookie);
int pkt_session_set_buffers(struct hfi_session_set_buffers_pkt *pkt,
void *cookie, struct hfi_buffer_desc *bd);
int pkt_session_unset_buffers(struct hfi_session_release_buffer_pkt *pkt,
void *cookie, struct hfi_buffer_desc *bd);
int pkt_session_etb_decoder(struct hfi_session_empty_buffer_compressed_pkt *pkt,
void *cookie, struct hfi_frame_data *input_frame);
int pkt_session_etb_encoder(
struct hfi_session_empty_buffer_uncompressed_plane0_pkt *pkt,
void *cookie, struct hfi_frame_data *input_frame);
int pkt_session_ftb(struct hfi_session_fill_buffer_pkt *pkt,
void *cookie, struct hfi_frame_data *output_frame);
int pkt_session_parse_seq_header(
struct hfi_session_parse_sequence_header_pkt *pkt,
void *cookie, u32 seq_hdr, u32 seq_hdr_len);
int pkt_session_get_seq_hdr(struct hfi_session_get_sequence_header_pkt *pkt,
void *cookie, u32 seq_hdr, u32 seq_hdr_len);
int pkt_session_flush(struct hfi_session_flush_pkt *pkt, void *cookie,
u32 flush_mode);
int pkt_session_get_property(struct hfi_session_get_property_pkt *pkt,
void *cookie, u32 ptype);
int pkt_session_set_property(struct hfi_session_set_property_pkt *pkt,
void *cookie, u32 ptype, void *pdata);
#endif