Get rid of 'remove_new' relic from platform driver struct
[linux.git] / drivers / extcon / extcon-rtk-type-c.c
blobbdc2b7b3a2465604678945a1eb5c259572697297
1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * * extcon-rtk-type-c.c - Realtek Extcon Type C driver
5 * Copyright (C) 2023 Realtek Semiconductor Corporation
7 */
9 #include <linux/module.h>
10 #include <linux/kernel.h>
11 #include <linux/slab.h>
12 #include <linux/platform_device.h>
13 #include <linux/of.h>
14 #include <linux/of_address.h>
15 #include <linux/of_irq.h>
16 #include <linux/io.h>
17 #include <linux/interrupt.h>
18 #include <linux/syscalls.h>
19 #include <linux/suspend.h>
20 #include <linux/debugfs.h>
21 #include <linux/extcon.h>
22 #include <linux/extcon-provider.h>
23 #include <linux/sys_soc.h>
24 #include <linux/nvmem-consumer.h>
25 #include <linux/gpio/consumer.h>
26 #include <linux/usb/otg.h>
27 #include <linux/usb/typec.h>
29 struct cc_param {
30 u32 rp_4p7k_code;
31 u32 rp_36k_code;
32 u32 rp_12k_code;
33 u32 rd_code;
34 u32 ra_code;
35 u32 vref_2p6v;
36 u32 vref_1p23v;
37 u32 vref_0p8v;
38 u32 vref_0p66v;
39 u32 vref_0p4v;
40 u32 vref_0p2v;
41 u32 vref_1_1p6v;
42 u32 vref_0_1p6v;
45 struct type_c_cfg {
46 int parameter_ver; /* Parameter version */
47 int cc_dfp_mode;
48 struct cc_param cc1_param;
49 struct cc_param cc2_param;
51 u32 debounce_val;
52 bool use_defalut_parameter;
55 struct type_c_data {
56 void __iomem *reg_base;
57 struct device *dev;
58 struct extcon_dev *edev;
60 u32 irq;
62 /* rd control GPIO only for rtd1295 */
63 struct gpio_desc *rd_ctrl_gpio_desc;
65 /* Parameters */
66 struct type_c_cfg *type_c_cfg;
67 u32 dfp_mode_rp_en;
68 u32 ufp_mode_rd_en;
69 u32 cc1_code;
70 u32 cc2_code;
71 u32 cc1_vref;
72 u32 cc2_vref;
73 u32 debounce; /* 1b,1us 7f,4.7us */
75 /* type_c state */
76 int connect_change;
77 #define CONNECT_CHANGE 1
78 #define CONNECT_NO_CHANGE 0
79 int cc_mode; /* cc is host or device */
80 #define IN_HOST_MODE 0x10
81 #define IN_DEVICE_MODE 0x20
82 int is_attach;
83 #define IN_ATTACH 1
84 #define TO_ATTACH 1
85 #define IN_DETACH 0
86 #define TO_DETACH 0
87 int at_cc1;
88 #define AT_CC1 1
89 #define AT_CC2 0
91 u32 int_status;
92 u32 cc_status;
93 /* protect the data member */
94 spinlock_t lock;
95 struct delayed_work delayed_work;
97 bool rd_en_at_first;
99 struct dentry *debug_dir;
101 struct typec_port *port;
104 /* Type C register offset */
105 #define USB_TYPEC_CTRL_CC1_0 0x0
106 #define USB_TYPEC_CTRL_CC1_1 0x4
107 #define USB_TYPEC_CTRL_CC2_0 0x8
108 #define USB_TYPEC_CTRL_CC2_1 0xC
109 #define USB_TYPEC_STS 0x10
110 #define USB_TYPEC_CTRL 0x14
111 #define USB_DBUS_PWR_CTRL 0x18
113 #define ENABLE_CC1 0x1
114 #define ENABLE_CC2 0x2
115 #define DISABLE_CC 0x0
117 /* Bit mapping USB_TYPEC_CTRL_CC1_0 and USB_TYPEC_CTRL_CC2_0 */
118 #define PLR_EN BIT(29)
119 #define CC_SWITCH_MASK (BIT(29) | BIT(28) | BIT(27))
120 #define CC_CODE_MASK (0xfffff << 7)
121 #define rp4pk_code(val) ((0x1f & (val)) << 22)
122 #define code_rp4pk(val) (((val) >> 22) & 0x1f)
123 #define rp36k_code(val) ((0x1f & (val)) << 17)
124 #define code_rp36k(val) (((val) >> 17) & 0x1f)
125 #define rp12k_code(val) ((0x1f & (val)) << 12)
126 #define code_rp12k(val) (((val) >> 12) & 0x1f)
127 #define rd_code(val) ((0x1f & (val)) << 7)
128 #define code_rd(val) (((val) >> 7) & 0x1f)
129 #define dfp_mode(val) ((0x3 & (val)) << 5)
130 #define EN_RP4P7K BIT(4)
131 #define EN_RP36K BIT(3)
132 #define EN_RP12K BIT(2)
133 #define EN_RD BIT(1)
134 #define EN_CC_DET BIT(0)
136 #define CC_MODE_UFP 0x0
137 #define CC_MODE_DFP_USB 0x1
138 #define CC_MODE_DFP_1_5 0x2
139 #define CC_MODE_DFP_3_0 0x3
142 * PARAMETER_V0:
143 * Realtek Kylin rtd1295
144 * Realtek Hercules rtd1395
145 * Realtek Thor rtd1619
146 * Realtek Hank rtd1319
147 * Realtek Groot rtd1312c
148 * PARAMETER_V1:
149 * Realtek Stark rtd1619b
150 * Realtek Parker rtd1319d
151 * Realtek Danvers rtd1315e
153 enum parameter_version {
154 PARAMETER_V0 = 0,
155 PARAMETER_V1 = 1,
158 /* Bit mapping USB_TYPEC_CTRL_CC1_1 and USB_TYPEC_CTRL_CC2_1 */
159 #define V0_vref_2p6v(val) ((0xf & (val)) << 26) /* Bit 29 for groot */
160 #define V0_vref_1p23v(val) ((0xf & (val)) << 22)
161 #define V0_vref_0p8v(val) ((0xf & (val)) << 18)
162 #define V0_vref_0p66v(val) ((0xf & (val)) << 14)
163 #define V0_vref_0p4v(val) ((0x7 & (val)) << 11)
164 #define V0_vref_0p2v(val) ((0x7 & (val)) << 8)
165 #define V0_vref_1_1p6v(val) ((0xf & (val)) << 4)
166 #define V0_vref_0_1p6v(val) ((0xf & (val)) << 0)
168 #define V0_decode_2p6v(val) (((val) >> 26) & 0xf) /* Bit 29 for groot */
169 #define V0_decode_1p23v(val) (((val) >> 22) & 0xf)
170 #define V0_decode_0p8v(val) (((val) >> 18) & 0xf)
171 #define V0_decode_0p66v(val) (((val) >> 14) & 0xf)
172 #define V0_decode_0p4v(val) (((val) >> 11) & 0x7)
173 #define V0_decode_0p2v(val) (((val) >> 8) & 0x7)
174 #define V0_decode_1_1p6v(val) (((val) >> 4) & 0xf)
175 #define V0_decode_0_1p6v(val) (((val) >> 0) & 0xf)
177 /* new Bit mapping USB_TYPEC_CTRL_CC1_1 and USB_TYPEC_CTRL_CC2_1 */
178 #define V1_vref_2p6v(val) ((0xf & (val)) << 28)
179 #define V1_vref_1p23v(val) ((0xf & (val)) << 24)
180 #define V1_vref_0p8v(val) ((0xf & (val)) << 20)
181 #define V1_vref_0p66v(val) ((0xf & (val)) << 16)
182 #define V1_vref_0p4v(val) ((0xf & (val)) << 12)
183 #define V1_vref_0p2v(val) ((0xf & (val)) << 8)
184 #define V1_vref_1_1p6v(val) ((0xf & (val)) << 4)
185 #define V1_vref_0_1p6v(val) ((0xf & (val)) << 0)
187 #define V1_decode_2p6v(val) (((val) >> 28) & 0xf)
188 #define V1_decode_1p23v(val) (((val) >> 24) & 0xf)
189 #define V1_decode_0p8v(val) (((val) >> 20) & 0xf)
190 #define V1_decode_0p66v(val) (((val) >> 16) & 0xf)
191 #define V1_decode_0p4v(val) (((val) >> 12) & 0xf)
192 #define V1_decode_0p2v(val) (((val) >> 8) & 0xf)
193 #define V1_decode_1_1p6v(val) (((val) >> 4) & 0xf)
194 #define V1_decode_0_1p6v(val) (((val) >> 0) & 0xf)
196 /* Bit mapping USB_TYPEC_STS */
197 #define DET_STS 0x7
198 #define CC1_DET_STS (DET_STS)
199 #define CC2_DET_STS (DET_STS << 3)
200 #define DET_STS_RA 0x1
201 #define DET_STS_RD 0x3
202 #define DET_STS_RP 0x1
203 #define CC1_DET_STS_RA (DET_STS_RA)
204 #define CC1_DET_STS_RD (DET_STS_RD)
205 #define CC1_DET_STS_RP (DET_STS_RP)
206 #define CC2_DET_STS_RA (DET_STS_RA << 3)
207 #define CC2_DET_STS_RD (DET_STS_RD << 3)
208 #define CC2_DET_STS_RP (DET_STS_RP << 3)
210 /* Bit mapping USB_TYPEC_CTRL */
211 #define CC2_INT_EN BIT(11)
212 #define CC1_INT_EN BIT(10)
213 #define CC2_INT_STS BIT(9)
214 #define CC1_INT_STS BIT(8)
215 #define DEBOUNCE_TIME_MASK 0xff
216 #define DEBOUNCE_EN BIT(0)
217 #define ENABLE_TYPE_C_DETECT (CC1_INT_EN | CC2_INT_EN)
218 #define ALL_CC_INT_STS (CC1_INT_STS | CC2_INT_STS)
220 /* Parameter */
221 #define DETECT_TIME 50 /* ms */
223 static const unsigned int usb_type_c_cable[] = {
224 EXTCON_USB,
225 EXTCON_USB_HOST,
226 EXTCON_NONE,
229 enum usb_data_roles {
230 DR_NONE,
231 DR_HOST,
232 DR_DEVICE,
235 static const struct soc_device_attribute rtk_soc_kylin[] = {
236 { .family = "Realtek Kylin", },
237 { /* empty */ }
240 static int rtd129x_switch_type_c_plug_config(struct type_c_data *type_c,
241 int dr_mode, int cc)
243 void __iomem *reg = type_c->reg_base + USB_TYPEC_CTRL_CC1_0;
244 int val_cc;
246 #define TYPE_C_EN_SWITCH BIT(29)
247 #define TYPE_C_TXRX_SEL (BIT(28) | BIT(27))
248 #define TYPE_C_SWITCH_MASK (TYPE_C_EN_SWITCH | TYPE_C_TXRX_SEL)
249 #define TYPE_C_ENABLE_CC1 TYPE_C_EN_SWITCH
250 #define TYPE_C_ENABLE_CC2 (TYPE_C_EN_SWITCH | TYPE_C_TXRX_SEL)
251 #define TYPE_C_DISABLE_CC ~TYPE_C_SWITCH_MASK
253 val_cc = readl(reg);
254 val_cc &= ~TYPE_C_SWITCH_MASK;
256 if (cc == DISABLE_CC) {
257 val_cc &= TYPE_C_DISABLE_CC;
258 } else if (cc == ENABLE_CC1) {
259 val_cc |= TYPE_C_ENABLE_CC1;
260 } else if (cc == ENABLE_CC2) {
261 val_cc |= TYPE_C_ENABLE_CC2;
262 } else {
263 dev_err(type_c->dev, "%s: Error cc setting cc=0x%x\n", __func__, cc);
264 return -EINVAL;
266 writel(val_cc, reg);
268 /* waiting cc stable for enable/disable */
269 mdelay(1);
271 dev_dbg(type_c->dev, "%s: cc=0x%x val_cc=0x%x usb_typec_ctrl_cc1_0=0x%x\n",
272 __func__, cc, val_cc, readl(reg));
274 return 0;
277 static inline void switch_type_c_plug_config(struct type_c_data *type_c,
278 int dr_mode, int cc)
280 int ret = 0;
282 if (soc_device_match(rtk_soc_kylin))
283 ret = rtd129x_switch_type_c_plug_config(type_c, dr_mode, cc);
285 if (ret < 0)
286 dev_err(type_c->dev, "%s: Error set type c plug config\n",
287 __func__);
290 static void switch_type_c_dr_mode(struct type_c_data *type_c, int dr_mode, int cc)
292 bool is_host = false;
293 bool is_device = false;
294 bool polarity = false;
295 bool vbus = false;
296 bool ss = true;
298 switch_type_c_plug_config(type_c, dr_mode, cc);
299 if (cc == ENABLE_CC2)
300 polarity = true;
302 switch (dr_mode) {
303 case USB_DR_MODE_HOST:
304 is_host = true;
305 break;
306 case USB_DR_MODE_PERIPHERAL:
307 is_device = true;
308 vbus = true;
309 break;
310 default:
311 dev_dbg(type_c->dev, "%s dr_mode=%d ==> no host or device\n",
312 __func__, dr_mode);
313 break;
316 dev_dbg(type_c->dev, "%s is_host=%d is_device=%d vbus=%d polarity=%d\n",
317 __func__, is_host, is_device, vbus, polarity);
319 /* for EXTCON_USB device mode */
320 extcon_set_state(type_c->edev, EXTCON_USB, is_device);
321 extcon_set_property(type_c->edev, EXTCON_USB,
322 EXTCON_PROP_USB_VBUS,
323 (union extcon_property_value)(int)vbus);
324 extcon_set_property(type_c->edev, EXTCON_USB,
325 EXTCON_PROP_USB_TYPEC_POLARITY,
326 (union extcon_property_value)(int)polarity);
327 extcon_set_property(type_c->edev, EXTCON_USB,
328 EXTCON_PROP_USB_SS,
329 (union extcon_property_value)(int)ss);
331 /* for EXTCON_USB_HOST host mode */
332 extcon_set_state(type_c->edev, EXTCON_USB_HOST, is_host);
333 extcon_set_property(type_c->edev, EXTCON_USB_HOST,
334 EXTCON_PROP_USB_VBUS,
335 (union extcon_property_value)(int)vbus);
336 extcon_set_property(type_c->edev, EXTCON_USB_HOST,
337 EXTCON_PROP_USB_TYPEC_POLARITY,
338 (union extcon_property_value)(int)polarity);
339 extcon_set_property(type_c->edev, EXTCON_USB_HOST,
340 EXTCON_PROP_USB_SS,
341 (union extcon_property_value)(int)ss);
343 /* sync EXTCON_USB and EXTCON_USB_HOST */
344 extcon_sync(type_c->edev, EXTCON_USB);
345 extcon_sync(type_c->edev, EXTCON_USB_HOST);
347 if (type_c->port) {
348 switch (dr_mode) {
349 case USB_DR_MODE_HOST:
350 typec_set_data_role(type_c->port, TYPEC_HOST);
351 typec_set_pwr_role(type_c->port, TYPEC_SOURCE);
352 break;
353 case USB_DR_MODE_PERIPHERAL:
354 typec_set_data_role(type_c->port, TYPEC_DEVICE);
355 typec_set_pwr_role(type_c->port, TYPEC_SINK);
356 break;
357 default:
358 dev_dbg(type_c->dev, "%s unknown dr_mode=%d\n",
359 __func__, dr_mode);
360 break;
365 /* connector attached/detached */
366 static int connector_attached(struct type_c_data *type_c, u32 cc, int dr_mode)
368 void __iomem *reg = type_c->reg_base + USB_TYPEC_CTRL;
370 cancel_delayed_work(&type_c->delayed_work);
372 switch_type_c_dr_mode(type_c, dr_mode, cc);
374 writel(ENABLE_TYPE_C_DETECT | readl(reg), reg);
376 return 0;
379 static int connector_detached(struct type_c_data *type_c, u32 cc, int dr_mode)
381 void __iomem *reg = type_c->reg_base + USB_TYPEC_CTRL;
383 writel(~ENABLE_TYPE_C_DETECT & readl(reg), reg);
385 switch_type_c_dr_mode(type_c, 0, cc);
387 schedule_delayed_work(&type_c->delayed_work, msecs_to_jiffies(DETECT_TIME));
389 return 0;
392 /* detect host device switch */
393 static int __detect_host_device(struct type_c_data *type_c, u32 rp_or_rd_en)
395 struct device *dev = type_c->dev;
396 void __iomem *reg_base = type_c->reg_base;
397 u32 cc1_config, cc2_config, default_ctrl;
398 u32 cc1_switch = 0;
400 default_ctrl = readl(reg_base + USB_TYPEC_CTRL) & DEBOUNCE_TIME_MASK;
401 writel(default_ctrl, reg_base + USB_TYPEC_CTRL);
403 cc1_config = readl(reg_base + USB_TYPEC_CTRL_CC1_0);
404 cc2_config = readl(reg_base + USB_TYPEC_CTRL_CC2_0);
406 cc1_config &= ~EN_CC_DET;
407 cc2_config &= ~EN_CC_DET;
408 writel(cc1_config, reg_base + USB_TYPEC_CTRL_CC1_0);
409 writel(cc2_config, reg_base + USB_TYPEC_CTRL_CC2_0);
411 if (soc_device_match(rtk_soc_kylin))
412 cc1_switch = cc1_config & CC_SWITCH_MASK;
414 cc1_config &= CC_CODE_MASK;
415 cc1_config |= rp_or_rd_en | cc1_switch;
416 cc2_config &= CC_CODE_MASK;
417 cc2_config |= rp_or_rd_en;
418 writel(cc2_config, reg_base + USB_TYPEC_CTRL_CC2_0);
419 writel(cc1_config, reg_base + USB_TYPEC_CTRL_CC1_0);
421 /* For kylin to disable external rd control gpio */
422 if (soc_device_match(rtk_soc_kylin)) {
423 struct gpio_desc *gpio = type_c->rd_ctrl_gpio_desc;
425 if (gpio && gpiod_direction_output(gpio, 1))
426 dev_err(dev, "%s ERROR set rd_ctrl_gpio_desc fail\n", __func__);
429 cc1_config |= EN_CC_DET;
430 cc2_config |= EN_CC_DET;
431 writel(cc1_config, reg_base + USB_TYPEC_CTRL_CC1_0);
432 writel(cc2_config, reg_base + USB_TYPEC_CTRL_CC2_0);
434 return 0;
437 static int detect_device(struct type_c_data *type_c)
439 return __detect_host_device(type_c, type_c->dfp_mode_rp_en);
442 static int detect_host(struct type_c_data *type_c)
444 return __detect_host_device(type_c, type_c->ufp_mode_rd_en);
447 static int host_device_switch_detection(struct type_c_data *type_c)
449 if (type_c->cc_mode == IN_HOST_MODE) {
450 type_c->cc_mode = IN_DEVICE_MODE;
451 detect_host(type_c);
452 } else {
453 type_c->cc_mode = IN_HOST_MODE;
454 detect_device(type_c);
457 return 0;
460 static int detect_type_c_state(struct type_c_data *type_c)
462 struct device *dev = type_c->dev;
463 void __iomem *reg_base = type_c->reg_base;
464 u32 int_status, cc_status, cc_status_check;
465 unsigned long flags;
467 spin_lock_irqsave(&type_c->lock, flags);
469 int_status = readl(reg_base + USB_TYPEC_CTRL);
470 cc_status = readl(reg_base + USB_TYPEC_STS);
472 type_c->connect_change = CONNECT_NO_CHANGE;
474 switch (type_c->cc_mode | type_c->is_attach) {
475 case IN_HOST_MODE | IN_ATTACH:
476 if (((cc_status & CC1_DET_STS) == CC1_DET_STS) && type_c->at_cc1 == AT_CC1) {
477 dev_dbg(dev, "IN host mode and cc1 device detach (cc_status=0x%x)",
478 cc_status);
479 type_c->is_attach = TO_DETACH;
480 type_c->connect_change = CONNECT_CHANGE;
481 } else if (((cc_status & CC2_DET_STS) == CC2_DET_STS) &&
482 type_c->at_cc1 == AT_CC2) {
483 dev_dbg(dev, "IN host mode and cc2 device detach (cc_status=0x%x)",
484 cc_status);
485 type_c->is_attach = TO_DETACH;
486 type_c->connect_change = CONNECT_CHANGE;
488 break;
489 case IN_HOST_MODE | IN_DETACH:
490 cc_status_check = readl(reg_base + USB_TYPEC_STS);
491 if (cc_status_check != (CC1_DET_STS | CC2_DET_STS)) {
492 if (in_interrupt()) {
493 /* Add delay time to avoid capacitive effect of cable. */
494 mdelay(300);
495 } else {
496 spin_unlock_irqrestore(&type_c->lock, flags);
497 /* Add delay time to avoid capacitive effect of cable. */
498 msleep(300);
499 spin_lock_irqsave(&type_c->lock, flags);
501 cc_status_check = readl(reg_base + USB_TYPEC_STS);
503 if (cc_status != cc_status_check) {
504 dev_warn(dev, "IN_HOST_MODE: cc_status (0x%x) != cc_status_check (0x%x)\n",
505 cc_status, cc_status_check);
506 cc_status = readl(reg_base + USB_TYPEC_STS);
509 if ((cc_status & CC1_DET_STS) == CC1_DET_STS_RD) {
510 dev_dbg(dev, "IN host mode and cc1 device attach (cc_status=0x%x)",
511 cc_status);
512 type_c->is_attach = TO_ATTACH;
513 type_c->at_cc1 = AT_CC1;
514 type_c->connect_change = CONNECT_CHANGE;
515 } else if ((cc_status & CC2_DET_STS) == CC2_DET_STS_RD) {
516 dev_dbg(dev, "In host mode and cc2 device attach (cc_status=0x%x)",
517 cc_status);
518 type_c->is_attach = TO_ATTACH;
519 type_c->at_cc1 = AT_CC2;
520 type_c->connect_change = CONNECT_CHANGE;
522 break;
523 case IN_DEVICE_MODE | IN_ATTACH:
524 if ((cc_status & CC1_DET_STS) < CC1_DET_STS_RP ||
525 (cc_status & CC2_DET_STS) < CC2_DET_STS_RP) {
526 /* Add a sw debounce to filter cc signal sent from apple pd adapter */
527 mdelay(5);
528 cc_status_check = readl(reg_base + USB_TYPEC_STS);
530 if (cc_status != cc_status_check) {
531 dev_dbg(dev, "IN_DEVICE_MODE: cc_status (0x%x) != cc_status_check (0x%x) maybe use a pd adapter\n",
532 cc_status, cc_status_check);
533 cc_status = cc_status_check;
537 if ((cc_status & CC1_DET_STS) < CC1_DET_STS_RP && type_c->at_cc1 == AT_CC1) {
538 dev_dbg(dev, "IN device mode and cc1 host disconnect (cc_status=0x%x)",
539 cc_status);
540 type_c->is_attach = TO_DETACH;
541 type_c->connect_change = CONNECT_CHANGE;
542 } else if ((cc_status & CC2_DET_STS) < CC2_DET_STS_RP &&
543 type_c->at_cc1 == AT_CC2) {
544 dev_dbg(dev, "IN device mode and cc2 host disconnect (cc_status=0x%x)",
545 cc_status);
546 type_c->is_attach = TO_DETACH;
547 type_c->connect_change = CONNECT_CHANGE;
549 break;
550 case IN_DEVICE_MODE | IN_DETACH:
551 cc_status_check = readl(reg_base + USB_TYPEC_STS);
552 if (cc_status_check != 0x0) {
553 if (in_interrupt()) {
554 /* Add delay time to avoid capacitive effect of cable. */
555 mdelay(300);
556 } else {
557 spin_unlock_irqrestore(&type_c->lock, flags);
558 /* Add delay time to avoid capacitive effect of cable. */
559 msleep(300);
560 spin_lock_irqsave(&type_c->lock, flags);
562 cc_status_check = readl(reg_base + USB_TYPEC_STS);
565 if (cc_status != cc_status_check) {
566 dev_warn(dev, "IN_DEVICE_MODE: cc_status (0x%x) != cc_status_check (0x%x)\n",
567 cc_status, cc_status_check);
568 cc_status = readl(reg_base + USB_TYPEC_STS);
571 if ((cc_status & CC1_DET_STS) >= CC1_DET_STS_RP) {
572 dev_dbg(dev, "IN device mode and cc1 host connect (cc_status=0x%x)",
573 cc_status);
574 type_c->at_cc1 = AT_CC1;
575 type_c->is_attach = TO_ATTACH;
576 type_c->connect_change = CONNECT_CHANGE;
577 } else if ((cc_status & CC2_DET_STS) >= CC2_DET_STS_RP) {
578 dev_dbg(dev, "IN device mode and cc2 host connect (cc_status=0x%x)",
579 cc_status);
580 type_c->at_cc1 = AT_CC2;
581 type_c->is_attach = TO_ATTACH;
582 type_c->connect_change = CONNECT_CHANGE;
584 break;
585 default:
586 dev_err(dev, "error host or device mode (cc_mode=%d, is_attach=%d) ",
587 type_c->cc_mode, type_c->is_attach);
590 type_c->int_status = int_status;
591 type_c->cc_status = cc_status;
593 spin_unlock_irqrestore(&type_c->lock, flags);
594 return 0;
597 static void host_device_switch(struct work_struct *work)
599 struct type_c_data *type_c = container_of(work, struct type_c_data,
600 delayed_work.work);
601 struct device *dev = type_c->dev;
602 unsigned long flags;
603 int connect_change = 0;
604 int cc_mode = 0;
605 int is_attach = 0;
606 int at_cc1 = 0;
608 spin_lock_irqsave(&type_c->lock, flags);
609 if (type_c->connect_change)
610 connect_change = type_c->connect_change;
611 spin_unlock_irqrestore(&type_c->lock, flags);
613 if (!connect_change)
614 detect_type_c_state(type_c);
616 spin_lock_irqsave(&type_c->lock, flags);
617 if (type_c->connect_change) {
618 connect_change = type_c->connect_change;
619 cc_mode = type_c->cc_mode;
620 is_attach = type_c->is_attach;
621 at_cc1 = type_c->at_cc1;
622 type_c->connect_change = CONNECT_NO_CHANGE;
623 } else {
624 host_device_switch_detection(type_c);
626 schedule_delayed_work(&type_c->delayed_work, msecs_to_jiffies(DETECT_TIME));
628 spin_unlock_irqrestore(&type_c->lock, flags);
630 if (!connect_change)
631 return;
633 dev_dbg(dev, "%s: usb cable connection change\n", __func__);
634 if (cc_mode == IN_HOST_MODE) {
635 if (is_attach && at_cc1)
636 connector_attached(type_c, ENABLE_CC1, USB_DR_MODE_HOST);
637 else if (is_attach && !at_cc1)
638 connector_attached(type_c, ENABLE_CC2, USB_DR_MODE_HOST);
639 else
640 connector_detached(type_c, DISABLE_CC, USB_DR_MODE_HOST);
641 } else if (cc_mode == IN_DEVICE_MODE) {
642 if (is_attach && at_cc1)
643 connector_attached(type_c, ENABLE_CC1, USB_DR_MODE_PERIPHERAL);
644 else if (is_attach && !at_cc1)
645 connector_attached(type_c, ENABLE_CC2, USB_DR_MODE_PERIPHERAL);
646 else
647 connector_detached(type_c, DISABLE_CC, USB_DR_MODE_PERIPHERAL);
648 } else {
649 dev_err(dev, "Error: IN unknown mode %d to %s at %s (cc_status=0x%x)\n",
650 cc_mode, is_attach ? "attach" : "detach",
651 at_cc1 ? "cc1" : "cc2", type_c->cc_status);
653 dev_info(dev, "Connection change OK: IN %s mode to %s at %s (cc_status=0x%x)\n",
654 cc_mode == IN_HOST_MODE ? "host" : "device",
655 is_attach ? "attach" : "detach",
656 at_cc1 ? "cc1" : "cc2", type_c->cc_status);
659 static irqreturn_t type_c_detect_irq(int irq, void *__data)
661 struct type_c_data *type_c = (struct type_c_data *)__data;
662 struct device *dev = type_c->dev;
663 void __iomem *reg = type_c->reg_base + USB_TYPEC_CTRL;
664 unsigned long flags;
666 detect_type_c_state(type_c);
668 spin_lock_irqsave(&type_c->lock, flags);
670 if (type_c->connect_change) {
671 dev_dbg(dev, "%s: IN %s mode to %s (at %s interrupt) int_status=0x%x, cc_status=0x%x",
672 __func__,
673 type_c->cc_mode == IN_HOST_MODE ? "host" : "device",
674 type_c->is_attach ? "attach" : "detach",
675 type_c->at_cc1 ? "cc1" : "cc2",
676 type_c->int_status, type_c->cc_status);
678 /* clear interrupt status */
679 writel(~ALL_CC_INT_STS & readl(reg), reg);
681 cancel_delayed_work(&type_c->delayed_work);
682 schedule_delayed_work(&type_c->delayed_work, msecs_to_jiffies(0));
683 } else {
684 static int local_count;
686 /* if no connect_change, we keep the status to avoid status lose */
687 if (local_count++ > 10) {
688 /* clear interrupt status */
689 writel(~ALL_CC_INT_STS & readl(reg), reg);
690 local_count = 0;
694 spin_unlock_irqrestore(&type_c->lock, flags);
696 return IRQ_HANDLED;
699 static int type_c_port_dr_set(struct typec_port *port,
700 enum typec_data_role role)
702 struct type_c_data *type_c = typec_get_drvdata(port);
703 u32 enable_cc;
704 unsigned long flags;
706 spin_lock_irqsave(&type_c->lock, flags);
707 enable_cc = type_c->at_cc1 ? ENABLE_CC1 : ENABLE_CC2;
708 spin_unlock_irqrestore(&type_c->lock, flags);
710 if (role == TYPEC_HOST)
711 switch_type_c_dr_mode(type_c, USB_DR_MODE_HOST, enable_cc);
712 else if (role == TYPEC_DEVICE)
713 switch_type_c_dr_mode(type_c, USB_DR_MODE_PERIPHERAL, enable_cc);
714 else
715 switch_type_c_dr_mode(type_c, 0, DISABLE_CC);
717 return 0;
720 static const struct typec_operations type_c_port_ops = {
721 .dr_set = type_c_port_dr_set,
724 #ifdef CONFIG_DEBUG_FS
725 static int type_c_parameter_show(struct seq_file *s, void *unused)
727 struct type_c_data *type_c = s->private;
728 struct type_c_cfg *type_c_cfg = type_c->type_c_cfg;
729 struct cc_param *cc_param;
730 unsigned long flags;
732 spin_lock_irqsave(&type_c->lock, flags);
734 seq_printf(s, "cc_dfp_mode %s\n",
735 ({ char *tmp;
736 switch (type_c_cfg->cc_dfp_mode) {
737 case CC_MODE_DFP_USB:
738 tmp = "CC_MODE_DFP_USB"; break;
739 case CC_MODE_DFP_1_5:
740 tmp = "CC_MODE_DFP_1_5"; break;
741 case CC_MODE_DFP_3_0:
742 tmp = "CC_MODE_DFP_3_0"; break;
743 default:
744 tmp = "?"; break;
745 } tmp; }));
747 seq_printf(s, "dfp_mode_rp_en 0x%x\n", type_c->dfp_mode_rp_en);
748 seq_printf(s, "ufp_mode_rd_en 0x%x\n", type_c->ufp_mode_rd_en);
749 seq_printf(s, "cc1_code 0x%x\n", type_c->cc1_code);
750 seq_printf(s, "cc2_code 0x%x\n", type_c->cc2_code);
751 seq_printf(s, "cc1_vref 0x%x\n", type_c->cc1_vref);
752 seq_printf(s, "cc2_vref 0x%x\n", type_c->cc2_vref);
753 seq_printf(s, "debounce 0x%x\n", type_c->debounce);
754 seq_puts(s, "\n");
756 cc_param = &type_c_cfg->cc1_param;
757 seq_puts(s, "cc1_param:\n");
758 seq_printf(s, " rp_4p7k_code 0x%x\n", cc_param->rp_4p7k_code);
759 seq_printf(s, " rp_36k_code 0x%x\n", cc_param->rp_36k_code);
760 seq_printf(s, " rp_12k_code 0x%x\n", cc_param->rp_12k_code);
761 seq_printf(s, " rd_code 0x%x\n", cc_param->rd_code);
762 seq_printf(s, " vref_2p6v 0x%x\n", cc_param->vref_2p6v);
763 seq_printf(s, " vref_1p23v 0x%x\n", cc_param->vref_1p23v);
764 seq_printf(s, " vref_0p8v 0x%x\n", cc_param->vref_0p8v);
765 seq_printf(s, " vref_0p66v 0x%x\n", cc_param->vref_0p66v);
766 seq_printf(s, " vref_0p4v 0x%x\n", cc_param->vref_0p4v);
767 seq_printf(s, " vref_0p2v 0x%x\n", cc_param->vref_0p2v);
768 seq_printf(s, " vref_1_1p6v 0x%x\n", cc_param->vref_1_1p6v);
769 seq_printf(s, " vref_0_1p6v 0x%x\n", cc_param->vref_0_1p6v);
771 cc_param = &type_c_cfg->cc2_param;
772 seq_puts(s, "cc2_param:\n");
773 seq_printf(s, " rp_4p7k_code 0x%x\n", cc_param->rp_4p7k_code);
774 seq_printf(s, " rp_36k_code 0x%x\n", cc_param->rp_36k_code);
775 seq_printf(s, " rp_12k_code 0x%x\n", cc_param->rp_12k_code);
776 seq_printf(s, " rd_code 0x%x\n", cc_param->rd_code);
777 seq_printf(s, " vref_2p6v 0x%x\n", cc_param->vref_2p6v);
778 seq_printf(s, " vref_1p23v 0x%x\n", cc_param->vref_1p23v);
779 seq_printf(s, " vref_0p8v 0x%x\n", cc_param->vref_0p8v);
780 seq_printf(s, " vref_0p66v 0x%x\n", cc_param->vref_0p66v);
781 seq_printf(s, " vref_0p4v 0x%x\n", cc_param->vref_0p4v);
782 seq_printf(s, " vref_0p2v 0x%x\n", cc_param->vref_0p2v);
783 seq_printf(s, " vref_1_1p6v 0x%x\n", cc_param->vref_1_1p6v);
784 seq_printf(s, " vref_0_1p6v 0x%x\n", cc_param->vref_0_1p6v);
786 spin_unlock_irqrestore(&type_c->lock, flags);
788 return 0;
791 static int type_c_parameter_open(struct inode *inode, struct file *file)
793 return single_open(file, type_c_parameter_show, inode->i_private);
796 static const struct file_operations type_c_parameter_fops = {
797 .open = type_c_parameter_open,
798 .read = seq_read,
799 .llseek = seq_lseek,
800 .release = single_release,
803 static int type_c_status_show(struct seq_file *s, void *unused)
805 struct type_c_data *type_c = s->private;
806 unsigned long flags;
808 spin_lock_irqsave(&type_c->lock, flags);
810 seq_printf(s, "In %s mode %s at %s (cc_status=0x%x)\n",
811 type_c->cc_mode == IN_HOST_MODE ? "host" : "device",
812 type_c->is_attach ? "attach" : "detach",
813 type_c->at_cc1 ? "cc1" : "cc2", type_c->cc_status);
815 seq_printf(s, "Read Register (type_c_ctrl_cc1_0=0x%x)\n",
816 readl(type_c->reg_base + 0x0));
817 seq_printf(s, "Read Register (type_c_ctrl_cc1_1=0x%x)\n",
818 readl(type_c->reg_base + 0x4));
819 seq_printf(s, "Read Register (type_c_ctrl_cc2_0=0x%x)\n",
820 readl(type_c->reg_base + 0x8));
821 seq_printf(s, "Read Register (type_c_ctrl_cc2_1=0x%x)\n",
822 readl(type_c->reg_base + 0xc));
823 seq_printf(s, "Read Register (type_c_status=0x%x)\n",
824 readl(type_c->reg_base + 0x10));
825 seq_printf(s, "Read Register (type_c_ctrl=0x%x)\n",
826 readl(type_c->reg_base + 0x14));
828 spin_unlock_irqrestore(&type_c->lock, flags);
830 return 0;
833 static int type_c_status_open(struct inode *inode, struct file *file)
835 return single_open(file, type_c_status_show, inode->i_private);
838 static const struct file_operations type_c_status_fops = {
839 .open = type_c_status_open,
840 .read = seq_read,
841 .llseek = seq_lseek,
842 .release = single_release,
845 static inline void create_debug_files(struct type_c_data *type_c)
847 type_c->debug_dir = debugfs_create_dir("type_c", usb_debug_root);
849 debugfs_create_file("parameter", 0444, type_c->debug_dir, type_c,
850 &type_c_parameter_fops);
852 debugfs_create_file("status", 0444, type_c->debug_dir, type_c,
853 &type_c_status_fops);
856 static inline void remove_debug_files(struct type_c_data *type_c)
858 debugfs_remove_recursive(type_c->debug_dir);
860 #else
861 static inline void create_debug_files(struct type_c_data *type_c) { }
862 static inline void remove_debug_files(struct type_c_data *type_c) { }
863 #endif /* CONFIG_DEBUG_FS */
865 /* Init and probe */
867 static inline s8 get_value(s8 value)
869 return (((s8)value & 0x8) ? (-(s8)(0x7 & value)) : ((s8)(value)));
872 static int __updated_type_c_parameter_by_efuse(struct type_c_data *type_c)
874 struct type_c_cfg *type_c_cfg = type_c->type_c_cfg;
875 struct cc_param *cc_param;
876 struct nvmem_cell *cell;
877 s8 cc1_4p7k = 0;
878 s8 cc1_12k = 0;
879 s8 cc1_0p2v = 0;
880 s8 cc1_0p8v = 0;
881 s8 cc1_2p6v = 0;
882 s8 cc1_0p66v = 0;
883 s8 cc1_1p23v = 0;
884 s8 cc2_4p7k = 0;
885 s8 cc2_12k = 0;
886 s8 cc2_0p2v = 0;
887 s8 cc2_0p8v = 0;
888 s8 cc2_2p6v = 0;
889 s8 cc2_0p66v = 0;
890 s8 cc2_1p23v = 0;
892 cell = nvmem_cell_get(type_c->dev, "usb-cal");
893 if (IS_ERR(cell)) {
894 dev_warn(type_c->dev, "%s failed to get usb-cal: %ld\n",
895 __func__, PTR_ERR(cell));
896 } else {
897 unsigned char *buf;
898 size_t buf_size;
899 int value_size = 4;
900 int value_mask = (BIT(value_size) - 1);
902 buf = nvmem_cell_read(cell, &buf_size);
903 if (!IS_ERR(buf)) {
904 cc1_0p2v = get_value((buf[0] >> value_size * 0) & value_mask);
905 cc1_0p8v = get_value((buf[0] >> value_size * 1) & value_mask);
906 cc1_2p6v = get_value((buf[1] >> value_size * 0) & value_mask);
907 cc1_0p66v = get_value((buf[1] >> value_size * 1) & value_mask);
908 cc1_1p23v = get_value((buf[2] >> value_size * 0) & value_mask);
910 cc2_0p2v = get_value((buf[3] >> value_size * 0) & value_mask);
911 cc2_0p8v = get_value((buf[3] >> value_size * 1) & value_mask);
912 cc2_2p6v = get_value((buf[4] >> value_size * 0) & value_mask);
913 cc2_0p66v = get_value((buf[4] >> value_size * 1) & value_mask);
914 cc2_1p23v = get_value((buf[5] >> value_size * 0) & value_mask);
916 cc1_4p7k = get_value((buf[6] >> value_size * 0) & value_mask);
917 cc1_12k = get_value((buf[6] >> value_size * 1) & value_mask);
918 cc2_4p7k = get_value((buf[7] >> value_size * 0) & value_mask);
919 cc2_12k = get_value((buf[7] >> value_size * 1) & value_mask);
921 kfree(buf);
923 nvmem_cell_put(cell);
926 dev_dbg(type_c->dev, "check efuse cc1_4p7k=%d cc1_12k=%d cc2_4p7k=%d cc2_12k=%d\n",
927 cc1_4p7k, cc1_12k, cc2_4p7k, cc2_12k);
928 dev_dbg(type_c->dev, "check efuse cc1_0p2v=%d cc1_0p8v=%d cc1_2p6v=%d cc1_0p66v=%d cc1_1p23v=%d\n",
929 cc1_0p2v, cc1_0p8v, cc1_2p6v, cc1_0p66v, cc1_1p23v);
930 dev_dbg(type_c->dev, "check efuse cc2_0p2v=%d cc2_0p8v=%d cc2_2p6v=%d cc2_0p66v=%d cc2_1p23v=%d\n",
931 cc2_0p2v, cc2_0p8v, cc2_2p6v, cc2_0p66v, cc2_1p23v);
933 cc_param = &type_c_cfg->cc1_param;
934 cc_param->rp_4p7k_code = cc_param->rp_4p7k_code + cc1_4p7k;
935 cc_param->rp_12k_code = cc_param->rp_12k_code + cc1_12k;
937 cc_param->vref_1p23v = cc_param->vref_1p23v + cc1_1p23v;
938 cc_param->vref_0p66v = cc_param->vref_0p66v + cc1_0p66v;
939 cc_param->vref_2p6v = cc_param->vref_2p6v + cc1_2p6v;
940 cc_param->vref_0p8v = cc_param->vref_0p8v + cc1_0p8v;
941 cc_param->vref_0p2v = cc_param->vref_0p2v + cc1_0p2v;
943 cc_param = &type_c_cfg->cc2_param;
944 cc_param->rp_4p7k_code = cc_param->rp_4p7k_code + cc2_4p7k;
945 cc_param->rp_12k_code = cc_param->rp_12k_code + cc2_12k;
947 cc_param->vref_1p23v = cc_param->vref_1p23v + cc2_1p23v;
948 cc_param->vref_0p66v = cc_param->vref_0p66v + cc2_0p66v;
949 cc_param->vref_2p6v = cc_param->vref_2p6v + cc2_2p6v;
950 cc_param->vref_0p8v = cc_param->vref_0p8v + cc2_0p8v;
951 cc_param->vref_0p2v = cc_param->vref_0p2v + cc2_0p2v;
953 return 0;
956 static int __updated_type_c_parameter_by_efuse_v2(struct type_c_data *type_c)
958 struct type_c_cfg *type_c_cfg = type_c->type_c_cfg;
959 struct cc_param *cc_param;
960 struct nvmem_cell *cell;
961 s8 cc1_4p7k = 0;
962 s8 cc1_12k = 0;
963 s8 cc1_0p2v = 0;
964 s8 cc1_0p8v = 0;
965 s8 cc1_2p6v = 0;
966 s8 cc1_0p66v = 0;
967 s8 cc1_1p23v = 0;
968 s8 cc2_4p7k = 0;
969 s8 cc2_12k = 0;
970 s8 cc2_0p2v = 0;
971 s8 cc2_0p8v = 0;
972 s8 cc2_2p6v = 0;
973 s8 cc2_0p66v = 0;
974 s8 cc2_1p23v = 0;
976 cell = nvmem_cell_get(type_c->dev, "usb-type-c-cal");
977 if (IS_ERR(cell)) {
978 dev_warn(type_c->dev, "%s failed to get usb-type-c-cal: %ld\n",
979 __func__, PTR_ERR(cell));
980 } else {
981 unsigned char *buf;
982 size_t buf_size;
983 int value_size = 0;
984 int value_mask = (BIT(value_size) - 1);
986 buf = nvmem_cell_read(cell, &buf_size);
987 if (!IS_ERR(buf)) {
988 value_size = 5;
989 value_mask = (BIT(value_size) - 1);
990 cc1_4p7k = buf[0] & value_mask;
991 cc1_12k = buf[1] & value_mask;
992 cc2_4p7k = buf[2] & value_mask;
993 cc2_12k = buf[3] & value_mask;
995 value_size = 4;
996 value_mask = (BIT(value_size) - 1);
997 cc1_0p2v = (buf[4] >> value_size * 0) & value_mask;
998 cc1_0p66v = (buf[4] >> value_size * 1) & value_mask;
999 cc1_0p8v = (buf[5] >> value_size * 0) & value_mask;
1000 cc1_1p23v = (buf[5] >> value_size * 1) & value_mask;
1001 cc1_2p6v = (buf[6] >> value_size * 0) & value_mask;
1003 cc2_0p2v = (buf[6] >> value_size * 1) & value_mask;
1004 cc2_0p66v = (buf[7] >> value_size * 0) & value_mask;
1005 cc2_0p8v = (buf[7] >> value_size * 1) & value_mask;
1006 cc2_1p23v = (buf[8] >> value_size * 0) & value_mask;
1007 cc2_2p6v = (buf[8] >> value_size * 1) & value_mask;
1009 kfree(buf);
1011 nvmem_cell_put(cell);
1014 dev_dbg(type_c->dev, "check efuse v2 cc1_4p7k=%d cc1_12k=%d cc2_4p7k=%d cc2_12k=%d\n",
1015 cc1_4p7k, cc1_12k, cc2_4p7k, cc2_12k);
1016 dev_dbg(type_c->dev, "check efuse v2 cc1_0p2v=%d cc1_0p8v=%d cc1_2p6v=%d cc1_0p66v=%d cc1_1p23v=%d\n",
1017 cc1_0p2v, cc1_0p8v, cc1_2p6v, cc1_0p66v, cc1_1p23v);
1018 dev_dbg(type_c->dev, "check efuse v2 cc2_0p2v=%d cc2_0p8v=%d cc2_2p6v=%d cc2_0p66v=%d cc2_1p23v=%d\n",
1019 cc2_0p2v, cc2_0p8v, cc2_2p6v, cc2_0p66v, cc2_1p23v);
1021 cc_param = &type_c_cfg->cc1_param;
1022 if (cc1_4p7k)
1023 cc_param->rp_4p7k_code = cc1_4p7k;
1024 if (cc1_12k)
1025 cc_param->rp_12k_code = cc1_12k;
1027 if (cc1_1p23v)
1028 cc_param->vref_1p23v = cc1_1p23v;
1029 if (cc1_0p66v)
1030 cc_param->vref_0p66v = cc1_0p66v;
1031 if (cc1_2p6v)
1032 cc_param->vref_2p6v = cc1_2p6v;
1033 if (cc1_0p8v)
1034 cc_param->vref_0p8v = cc1_0p8v;
1035 if (cc1_0p2v)
1036 cc_param->vref_0p2v = cc1_0p2v;
1038 cc_param = &type_c_cfg->cc2_param;
1039 if (cc2_4p7k)
1040 cc_param->rp_4p7k_code = cc2_4p7k;
1041 if (cc2_12k)
1042 cc_param->rp_12k_code = cc2_12k;
1044 if (cc2_1p23v)
1045 cc_param->vref_1p23v = cc2_1p23v;
1046 if (cc2_0p66v)
1047 cc_param->vref_0p66v = cc2_0p66v;
1048 if (cc2_2p6v)
1049 cc_param->vref_2p6v = cc2_2p6v;
1050 if (cc2_0p8v)
1051 cc_param->vref_0p8v = cc2_0p8v;
1052 if (cc2_0p2v)
1053 cc_param->vref_0p2v = cc2_0p2v;
1055 return 0;
1058 static void get_default_type_c_parameter(struct type_c_data *type_c)
1060 void __iomem *reg;
1061 int val;
1063 type_c->dfp_mode_rp_en = dfp_mode(CC_MODE_DFP_3_0) | EN_RP4P7K;
1064 type_c->ufp_mode_rd_en = EN_RD;
1066 reg = type_c->reg_base + USB_TYPEC_CTRL_CC1_0;
1067 val = readl(reg);
1068 type_c->cc1_code = CC_CODE_MASK & val;
1070 reg = type_c->reg_base + USB_TYPEC_CTRL_CC2_0;
1071 val = readl(reg);
1072 type_c->cc2_code = CC_CODE_MASK & val;
1074 reg = type_c->reg_base + USB_TYPEC_CTRL_CC1_1;
1075 val = readl(reg);
1076 type_c->cc1_vref = val;
1078 reg = type_c->reg_base + USB_TYPEC_CTRL_CC2_1;
1079 val = readl(reg);
1080 type_c->cc2_vref = val;
1082 reg = type_c->reg_base + USB_TYPEC_CTRL;
1083 val = readl(reg);
1084 type_c->debounce = DEBOUNCE_TIME_MASK & val;
1087 static int setup_type_c_parameter(struct type_c_data *type_c)
1089 struct type_c_cfg *type_c_cfg = type_c->type_c_cfg;
1090 struct cc_param *cc_param;
1091 struct soc_device_attribute rtk_soc_efuse_v1[] = {
1092 { .family = "Realtek Phoenix",},
1093 { .family = "Realtek Kylin",},
1094 { .family = "Realtek Hercules",},
1095 { .family = "Realtek Thor",},
1096 { .family = "Realtek Hank",},
1097 { .family = "Realtek Groot",},
1098 { .family = "Realtek Stark",},
1099 { .family = "Realtek Parker",},
1100 { /* empty */ }
1103 if (type_c_cfg->use_defalut_parameter) {
1104 get_default_type_c_parameter(type_c);
1105 return 0;
1108 if (soc_device_match(rtk_soc_efuse_v1))
1109 __updated_type_c_parameter_by_efuse(type_c);
1110 else
1111 __updated_type_c_parameter_by_efuse_v2(type_c);
1114 * UFP rd vref_ufp : 1p23v, 0p66v, 0p2v
1115 * DFP_USB rp36k vref_dfp_usb: 0_1p6v, 0p2v, unused
1116 * DFP_1.5 rp12k vref_dfp_1_5: 1_1p6v, 0p4v, 0p2v
1117 * DFP_3.0 rp4p7k vref_dfp_3_0: 2p6v, 0p8v, 0p2v
1120 switch (type_c_cfg->cc_dfp_mode) {
1121 case CC_MODE_DFP_USB:
1122 type_c->dfp_mode_rp_en = dfp_mode(CC_MODE_DFP_USB) | EN_RP36K;
1123 break;
1124 case CC_MODE_DFP_1_5:
1125 type_c->dfp_mode_rp_en = dfp_mode(CC_MODE_DFP_1_5) | EN_RP12K;
1126 break;
1127 case CC_MODE_DFP_3_0:
1128 type_c->dfp_mode_rp_en = dfp_mode(CC_MODE_DFP_3_0) | EN_RP4P7K;
1129 break;
1130 default:
1131 dev_err(type_c->dev, "%s: unknown cc_dfp_mode %d\n",
1132 __func__, type_c_cfg->cc_dfp_mode);
1135 type_c->ufp_mode_rd_en = EN_RD;
1137 cc_param = &type_c_cfg->cc1_param;
1138 type_c->cc1_code = rp4pk_code(cc_param->rp_4p7k_code) |
1139 rp36k_code(cc_param->rp_36k_code) |
1140 rp12k_code(cc_param->rp_12k_code) |
1141 rd_code(cc_param->rd_code);
1143 if (type_c_cfg->parameter_ver == PARAMETER_V0)
1144 type_c->cc1_vref = V0_vref_2p6v(cc_param->vref_2p6v) |
1145 V0_vref_1p23v(cc_param->vref_1p23v) |
1146 V0_vref_0p8v(cc_param->vref_0p8v) |
1147 V0_vref_0p66v(cc_param->vref_0p66v) |
1148 V0_vref_0p4v(cc_param->vref_0p4v) |
1149 V0_vref_0p2v(cc_param->vref_0p2v) |
1150 V0_vref_1_1p6v(cc_param->vref_1_1p6v) |
1151 V0_vref_0_1p6v(cc_param->vref_0_1p6v);
1152 else if (type_c_cfg->parameter_ver == PARAMETER_V1)
1153 type_c->cc1_vref = V1_vref_2p6v(cc_param->vref_2p6v) |
1154 V1_vref_1p23v(cc_param->vref_1p23v) |
1155 V1_vref_0p8v(cc_param->vref_0p8v) |
1156 V1_vref_0p66v(cc_param->vref_0p66v) |
1157 V1_vref_0p4v(cc_param->vref_0p4v) |
1158 V1_vref_0p2v(cc_param->vref_0p2v) |
1159 V1_vref_1_1p6v(cc_param->vref_1_1p6v) |
1160 V1_vref_0_1p6v(cc_param->vref_0_1p6v);
1161 else
1162 dev_err(type_c->dev, "%s: unknown parameter_ver %d\n",
1163 __func__, type_c_cfg->parameter_ver);
1165 cc_param = &type_c_cfg->cc2_param;
1166 type_c->cc2_code = rp4pk_code(cc_param->rp_4p7k_code)
1167 | rp36k_code(cc_param->rp_36k_code)
1168 | rp12k_code(cc_param->rp_12k_code)
1169 | rd_code(cc_param->rd_code);
1171 if (type_c_cfg->parameter_ver == PARAMETER_V0)
1172 type_c->cc2_vref = V0_vref_2p6v(cc_param->vref_2p6v) |
1173 V0_vref_1p23v(cc_param->vref_1p23v) |
1174 V0_vref_0p8v(cc_param->vref_0p8v) |
1175 V0_vref_0p66v(cc_param->vref_0p66v) |
1176 V0_vref_0p4v(cc_param->vref_0p4v) |
1177 V0_vref_0p2v(cc_param->vref_0p2v) |
1178 V0_vref_1_1p6v(cc_param->vref_1_1p6v) |
1179 V0_vref_0_1p6v(cc_param->vref_0_1p6v);
1180 else if (type_c_cfg->parameter_ver == PARAMETER_V1)
1181 type_c->cc2_vref = V1_vref_2p6v(cc_param->vref_2p6v) |
1182 V1_vref_1p23v(cc_param->vref_1p23v) |
1183 V1_vref_0p8v(cc_param->vref_0p8v) |
1184 V1_vref_0p66v(cc_param->vref_0p66v) |
1185 V1_vref_0p4v(cc_param->vref_0p4v) |
1186 V1_vref_0p2v(cc_param->vref_0p2v) |
1187 V1_vref_1_1p6v(cc_param->vref_1_1p6v) |
1188 V1_vref_0_1p6v(cc_param->vref_0_1p6v);
1189 else
1190 dev_err(type_c->dev, "%s: unknown parameter_ver %d\n",
1191 __func__, type_c_cfg->parameter_ver);
1193 type_c->debounce = (type_c_cfg->debounce_val << 1) | DEBOUNCE_EN;
1195 return 0;
1198 static int extcon_rtk_type_c_init(struct type_c_data *type_c)
1200 struct device *dev = type_c->dev;
1201 unsigned long flags;
1202 void __iomem *reg;
1203 int val;
1205 spin_lock_irqsave(&type_c->lock, flags);
1207 /* set parameter */
1208 reg = type_c->reg_base + USB_TYPEC_CTRL_CC1_0;
1209 val = readl(reg);
1210 val = (~CC_CODE_MASK & val) | (type_c->cc1_code & CC_CODE_MASK);
1211 writel(val, reg);
1213 reg = type_c->reg_base + USB_TYPEC_CTRL_CC2_0;
1214 val = readl(reg);
1215 val = (~CC_CODE_MASK & val) | (type_c->cc2_code & CC_CODE_MASK);
1217 reg = type_c->reg_base + USB_TYPEC_CTRL_CC1_1;
1218 writel(type_c->cc1_vref, reg);
1220 reg = type_c->reg_base + USB_TYPEC_CTRL_CC2_1;
1221 writel(type_c->cc2_vref, reg);
1223 reg = type_c->reg_base + USB_TYPEC_CTRL;
1224 val = readl(reg);
1225 val = (~DEBOUNCE_TIME_MASK & val) | (type_c->debounce & DEBOUNCE_TIME_MASK);
1227 dev_info(dev, "First check USB_DR_MODE_PERIPHERAL");
1228 type_c->cc_mode = IN_DEVICE_MODE;
1229 type_c->is_attach = IN_DETACH;
1230 type_c->connect_change = CONNECT_NO_CHANGE;
1232 detect_host(type_c);
1234 spin_unlock_irqrestore(&type_c->lock, flags);
1236 schedule_delayed_work(&type_c->delayed_work, msecs_to_jiffies(0));
1238 if (!type_c->port) {
1239 struct typec_capability typec_cap = { };
1240 struct fwnode_handle *fwnode;
1241 const char *buf;
1242 int ret;
1244 typec_cap.revision = USB_TYPEC_REV_1_0;
1245 typec_cap.prefer_role = TYPEC_NO_PREFERRED_ROLE;
1246 typec_cap.driver_data = type_c;
1247 typec_cap.ops = &type_c_port_ops;
1249 fwnode = device_get_named_child_node(dev, "connector");
1250 if (!fwnode)
1251 return -EINVAL;
1253 ret = fwnode_property_read_string(fwnode, "power-role", &buf);
1254 if (ret) {
1255 dev_err(dev, "power-role not found: %d\n", ret);
1256 return ret;
1259 ret = typec_find_port_power_role(buf);
1260 if (ret < 0)
1261 return ret;
1262 typec_cap.type = ret;
1264 ret = fwnode_property_read_string(fwnode, "data-role", &buf);
1265 if (ret) {
1266 dev_err(dev, "data-role not found: %d\n", ret);
1267 return ret;
1270 ret = typec_find_port_data_role(buf);
1271 if (ret < 0)
1272 return ret;
1273 typec_cap.data = ret;
1275 type_c->port = typec_register_port(type_c->dev, &typec_cap);
1276 if (IS_ERR(type_c->port))
1277 return PTR_ERR(type_c->port);
1280 return 0;
1283 static int extcon_rtk_type_c_edev_register(struct type_c_data *type_c)
1285 struct device *dev = type_c->dev;
1286 int ret = 0;
1288 type_c->edev = devm_extcon_dev_allocate(dev, usb_type_c_cable);
1289 if (IS_ERR(type_c->edev)) {
1290 dev_err(dev, "failed to allocate extcon device\n");
1291 return -ENOMEM;
1294 ret = devm_extcon_dev_register(dev, type_c->edev);
1295 if (ret < 0) {
1296 dev_err(dev, "failed to register extcon device\n");
1297 return ret;
1300 extcon_set_property_capability(type_c->edev, EXTCON_USB,
1301 EXTCON_PROP_USB_VBUS);
1302 extcon_set_property_capability(type_c->edev, EXTCON_USB,
1303 EXTCON_PROP_USB_TYPEC_POLARITY);
1304 extcon_set_property_capability(type_c->edev, EXTCON_USB,
1305 EXTCON_PROP_USB_SS);
1307 extcon_set_property_capability(type_c->edev, EXTCON_USB_HOST,
1308 EXTCON_PROP_USB_VBUS);
1309 extcon_set_property_capability(type_c->edev, EXTCON_USB_HOST,
1310 EXTCON_PROP_USB_TYPEC_POLARITY);
1311 extcon_set_property_capability(type_c->edev, EXTCON_USB_HOST,
1312 EXTCON_PROP_USB_SS);
1314 return ret;
1317 static int extcon_rtk_type_c_probe(struct platform_device *pdev)
1319 struct device *dev = &pdev->dev;
1320 struct type_c_data *type_c;
1321 const struct type_c_cfg *type_c_cfg;
1322 int ret = 0;
1324 type_c = devm_kzalloc(dev, sizeof(*type_c), GFP_KERNEL);
1325 if (!type_c)
1326 return -ENOMEM;
1328 type_c->reg_base = devm_platform_ioremap_resource(pdev, 0);
1329 if (IS_ERR(type_c->reg_base))
1330 return PTR_ERR(type_c->reg_base);
1332 type_c->dev = dev;
1334 type_c->irq = irq_of_parse_and_map(pdev->dev.of_node, 0);
1335 if (type_c->irq <= 0) {
1336 dev_err(&pdev->dev, "Type C driver with no IRQ. Check %s setup!\n",
1337 dev_name(&pdev->dev));
1338 ret = -ENODEV;
1339 goto err;
1342 ret = devm_request_irq(dev, type_c->irq, type_c_detect_irq,
1343 IRQF_SHARED, "type_c_detect", type_c);
1345 spin_lock_init(&type_c->lock);
1347 type_c->rd_ctrl_gpio_desc = NULL;
1348 if (soc_device_match(rtk_soc_kylin)) {
1349 struct gpio_desc *gpio;
1351 gpio = fwnode_gpiod_get_index(of_fwnode_handle(dev->of_node),
1352 "realtek,rd-ctrl-gpios",
1353 0, GPIOD_OUT_HIGH, "rd-ctrl-gpio");
1354 if (IS_ERR(gpio)) {
1355 dev_err(dev, "Error rd_ctrl-gpios no found (err=%d)\n",
1356 (int)PTR_ERR(gpio));
1357 } else {
1358 type_c->rd_ctrl_gpio_desc = gpio;
1359 dev_dbg(dev, "%s get rd-ctrl-gpios (id=%d) OK\n",
1360 __func__, desc_to_gpio(gpio));
1364 type_c_cfg = of_device_get_match_data(dev);
1365 if (!type_c_cfg) {
1366 dev_err(dev, "type_c config are not assigned!\n");
1367 ret = -EINVAL;
1368 goto err;
1371 type_c->type_c_cfg = devm_kzalloc(dev, sizeof(*type_c_cfg), GFP_KERNEL);
1373 memcpy(type_c->type_c_cfg, type_c_cfg, sizeof(*type_c_cfg));
1375 if (setup_type_c_parameter(type_c)) {
1376 dev_err(dev, "ERROR: %s to setup type c parameter!!", __func__);
1377 ret = -EINVAL;
1378 goto err;
1381 INIT_DELAYED_WORK(&type_c->delayed_work, host_device_switch);
1383 ret = extcon_rtk_type_c_init(type_c);
1384 if (ret) {
1385 dev_err(dev, "%s failed to init type_c\n", __func__);
1386 goto err;
1389 platform_set_drvdata(pdev, type_c);
1391 ret = extcon_rtk_type_c_edev_register(type_c);
1393 create_debug_files(type_c);
1395 return 0;
1397 err:
1398 dev_err(&pdev->dev, "%s: Probe fail, %d\n", __func__, ret);
1400 return ret;
1403 static void extcon_rtk_type_c_remove(struct platform_device *pdev)
1405 struct device *dev = &pdev->dev;
1406 struct type_c_data *type_c = dev_get_drvdata(dev);
1407 u32 default_ctrl;
1408 unsigned long flags;
1410 remove_debug_files(type_c);
1412 if (type_c->port) {
1413 typec_unregister_port(type_c->port);
1414 type_c->port = NULL;
1417 cancel_delayed_work_sync(&type_c->delayed_work);
1418 flush_delayed_work(&type_c->delayed_work);
1419 WARN_ON_ONCE(delayed_work_pending(&type_c->delayed_work));
1421 spin_lock_irqsave(&type_c->lock, flags);
1422 /* disable interrupt */
1423 default_ctrl = readl(type_c->reg_base + USB_TYPEC_CTRL) &
1424 DEBOUNCE_TIME_MASK;
1425 writel(default_ctrl, type_c->reg_base + USB_TYPEC_CTRL);
1427 /* disable cc detect, rp, rd */
1428 writel(PLR_EN, type_c->reg_base + USB_TYPEC_CTRL_CC1_0);
1429 writel(0, type_c->reg_base + USB_TYPEC_CTRL_CC2_0);
1431 spin_unlock_irqrestore(&type_c->lock, flags);
1433 if (type_c->rd_ctrl_gpio_desc)
1434 gpiod_put(type_c->rd_ctrl_gpio_desc);
1435 type_c->rd_ctrl_gpio_desc = NULL;
1437 free_irq(type_c->irq, type_c);
1440 static const struct type_c_cfg rtd1295_type_c_cfg = {
1441 .parameter_ver = PARAMETER_V0,
1442 .cc_dfp_mode = CC_MODE_DFP_3_0,
1443 .cc1_param = { .rp_4p7k_code = 0xb,
1444 .rp_36k_code = 0x17,
1445 .rp_12k_code = 0x10,
1446 .rd_code = 0,
1447 .ra_code = 0,
1448 .vref_2p6v = 0x0,
1449 .vref_1p23v = 0x0,
1450 .vref_0p8v = 0x3,
1451 .vref_0p66v = 0x0,
1452 .vref_0p4v = 0x0,
1453 .vref_0p2v = 0x4,
1454 .vref_1_1p6v = 0,
1455 .vref_0_1p6v = 0 },
1456 .cc2_param = { .rp_4p7k_code = 0xc,
1457 .rp_36k_code = 0x17,
1458 .rp_12k_code = 0x12,
1459 .rd_code = 0,
1460 .ra_code = 0,
1461 .vref_2p6v = 0x2,
1462 .vref_1p23v = 0x0,
1463 .vref_0p8v = 0x3,
1464 .vref_0p66v = 0x0,
1465 .vref_0p4v = 0x0,
1466 .vref_0p2v = 0x5,
1467 .vref_1_1p6v = 0,
1468 .vref_0_1p6v = 0 },
1469 .debounce_val = 0x7f, /* 1b,1us 7f,4.7us */
1470 .use_defalut_parameter = false,
1473 static const struct type_c_cfg rtd1395_type_c_cfg = {
1474 .parameter_ver = PARAMETER_V0,
1475 .cc_dfp_mode = CC_MODE_DFP_3_0,
1476 .cc1_param = { .rp_4p7k_code = 0xc,
1477 .rp_36k_code = 0xb,
1478 .rp_12k_code = 0xe,
1479 .rd_code = 0x10,
1480 .ra_code = 0x0,
1481 .vref_2p6v = 0x0,
1482 .vref_1p23v = 0x1,
1483 .vref_0p8v = 0x0,
1484 .vref_0p66v = 0x0,
1485 .vref_0p4v = 0x3,
1486 .vref_0p2v = 0x0,
1487 .vref_1_1p6v = 0x7,
1488 .vref_0_1p6v = 0x7 },
1489 .cc2_param = { .rp_4p7k_code = 0xb,
1490 .rp_36k_code = 0x9,
1491 .rp_12k_code = 0xe,
1492 .rd_code = 0xf,
1493 .ra_code = 0x0,
1494 .vref_2p6v = 0x1,
1495 .vref_1p23v = 0x3,
1496 .vref_0p8v = 0x3,
1497 .vref_0p66v = 0x2,
1498 .vref_0p4v = 0x3,
1499 .vref_0p2v = 0x2,
1500 .vref_1_1p6v = 0x7,
1501 .vref_0_1p6v = 0x7 },
1502 .debounce_val = 0x7f, /* 1b,1us 7f,4.7us */
1503 .use_defalut_parameter = false,
1506 static const struct type_c_cfg rtd1619_type_c_cfg = {
1507 .parameter_ver = PARAMETER_V0,
1508 .cc_dfp_mode = CC_MODE_DFP_3_0,
1509 .cc1_param = { .rp_4p7k_code = 0xc,
1510 .rp_36k_code = 0xf,
1511 .rp_12k_code = 0xe,
1512 .rd_code = 0x11,
1513 .ra_code = 0x0,
1514 .vref_2p6v = 0x5,
1515 .vref_1p23v = 0x7,
1516 .vref_0p8v = 0xa,
1517 .vref_0p66v = 0xa,
1518 .vref_0p4v = 0x3,
1519 .vref_0p2v = 0x2,
1520 .vref_1_1p6v = 0x7,
1521 .vref_0_1p6v = 0x7 },
1522 .cc2_param = { .rp_4p7k_code = 0xc,
1523 .rp_36k_code = 0xf,
1524 .rp_12k_code = 0xe,
1525 .rd_code = 0xf,
1526 .ra_code = 0x0,
1527 .vref_2p6v = 0x5,
1528 .vref_1p23v = 0x8,
1529 .vref_0p8v = 0xa,
1530 .vref_0p66v = 0xa,
1531 .vref_0p4v = 0x3,
1532 .vref_0p2v = 0x2,
1533 .vref_1_1p6v = 0x7,
1534 .vref_0_1p6v = 0x7 },
1535 .debounce_val = 0x7f, /* 1b,1us 7f,4.7us */
1536 .use_defalut_parameter = false,
1539 static const struct type_c_cfg rtd1319_type_c_cfg = {
1540 .parameter_ver = PARAMETER_V0,
1541 .cc_dfp_mode = CC_MODE_DFP_1_5,
1542 .cc1_param = { .rp_4p7k_code = 0x9,
1543 .rp_36k_code = 0xe,
1544 .rp_12k_code = 0x9,
1545 .rd_code = 0x9,
1546 .ra_code = 0x7,
1547 .vref_2p6v = 0x3,
1548 .vref_1p23v = 0x7,
1549 .vref_0p8v = 0x7,
1550 .vref_0p66v = 0x6,
1551 .vref_0p4v = 0x2,
1552 .vref_0p2v = 0x3,
1553 .vref_1_1p6v = 0x4,
1554 .vref_0_1p6v = 0x7 },
1555 .cc2_param = { .rp_4p7k_code = 0x8,
1556 .rp_36k_code = 0xe,
1557 .rp_12k_code = 0x9,
1558 .rd_code = 0x9,
1559 .ra_code = 0x7,
1560 .vref_2p6v = 0x3,
1561 .vref_1p23v = 0x7,
1562 .vref_0p8v = 0x7,
1563 .vref_0p66v = 0x6,
1564 .vref_0p4v = 0x3,
1565 .vref_0p2v = 0x3,
1566 .vref_1_1p6v = 0x6,
1567 .vref_0_1p6v = 0x7 },
1568 .debounce_val = 0x7f, /* 1b,1us 7f,4.7us */
1569 .use_defalut_parameter = false,
1572 static const struct type_c_cfg rtd1312c_type_c_cfg = {
1573 .parameter_ver = PARAMETER_V0,
1574 .cc_dfp_mode = CC_MODE_DFP_1_5,
1575 .cc1_param = { .rp_4p7k_code = 0xe,
1576 .rp_36k_code = 0xc,
1577 .rp_12k_code = 0xc,
1578 .rd_code = 0xa,
1579 .ra_code = 0x3,
1580 .vref_2p6v = 0xa,
1581 .vref_1p23v = 0x7,
1582 .vref_0p8v = 0x7,
1583 .vref_0p66v = 0x7,
1584 .vref_0p4v = 0x4,
1585 .vref_0p2v = 0x4,
1586 .vref_1_1p6v = 0x7,
1587 .vref_0_1p6v = 0x7 },
1588 .cc2_param = { .rp_4p7k_code = 0xe,
1589 .rp_36k_code = 0xc,
1590 .rp_12k_code = 0xc,
1591 .rd_code = 0xa,
1592 .ra_code = 0x3,
1593 .vref_2p6v = 0xa,
1594 .vref_1p23v = 0x7,
1595 .vref_0p8v = 0x7,
1596 .vref_0p66v = 0x7,
1597 .vref_0p4v = 0x4,
1598 .vref_0p2v = 0x4,
1599 .vref_1_1p6v = 0x7,
1600 .vref_0_1p6v = 0x7 },
1601 .debounce_val = 0x7f, /* 1b,1us 7f,4.7us */
1602 .use_defalut_parameter = false,
1605 static const struct type_c_cfg rtd1619b_type_c_cfg = {
1606 .parameter_ver = PARAMETER_V1,
1607 .cc_dfp_mode = CC_MODE_DFP_1_5,
1608 .cc1_param = { .rp_4p7k_code = 0xf,
1609 .rp_36k_code = 0xf,
1610 .rp_12k_code = 0xf,
1611 .rd_code = 0xf,
1612 .ra_code = 0x7,
1613 .vref_2p6v = 0x9,
1614 .vref_1p23v = 0x7,
1615 .vref_0p8v = 0x9,
1616 .vref_0p66v = 0x8,
1617 .vref_0p4v = 0x7,
1618 .vref_0p2v = 0x9,
1619 .vref_1_1p6v = 0x7,
1620 .vref_0_1p6v = 0x7 },
1621 .cc2_param = { .rp_4p7k_code = 0xf,
1622 .rp_36k_code = 0xf,
1623 .rp_12k_code = 0xf,
1624 .rd_code = 0xf,
1625 .ra_code = 0x7,
1626 .vref_1p23v = 0x7,
1627 .vref_0p8v = 0x9,
1628 .vref_0p66v = 0x8,
1629 .vref_0p4v = 0x7,
1630 .vref_0p2v = 0x8,
1631 .vref_1_1p6v = 0x7,
1632 .vref_0_1p6v = 0x7 },
1633 .debounce_val = 0x7f, /* 1b,1us 7f,4.7us */
1634 .use_defalut_parameter = false,
1637 static const struct type_c_cfg rtd1319d_type_c_cfg = {
1638 .parameter_ver = PARAMETER_V1,
1639 .cc_dfp_mode = CC_MODE_DFP_1_5,
1640 .cc1_param = { .rp_4p7k_code = 0xe,
1641 .rp_36k_code = 0x3,
1642 .rp_12k_code = 0xe,
1643 .rd_code = 0xf,
1644 .ra_code = 0x6,
1645 .vref_2p6v = 0x7,
1646 .vref_1p23v = 0x7,
1647 .vref_0p8v = 0x8,
1648 .vref_0p66v = 0x7,
1649 .vref_0p4v = 0x7,
1650 .vref_0p2v = 0x7,
1651 .vref_1_1p6v = 0x7,
1652 .vref_0_1p6v = 0x7 },
1653 .cc2_param = { .rp_4p7k_code = 0xe,
1654 .rp_36k_code = 0x3,
1655 .rp_12k_code = 0xe,
1656 .rd_code = 0xf,
1657 .ra_code = 0x6,
1658 .vref_2p6v = 0x7,
1659 .vref_1p23v = 0x7,
1660 .vref_0p8v = 0x8,
1661 .vref_0p66v = 0x7,
1662 .vref_0p4v = 0x7,
1663 .vref_0p2v = 0x8,
1664 .vref_1_1p6v = 0x7,
1665 .vref_0_1p6v = 0x7 },
1666 .debounce_val = 0x7f, /* 1b,1us 7f,4.7us */
1667 .use_defalut_parameter = false,
1670 static const struct type_c_cfg rtd1315e_type_c_cfg = {
1671 .parameter_ver = PARAMETER_V1,
1672 .cc_dfp_mode = CC_MODE_DFP_1_5,
1673 .cc1_param = { .rp_4p7k_code = 0xe,
1674 .rp_36k_code = 0x3,
1675 .rp_12k_code = 0xe,
1676 .rd_code = 0xf,
1677 .ra_code = 0x6,
1678 .vref_2p6v = 0x7,
1679 .vref_1p23v = 0x7,
1680 .vref_0p8v = 0x8,
1681 .vref_0p66v = 0x7,
1682 .vref_0p4v = 0x7,
1683 .vref_0p2v = 0x7,
1684 .vref_1_1p6v = 0x7,
1685 .vref_0_1p6v = 0x7 },
1686 .cc2_param = { .rp_4p7k_code = 0xe,
1687 .rp_36k_code = 0x3,
1688 .rp_12k_code = 0xe,
1689 .rd_code = 0xf,
1690 .ra_code = 0x6,
1691 .vref_2p6v = 0x7,
1692 .vref_1p23v = 0x7,
1693 .vref_0p8v = 0x8,
1694 .vref_0p66v = 0x7,
1695 .vref_0p4v = 0x7,
1696 .vref_0p2v = 0x8,
1697 .vref_1_1p6v = 0x7,
1698 .vref_0_1p6v = 0x7 },
1699 .debounce_val = 0x7f, /* 1b,1us 7f,4.7us */
1700 .use_defalut_parameter = false,
1703 static const struct of_device_id extcon_rtk_type_c_match[] = {
1704 { .compatible = "realtek,rtd1295-type-c", .data = &rtd1295_type_c_cfg },
1705 { .compatible = "realtek,rtd1312c-type-c", .data = &rtd1312c_type_c_cfg },
1706 { .compatible = "realtek,rtd1315e-type-c", .data = &rtd1315e_type_c_cfg },
1707 { .compatible = "realtek,rtd1319-type-c", .data = &rtd1319_type_c_cfg },
1708 { .compatible = "realtek,rtd1319d-type-c", .data = &rtd1319d_type_c_cfg },
1709 { .compatible = "realtek,rtd1395-type-c", .data = &rtd1395_type_c_cfg },
1710 { .compatible = "realtek,rtd1619-type-c", .data = &rtd1619_type_c_cfg },
1711 { .compatible = "realtek,rtd1619b-type-c", .data = &rtd1619b_type_c_cfg },
1714 MODULE_DEVICE_TABLE(of, extcon_rtk_type_c_match);
1716 #ifdef CONFIG_PM_SLEEP
1717 static int extcon_rtk_type_c_prepare(struct device *dev)
1719 struct type_c_data *type_c = dev_get_drvdata(dev);
1720 u32 default_ctrl;
1721 unsigned long flags;
1723 cancel_delayed_work_sync(&type_c->delayed_work);
1724 flush_delayed_work(&type_c->delayed_work);
1725 WARN_ON_ONCE(delayed_work_pending(&type_c->delayed_work));
1727 spin_lock_irqsave(&type_c->lock, flags);
1728 /* disable interrupt */
1729 default_ctrl = readl(type_c->reg_base + USB_TYPEC_CTRL) &
1730 DEBOUNCE_TIME_MASK;
1731 writel(default_ctrl, type_c->reg_base + USB_TYPEC_CTRL);
1733 /* disable cc detect, rp, rd */
1734 writel(PLR_EN, type_c->reg_base + USB_TYPEC_CTRL_CC1_0);
1735 writel(0, type_c->reg_base + USB_TYPEC_CTRL_CC2_0);
1737 spin_unlock_irqrestore(&type_c->lock, flags);
1739 return 0;
1742 static void extcon_rtk_type_c_complete(struct device *dev)
1744 /* nothing */
1747 static int extcon_rtk_type_c_suspend(struct device *dev)
1749 /* nothing */
1751 return 0;
1754 static int extcon_rtk_type_c_resume(struct device *dev)
1756 struct type_c_data *type_c = dev_get_drvdata(dev);
1757 int ret;
1759 ret = extcon_rtk_type_c_init(type_c);
1760 if (ret) {
1761 dev_err(dev, "%s failed to init type_c\n", __func__);
1762 return ret;
1765 return 0;
1768 static const struct dev_pm_ops extcon_rtk_type_c_pm_ops = {
1769 SET_LATE_SYSTEM_SLEEP_PM_OPS(extcon_rtk_type_c_suspend, extcon_rtk_type_c_resume)
1770 .prepare = extcon_rtk_type_c_prepare,
1771 .complete = extcon_rtk_type_c_complete,
1774 #define DEV_PM_OPS (&extcon_rtk_type_c_pm_ops)
1775 #else
1776 #define DEV_PM_OPS NULL
1777 #endif /* CONFIG_PM_SLEEP */
1779 static struct platform_driver extcon_rtk_type_c_driver = {
1780 .probe = extcon_rtk_type_c_probe,
1781 .remove = extcon_rtk_type_c_remove,
1782 .driver = {
1783 .name = "extcon-rtk-type_c",
1784 .of_match_table = extcon_rtk_type_c_match,
1785 .pm = DEV_PM_OPS,
1789 module_platform_driver(extcon_rtk_type_c_driver);
1791 MODULE_DESCRIPTION("Realtek Extcon Type C driver");
1792 MODULE_AUTHOR("Stanley Chang <stanley_chang@realtek.com>");
1793 MODULE_LICENSE("GPL");