1 #ifndef __MSM_HDMI_HDCP_MGR_H
2 #define __MSM_HDMI_HDCP_MGR_H
3 
4 enum DS_TYPE {  /* type of downstream device */
5 	DS_UNKNOWN,
6 	DS_RECEIVER,
7 	DS_REPEATER,
8 };
9 
10 enum {
11 	MSG_ID_IDX,
12 	RET_CODE_IDX,
13 	HEADER_LEN,
14 };
15 
16 enum RET_CODE {
17 	HDCP_NOT_AUTHED,
18 	HDCP_AUTHED,
19 	HDCP_DISABLE,
20 };
21 
22 enum MSG_ID { /* List of functions expected to be called after it */
23 	DOWN_CHECK_TOPOLOGY,
24 	UP_REQUEST_TOPOLOGY,
25 	UP_SEND_TOPOLOGY,
26 	DOWN_REQUEST_TOPOLOGY,
27 	MSG_NUM,
28 };
29 
30 enum SOURCE_ID {
31 	HDCP_V1_TX,
32 	HDCP_V1_RX,
33 	HDCP_V2_RX,
34 	HDCP_V2_TX,
35 	SRC_NUM,
36 };
37 
38 /*
39  * how to parse sysfs params buffer
40  * from hdcp_tx driver.
41  */
42 
43 struct HDCP_V2V1_MSG_TOPOLOGY {
44 	/* indicates downstream's type */
45 	uint32_t ds_type;
46 	uint8_t bksv[5];
47 	uint8_t dev_count;
48 	uint8_t depth;
49 	uint8_t ksv_list[5 * 127];
50 	uint32_t max_cascade_exceeded;
51 	uint32_t max_dev_exceeded;
52 };
53 
54 #endif /* __MSM_HDMI_HDCP_MGR_H */
55