Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

mfd: rtsx: Add support for rts525A

Add support for new chip rts525A.

Signed-off-by: Micky Ching <micky_ching@realsil.com.cn>
Signed-off-by: Lee Jones <lee.jones@linaro.org>

authored by

Micky Ching and committed by
Lee Jones
41bc2334 663c425f

+129 -3
+103
drivers/mfd/rts5249.c
··· 487 487 pcr->ops = &rts524a_pcr_ops; 488 488 } 489 489 490 + static int rts525a_card_power_on(struct rtsx_pcr *pcr, int card) 491 + { 492 + rtsx_pci_write_register(pcr, LDO_VCC_CFG1, 493 + LDO_VCC_TUNE_MASK, LDO_VCC_3V3); 494 + return rtsx_base_card_power_on(pcr, card); 495 + } 496 + 497 + static int rts525a_switch_output_voltage(struct rtsx_pcr *pcr, u8 voltage) 498 + { 499 + switch (voltage) { 500 + case OUTPUT_3V3: 501 + rtsx_pci_write_register(pcr, LDO_CONFIG2, 502 + LDO_D3318_MASK, LDO_D3318_33V); 503 + rtsx_pci_write_register(pcr, SD_PAD_CTL, SD_IO_USING_1V8, 0); 504 + break; 505 + case OUTPUT_1V8: 506 + rtsx_pci_write_register(pcr, LDO_CONFIG2, 507 + LDO_D3318_MASK, LDO_D3318_18V); 508 + rtsx_pci_write_register(pcr, SD_PAD_CTL, SD_IO_USING_1V8, 509 + SD_IO_USING_1V8); 510 + break; 511 + default: 512 + return -EINVAL; 513 + } 514 + 515 + rtsx_pci_init_cmd(pcr); 516 + rts5249_fill_driving(pcr, voltage); 517 + return rtsx_pci_send_cmd(pcr, 100); 518 + } 519 + 520 + static int rts525a_optimize_phy(struct rtsx_pcr *pcr) 521 + { 522 + int err; 523 + 524 + err = rtsx_pci_write_register(pcr, RTS524A_PM_CTRL3, 525 + D3_DELINK_MODE_EN, 0x00); 526 + if (err < 0) 527 + return err; 528 + 529 + rtsx_pci_write_phy_register(pcr, _PHY_FLD0, 530 + _PHY_FLD0_CLK_REQ_20C | _PHY_FLD0_RX_IDLE_EN | 531 + _PHY_FLD0_BIT_ERR_RSTN | _PHY_FLD0_BER_COUNT | 532 + _PHY_FLD0_BER_TIMER | _PHY_FLD0_CHECK_EN); 533 + 534 + rtsx_pci_write_phy_register(pcr, _PHY_ANA03, 535 + _PHY_ANA03_TIMER_MAX | _PHY_ANA03_OOBS_DEB_EN | 536 + _PHY_CMU_DEBUG_EN); 537 + 538 + if (is_version(pcr, 0x525A, IC_VER_A)) 539 + rtsx_pci_write_phy_register(pcr, _PHY_REV0, 540 + _PHY_REV0_FILTER_OUT | _PHY_REV0_CDR_BYPASS_PFD | 541 + _PHY_REV0_CDR_RX_IDLE_BYPASS); 542 + 543 + return 0; 544 + } 545 + 546 + static int rts525a_extra_init_hw(struct rtsx_pcr *pcr) 547 + { 548 + rts5249_extra_init_hw(pcr); 549 + 550 + rtsx_pci_write_register(pcr, PCLK_CTL, PCLK_MODE_SEL, PCLK_MODE_SEL); 551 + if (is_version(pcr, 0x525A, IC_VER_A)) { 552 + rtsx_pci_write_register(pcr, L1SUB_CONFIG2, 553 + L1SUB_AUTO_CFG, L1SUB_AUTO_CFG); 554 + rtsx_pci_write_register(pcr, RREF_CFG, 555 + RREF_VBGSEL_MASK, RREF_VBGSEL_1V25); 556 + rtsx_pci_write_register(pcr, LDO_VIO_CFG, 557 + LDO_VIO_TUNE_MASK, LDO_VIO_1V7); 558 + rtsx_pci_write_register(pcr, LDO_DV12S_CFG, 559 + LDO_D12_TUNE_MASK, LDO_D12_TUNE_DF); 560 + rtsx_pci_write_register(pcr, LDO_AV12S_CFG, 561 + LDO_AV12S_TUNE_MASK, LDO_AV12S_TUNE_DF); 562 + rtsx_pci_write_register(pcr, LDO_VCC_CFG0, 563 + LDO_VCC_LMTVTH_MASK, LDO_VCC_LMTVTH_2A); 564 + rtsx_pci_write_register(pcr, OOBS_CONFIG, 565 + OOBS_AUTOK_DIS | OOBS_VAL_MASK, 0x89); 566 + } 567 + 568 + return 0; 569 + } 570 + 571 + static const struct pcr_ops rts525a_pcr_ops = { 572 + .fetch_vendor_settings = rtsx_base_fetch_vendor_settings, 573 + .extra_init_hw = rts525a_extra_init_hw, 574 + .optimize_phy = rts525a_optimize_phy, 575 + .turn_on_led = rtsx_base_turn_on_led, 576 + .turn_off_led = rtsx_base_turn_off_led, 577 + .enable_auto_blink = rtsx_base_enable_auto_blink, 578 + .disable_auto_blink = rtsx_base_disable_auto_blink, 579 + .card_power_on = rts525a_card_power_on, 580 + .card_power_off = rtsx_base_card_power_off, 581 + .switch_output_voltage = rts525a_switch_output_voltage, 582 + .force_power_down = rtsx_base_force_power_down, 583 + }; 584 + 585 + void rts525a_init_params(struct rtsx_pcr *pcr) 586 + { 587 + rts5249_init_params(pcr); 588 + 589 + pcr->reg_pm_ctrl3 = RTS524A_PM_CTRL3; 590 + pcr->ops = &rts525a_pcr_ops; 591 + } 592 +
+10 -3
drivers/mfd/rtsx_pcr.c
··· 59 59 { PCI_DEVICE(0x10EC, 0x5287), PCI_CLASS_OTHERS << 16, 0xFF0000 }, 60 60 { PCI_DEVICE(0x10EC, 0x5286), PCI_CLASS_OTHERS << 16, 0xFF0000 }, 61 61 { PCI_DEVICE(0x10EC, 0x524A), PCI_CLASS_OTHERS << 16, 0xFF0000 }, 62 + { PCI_DEVICE(0x10EC, 0x525A), PCI_CLASS_OTHERS << 16, 0xFF0000 }, 62 63 { 0, } 63 64 }; 64 65 ··· 1115 1114 rts524a_init_params(pcr); 1116 1115 break; 1117 1116 1117 + case 0x525A: 1118 + rts525a_init_params(pcr); 1119 + break; 1120 + 1118 1121 case 0x5287: 1119 1122 rtl8411b_init_params(pcr); 1120 1123 break; ··· 1164 1159 struct rtsx_pcr *pcr; 1165 1160 struct pcr_handle *handle; 1166 1161 u32 base, len; 1167 - int ret, i; 1162 + int ret, i, bar = 0; 1168 1163 1169 1164 dev_dbg(&(pcidev->dev), 1170 1165 ": Realtek PCI-E Card Reader found at %s [%04x:%04x] (rev %x)\n", ··· 1209 1204 pcr->pci = pcidev; 1210 1205 dev_set_drvdata(&pcidev->dev, handle); 1211 1206 1212 - len = pci_resource_len(pcidev, 0); 1213 - base = pci_resource_start(pcidev, 0); 1207 + if (CHK_PCI_PID(pcr, 0x525A)) 1208 + bar = 1; 1209 + len = pci_resource_len(pcidev, bar); 1210 + base = pci_resource_start(pcidev, bar); 1214 1211 pcr->remap_addr = ioremap_nocache(base, len); 1215 1212 if (!pcr->remap_addr) { 1216 1213 ret = -ENOMEM;
+1
drivers/mfd/rtsx_pcr.h
··· 40 40 void rts5227_init_params(struct rtsx_pcr *pcr); 41 41 void rts5249_init_params(struct rtsx_pcr *pcr); 42 42 void rts524a_init_params(struct rtsx_pcr *pcr); 43 + void rts525a_init_params(struct rtsx_pcr *pcr); 43 44 void rtl8411b_init_params(struct rtsx_pcr *pcr); 44 45 45 46 static inline u8 map_sd_drive(int idx)
+15
include/linux/mfd/rtsx_pci.h
··· 727 727 #define PHY_SSCCR3 0x03 728 728 #define PHY_SSCCR3_STEP_IN 0x2740 729 729 #define PHY_SSCCR3_CHECK_DELAY 0x0008 730 + #define _PHY_ANA03 0x03 731 + #define _PHY_ANA03_TIMER_MAX 0x2700 732 + #define _PHY_ANA03_OOBS_DEB_EN 0x0040 733 + #define _PHY_CMU_DEBUG_EN 0x0008 730 734 731 735 #define PHY_RTCR 0x04 732 736 #define PHY_RDR 0x05 ··· 789 785 #define PHY_REV_STOP_CLKRD 0x0020 790 786 #define PHY_REV_RX_PWST 0x0008 791 787 #define PHY_REV_STOP_CLKWR 0x0004 788 + #define _PHY_REV0 0x19 789 + #define _PHY_REV0_FILTER_OUT 0x3800 790 + #define _PHY_REV0_CDR_BYPASS_PFD 0x0100 791 + #define _PHY_REV0_CDR_RX_IDLE_BYPASS 0x0002 792 792 793 793 #define PHY_FLD0 0x1A 794 794 #define PHY_ANA1A 0x1A ··· 808 800 #define PHY_FLD3_RXDELINK 0x0004 809 801 #define PHY_ANA1D 0x1D 810 802 #define PHY_ANA1D_DEBUG_ADDR 0x0004 803 + #define _PHY_FLD0 0x1D 804 + #define _PHY_FLD0_CLK_REQ_20C 0x8000 805 + #define _PHY_FLD0_RX_IDLE_EN 0x1000 806 + #define _PHY_FLD0_BIT_ERR_RSTN 0x0800 807 + #define _PHY_FLD0_BER_COUNT 0x01E0 808 + #define _PHY_FLD0_BER_TIMER 0x001E 809 + #define _PHY_FLD0_CHECK_EN 0x0001 811 810 812 811 #define PHY_FLD4 0x1E 813 812 #define PHY_FLD4_FLDEN_SEL 0x4000