1 // SPDX-License-Identifier: GPL-2.0+
3 * Driver for Realtek PCI-Express card reader
5 * Copyright(c) 2009-2013 Realtek Semiconductor Corp. All rights reserved.
12 #include <linux/blkdev.h>
13 #include <linux/kthread.h>
14 #include <linux/sched.h>
15 #include <linux/workqueue.h>
16 #include <linux/kernel.h>
23 void do_remaining_work(struct rtsx_chip *chip)
25 struct sd_info *sd_card = &chip->sd_card;
27 struct xd_info *xd_card = &chip->xd_card;
29 struct ms_info *ms_card = &chip->ms_card;
31 if (chip->card_ready & SD_CARD) {
32 if (sd_card->seq_mode) {
33 rtsx_set_stat(chip, RTSX_STAT_RUN);
34 sd_card->cleanup_counter++;
36 sd_card->cleanup_counter = 0;
41 if (chip->card_ready & XD_CARD) {
42 if (xd_card->delay_write.delay_write_flag) {
43 rtsx_set_stat(chip, RTSX_STAT_RUN);
44 xd_card->cleanup_counter++;
46 xd_card->cleanup_counter = 0;
51 if (chip->card_ready & MS_CARD) {
52 if (CHK_MSPRO(ms_card)) {
53 if (ms_card->seq_mode) {
54 rtsx_set_stat(chip, RTSX_STAT_RUN);
55 ms_card->cleanup_counter++;
57 ms_card->cleanup_counter = 0;
61 if (ms_card->delay_write.delay_write_flag) {
62 rtsx_set_stat(chip, RTSX_STAT_RUN);
63 ms_card->cleanup_counter++;
65 ms_card->cleanup_counter = 0;
71 if (sd_card->cleanup_counter > POLLING_WAIT_CNT)
72 sd_cleanup_work(chip);
74 if (xd_card->cleanup_counter > POLLING_WAIT_CNT)
75 xd_cleanup_work(chip);
77 if (ms_card->cleanup_counter > POLLING_WAIT_CNT)
78 ms_cleanup_work(chip);
81 void try_to_switch_sdio_ctrl(struct rtsx_chip *chip)
83 u8 reg1 = 0, reg2 = 0;
85 rtsx_read_register(chip, 0xFF34, ®1);
86 rtsx_read_register(chip, 0xFF38, ®2);
87 dev_dbg(rtsx_dev(chip), "reg 0xFF34: 0x%x, reg 0xFF38: 0x%x\n",
89 if ((reg1 & 0xC0) && (reg2 & 0xC0)) {
91 rtsx_write_register(chip, SDIO_CTRL, 0xFF,
92 SDIO_BUS_CTRL | SDIO_CD_CTRL);
93 rtsx_write_register(chip, PWR_GATE_CTRL,
94 LDO3318_PWR_MASK, LDO_ON);
98 #ifdef SUPPORT_SDIO_ASPM
99 void dynamic_configure_sdio_aspm(struct rtsx_chip *chip)
104 for (i = 0; i < 12; i++)
105 rtsx_read_register(chip, 0xFF08 + i, &buf[i]);
106 rtsx_read_register(chip, 0xFF25, ®);
107 if ((memcmp(buf, chip->sdio_raw_data, 12) != 0) || (reg & 0x03)) {
108 chip->sdio_counter = 0;
111 if (!chip->sdio_idle) {
112 chip->sdio_counter++;
113 if (chip->sdio_counter >= SDIO_IDLE_COUNT) {
114 chip->sdio_counter = 0;
119 memcpy(chip->sdio_raw_data, buf, 12);
121 if (chip->sdio_idle) {
122 if (!chip->sdio_aspm) {
123 dev_dbg(rtsx_dev(chip), "SDIO enter ASPM!\n");
124 rtsx_write_register(chip, ASPM_FORCE_CTL, 0xFC,
125 0x30 | (chip->aspm_level[1] << 2));
129 if (chip->sdio_aspm) {
130 dev_dbg(rtsx_dev(chip), "SDIO exit ASPM!\n");
131 rtsx_write_register(chip, ASPM_FORCE_CTL, 0xFC, 0x30);
138 void do_reset_sd_card(struct rtsx_chip *chip)
142 dev_dbg(rtsx_dev(chip), "%s: %d, card2lun = 0x%x\n", __func__,
143 chip->sd_reset_counter, chip->card2lun[SD_CARD]);
145 if (chip->card2lun[SD_CARD] >= MAX_ALLOWED_LUN_CNT) {
146 clear_bit(SD_NR, &chip->need_reset);
147 chip->sd_reset_counter = 0;
148 chip->sd_show_cnt = 0;
152 chip->rw_fail_cnt[chip->card2lun[SD_CARD]] = 0;
154 rtsx_set_stat(chip, RTSX_STAT_RUN);
155 rtsx_write_register(chip, SDIO_CTRL, 0xFF, 0);
157 retval = reset_sd_card(chip);
158 if (chip->need_release & SD_CARD)
160 if (retval == STATUS_SUCCESS) {
161 clear_bit(SD_NR, &chip->need_reset);
162 chip->sd_reset_counter = 0;
163 chip->sd_show_cnt = 0;
164 chip->card_ready |= SD_CARD;
165 chip->card_fail &= ~SD_CARD;
166 chip->rw_card[chip->card2lun[SD_CARD]] = sd_rw;
168 if (chip->sd_io || (chip->sd_reset_counter >= MAX_RESET_CNT)) {
169 clear_bit(SD_NR, &chip->need_reset);
170 chip->sd_reset_counter = 0;
171 chip->sd_show_cnt = 0;
173 chip->sd_reset_counter++;
175 chip->card_ready &= ~SD_CARD;
176 chip->card_fail |= SD_CARD;
177 chip->capacity[chip->card2lun[SD_CARD]] = 0;
178 chip->rw_card[chip->card2lun[SD_CARD]] = NULL;
180 rtsx_write_register(chip, CARD_OE, SD_OUTPUT_EN, 0);
181 if (!chip->ft2_fast_mode)
182 card_power_off(chip, SD_CARD);
185 try_to_switch_sdio_ctrl(chip);
187 disable_card_clock(chip, SD_CARD);
192 void do_reset_xd_card(struct rtsx_chip *chip)
196 dev_dbg(rtsx_dev(chip), "%s: %d, card2lun = 0x%x\n", __func__,
197 chip->xd_reset_counter, chip->card2lun[XD_CARD]);
199 if (chip->card2lun[XD_CARD] >= MAX_ALLOWED_LUN_CNT) {
200 clear_bit(XD_NR, &chip->need_reset);
201 chip->xd_reset_counter = 0;
202 chip->xd_show_cnt = 0;
206 chip->rw_fail_cnt[chip->card2lun[XD_CARD]] = 0;
208 rtsx_set_stat(chip, RTSX_STAT_RUN);
209 rtsx_write_register(chip, SDIO_CTRL, 0xFF, 0);
211 retval = reset_xd_card(chip);
212 if (chip->need_release & XD_CARD)
214 if (retval == STATUS_SUCCESS) {
215 clear_bit(XD_NR, &chip->need_reset);
216 chip->xd_reset_counter = 0;
217 chip->card_ready |= XD_CARD;
218 chip->card_fail &= ~XD_CARD;
219 chip->rw_card[chip->card2lun[XD_CARD]] = xd_rw;
221 if (chip->xd_reset_counter >= MAX_RESET_CNT) {
222 clear_bit(XD_NR, &chip->need_reset);
223 chip->xd_reset_counter = 0;
224 chip->xd_show_cnt = 0;
226 chip->xd_reset_counter++;
228 chip->card_ready &= ~XD_CARD;
229 chip->card_fail |= XD_CARD;
230 chip->capacity[chip->card2lun[XD_CARD]] = 0;
231 chip->rw_card[chip->card2lun[XD_CARD]] = NULL;
233 rtsx_write_register(chip, CARD_OE, XD_OUTPUT_EN, 0);
234 if (!chip->ft2_fast_mode)
235 card_power_off(chip, XD_CARD);
236 disable_card_clock(chip, XD_CARD);
240 void do_reset_ms_card(struct rtsx_chip *chip)
244 dev_dbg(rtsx_dev(chip), "%s: %d, card2lun = 0x%x\n", __func__,
245 chip->ms_reset_counter, chip->card2lun[MS_CARD]);
247 if (chip->card2lun[MS_CARD] >= MAX_ALLOWED_LUN_CNT) {
248 clear_bit(MS_NR, &chip->need_reset);
249 chip->ms_reset_counter = 0;
250 chip->ms_show_cnt = 0;
254 chip->rw_fail_cnt[chip->card2lun[MS_CARD]] = 0;
256 rtsx_set_stat(chip, RTSX_STAT_RUN);
257 rtsx_write_register(chip, SDIO_CTRL, 0xFF, 0);
259 retval = reset_ms_card(chip);
260 if (chip->need_release & MS_CARD)
262 if (retval == STATUS_SUCCESS) {
263 clear_bit(MS_NR, &chip->need_reset);
264 chip->ms_reset_counter = 0;
265 chip->card_ready |= MS_CARD;
266 chip->card_fail &= ~MS_CARD;
267 chip->rw_card[chip->card2lun[MS_CARD]] = ms_rw;
269 if (chip->ms_reset_counter >= MAX_RESET_CNT) {
270 clear_bit(MS_NR, &chip->need_reset);
271 chip->ms_reset_counter = 0;
272 chip->ms_show_cnt = 0;
274 chip->ms_reset_counter++;
276 chip->card_ready &= ~MS_CARD;
277 chip->card_fail |= MS_CARD;
278 chip->capacity[chip->card2lun[MS_CARD]] = 0;
279 chip->rw_card[chip->card2lun[MS_CARD]] = NULL;
281 rtsx_write_register(chip, CARD_OE, MS_OUTPUT_EN, 0);
282 if (!chip->ft2_fast_mode)
283 card_power_off(chip, MS_CARD);
284 disable_card_clock(chip, MS_CARD);
288 static void release_sdio(struct rtsx_chip *chip)
291 rtsx_write_register(chip, CARD_STOP, SD_STOP | SD_CLR_ERR,
292 SD_STOP | SD_CLR_ERR);
294 if (chip->chip_insert_with_sdio) {
295 chip->chip_insert_with_sdio = 0;
297 if (CHECK_PID(chip, 0x5288))
298 rtsx_write_register(chip, 0xFE5A, 0x08, 0x00);
300 rtsx_write_register(chip, 0xFE70, 0x80, 0x00);
303 rtsx_write_register(chip, SDIO_CTRL, SDIO_CD_CTRL, 0);
308 void rtsx_power_off_card(struct rtsx_chip *chip)
310 if ((chip->card_ready & SD_CARD) || chip->sd_io) {
311 sd_cleanup_work(chip);
312 sd_power_off_card3v3(chip);
315 if (chip->card_ready & XD_CARD) {
316 xd_cleanup_work(chip);
317 xd_power_off_card3v3(chip);
320 if (chip->card_ready & MS_CARD) {
321 ms_cleanup_work(chip);
322 ms_power_off_card3v3(chip);
326 void rtsx_release_cards(struct rtsx_chip *chip)
328 chip->int_reg = rtsx_readl(chip, RTSX_BIPR);
330 if ((chip->card_ready & SD_CARD) || chip->sd_io) {
331 if (chip->int_reg & SD_EXIST)
332 sd_cleanup_work(chip);
333 release_sd_card(chip);
336 if (chip->card_ready & XD_CARD) {
337 if (chip->int_reg & XD_EXIST)
338 xd_cleanup_work(chip);
339 release_xd_card(chip);
342 if (chip->card_ready & MS_CARD) {
343 if (chip->int_reg & MS_EXIST)
344 ms_cleanup_work(chip);
345 release_ms_card(chip);
349 void rtsx_reset_cards(struct rtsx_chip *chip)
351 if (!chip->need_reset)
354 rtsx_set_stat(chip, RTSX_STAT_RUN);
356 rtsx_force_power_on(chip, SSC_PDCTL | OC_PDCTL);
358 rtsx_disable_aspm(chip);
360 if ((chip->need_reset & SD_CARD) && chip->chip_insert_with_sdio)
361 clear_bit(SD_NR, &chip->need_reset);
363 if (chip->need_reset & XD_CARD) {
364 chip->card_exist |= XD_CARD;
366 if (chip->xd_show_cnt >= MAX_SHOW_CNT)
367 do_reset_xd_card(chip);
371 if (CHECK_PID(chip, 0x5288) && CHECK_BARO_PKG(chip, QFN)) {
372 if (chip->card_exist & XD_CARD) {
373 clear_bit(SD_NR, &chip->need_reset);
374 clear_bit(MS_NR, &chip->need_reset);
377 if (chip->need_reset & SD_CARD) {
378 chip->card_exist |= SD_CARD;
380 if (chip->sd_show_cnt >= MAX_SHOW_CNT) {
381 rtsx_write_register(chip, RBCTL, RB_FLUSH, RB_FLUSH);
382 do_reset_sd_card(chip);
387 if (chip->need_reset & MS_CARD) {
388 chip->card_exist |= MS_CARD;
390 if (chip->ms_show_cnt >= MAX_SHOW_CNT)
391 do_reset_ms_card(chip);
397 void rtsx_reinit_cards(struct rtsx_chip *chip, int reset_chip)
399 rtsx_set_stat(chip, RTSX_STAT_RUN);
401 rtsx_force_power_on(chip, SSC_PDCTL | OC_PDCTL);
404 rtsx_reset_chip(chip);
406 chip->int_reg = rtsx_readl(chip, RTSX_BIPR);
408 if ((chip->int_reg & SD_EXIST) && (chip->need_reinit & SD_CARD)) {
410 release_sd_card(chip);
414 chip->card_exist |= SD_CARD;
415 do_reset_sd_card(chip);
418 if ((chip->int_reg & XD_EXIST) && (chip->need_reinit & XD_CARD)) {
419 release_xd_card(chip);
423 chip->card_exist |= XD_CARD;
424 do_reset_xd_card(chip);
427 if ((chip->int_reg & MS_EXIST) && (chip->need_reinit & MS_CARD)) {
428 release_ms_card(chip);
432 chip->card_exist |= MS_CARD;
433 do_reset_ms_card(chip);
436 chip->need_reinit = 0;
439 #ifdef DISABLE_CARD_INT
440 void card_cd_debounce(struct rtsx_chip *chip, unsigned long *need_reset,
441 unsigned long *need_release)
443 u8 release_map = 0, reset_map = 0;
445 chip->int_reg = rtsx_readl(chip, RTSX_BIPR);
447 if (chip->card_exist) {
448 if (chip->card_exist & XD_CARD) {
449 if (!(chip->int_reg & XD_EXIST))
450 release_map |= XD_CARD;
451 } else if (chip->card_exist & SD_CARD) {
452 if (!(chip->int_reg & SD_EXIST))
453 release_map |= SD_CARD;
454 } else if (chip->card_exist & MS_CARD) {
455 if (!(chip->int_reg & MS_EXIST))
456 release_map |= MS_CARD;
459 if (chip->int_reg & XD_EXIST)
460 reset_map |= XD_CARD;
461 else if (chip->int_reg & SD_EXIST)
462 reset_map |= SD_CARD;
463 else if (chip->int_reg & MS_EXIST)
464 reset_map |= MS_CARD;
468 int xd_cnt = 0, sd_cnt = 0, ms_cnt = 0;
471 for (i = 0; i < (DEBOUNCE_CNT); i++) {
472 chip->int_reg = rtsx_readl(chip, RTSX_BIPR);
474 if (chip->int_reg & XD_EXIST)
479 if (chip->int_reg & SD_EXIST)
484 if (chip->int_reg & MS_EXIST)
493 if (!(chip->card_exist & XD_CARD) &&
494 (xd_cnt > (DEBOUNCE_CNT - 1)))
495 reset_map |= XD_CARD;
496 if (!(chip->card_exist & SD_CARD) &&
497 (sd_cnt > (DEBOUNCE_CNT - 1)))
498 reset_map |= SD_CARD;
499 if (!(chip->card_exist & MS_CARD) &&
500 (ms_cnt > (DEBOUNCE_CNT - 1)))
501 reset_map |= MS_CARD;
504 if (CHECK_PID(chip, 0x5288) && CHECK_BARO_PKG(chip, QFN))
505 rtsx_write_register(chip, HOST_SLEEP_STATE, 0xC0, 0x00);
508 *need_reset = reset_map;
510 *need_release = release_map;
514 void rtsx_init_cards(struct rtsx_chip *chip)
516 if (RTSX_TST_DELINK(chip) && (rtsx_get_stat(chip) != RTSX_STAT_SS)) {
517 dev_dbg(rtsx_dev(chip), "Reset chip in polling thread!\n");
518 rtsx_reset_chip(chip);
519 RTSX_CLR_DELINK(chip);
522 #ifdef DISABLE_CARD_INT
523 card_cd_debounce(chip, &chip->need_reset, &chip->need_release);
526 if (chip->need_release) {
527 if (CHECK_PID(chip, 0x5288) && CHECK_BARO_PKG(chip, QFN)) {
528 if (chip->int_reg & XD_EXIST) {
529 clear_bit(SD_NR, &chip->need_release);
530 clear_bit(MS_NR, &chip->need_release);
534 if (!(chip->card_exist & SD_CARD) && !chip->sd_io)
535 clear_bit(SD_NR, &chip->need_release);
536 if (!(chip->card_exist & XD_CARD))
537 clear_bit(XD_NR, &chip->need_release);
538 if (!(chip->card_exist & MS_CARD))
539 clear_bit(MS_NR, &chip->need_release);
541 dev_dbg(rtsx_dev(chip), "chip->need_release = 0x%x\n",
542 (unsigned int)(chip->need_release));
545 if (chip->need_release) {
546 if (chip->ocp_stat & (CARD_OC_NOW | CARD_OC_EVER))
547 rtsx_write_register(chip, OCPCLR,
555 if (chip->need_release) {
556 rtsx_set_stat(chip, RTSX_STAT_RUN);
557 rtsx_force_power_on(chip, SSC_PDCTL | OC_PDCTL);
560 if (chip->need_release & SD_CARD) {
561 clear_bit(SD_NR, &chip->need_release);
562 chip->card_exist &= ~SD_CARD;
563 chip->card_ejected &= ~SD_CARD;
564 chip->card_fail &= ~SD_CARD;
565 CLR_BIT(chip->lun_mc, chip->card2lun[SD_CARD]);
566 chip->rw_fail_cnt[chip->card2lun[SD_CARD]] = 0;
567 rtsx_write_register(chip, RBCTL, RB_FLUSH, RB_FLUSH);
570 release_sd_card(chip);
573 if (chip->need_release & XD_CARD) {
574 clear_bit(XD_NR, &chip->need_release);
575 chip->card_exist &= ~XD_CARD;
576 chip->card_ejected &= ~XD_CARD;
577 chip->card_fail &= ~XD_CARD;
578 CLR_BIT(chip->lun_mc, chip->card2lun[XD_CARD]);
579 chip->rw_fail_cnt[chip->card2lun[XD_CARD]] = 0;
581 release_xd_card(chip);
583 if (CHECK_PID(chip, 0x5288) &&
584 CHECK_BARO_PKG(chip, QFN))
585 rtsx_write_register(chip, HOST_SLEEP_STATE,
589 if (chip->need_release & MS_CARD) {
590 clear_bit(MS_NR, &chip->need_release);
591 chip->card_exist &= ~MS_CARD;
592 chip->card_ejected &= ~MS_CARD;
593 chip->card_fail &= ~MS_CARD;
594 CLR_BIT(chip->lun_mc, chip->card2lun[MS_CARD]);
595 chip->rw_fail_cnt[chip->card2lun[MS_CARD]] = 0;
597 release_ms_card(chip);
600 dev_dbg(rtsx_dev(chip), "chip->card_exist = 0x%x\n",
603 if (!chip->card_exist)
604 turn_off_led(chip, LED_GPIO);
607 if (chip->need_reset) {
608 dev_dbg(rtsx_dev(chip), "chip->need_reset = 0x%x\n",
609 (unsigned int)(chip->need_reset));
611 rtsx_reset_cards(chip);
614 if (chip->need_reinit) {
615 dev_dbg(rtsx_dev(chip), "chip->need_reinit = 0x%x\n",
616 (unsigned int)(chip->need_reinit));
618 rtsx_reinit_cards(chip, 0);
622 int switch_ssc_clock(struct rtsx_chip *chip, int clk)
625 u8 n = (u8)(clk - 2), min_n, max_n;
626 u8 mcu_cnt, div, max_div, ssc_depth, ssc_depth_mask;
627 int sd_vpclk_phase_reset = 0;
629 if (chip->cur_clk == clk)
630 return STATUS_SUCCESS;
636 dev_dbg(rtsx_dev(chip), "Switch SSC clock to %dMHz (cur_clk = %d)\n",
639 if ((clk <= 2) || (n > max_n))
642 mcu_cnt = (u8)(125 / clk + 3);
647 while ((n < min_n) && (div < max_div)) {
651 dev_dbg(rtsx_dev(chip), "n = %d, div = %d\n", n, div);
660 ssc_depth_mask = 0x03;
662 dev_dbg(rtsx_dev(chip), "ssc_depth = %d\n", ssc_depth);
665 rtsx_add_cmd(chip, WRITE_REG_CMD, CLK_CTL, CLK_LOW_FREQ, CLK_LOW_FREQ);
666 rtsx_add_cmd(chip, WRITE_REG_CMD, CLK_DIV, 0xFF, (div << 4) | mcu_cnt);
667 rtsx_add_cmd(chip, WRITE_REG_CMD, SSC_CTL1, SSC_RSTB, 0);
668 rtsx_add_cmd(chip, WRITE_REG_CMD, SSC_CTL2, ssc_depth_mask, ssc_depth);
669 rtsx_add_cmd(chip, WRITE_REG_CMD, SSC_DIV_N_0, 0xFF, n);
670 rtsx_add_cmd(chip, WRITE_REG_CMD, SSC_CTL1, SSC_RSTB, SSC_RSTB);
671 if (sd_vpclk_phase_reset) {
672 rtsx_add_cmd(chip, WRITE_REG_CMD, SD_VPCLK0_CTL,
674 rtsx_add_cmd(chip, WRITE_REG_CMD, SD_VPCLK0_CTL,
675 PHASE_NOT_RESET, PHASE_NOT_RESET);
678 retval = rtsx_send_cmd(chip, 0, WAIT_TIME);
683 retval = rtsx_write_register(chip, CLK_CTL, CLK_LOW_FREQ, 0);
689 return STATUS_SUCCESS;
692 int switch_normal_clock(struct rtsx_chip *chip, int clk)
695 u8 sel, div, mcu_cnt;
696 int sd_vpclk_phase_reset = 0;
698 if (chip->cur_clk == clk)
699 return STATUS_SUCCESS;
703 dev_dbg(rtsx_dev(chip), "Switch clock to 20MHz\n");
710 dev_dbg(rtsx_dev(chip), "Switch clock to 30MHz\n");
717 dev_dbg(rtsx_dev(chip), "Switch clock to 40MHz\n");
724 dev_dbg(rtsx_dev(chip), "Switch clock to 50MHz\n");
731 dev_dbg(rtsx_dev(chip), "Switch clock to 60MHz\n");
738 dev_dbg(rtsx_dev(chip), "Switch clock to 80MHz\n");
745 dev_dbg(rtsx_dev(chip), "Switch clock to 100MHz\n");
752 dev_dbg(rtsx_dev(chip), "Switch clock to 120MHz\n");
759 dev_dbg(rtsx_dev(chip), "Switch clock to 150MHz\n");
766 dev_dbg(rtsx_dev(chip), "Switch clock to 200MHz\n");
773 dev_dbg(rtsx_dev(chip), "Try to switch to an illegal clock (%d)\n",
778 retval = rtsx_write_register(chip, CLK_CTL, 0xFF, CLK_LOW_FREQ);
781 if (sd_vpclk_phase_reset) {
782 retval = rtsx_write_register(chip, SD_VPCLK0_CTL,
786 retval = rtsx_write_register(chip, SD_VPCLK1_CTL,
791 retval = rtsx_write_register(chip, CLK_DIV, 0xFF,
792 (div << 4) | mcu_cnt);
795 retval = rtsx_write_register(chip, CLK_SEL, 0xFF, sel);
799 if (sd_vpclk_phase_reset) {
801 retval = rtsx_write_register(chip, SD_VPCLK0_CTL,
802 PHASE_NOT_RESET, PHASE_NOT_RESET);
805 retval = rtsx_write_register(chip, SD_VPCLK1_CTL,
806 PHASE_NOT_RESET, PHASE_NOT_RESET);
811 retval = rtsx_write_register(chip, CLK_CTL, 0xFF, 0);
817 return STATUS_SUCCESS;
820 void trans_dma_enable(enum dma_data_direction dir, struct rtsx_chip *chip,
821 u32 byte_cnt, u8 pack_size)
823 if (pack_size > DMA_1024)
826 rtsx_add_cmd(chip, WRITE_REG_CMD, IRQSTAT0, DMA_DONE_INT, DMA_DONE_INT);
828 rtsx_add_cmd(chip, WRITE_REG_CMD, DMATC3, 0xFF, (u8)(byte_cnt >> 24));
829 rtsx_add_cmd(chip, WRITE_REG_CMD, DMATC2, 0xFF, (u8)(byte_cnt >> 16));
830 rtsx_add_cmd(chip, WRITE_REG_CMD, DMATC1, 0xFF, (u8)(byte_cnt >> 8));
831 rtsx_add_cmd(chip, WRITE_REG_CMD, DMATC0, 0xFF, (u8)byte_cnt);
833 if (dir == DMA_FROM_DEVICE) {
834 rtsx_add_cmd(chip, WRITE_REG_CMD, DMACTL,
835 0x03 | DMA_PACK_SIZE_MASK,
836 DMA_DIR_FROM_CARD | DMA_EN | pack_size);
838 rtsx_add_cmd(chip, WRITE_REG_CMD, DMACTL,
839 0x03 | DMA_PACK_SIZE_MASK,
840 DMA_DIR_TO_CARD | DMA_EN | pack_size);
843 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_DATA_SOURCE, 0x01, RING_BUFFER);
846 int enable_card_clock(struct rtsx_chip *chip, u8 card)
858 retval = rtsx_write_register(chip, CARD_CLK_EN, clk_en, clk_en);
862 return STATUS_SUCCESS;
865 int disable_card_clock(struct rtsx_chip *chip, u8 card)
877 retval = rtsx_write_register(chip, CARD_CLK_EN, clk_en, 0);
881 return STATUS_SUCCESS;
884 int card_power_on(struct rtsx_chip *chip, u8 card)
889 if (CHECK_LUN_MODE(chip, SD_MS_2LUN) && (card == MS_CARD)) {
890 mask = MS_POWER_MASK;
891 val1 = MS_PARTIAL_POWER_ON;
894 mask = SD_POWER_MASK;
895 val1 = SD_PARTIAL_POWER_ON;
900 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_PWR_CTL, mask, val1);
902 retval = rtsx_send_cmd(chip, 0, 100);
903 if (retval != STATUS_SUCCESS)
906 udelay(chip->pmos_pwr_on_interval);
909 rtsx_add_cmd(chip, WRITE_REG_CMD, CARD_PWR_CTL, mask, val2);
911 retval = rtsx_send_cmd(chip, 0, 100);
912 if (retval != STATUS_SUCCESS)
915 return STATUS_SUCCESS;
918 int card_power_off(struct rtsx_chip *chip, u8 card)
923 if (CHECK_LUN_MODE(chip, SD_MS_2LUN) && (card == MS_CARD)) {
924 mask = MS_POWER_MASK;
927 mask = SD_POWER_MASK;
931 retval = rtsx_write_register(chip, CARD_PWR_CTL, mask, val);
935 return STATUS_SUCCESS;
938 int card_rw(struct scsi_cmnd *srb, struct rtsx_chip *chip,
939 u32 sec_addr, u16 sec_cnt)
942 unsigned int lun = SCSI_LUN(srb);
945 if (!chip->rw_card[lun])
948 for (i = 0; i < 3; i++) {
949 chip->rw_need_retry = 0;
951 retval = chip->rw_card[lun](srb, chip, sec_addr, sec_cnt);
952 if (retval != STATUS_SUCCESS) {
953 if (rtsx_check_chip_exist(chip) != STATUS_SUCCESS) {
954 rtsx_release_chip(chip);
957 if (detect_card_cd(chip, chip->cur_card) !=
962 if (!chip->rw_need_retry) {
963 dev_dbg(rtsx_dev(chip), "RW fail, but no need to retry\n");
967 chip->rw_need_retry = 0;
971 dev_dbg(rtsx_dev(chip), "Retry RW, (i = %d)\n", i);
977 int card_share_mode(struct rtsx_chip *chip, int card)
982 if (CHECK_PID(chip, 0x5208)) {
983 mask = CARD_SHARE_MASK;
985 value = CARD_SHARE_48_SD;
986 else if (card == MS_CARD)
987 value = CARD_SHARE_48_MS;
988 else if (card == XD_CARD)
989 value = CARD_SHARE_48_XD;
993 } else if (CHECK_PID(chip, 0x5288)) {
996 value = CARD_SHARE_BAROSSA_SD;
997 else if (card == MS_CARD)
998 value = CARD_SHARE_BAROSSA_MS;
999 else if (card == XD_CARD)
1000 value = CARD_SHARE_BAROSSA_XD;
1008 retval = rtsx_write_register(chip, CARD_SHARE_MODE, mask, value);
1012 return STATUS_SUCCESS;
1015 int select_card(struct rtsx_chip *chip, int card)
1019 if (chip->cur_card != card) {
1022 if (card == SD_CARD)
1024 else if (card == MS_CARD)
1026 else if (card == XD_CARD)
1028 else if (card == SPI_CARD)
1033 retval = rtsx_write_register(chip, CARD_SELECT, 0x07, mod);
1036 chip->cur_card = card;
1038 retval = card_share_mode(chip, card);
1039 if (retval != STATUS_SUCCESS)
1043 return STATUS_SUCCESS;
1046 void toggle_gpio(struct rtsx_chip *chip, u8 gpio)
1050 rtsx_read_register(chip, CARD_GPIO, &temp_reg);
1051 temp_reg ^= (0x01 << gpio);
1052 rtsx_write_register(chip, CARD_GPIO, 0xFF, temp_reg);
1055 void turn_on_led(struct rtsx_chip *chip, u8 gpio)
1057 if (CHECK_PID(chip, 0x5288))
1058 rtsx_write_register(chip, CARD_GPIO, (u8)(1 << gpio),
1061 rtsx_write_register(chip, CARD_GPIO, (u8)(1 << gpio), 0);
1064 void turn_off_led(struct rtsx_chip *chip, u8 gpio)
1066 if (CHECK_PID(chip, 0x5288))
1067 rtsx_write_register(chip, CARD_GPIO, (u8)(1 << gpio), 0);
1069 rtsx_write_register(chip, CARD_GPIO, (u8)(1 << gpio),
1073 int detect_card_cd(struct rtsx_chip *chip, int card)
1075 u32 card_cd, status;
1077 if (card == SD_CARD) {
1079 } else if (card == MS_CARD) {
1081 } else if (card == XD_CARD) {
1084 dev_dbg(rtsx_dev(chip), "Wrong card type: 0x%x\n", card);
1088 status = rtsx_readl(chip, RTSX_BIPR);
1089 if (!(status & card_cd))
1092 return STATUS_SUCCESS;
1095 int check_card_exist(struct rtsx_chip *chip, unsigned int lun)
1097 if (chip->card_exist & chip->lun2card[lun])
1103 int check_card_ready(struct rtsx_chip *chip, unsigned int lun)
1105 if (chip->card_ready & chip->lun2card[lun])
1111 int check_card_wp(struct rtsx_chip *chip, unsigned int lun)
1113 if (chip->card_wp & chip->lun2card[lun])
1119 u8 get_lun_card(struct rtsx_chip *chip, unsigned int lun)
1121 if ((chip->card_ready & chip->lun2card[lun]) == XD_CARD)
1123 else if ((chip->card_ready & chip->lun2card[lun]) == SD_CARD)
1125 else if ((chip->card_ready & chip->lun2card[lun]) == MS_CARD)
1131 void eject_card(struct rtsx_chip *chip, unsigned int lun)
1133 do_remaining_work(chip);
1135 if ((chip->card_ready & chip->lun2card[lun]) == SD_CARD) {
1136 release_sd_card(chip);
1137 chip->card_ejected |= SD_CARD;
1138 chip->card_ready &= ~SD_CARD;
1139 chip->capacity[lun] = 0;
1140 } else if ((chip->card_ready & chip->lun2card[lun]) == XD_CARD) {
1141 release_xd_card(chip);
1142 chip->card_ejected |= XD_CARD;
1143 chip->card_ready &= ~XD_CARD;
1144 chip->capacity[lun] = 0;
1145 } else if ((chip->card_ready & chip->lun2card[lun]) == MS_CARD) {
1146 release_ms_card(chip);
1147 chip->card_ejected |= MS_CARD;
1148 chip->card_ready &= ~MS_CARD;
1149 chip->capacity[lun] = 0;