|
15 | 15 |
|
16 | 16 | #include "tcpci.h"
|
17 | 17 |
|
| 18 | +#define MT6360_REG_PHYCTRL1 0x80 |
| 19 | +#define MT6360_REG_PHYCTRL3 0x82 |
| 20 | +#define MT6360_REG_PHYCTRL7 0x86 |
18 | 21 | #define MT6360_REG_VCONNCTRL1 0x8C
|
19 | 22 | #define MT6360_REG_MODECTRL2 0x8F
|
20 | 23 | #define MT6360_REG_SWRESET 0xA0
|
21 | 24 | #define MT6360_REG_DEBCTRL1 0xA1
|
22 | 25 | #define MT6360_REG_DRPCTRL1 0xA2
|
23 | 26 | #define MT6360_REG_DRPCTRL2 0xA3
|
24 | 27 | #define MT6360_REG_I2CTORST 0xBF
|
| 28 | +#define MT6360_REG_PHYCTRL11 0xCA |
| 29 | +#define MT6360_REG_RXCTRL1 0xCE |
25 | 30 | #define MT6360_REG_RXCTRL2 0xCF
|
26 | 31 | #define MT6360_REG_CTDCTRL2 0xEC
|
27 | 32 |
|
@@ -106,6 +111,27 @@ static int mt6360_tcpc_init(struct tcpci *tcpci, struct tcpci_data *tdata)
|
106 | 111 | if (ret)
|
107 | 112 | return ret;
|
108 | 113 |
|
| 114 | + /* BMC PHY */ |
| 115 | + ret = mt6360_tcpc_write16(regmap, MT6360_REG_PHYCTRL1, 0x3A70); |
| 116 | + if (ret) |
| 117 | + return ret; |
| 118 | + |
| 119 | + ret = regmap_write(regmap, MT6360_REG_PHYCTRL3, 0x82); |
| 120 | + if (ret) |
| 121 | + return ret; |
| 122 | + |
| 123 | + ret = regmap_write(regmap, MT6360_REG_PHYCTRL7, 0x36); |
| 124 | + if (ret) |
| 125 | + return ret; |
| 126 | + |
| 127 | + ret = mt6360_tcpc_write16(regmap, MT6360_REG_PHYCTRL11, 0x3C60); |
| 128 | + if (ret) |
| 129 | + return ret; |
| 130 | + |
| 131 | + ret = regmap_write(regmap, MT6360_REG_RXCTRL1, 0xE8); |
| 132 | + if (ret) |
| 133 | + return ret; |
| 134 | + |
109 | 135 | /* Set shipping mode off, AUTOIDLE on */
|
110 | 136 | return regmap_write(regmap, MT6360_REG_MODECTRL2, 0x7A);
|
111 | 137 | }
|
|
0 commit comments