xref: /linux/include/linux/phy/phy-dp.h (revision db5d28c0bfe566908719bec8e25443aabecbb802)
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3  * Copyright (C) 2019 Cadence Design Systems Inc.
4  */
5 
6 #ifndef __PHY_DP_H_
7 #define __PHY_DP_H_
8 
9 #include <linux/types.h>
10 
11 #define PHY_SUBMODE_DP	0
12 #define PHY_SUBMODE_EDP	1
13 
14 /**
15  * struct phy_configure_opts_dp - DisplayPort PHY configuration set
16  *
17  * This structure is used to represent the configuration state of a
18  * DisplayPort phy.
19  */
20 struct phy_configure_opts_dp {
21 	/**
22 	 * @link_rate:
23 	 *
24 	 * Link Rate, in Mb/s, of the main link.
25 	 *
26 	 * Allowed values: 1620, 2160, 2430, 2700, 3240, 4320, 5400, 8100 Mb/s
27 	 */
28 	unsigned int link_rate;
29 
30 	/**
31 	 * @lanes:
32 	 *
33 	 * Number of active, consecutive, data lanes, starting from
34 	 * lane 0, used for the transmissions on main link.
35 	 *
36 	 * Allowed values: 1, 2, 4
37 	 */
38 	unsigned int lanes;
39 
40 	/**
41 	 * @voltage:
42 	 *
43 	 * Voltage swing levels, as specified by DisplayPort specification,
44 	 * to be used by particular lanes. One value per lane.
45 	 * voltage[0] is for lane 0, voltage[1] is for lane 1, etc.
46 	 *
47 	 * Maximum value: 3
48 	 */
49 	unsigned int voltage[4];
50 
51 	/**
52 	 * @pre:
53 	 *
54 	 * Pre-emphasis levels, as specified by DisplayPort specification, to be
55 	 * used by particular lanes. One value per lane.
56 	 *
57 	 * Maximum value: 3
58 	 */
59 	unsigned int pre[4];
60 
61 	/**
62 	 * @ssc:
63 	 *
64 	 * Flag indicating, whether or not to enable spread-spectrum clocking.
65 	 *
66 	 */
67 	u8 ssc : 1;
68 
69 	/**
70 	 * @set_rate:
71 	 *
72 	 * Flag indicating, whether or not reconfigure link rate and SSC to
73 	 * requested values.
74 	 *
75 	 */
76 	u8 set_rate : 1;
77 
78 	/**
79 	 * @set_lanes:
80 	 *
81 	 * Flag indicating, whether or not reconfigure lane count to
82 	 * requested value.
83 	 *
84 	 */
85 	u8 set_lanes : 1;
86 
87 	/**
88 	 * @set_voltages:
89 	 *
90 	 * Flag indicating, whether or not reconfigure voltage swing
91 	 * and pre-emphasis to requested values. Only lanes specified
92 	 * by "lanes" parameter will be affected.
93 	 *
94 	 */
95 	u8 set_voltages : 1;
96 };
97 
98 #endif /* __PHY_DP_H_ */
99