sde_hdcp.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2012, 2014-2020, The Linux Foundation. All rights reserved.
  4. * Copyright (c) 2022 Qualcomm Innovation Center, Inc. All rights reserved.
  5. */
  6. #ifndef __SDE_HDCP_H__
  7. #define __SDE_HDCP_H__
  8. #include <linux/types.h>
  9. #include <linux/bitops.h>
  10. #include <linux/debugfs.h>
  11. #include <linux/of_device.h>
  12. #include <linux/i2c.h>
  13. #include <linux/list.h>
  14. #include <drm/drm_crtc.h>
  15. #include <drm/drm_edid.h>
  16. #if IS_ENABLED(CONFIG_HDCP_QSEECOM)
  17. #include <linux/hdcp_qseecom.h>
  18. #endif
  19. #include "sde_kms.h"
  20. #define MAX_STREAM_COUNT 2
  21. enum sde_hdcp_client_id {
  22. HDCP_CLIENT_HDMI,
  23. HDCP_CLIENT_DP,
  24. };
  25. enum sde_hdcp_state {
  26. HDCP_STATE_INACTIVE,
  27. HDCP_STATE_AUTHENTICATING,
  28. HDCP_STATE_AUTHENTICATED,
  29. HDCP_STATE_AUTH_FAIL,
  30. };
  31. enum sde_hdcp_version {
  32. HDCP_VERSION_NONE,
  33. HDCP_VERSION_1X = BIT(0),
  34. HDCP_VERSION_2P2 = BIT(1),
  35. HDCP_VERSION_MAX = BIT(2),
  36. };
  37. struct stream_info {
  38. u8 stream_id;
  39. u8 virtual_channel;
  40. };
  41. struct sde_hdcp_stream {
  42. struct list_head list;
  43. u8 stream_id;
  44. u8 virtual_channel;
  45. u32 stream_handle;
  46. bool active;
  47. };
  48. struct sde_hdcp_init_data {
  49. struct device *msm_hdcp_dev;
  50. struct dss_io_data *core_io;
  51. struct dss_io_data *dp_ahb;
  52. struct dss_io_data *dp_aux;
  53. struct dss_io_data *dp_link;
  54. struct dss_io_data *dp_p0;
  55. struct dss_io_data *qfprom_io;
  56. struct dss_io_data *hdcp_io;
  57. struct drm_dp_aux *drm_aux;
  58. struct mutex *mutex;
  59. struct workqueue_struct *workq;
  60. void *cb_data;
  61. void (*notify_status)(void *cb_data, enum sde_hdcp_state state);
  62. u8 sink_rx_status;
  63. unsigned char *revision;
  64. u32 phy_addr;
  65. bool sec_access;
  66. enum sde_hdcp_client_id client_id;
  67. };
  68. struct sde_hdcp_ops {
  69. int (*isr)(void *ptr);
  70. int (*cp_irq)(void *ptr);
  71. int (*reauthenticate)(void *input);
  72. int (*authenticate)(void *hdcp_ctrl);
  73. bool (*feature_supported)(void *input);
  74. void (*force_encryption)(void *input, bool enable);
  75. bool (*sink_support)(void *input);
  76. void (*abort)(void *input, bool abort);
  77. int (*set_mode)(void *input, bool mst_enabled);
  78. int (*on)(void *input);
  79. void (*off)(void *hdcp_ctrl);
  80. int (*register_streams)(void *input, u8 num_streams,
  81. struct stream_info *streams);
  82. int (*deregister_streams)(void *input, u8 num_streams,
  83. struct stream_info *streams);
  84. };
  85. static inline const char *sde_hdcp_state_name(enum sde_hdcp_state hdcp_state)
  86. {
  87. switch (hdcp_state) {
  88. case HDCP_STATE_INACTIVE: return "HDCP_STATE_INACTIVE";
  89. case HDCP_STATE_AUTHENTICATING: return "HDCP_STATE_AUTHENTICATING";
  90. case HDCP_STATE_AUTHENTICATED: return "HDCP_STATE_AUTHENTICATED";
  91. case HDCP_STATE_AUTH_FAIL: return "HDCP_STATE_AUTH_FAIL";
  92. default: return "???";
  93. }
  94. }
  95. static inline const char *sde_hdcp_version(enum sde_hdcp_version hdcp_version)
  96. {
  97. switch (hdcp_version) {
  98. case HDCP_VERSION_NONE: return "HDCP_VERSION_NONE";
  99. case HDCP_VERSION_1X: return "HDCP_VERSION_1X";
  100. case HDCP_VERSION_2P2: return "HDCP_VERSION_2P2";
  101. default: return "???";
  102. }
  103. }
  104. #if IS_ENABLED(CONFIG_HDCP_QSEECOM)
  105. void *sde_hdcp_1x_init(struct sde_hdcp_init_data *init_data);
  106. void sde_hdcp_1x_deinit(void *input);
  107. struct sde_hdcp_ops *sde_hdcp_1x_get(void *input);
  108. void *sde_dp_hdcp2p2_init(struct sde_hdcp_init_data *init_data);
  109. void sde_dp_hdcp2p2_deinit(void *input);
  110. struct sde_hdcp_ops *sde_dp_hdcp2p2_get(void *input);
  111. #else
  112. void *sde_hdcp_1x_init(struct sde_hdcp_init_data *init_data)
  113. {
  114. return NULL;
  115. }
  116. void sde_hdcp_1x_deinit(void *input)
  117. {
  118. }
  119. struct sde_hdcp_ops *sde_hdcp_1x_get(void *input)
  120. {
  121. return NULL;
  122. }
  123. void *sde_dp_hdcp2p2_init(struct sde_hdcp_init_data *init_data)
  124. {
  125. return NULL;
  126. }
  127. void sde_dp_hdcp2p2_deinit(void *input)
  128. {
  129. }
  130. struct sde_hdcp_ops *sde_dp_hdcp2p2_get(void *input)
  131. {
  132. return NULL;
  133. }
  134. #endif
  135. #endif /* __SDE_HDCP_H__ */