1 // SPDX-License-Identifier: GPL-2.0 2 /* 3 * * extcon-rtk-type-c.c - Realtek Extcon Type C driver 4 * 5 * Copyright (C) 2023 Realtek Semiconductor Corporation 6 * 7 */ 8 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> 28 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; 43 }; 44 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; 50 51 u32 debounce_val; 52 bool use_defalut_parameter; 53 }; 54 55 struct type_c_data { 56 void __iomem *reg_base; 57 struct device *dev; 58 struct extcon_dev *edev; 59 60 u32 irq; 61 62 /* rd control GPIO only for rtd1295 */ 63 struct gpio_desc *rd_ctrl_gpio_desc; 64 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 */ 74 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 90 91 u32 int_status; 92 u32 cc_status; 93 /* protect the data member */ 94 spinlock_t lock; 95 struct delayed_work delayed_work; 96 97 bool rd_en_at_first; 98 99 struct dentry *debug_dir; 100 101 struct typec_port *port; 102 }; 103 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 112 113 #define ENABLE_CC1 0x1 114 #define ENABLE_CC2 0x2 115 #define DISABLE_CC 0x0 116 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) 135 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 140 141 /* 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 152 */ 153 enum parameter_version { 154 PARAMETER_V0 = 0, 155 PARAMETER_V1 = 1, 156 }; 157 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) 167 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) 176 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) 186 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) 195 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) 209 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) 219 220 /* Parameter */ 221 #define DETECT_TIME 50 /* ms */ 222 223 static const unsigned int usb_type_c_cable[] = { 224 EXTCON_USB, 225 EXTCON_USB_HOST, 226 EXTCON_NONE, 227 }; 228 229 enum usb_data_roles { 230 DR_NONE, 231 DR_HOST, 232 DR_DEVICE, 233 }; 234 235 static const struct soc_device_attribute rtk_soc_kylin[] = { 236 { .family = "Realtek Kylin", }, 237 { /* empty */ } 238 }; 239 240 static int rtd129x_switch_type_c_plug_config(struct type_c_data *type_c, 241 int dr_mode, int cc) 242 { 243 void __iomem *reg = type_c->reg_base + USB_TYPEC_CTRL_CC1_0; 244 int val_cc; 245 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 252 253 val_cc = readl(reg); 254 val_cc &= ~TYPE_C_SWITCH_MASK; 255 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; 265 } 266 writel(val_cc, reg); 267 268 /* waiting cc stable for enable/disable */ 269 mdelay(1); 270 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)); 273 274 return 0; 275 } 276 277 static inline void switch_type_c_plug_config(struct type_c_data *type_c, 278 int dr_mode, int cc) 279 { 280 int ret = 0; 281 282 if (soc_device_match(rtk_soc_kylin)) 283 ret = rtd129x_switch_type_c_plug_config(type_c, dr_mode, cc); 284 285 if (ret < 0) 286 dev_err(type_c->dev, "%s: Error set type c plug config\n", 287 __func__); 288 } 289 290 static void switch_type_c_dr_mode(struct type_c_data *type_c, int dr_mode, int cc) 291 { 292 bool is_host = false; 293 bool is_device = false; 294 bool polarity = false; 295 bool vbus = false; 296 bool ss = true; 297 298 switch_type_c_plug_config(type_c, dr_mode, cc); 299 if (cc == ENABLE_CC2) 300 polarity = true; 301 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; 314 } 315 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); 318 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); 330 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); 342 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); 346 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; 361 } 362 } 363 } 364 365 /* connector attached/detached */ 366 static int connector_attached(struct type_c_data *type_c, u32 cc, int dr_mode) 367 { 368 void __iomem *reg = type_c->reg_base + USB_TYPEC_CTRL; 369 370 cancel_delayed_work(&type_c->delayed_work); 371 372 switch_type_c_dr_mode(type_c, dr_mode, cc); 373 374 writel(ENABLE_TYPE_C_DETECT | readl(reg), reg); 375 376 return 0; 377 } 378 379 static int connector_detached(struct type_c_data *type_c, u32 cc, int dr_mode) 380 { 381 void __iomem *reg = type_c->reg_base + USB_TYPEC_CTRL; 382 383 writel(~ENABLE_TYPE_C_DETECT & readl(reg), reg); 384 385 switch_type_c_dr_mode(type_c, 0, cc); 386 387 schedule_delayed_work(&type_c->delayed_work, msecs_to_jiffies(DETECT_TIME)); 388 389 return 0; 390 } 391 392 /* detect host device switch */ 393 static int __detect_host_device(struct type_c_data *type_c, u32 rp_or_rd_en) 394 { 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; 399 400 default_ctrl = readl(reg_base + USB_TYPEC_CTRL) & DEBOUNCE_TIME_MASK; 401 writel(default_ctrl, reg_base + USB_TYPEC_CTRL); 402 403 cc1_config = readl(reg_base + USB_TYPEC_CTRL_CC1_0); 404 cc2_config = readl(reg_base + USB_TYPEC_CTRL_CC2_0); 405 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); 410 411 if (soc_device_match(rtk_soc_kylin)) 412 cc1_switch = cc1_config & CC_SWITCH_MASK; 413 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); 420 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; 424 425 if (gpio && gpiod_direction_output(gpio, 1)) 426 dev_err(dev, "%s ERROR set rd_ctrl_gpio_desc fail\n", __func__); 427 } 428 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); 433 434 return 0; 435 } 436 437 static int detect_device(struct type_c_data *type_c) 438 { 439 return __detect_host_device(type_c, type_c->dfp_mode_rp_en); 440 } 441 442 static int detect_host(struct type_c_data *type_c) 443 { 444 return __detect_host_device(type_c, type_c->ufp_mode_rd_en); 445 } 446 447 static int host_device_switch_detection(struct type_c_data *type_c) 448 { 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); 455 } 456 457 return 0; 458 } 459 460 static int detect_type_c_state(struct type_c_data *type_c) 461 { 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; 466 467 spin_lock_irqsave(&type_c->lock, flags); 468 469 int_status = readl(reg_base + USB_TYPEC_CTRL); 470 cc_status = readl(reg_base + USB_TYPEC_STS); 471 472 type_c->connect_change = CONNECT_NO_CHANGE; 473 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; 487 } 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); 500 } 501 cc_status_check = readl(reg_base + USB_TYPEC_STS); 502 } 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); 507 } 508 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; 521 } 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); 529 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; 534 } 535 } 536 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; 548 } 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); 561 } 562 cc_status_check = readl(reg_base + USB_TYPEC_STS); 563 } 564 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); 569 } 570 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; 583 } 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); 588 } 589 590 type_c->int_status = int_status; 591 type_c->cc_status = cc_status; 592 593 spin_unlock_irqrestore(&type_c->lock, flags); 594 return 0; 595 } 596 597 static void host_device_switch(struct work_struct *work) 598 { 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; 607 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); 612 613 if (!connect_change) 614 detect_type_c_state(type_c); 615 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); 625 626 schedule_delayed_work(&type_c->delayed_work, msecs_to_jiffies(DETECT_TIME)); 627 } 628 spin_unlock_irqrestore(&type_c->lock, flags); 629 630 if (!connect_change) 631 return; 632 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); 652 } 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); 657 } 658 659 static irqreturn_t type_c_detect_irq(int irq, void *__data) 660 { 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; 665 666 detect_type_c_state(type_c); 667 668 spin_lock_irqsave(&type_c->lock, flags); 669 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); 677 678 /* clear interrupt status */ 679 writel(~ALL_CC_INT_STS & readl(reg), reg); 680 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; 685 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; 691 } 692 } 693 694 spin_unlock_irqrestore(&type_c->lock, flags); 695 696 return IRQ_HANDLED; 697 } 698 699 static int type_c_port_dr_set(struct typec_port *port, 700 enum typec_data_role role) 701 { 702 struct type_c_data *type_c = typec_get_drvdata(port); 703 u32 enable_cc; 704 unsigned long flags; 705 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); 709 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); 716 717 return 0; 718 } 719 720 static const struct typec_operations type_c_port_ops = { 721 .dr_set = type_c_port_dr_set, 722 }; 723 724 #ifdef CONFIG_DEBUG_FS 725 static int type_c_parameter_show(struct seq_file *s, void *unused) 726 { 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; 731 732 spin_lock_irqsave(&type_c->lock, flags); 733 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; })); 746 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"); 755 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); 770 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); 785 786 spin_unlock_irqrestore(&type_c->lock, flags); 787 788 return 0; 789 } 790 791 static int type_c_parameter_open(struct inode *inode, struct file *file) 792 { 793 return single_open(file, type_c_parameter_show, inode->i_private); 794 } 795 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, 801 }; 802 803 static int type_c_status_show(struct seq_file *s, void *unused) 804 { 805 struct type_c_data *type_c = s->private; 806 unsigned long flags; 807 808 spin_lock_irqsave(&type_c->lock, flags); 809 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); 814 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)); 827 828 spin_unlock_irqrestore(&type_c->lock, flags); 829 830 return 0; 831 } 832 833 static int type_c_status_open(struct inode *inode, struct file *file) 834 { 835 return single_open(file, type_c_status_show, inode->i_private); 836 } 837 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, 843 }; 844 845 static inline void create_debug_files(struct type_c_data *type_c) 846 { 847 type_c->debug_dir = debugfs_create_dir("type_c", usb_debug_root); 848 849 debugfs_create_file("parameter", 0444, type_c->debug_dir, type_c, 850 &type_c_parameter_fops); 851 852 debugfs_create_file("status", 0444, type_c->debug_dir, type_c, 853 &type_c_status_fops); 854 } 855 856 static inline void remove_debug_files(struct type_c_data *type_c) 857 { 858 debugfs_remove_recursive(type_c->debug_dir); 859 } 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 */ 864 865 /* Init and probe */ 866 867 static inline s8 get_value(s8 value) 868 { 869 return (((s8)value & 0x8) ? (-(s8)(0x7 & value)) : ((s8)(value))); 870 } 871 872 static int __updated_type_c_parameter_by_efuse(struct type_c_data *type_c) 873 { 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; 891 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); 901 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); 909 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); 915 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); 920 921 kfree(buf); 922 } 923 nvmem_cell_put(cell); 924 } 925 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); 932 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; 936 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; 942 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; 946 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; 952 953 return 0; 954 } 955 956 static int __updated_type_c_parameter_by_efuse_v2(struct type_c_data *type_c) 957 { 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; 975 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); 985 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; 994 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; 1002 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; 1008 1009 kfree(buf); 1010 } 1011 nvmem_cell_put(cell); 1012 } 1013 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); 1020 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; 1026 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; 1037 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; 1043 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; 1054 1055 return 0; 1056 } 1057 1058 static void get_default_type_c_parameter(struct type_c_data *type_c) 1059 { 1060 void __iomem *reg; 1061 int val; 1062 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; 1065 1066 reg = type_c->reg_base + USB_TYPEC_CTRL_CC1_0; 1067 val = readl(reg); 1068 type_c->cc1_code = CC_CODE_MASK & val; 1069 1070 reg = type_c->reg_base + USB_TYPEC_CTRL_CC2_0; 1071 val = readl(reg); 1072 type_c->cc2_code = CC_CODE_MASK & val; 1073 1074 reg = type_c->reg_base + USB_TYPEC_CTRL_CC1_1; 1075 val = readl(reg); 1076 type_c->cc1_vref = val; 1077 1078 reg = type_c->reg_base + USB_TYPEC_CTRL_CC2_1; 1079 val = readl(reg); 1080 type_c->cc2_vref = val; 1081 1082 reg = type_c->reg_base + USB_TYPEC_CTRL; 1083 val = readl(reg); 1084 type_c->debounce = DEBOUNCE_TIME_MASK & val; 1085 } 1086 1087 static int setup_type_c_parameter(struct type_c_data *type_c) 1088 { 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 */ } 1101 }; 1102 1103 if (type_c_cfg->use_defalut_parameter) { 1104 get_default_type_c_parameter(type_c); 1105 return 0; 1106 } 1107 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); 1112 1113 /* 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 1118 */ 1119 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); 1133 } 1134 1135 type_c->ufp_mode_rd_en = EN_RD; 1136 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); 1142 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); 1164 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); 1170 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); 1192 1193 type_c->debounce = (type_c_cfg->debounce_val << 1) | DEBOUNCE_EN; 1194 1195 return 0; 1196 } 1197 1198 static int extcon_rtk_type_c_init(struct type_c_data *type_c) 1199 { 1200 struct device *dev = type_c->dev; 1201 unsigned long flags; 1202 void __iomem *reg; 1203 int val; 1204 1205 spin_lock_irqsave(&type_c->lock, flags); 1206 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); 1212 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); 1216 1217 reg = type_c->reg_base + USB_TYPEC_CTRL_CC1_1; 1218 writel(type_c->cc1_vref, reg); 1219 1220 reg = type_c->reg_base + USB_TYPEC_CTRL_CC2_1; 1221 writel(type_c->cc2_vref, reg); 1222 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); 1226 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; 1231 1232 detect_host(type_c); 1233 1234 spin_unlock_irqrestore(&type_c->lock, flags); 1235 1236 schedule_delayed_work(&type_c->delayed_work, msecs_to_jiffies(0)); 1237 1238 if (!type_c->port) { 1239 struct typec_capability typec_cap = { }; 1240 struct fwnode_handle *fwnode; 1241 const char *buf; 1242 int ret; 1243 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; 1248 1249 fwnode = device_get_named_child_node(dev, "connector"); 1250 if (!fwnode) 1251 return -EINVAL; 1252 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; 1257 } 1258 1259 ret = typec_find_port_power_role(buf); 1260 if (ret < 0) 1261 return ret; 1262 typec_cap.type = ret; 1263 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; 1268 } 1269 1270 ret = typec_find_port_data_role(buf); 1271 if (ret < 0) 1272 return ret; 1273 typec_cap.data = ret; 1274 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); 1278 } 1279 1280 return 0; 1281 } 1282 1283 static int extcon_rtk_type_c_edev_register(struct type_c_data *type_c) 1284 { 1285 struct device *dev = type_c->dev; 1286 int ret = 0; 1287 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; 1292 } 1293 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; 1298 } 1299 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); 1306 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); 1313 1314 return ret; 1315 } 1316 1317 static int extcon_rtk_type_c_probe(struct platform_device *pdev) 1318 { 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; 1323 1324 type_c = devm_kzalloc(dev, sizeof(*type_c), GFP_KERNEL); 1325 if (!type_c) 1326 return -ENOMEM; 1327 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); 1331 1332 type_c->dev = dev; 1333 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; 1340 } 1341 1342 ret = devm_request_irq(dev, type_c->irq, type_c_detect_irq, 1343 IRQF_SHARED, "type_c_detect", type_c); 1344 1345 spin_lock_init(&type_c->lock); 1346 1347 type_c->rd_ctrl_gpio_desc = NULL; 1348 if (soc_device_match(rtk_soc_kylin)) { 1349 struct gpio_desc *gpio; 1350 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)); 1361 } 1362 } 1363 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; 1369 } 1370 1371 type_c->type_c_cfg = devm_kzalloc(dev, sizeof(*type_c_cfg), GFP_KERNEL); 1372 1373 memcpy(type_c->type_c_cfg, type_c_cfg, sizeof(*type_c_cfg)); 1374 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; 1379 } 1380 1381 INIT_DELAYED_WORK(&type_c->delayed_work, host_device_switch); 1382 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; 1387 } 1388 1389 platform_set_drvdata(pdev, type_c); 1390 1391 ret = extcon_rtk_type_c_edev_register(type_c); 1392 1393 create_debug_files(type_c); 1394 1395 return 0; 1396 1397 err: 1398 dev_err(&pdev->dev, "%s: Probe fail, %d\n", __func__, ret); 1399 1400 return ret; 1401 } 1402 1403 static void extcon_rtk_type_c_remove(struct platform_device *pdev) 1404 { 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; 1409 1410 remove_debug_files(type_c); 1411 1412 if (type_c->port) { 1413 typec_unregister_port(type_c->port); 1414 type_c->port = NULL; 1415 } 1416 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)); 1420 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); 1426 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); 1430 1431 spin_unlock_irqrestore(&type_c->lock, flags); 1432 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; 1436 1437 free_irq(type_c->irq, type_c); 1438 } 1439 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, 1471 }; 1472 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, 1504 }; 1505 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, 1537 }; 1538 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, 1570 }; 1571 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, 1603 }; 1604 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, 1635 }; 1636 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, 1668 }; 1669 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, 1701 }; 1702 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 }, 1712 {}, 1713 }; 1714 MODULE_DEVICE_TABLE(of, extcon_rtk_type_c_match); 1715 1716 #ifdef CONFIG_PM_SLEEP 1717 static int extcon_rtk_type_c_prepare(struct device *dev) 1718 { 1719 struct type_c_data *type_c = dev_get_drvdata(dev); 1720 u32 default_ctrl; 1721 unsigned long flags; 1722 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)); 1726 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); 1732 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); 1736 1737 spin_unlock_irqrestore(&type_c->lock, flags); 1738 1739 return 0; 1740 } 1741 1742 static void extcon_rtk_type_c_complete(struct device *dev) 1743 { 1744 /* nothing */ 1745 } 1746 1747 static int extcon_rtk_type_c_suspend(struct device *dev) 1748 { 1749 /* nothing */ 1750 1751 return 0; 1752 } 1753 1754 static int extcon_rtk_type_c_resume(struct device *dev) 1755 { 1756 struct type_c_data *type_c = dev_get_drvdata(dev); 1757 int ret; 1758 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; 1763 } 1764 1765 return 0; 1766 } 1767 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, 1772 }; 1773 1774 #define DEV_PM_OPS (&extcon_rtk_type_c_pm_ops) 1775 #else 1776 #define DEV_PM_OPS NULL 1777 #endif /* CONFIG_PM_SLEEP */ 1778 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, 1786 }, 1787 }; 1788 1789 module_platform_driver(extcon_rtk_type_c_driver); 1790 1791 MODULE_DESCRIPTION("Realtek Extcon Type C driver"); 1792 MODULE_AUTHOR("Stanley Chang <stanley_chang@realtek.com>"); 1793 MODULE_LICENSE("GPL"); 1794