msm_vidc_platform.h 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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. #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. struct {
  46. u32 max_channel_override : 1;
  47. u32 mal_length_override : 1;
  48. u32 hb_override : 1;
  49. u32 bank_swzl_level_override : 1;
  50. u32 bank_swz2_level_override : 1;
  51. u32 bank_swz3_level_override : 1;
  52. u32 bank_spreading_override : 1;
  53. u32 reserved : 27;
  54. } override_bit_info;
  55. u32 max_channels;
  56. u32 mal_length;
  57. u32 highest_bank_bit;
  58. u32 bank_swzl_level;
  59. u32 bank_swz2_level;
  60. u32 bank_swz3_level;
  61. u32 bank_spreading;
  62. };
  63. struct msm_vidc_platform_data {
  64. struct msm_platform_core_capability *core_data;
  65. u32 core_data_size;
  66. struct msm_platform_inst_capability *instance_data;
  67. u32 instance_data_size;
  68. struct allowed_clock_rates_table *allowed_clks_tbl;
  69. u32 allowed_clks_tbl_size;
  70. struct msm_vidc_csc_coeff csc_data;
  71. struct msm_vidc_ubwc_config_data *ubwc_config;
  72. };
  73. struct msm_vidc_platform {
  74. void *core;
  75. struct msm_vidc_platform_data data;
  76. };
  77. int msm_vidc_init_platform(struct platform_device *pdev);
  78. int msm_vidc_deinit_platform(struct platform_device *pdev);
  79. #endif // _MSM_VIDC_PLATFORM_H_