msm_vidc_platform.h 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2020, 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. struct msm_vidc_core_data {
  10. enum msm_vidc_core_data_type type;
  11. u32 value;
  12. };
  13. struct msm_vidc_instance_data {
  14. enum msm_vidc_instance_data_type type;
  15. enum msm_vidc_domain_type domains;
  16. enum msm_vidc_codec_type codecs;
  17. u32 min;
  18. u32 max;
  19. u32 step_or_menu;
  20. u32 value;
  21. };
  22. struct msm_vidc_csc_coeff {
  23. u32 *vpe_csc_custom_matrix_coeff;
  24. u32 *vpe_csc_custom_bias_coeff;
  25. u32 *vpe_csc_custom_limit_coeff;
  26. };
  27. struct msm_vidc_efuse_data {
  28. u32 start_address;
  29. u32 size;
  30. u32 mask;
  31. u32 shift;
  32. enum efuse_purpose purpose;
  33. };
  34. struct msm_vidc_ubwc_config_data {
  35. struct {
  36. u32 max_channel_override : 1;
  37. u32 mal_length_override : 1;
  38. u32 hb_override : 1;
  39. u32 bank_swzl_level_override : 1;
  40. u32 bank_spreading_override : 1;
  41. u32 reserved : 27;
  42. } override_bit_info;
  43. u32 max_channels;
  44. u32 mal_length;
  45. u32 highest_bank_bit;
  46. u32 bank_swzl_level;
  47. u32 bank_spreading;
  48. };
  49. struct msm_vidc_platform_data {
  50. struct msm_vidc_core_data *core_data;
  51. u32 core_data_size;
  52. struct msm_vidc_instance_data *instance_data;
  53. u32 instance_data_size;
  54. struct allowed_clock_rates_table *allowed_clks_tbl;
  55. u32 allowed_clks_tbl_size;
  56. struct msm_vidc_csc_coeff csc_data;
  57. struct msm_vidc_ubwc_config_data *ubwc_config;
  58. };
  59. struct msm_vidc_platform {
  60. void *core;
  61. struct msm_vidc_platform_data data;
  62. };
  63. int msm_vidc_init_platform(struct platform_device *pdev);
  64. int msm_vidc_deinit_platform(struct platform_device *pdev);
  65. #endif // _MSM_VIDC_PLATFORM_H_