hfi_packetization.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2018-2021, The Linux Foundation. All rights reserved.
  4. */
  5. #ifndef __HFI_PACKETIZATION__
  6. #define __HFI_PACKETIZATION__
  7. #include <linux/types.h>
  8. #include "cvp_hfi_helper.h"
  9. #include "cvp_hfi.h"
  10. #include "cvp_hfi_api.h"
  11. #define call_hfi_pkt_op(q, op, ...) \
  12. (((q) && (q)->pkt_ops && (q)->pkt_ops->op) ? \
  13. ((q)->pkt_ops->op(__VA_ARGS__)) : 0)
  14. enum hfi_packetization_type {
  15. HFI_PACKETIZATION_4XX,
  16. };
  17. struct cvp_hfi_packetization_ops {
  18. int (*sys_init)(struct cvp_hfi_cmd_sys_init_packet *pkt, u32 arch_type);
  19. int (*sys_pc_prep)(struct cvp_hfi_cmd_sys_pc_prep_packet *pkt);
  20. int (*sys_power_control)(
  21. struct cvp_hfi_cmd_sys_set_property_packet *pkt,
  22. u32 enable);
  23. int (*sys_set_resource)(
  24. struct cvp_hfi_cmd_sys_set_resource_packet *pkt,
  25. struct cvp_resource_hdr *resource_hdr,
  26. void *resource_value);
  27. int (*sys_debug_config)(struct cvp_hfi_cmd_sys_set_property_packet *pkt,
  28. u32 mode);
  29. int (*sys_coverage_config)(
  30. struct cvp_hfi_cmd_sys_set_property_packet *pkt,
  31. u32 mode);
  32. int (*sys_set_idle_indicator)(
  33. struct cvp_hfi_cmd_sys_set_property_packet *pkt,
  34. u32 mode);
  35. int (*sys_release_resource)(
  36. struct cvp_hfi_cmd_sys_release_resource_packet *pkt,
  37. struct cvp_resource_hdr *resource_hdr);
  38. int (*sys_image_version)(
  39. struct cvp_hfi_cmd_sys_get_property_packet *pkt);
  40. int (*sys_ubwc_config)(struct cvp_hfi_cmd_sys_set_property_packet *pkt,
  41. struct msm_cvp_ubwc_config_data *ubwc_config);
  42. int (*ssr_cmd)(enum hal_ssr_trigger_type type,
  43. struct cvp_hfi_cmd_sys_test_ssr_packet *pkt);
  44. int (*session_init)(
  45. struct cvp_hfi_cmd_sys_session_init_packet *pkt,
  46. struct cvp_hal_session *session);
  47. int (*session_cmd)(struct cvp_hal_session_cmd_pkt *pkt,
  48. int pkt_type, struct cvp_hal_session *session);
  49. int (*session_set_buffers)(
  50. void *pkt,
  51. struct cvp_hal_session *session,
  52. u32 iova,
  53. u32 size);
  54. int (*session_release_buffers)(
  55. void *pkt,
  56. struct cvp_hal_session *session);
  57. int (*session_get_buf_req)(
  58. struct cvp_hfi_cmd_session_get_property_packet *pkt,
  59. struct cvp_hal_session *session);
  60. int (*session_sync_process)(
  61. struct cvp_hfi_cmd_session_sync_process_packet *pkt,
  62. struct cvp_hal_session *session);
  63. int (*session_send)(
  64. struct eva_kmd_hfi_packet *out_pkt,
  65. struct cvp_hal_session *session,
  66. struct eva_kmd_hfi_packet *in_pkt);
  67. };
  68. struct cvp_hfi_packetization_ops *cvp_hfi_get_pkt_ops_handle(
  69. enum hfi_packetization_type);
  70. #endif