msm_vidc_platform.h 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2020-2021,, The Linux Foundation. All rights reserved.
  4. */
  5. #ifndef _MSM_VIDC_PLATFORM_H_
  6. #define _MSM_VIDC_PLATFORM_H_
  7. #include <linux/platform_device.h>
  8. #include "msm_vidc_internal.h"
  9. #include <media/v4l2-ctrls.h>
  10. struct msm_platform_core_capability {
  11. enum msm_vidc_core_capability_type type;
  12. u32 value;
  13. };
  14. struct msm_platform_inst_capability {
  15. enum msm_vidc_inst_capability_type cap;
  16. enum msm_vidc_domain_type domain;
  17. enum msm_vidc_codec_type codec;
  18. s32 min;
  19. s32 max;
  20. u32 step_or_mask;
  21. s32 value;
  22. u32 v4l2_id;
  23. u32 hfi_id;
  24. enum msm_vidc_inst_capability_flags flags;
  25. enum msm_vidc_inst_capability_type parents[MAX_CAP_PARENTS];
  26. enum msm_vidc_inst_capability_type children[MAX_CAP_CHILDREN];
  27. int (*adjust)(void *inst,
  28. struct v4l2_ctrl *ctrl);
  29. int (*set)(void *inst,
  30. enum msm_vidc_inst_capability_type cap_id);
  31. };
  32. struct msm_vidc_csc_coeff {
  33. u32 *vpe_csc_custom_matrix_coeff;
  34. u32 *vpe_csc_custom_bias_coeff;
  35. u32 *vpe_csc_custom_limit_coeff;
  36. };
  37. struct msm_vidc_efuse_data {
  38. u32 start_address;
  39. u32 size;
  40. u32 mask;
  41. u32 shift;
  42. enum efuse_purpose purpose;
  43. };
  44. struct msm_vidc_ubwc_config_data {
  45. u32 max_channels;
  46. u32 mal_length;
  47. u32 highest_bank_bit;
  48. u32 bank_swzl_level;
  49. u32 bank_swz2_level;
  50. u32 bank_swz3_level;
  51. u32 bank_spreading;
  52. };
  53. struct msm_vidc_platform_data {
  54. struct msm_platform_core_capability *core_data;
  55. u32 core_data_size;
  56. struct msm_platform_inst_capability *instance_data;
  57. u32 instance_data_size;
  58. struct allowed_clock_rates_table *allowed_clks_tbl;
  59. u32 allowed_clks_tbl_size;
  60. struct msm_vidc_csc_coeff csc_data;
  61. struct msm_vidc_ubwc_config_data *ubwc_config;
  62. };
  63. struct msm_vidc_platform {
  64. void *core;
  65. struct msm_vidc_platform_data data;
  66. };
  67. int msm_vidc_init_platform(struct platform_device *pdev);
  68. int msm_vidc_deinit_platform(struct platform_device *pdev);
  69. #endif // _MSM_VIDC_PLATFORM_H_