msm_vidc_platform.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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_platform_core_capability {
  10. enum msm_vidc_core_capability_type type;
  11. u32 value;
  12. };
  13. struct msm_platform_inst_capability {
  14. enum msm_vidc_inst_capability_type cap;
  15. enum msm_vidc_domain_type domain;
  16. enum msm_vidc_codec_type codec;
  17. s32 min;
  18. s32 max;
  19. u32 step_or_menu;
  20. s32 value;
  21. enum msm_vidc_inst_capability_flags flags;
  22. u32 v4l2_id;
  23. u32 hfi_id;
  24. u8 parents[MAX_CAP_PARENTS];
  25. u8 children[MAX_CAP_CHILDREN];
  26. void (*adjust)(void *inst, s32 new_value);
  27. int (*set)(void *inst, struct v4l2_ctrl *ctrl);
  28. };
  29. struct msm_vidc_csc_coeff {
  30. u32 *vpe_csc_custom_matrix_coeff;
  31. u32 *vpe_csc_custom_bias_coeff;
  32. u32 *vpe_csc_custom_limit_coeff;
  33. };
  34. struct msm_vidc_efuse_data {
  35. u32 start_address;
  36. u32 size;
  37. u32 mask;
  38. u32 shift;
  39. enum efuse_purpose purpose;
  40. };
  41. struct msm_vidc_ubwc_config_data {
  42. struct {
  43. u32 max_channel_override : 1;
  44. u32 mal_length_override : 1;
  45. u32 hb_override : 1;
  46. u32 bank_swzl_level_override : 1;
  47. u32 bank_swz2_level_override : 1;
  48. u32 bank_swz3_level_override : 1;
  49. u32 bank_spreading_override : 1;
  50. u32 reserved : 27;
  51. } override_bit_info;
  52. u32 max_channels;
  53. u32 mal_length;
  54. u32 highest_bank_bit;
  55. u32 bank_swzl_level;
  56. u32 bank_swz2_level;
  57. u32 bank_swz3_level;
  58. u32 bank_spreading;
  59. };
  60. struct msm_vidc_platform_data {
  61. struct msm_platform_core_capability *core_data;
  62. u32 core_data_size;
  63. struct msm_platform_inst_capability *instance_data;
  64. u32 instance_data_size;
  65. struct allowed_clock_rates_table *allowed_clks_tbl;
  66. u32 allowed_clks_tbl_size;
  67. struct msm_vidc_csc_coeff csc_data;
  68. struct msm_vidc_ubwc_config_data *ubwc_config;
  69. };
  70. struct msm_vidc_platform {
  71. void *core;
  72. struct msm_vidc_platform_data data;
  73. };
  74. int msm_vidc_init_platform(struct platform_device *pdev);
  75. int msm_vidc_deinit_platform(struct platform_device *pdev);
  76. #endif // _MSM_VIDC_PLATFORM_H_