• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /* Driver for Realtek RTS51xx USB card reader
2  *
3  * Copyright(c) 2009 Realtek Semiconductor Corp. All rights reserved.
4  *
5  * This program is free software; you can redistribute it and/or modify it
6  * under the terms of the GNU General Public License as published by the
7  * Free Software Foundation; either version 2, or (at your option) any
8  * later version.
9  *
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License along
16  * with this program; if not, see <http://www.gnu.org/licenses/>.
17  *
18  * Author:
19  *   wwang (wei_wang@realsil.com.cn)
20  *   No. 450, Shenhu Road, Suzhou Industry Park, Suzhou, China
21  * Maintainer:
22  *   Edwin Rong (edwin_rong@realsil.com.cn)
23  *   No. 450, Shenhu Road, Suzhou Industry Park, Suzhou, China
24  */
25 
26 #include <linux/blkdev.h>
27 #include <linux/kthread.h>
28 #include <linux/sched.h>
29 #include <linux/workqueue.h>
30 
31 #include "debug.h"
32 #include "trace.h"
33 #include "rts51x.h"
34 #include "rts51x_chip.h"
35 #include "rts51x_card.h"
36 #include "rts51x_transport.h"
37 #include "rts51x_sys.h"
38 #include "xd.h"
39 #include "ms.h"
40 #include "sd.h"
41 
check_sd_speed_prior(u32 sd_speed_prior)42 static int check_sd_speed_prior(u32 sd_speed_prior)
43 {
44 	int i, fake_para = 0;
45 
46 	/* Check the legality of sd_speed_prior */
47 	for (i = 0; i < 4; i++) {
48 		u8 tmp = (u8) (sd_speed_prior >> (i * 8));
49 		if ((tmp < 0x01) || (tmp > 0x04)) {
50 			fake_para = 1;
51 			break;
52 		}
53 	}
54 
55 	return !fake_para;
56 }
57 
rts51x_reset_chip(struct rts51x_chip * chip)58 int rts51x_reset_chip(struct rts51x_chip *chip)
59 {
60 	int retval;
61 
62 	if (CHECK_PKG(chip, LQFP48)) {
63 		RTS51X_WRITE_REG(chip, CARD_PWR_CTL, LDO3318_PWR_MASK,
64 				 LDO_SUSPEND);
65 		RTS51X_WRITE_REG(chip, CARD_PWR_CTL, FORCE_LDO_POWERB,
66 				 FORCE_LDO_POWERB);
67 		RTS51X_WRITE_REG(chip, CARD_PULL_CTL1, 0x30, 0x10);
68 		RTS51X_WRITE_REG(chip, CARD_PULL_CTL5, 0x03, 0x01);
69 		RTS51X_WRITE_REG(chip, CARD_PULL_CTL6, 0x0C, 0x04);
70 	}
71 	if (chip->asic_code) {
72 		RTS51X_WRITE_REG(chip, SYS_DUMMY0, NYET_MSAK, NYET_EN);
73 		RTS51X_WRITE_REG(chip, CD_DEGLITCH_WIDTH, 0xFF, 0x08);
74 		rts51x_write_register(chip, CD_DEGLITCH_EN, XD_CD_DEGLITCH_EN,
75 				      0x00);
76 		rts51x_write_register(chip, SD30_DRIVE_SEL, SD30_DRIVE_MASK,
77 				      chip->option.sd30_pad_drive);
78 		rts51x_write_register(chip, CARD_DRIVE_SEL, SD20_DRIVE_MASK,
79 				      chip->option.sd20_pad_drive);
80 		if (chip->rts5179)
81 			rts51x_write_register(chip, CARD_PULL_CTL5, 0x03, 0x01);
82 		if (!chip->option.ww_enable) {
83 			if (CHECK_PKG(chip, LQFP48)) {
84 				rts51x_write_register(chip, CARD_PULL_CTL3,
85 						      0x80, 0x80);
86 				rts51x_write_register(chip, CARD_PULL_CTL6,
87 						      0xf0, 0xA0);
88 			} else {
89 				rts51x_write_register(chip, CARD_PULL_CTL1,
90 						      0x30, 0x20);
91 				rts51x_write_register(chip, CARD_PULL_CTL3,
92 						      0x80, 0x80);
93 				rts51x_write_register(chip, CARD_PULL_CTL6,
94 						      0x0c, 0x08);
95 			}
96 		}
97 	}
98 	if (chip->option.sd_ctl & SUPPORT_UHS50_MMC44) {
99 		SET_UHS50(chip);
100 		RTS51X_DEBUGP("option enable UHS50&MMC44,sd_ctl:0x%x\n",
101 			chip->option.sd_ctl);
102 	} else {
103 		/* if(CHECK_PID(chip, 0x0139)&&CHECK_PKG(chip, LQFP48)) */
104 		if ((CHECK_PID(chip, 0x0139) && CHECK_PKG(chip, LQFP48))
105 		    || chip->rts5179) {
106 			SET_UHS50(chip);
107 			RTS51X_DEBUGP("PID enable UHS50&MMC44\n");
108 		} else {
109 			CLEAR_UHS50(chip);
110 			RTS51X_DEBUGP("PID disable UHS50&MMC44\n");
111 		}
112 	}
113 
114 	if (chip->option.ms_errreg_fix && (chip->ic_version > 1))
115 		rts51x_write_register(chip, 0xFD4D, 0x01, 0x01);
116 	retval = rts51x_write_phy_register(chip, 0xC2, 0x7C);
117 	if (retval != STATUS_SUCCESS)
118 		TRACE_RET(chip, retval);
119 
120 	rts51x_init_cmd(chip);
121 
122 	/* GPIO OE */
123 	rts51x_add_cmd(chip, WRITE_REG_CMD, CARD_GPIO, GPIO_OE, GPIO_OE);
124 #ifdef LED_AUTO_BLINK
125 	/* LED autoblink */
126 	rts51x_add_cmd(chip, WRITE_REG_CMD, CARD_AUTO_BLINK,
127 		       BLINK_ENABLE | BLINK_SPEED_MASK,
128 		       BLINK_ENABLE | chip->option.led_blink_speed);
129 #endif
130 	rts51x_add_cmd(chip, WRITE_REG_CMD, CARD_DMA1_CTL,
131 		       EXTEND_DMA1_ASYNC_SIGNAL, EXTEND_DMA1_ASYNC_SIGNAL);
132 
133 	retval = rts51x_send_cmd(chip, MODE_C, 100);
134 	if (retval != STATUS_SUCCESS)
135 		TRACE_RET(chip, retval);
136 #ifdef SUPPORT_OCP
137 	if (chip->asic_code) {
138 		rts51x_write_register(chip, OCPCTL, MS_OCP_DETECT_EN,
139 				      MS_OCP_DETECT_EN);
140 		RTS51X_DEBUGP("Enable OCP detect!\n");
141 	}
142 #endif
143 	if (chip->option.FT2_fast_mode) {
144 		card_power_on(chip, SD_CARD | MS_CARD | XD_CARD);
145 		wait_timeout(10);
146 	}
147 	rts51x_clear_start_time(chip);
148 
149 	return STATUS_SUCCESS;
150 }
151 
rts51x_init_chip(struct rts51x_chip * chip)152 int rts51x_init_chip(struct rts51x_chip *chip)
153 {
154 	int retval;
155 	u8 val;
156 
157 	chip->max_lun = 0;
158 	chip->cur_clk = 0;
159 	chip->cur_card = 0;
160 
161 	chip->card2lun[XD_CARD] = 0;
162 	chip->card2lun[SD_CARD] = 0;
163 	chip->card2lun[MS_CARD] = 0;
164 	chip->card_ejected = 0;
165 
166 	chip->lun2card[0] = XD_CARD | SD_CARD | MS_CARD;
167 #if 0
168 	chip->option.sdr50_tx_phase = 0x01;
169 	chip->option.sdr50_rx_phase = 0x05;
170 	chip->option.ddr50_tx_phase = 0x09;
171 	chip->option.ddr50_rx_phase = 0x06; /* add for debug */
172 #endif
173 #ifdef CLOSE_SSC_POWER
174 	rts51x_write_register(chip, FPDCTL, SSC_POWER_MASK, SSC_POWER_ON);
175 	udelay(100);
176 	rts51x_write_register(chip, CLK_DIV, CLK_CHANGE, 0x00);
177 #endif
178 	RTS51X_SET_STAT(chip, STAT_RUN);
179 
180 	RTS51X_READ_REG(chip, HW_VERSION, &val);
181 	if ((val & 0x0f) >= 2)
182 		chip->option.rcc_bug_fix_en = 0;
183 	RTS51X_DEBUGP("rcc bug fix enable:%d\n", chip->option.rcc_bug_fix_en);
184 	RTS51X_DEBUGP("HW_VERSION: 0x%x\n", val);
185 	if (val & FPGA_VER) {
186 		chip->asic_code = 0;
187 		RTS51X_DEBUGP("FPGA!\n");
188 	} else {
189 		chip->asic_code = 1;
190 		RTS51X_DEBUGP("ASIC!\n");
191 	}
192 	chip->ic_version = val & HW_VER_MASK;
193 
194 	if (!check_sd_speed_prior(chip->option.sd_speed_prior))
195 		chip->option.sd_speed_prior = 0x01020403;
196 	RTS51X_DEBUGP("sd_speed_prior = 0x%08x\n",
197 		       chip->option.sd_speed_prior);
198 
199 	RTS51X_READ_REG(chip, CARD_SHARE_MODE, &val);
200 	if (val & CARD_SHARE_LQFP_SEL) {
201 		chip->package = LQFP48;
202 		RTS51X_DEBUGP("Package: LQFP48\n");
203 	} else {
204 		chip->package = QFN24;
205 		RTS51X_DEBUGP("Package: QFN24\n");
206 	}
207 
208 	RTS51X_READ_REG(chip, HS_USB_STAT, &val);
209 	if (val & USB_HI_SPEED) {
210 		chip->usb_speed = USB_20;
211 		RTS51X_DEBUGP("USB High Speed\n");
212 	} else {
213 		chip->usb_speed = USB_11;
214 		RTS51X_DEBUGP("USB Full Speed\n");
215 	}
216 
217 	RTS51X_READ_REG(chip, CFG_MODE_1, &val);
218 	if (val & RTS5179) {
219 		chip->rts5179 = 1;
220 		RTS51X_DEBUGP("device is rts5179\n");
221 	} else {
222 		chip->rts5179 = 0;
223 	}
224 
225 	retval = rts51x_reset_chip(chip);
226 	if (retval != STATUS_SUCCESS)
227 		TRACE_RET(chip, STATUS_FAIL);
228 
229 	return STATUS_SUCCESS;
230 }
231 
rts51x_release_chip(struct rts51x_chip * chip)232 int rts51x_release_chip(struct rts51x_chip *chip)
233 {
234 	xd_free_l2p_tbl(chip);
235 	ms_free_l2p_tbl(chip);
236 	chip->card_ready = 0;
237 	return STATUS_SUCCESS;
238 }
239 
240 #ifndef LED_AUTO_BLINK
rts51x_blink_led(struct rts51x_chip * chip)241 static inline void rts51x_blink_led(struct rts51x_chip *chip)
242 {
243 	/* Read/Write */
244 	if (chip->card_ready) {
245 		if (chip->led_toggle_counter <
246 				chip->option.led_toggle_interval) {
247 			chip->led_toggle_counter++;
248 		} else {
249 			chip->led_toggle_counter = 0;
250 			toggle_gpio(chip, LED_GPIO);
251 		}
252 	}
253 }
254 #endif
255 
rts51x_check_start_time(struct rts51x_chip * chip)256 int rts51x_check_start_time(struct rts51x_chip *chip)
257 {
258 	return 0;
259 }
260 
rts51x_set_start_time(struct rts51x_chip * chip)261 void rts51x_set_start_time(struct rts51x_chip *chip)
262 {
263 }
264 
rts51x_clear_start_time(struct rts51x_chip * chip)265 void rts51x_clear_start_time(struct rts51x_chip *chip)
266 {
267 }
268 
rts51x_auto_delink_cmd(struct rts51x_chip * chip)269 static void rts51x_auto_delink_cmd(struct rts51x_chip *chip)
270 {
271 	rts51x_write_register(chip, AUTO_DELINK_EN,
272 			AUTO_DELINK, AUTO_DELINK);
273 }
274 
rts51x_auto_delink_force_cmd(struct rts51x_chip * chip)275 static void rts51x_auto_delink_force_cmd(struct rts51x_chip *chip)
276 {
277 	rts51x_write_register(chip, AUTO_DELINK_EN,
278 			AUTO_DELINK | FORCE_DELINK,
279 			AUTO_DELINK | FORCE_DELINK);
280 }
281 
282 #ifdef USING_POLLING_CYCLE_DELINK
283 /* using polling cycle as delink time */
rts51x_auto_delink_polling_cycle(struct rts51x_chip * chip)284 static void rts51x_auto_delink_polling_cycle(struct rts51x_chip *chip)
285 {
286 	if (chip->auto_delink_counter <=
287 			chip->option.delink_delay * 2) {
288 		if (chip->auto_delink_counter ==
289 		    chip->option.delink_delay) {
290 			clear_first_install_mark(chip);
291 			if (chip->card_exist) {
292 				/* False card */
293 				if (!chip->card_ejected) {
294 					/* if card is not ejected or safely
295 					 * remove,then do force delink */
296 					RTS51X_DEBUGP("False card inserted,"
297 							"do force delink\n");
298 					rts51x_auto_delink_force_cmd(chip);
299 					chip->auto_delink_counter =
300 					    chip->option.delink_delay * 2 + 1;
301 				}
302 			} else {
303 				RTS51X_DEBUGP("No card inserted, do delink\n");
304 				/* rts51x_write_register(chip, CARD_PWR_CTL,
305 						DV3318_AUTO_PWR_OFF, 0); */
306 				rts51x_auto_delink_cmd(chip);
307 			}
308 		}
309 		if (chip->auto_delink_counter ==
310 		    chip->option.delink_delay * 2) {
311 			RTS51X_DEBUGP("Try to do force delink\n");
312 			rts51x_auto_delink_force_cmd(chip);
313 		}
314 		chip->auto_delink_counter++;
315 	}
316 }
317 
rts51x_auto_delink(struct rts51x_chip * chip)318 static void rts51x_auto_delink(struct rts51x_chip *chip)
319 {
320 	rts51x_auto_delink_polling_cycle(chip);
321 }
322 #else
323 /* some of called funcs are not implemented, so comment it out */
324 #if 0
325 /* using precise time as delink time */
326 static void rts51x_auto_delink_precise_time(struct rts51x_chip *chip)
327 {
328 	int retvalue = 0;
329 
330 	retvalue = rts51x_get_card_status(chip, &chip->card_status);
331 	/* get card CD status success and card CD not exist,
332 	 * then check whether delink */
333 	if ((retvalue == STATUS_SUCCESS)
334 	    && (!(chip->card_status & (SD_CD | MS_CD | XD_CD)))) {
335 		if (rts51x_count_delink_time(chip) >=
336 		    chip->option.delink_delay) {
337 			clear_first_install_mark(chip);
338 			RTS51X_DEBUGP("No card inserted, do delink\n");
339 			/* sangdy2010-05-17:disable because there is error
340 			 * after SSC clock closed and card power
341 			 * has been closed before */
342 			/* rts51x_write_register(chip, CARD_PWR_CTL,
343 					DV3318_AUTO_PWR_OFF, 0); */
344 			rts51x_auto_delink_cmd(chip);
345 	}
346 	/* card CD exist and not ready, then do force delink */
347 	if ((retvalue == STATUS_SUCCESS)
348 	    && (chip->card_status & (SD_CD | MS_CD | XD_CD))) {
349 		/* if card is not ejected or safely remove,
350 		 * then do force delink */
351 		if (!chip->card_ejected) {
352 			/* sangdy2010-11-16:polling at least 2 cycles
353 			 * then do force delink for card may force delink
354 			 * if card is extracted and insert quickly
355 			 * after ready. */
356 			if (chip->auto_delink_counter > 1) {
357 				if (rts51x_count_delink_time(chip) >
358 				    chip->option.delink_delay * 2) {
359 					RTS51X_DEBUGP("Try to do force"
360 							"delink\n");
361 					rts51x_auto_delink_force_cmd(chip);
362 				}
363 			}
364 		}
365 	}
366 	chip->auto_delink_counter++;
367 }
368 #else
rts51x_auto_delink_precise_time(struct rts51x_chip * chip)369 static void rts51x_auto_delink_precise_time(struct rts51x_chip *chip)
370 {
371 }
372 #endif
373 
rts51x_auto_delink(struct rts51x_chip * chip)374 static void rts51x_auto_delink(struct rts51x_chip *chip)
375 {
376 	rts51x_auto_delink_precise_time(chip);
377 }
378 #endif
379 
rts51x_polling_func(struct rts51x_chip * chip)380 void rts51x_polling_func(struct rts51x_chip *chip)
381 {
382 #ifdef SUPPORT_SD_LOCK
383 	struct sd_info *sd_card = &(chip->sd_card);
384 
385 	if (sd_card->sd_erase_status) {
386 		if (chip->card_exist & SD_CARD) {
387 			u8 val;
388 			rts51x_read_register(chip, SD_BUS_STAT, &val);
389 			if (val & SD_DAT0_STATUS) {
390 				/* Erase completed */
391 				sd_card->sd_erase_status = SD_NOT_ERASE;
392 				sd_card->sd_lock_notify = 1;
393 
394 				/* SD card should be reinited,
395 				 * so we release it here. */
396 				sd_cleanup_work(chip);
397 				release_sd_card(chip);
398 				chip->card_ready &= ~SD_CARD;
399 				chip->card_exist &= ~SD_CARD;
400 				chip->rw_card[chip->card2lun[SD_CARD]] = NULL;
401 				clear_bit(chip->card2lun[SD_CARD],
402 					  &(chip->lun_mc));
403 			}
404 		} else {
405 			sd_card->sd_erase_status = SD_NOT_ERASE;
406 		}
407 	}
408 #endif
409 
410 	rts51x_init_cards(chip);
411 
412 #ifdef SUPPORT_OCP
413 	/* if OCP happen and card exist, then close card OE */
414 	if ((chip->ocp_stat & (MS_OCP_NOW | MS_OCP_EVER)) &&
415 			(chip->card_exist)) {
416 
417 		rts51x_prepare_run(chip);
418 
419 		if (chip->card_exist & SD_CARD)
420 			rts51x_write_register(chip, CARD_OE, SD_OUTPUT_EN, 0);
421 		else if (chip->card_exist & MS_CARD)
422 			rts51x_write_register(chip, CARD_OE, MS_OUTPUT_EN, 0);
423 		else if (chip->card_exist & XD_CARD)
424 			rts51x_write_register(chip, CARD_OE, XD_OUTPUT_EN, 0);
425 	}
426 #endif
427 
428 	if (chip->idle_counter < IDLE_MAX_COUNT) {
429 		chip->idle_counter++;
430 	} else {
431 		if (!RTS51X_CHK_STAT(chip, STAT_IDLE)) {
432 			RTS51X_DEBUGP("Idle state!\n");
433 			RTS51X_SET_STAT(chip, STAT_IDLE);
434 #ifndef LED_AUTO_BLINK
435 			chip->led_toggle_counter = 0;
436 #endif
437 			/* Idle state, turn off LED
438 			 * to reduce power consumption */
439 			if (chip->option.led_always_on
440 			    && (chip->card_exist &
441 				(SD_CARD | MS_CARD | XD_CARD))
442 			    && (!chip->card_ejected)) {
443 				turn_on_led(chip, LED_GPIO);
444 			} else {
445 				if (chip->rts5179) {
446 					rts51x_ep0_write_register(chip,
447 								  CARD_GPIO,
448 								  0x03, 0x00);
449 				} else {
450 					turn_off_led(chip, LED_GPIO);
451 				}
452 
453 			}
454 
455 #ifdef CLOSE_SSC_POWER
456 			if (!chip->card_ready) {
457 				rts51x_write_register(chip, CLK_DIV, CLK_CHANGE,
458 						      CLK_CHANGE);
459 				rts51x_write_register(chip, FPDCTL,
460 						      SSC_POWER_MASK,
461 						      SSC_POWER_DOWN);
462 				RTS51X_DEBUGP("Close SSC clock power!\n");
463 			}
464 #endif
465 		}
466 	}
467 
468 	switch (RTS51X_GET_STAT(chip)) {
469 	case STAT_RUN:
470 #ifndef LED_AUTO_BLINK
471 		rts51x_blink_led(chip);
472 #endif
473 		do_remaining_work(chip);
474 		break;
475 
476 	case STAT_IDLE:
477 		break;
478 
479 	default:
480 		break;
481 	}
482 
483 	if (chip->option.auto_delink_en && !chip->card_ready) {
484 		rts51x_auto_delink(chip);
485 	} else {
486 		chip->auto_delink_counter = 0;
487 		rts51x_clear_start_time(chip);
488 	}
489 }
490 
rts51x_add_cmd(struct rts51x_chip * chip,u8 cmd_type,u16 reg_addr,u8 mask,u8 data)491 void rts51x_add_cmd(struct rts51x_chip *chip,
492 		    u8 cmd_type, u16 reg_addr, u8 mask, u8 data)
493 {
494 	int i;
495 
496 	if (chip->cmd_idx < ((CMD_BUF_LEN - CMD_OFFSET) / 4)) {
497 		i = CMD_OFFSET + chip->cmd_idx * 4;
498 		chip->cmd_buf[i++] =
499 		    ((cmd_type & 0x03) << 6) | (u8) ((reg_addr >> 8) & 0x3F);
500 		chip->cmd_buf[i++] = (u8) reg_addr;
501 		chip->cmd_buf[i++] = mask;
502 		chip->cmd_buf[i++] = data;
503 		chip->cmd_idx++;
504 	}
505 }
506 
rts51x_send_cmd(struct rts51x_chip * chip,u8 flag,int timeout)507 int rts51x_send_cmd(struct rts51x_chip *chip, u8 flag, int timeout)
508 {
509 	int result;
510 
511 	chip->cmd_buf[CNT_H] = (u8) (chip->cmd_idx >> 8);
512 	chip->cmd_buf[CNT_L] = (u8) (chip->cmd_idx);
513 	chip->cmd_buf[STAGE_FLAG] = flag;
514 
515 	result = rts51x_transfer_data_rcc(chip, SND_BULK_PIPE(chip),
516 					  (void *)(chip->cmd_buf),
517 					  chip->cmd_idx * 4 + CMD_OFFSET,
518 					  0, NULL, timeout, MODE_C);
519 	if (result != STATUS_SUCCESS)
520 		TRACE_RET(chip, result);
521 
522 	return STATUS_SUCCESS;
523 }
524 
rts51x_get_rsp(struct rts51x_chip * chip,int rsp_len,int timeout)525 int rts51x_get_rsp(struct rts51x_chip *chip, int rsp_len, int timeout)
526 {
527 	int result;
528 
529 	if (rsp_len <= 0)
530 		TRACE_RET(chip, STATUS_ERROR);
531 	/* rsp_len must aligned to dword */
532 	if (rsp_len % 4)
533 		rsp_len += (4 - rsp_len % 4);
534 
535 	result = rts51x_transfer_data_rcc(chip, RCV_BULK_PIPE(chip),
536 					  (void *)chip->rsp_buf, rsp_len,
537 					  0, NULL, timeout, STAGE_R);
538 	if (result != STATUS_SUCCESS)
539 		TRACE_RET(chip, result);
540 
541 	return STATUS_SUCCESS;
542 }
543 
rts51x_get_card_status(struct rts51x_chip * chip,u16 * status)544 int rts51x_get_card_status(struct rts51x_chip *chip, u16 *status)
545 {
546 	int retval;
547 	u16 val;
548 
549 #ifdef GET_CARD_STATUS_USING_EPC
550 	retval = rts51x_get_epc_status(chip, &val);
551 
552 	if (retval != STATUS_SUCCESS)
553 		TRACE_RET(chip, retval);
554 #else
555 	retval = rts51x_ctrl_transfer(chip, RCV_CTRL_PIPE(chip), 0x02, 0xC0,
556 				      0, 0, &val, 2, 100);
557 	if (retval != STATUS_SUCCESS)
558 		TRACE_RET(chip, retval);
559 #endif
560 
561 	if (status)
562 		*status = val;
563 
564 	return STATUS_SUCCESS;
565 }
566 
rts51x_write_register(struct rts51x_chip * chip,u16 addr,u8 mask,u8 data)567 int rts51x_write_register(struct rts51x_chip *chip, u16 addr, u8 mask, u8 data)
568 {
569 	int retval;
570 
571 	rts51x_init_cmd(chip);
572 	rts51x_add_cmd(chip, WRITE_REG_CMD, addr, mask, data);
573 	retval = rts51x_send_cmd(chip, MODE_C, 100);
574 	if (retval != STATUS_SUCCESS)
575 		TRACE_RET(chip, STATUS_FAIL);
576 
577 	return STATUS_SUCCESS;
578 }
579 
rts51x_read_register(struct rts51x_chip * chip,u16 addr,u8 * data)580 int rts51x_read_register(struct rts51x_chip *chip, u16 addr, u8 *data)
581 {
582 	int retval;
583 
584 	if (data)
585 		*data = 0;
586 	rts51x_init_cmd(chip);
587 	rts51x_add_cmd(chip, READ_REG_CMD, addr, 0, 0);
588 	retval = rts51x_send_cmd(chip, MODE_CR, 100);
589 	if (retval != STATUS_SUCCESS)
590 		TRACE_RET(chip, STATUS_FAIL);
591 
592 	retval = rts51x_get_rsp(chip, 1, 100);
593 
594 	if (retval != STATUS_SUCCESS)
595 		TRACE_RET(chip, STATUS_FAIL);
596 
597 	if (data)
598 		*data = chip->rsp_buf[0];
599 
600 	return STATUS_SUCCESS;
601 }
602 
rts51x_ep0_write_register(struct rts51x_chip * chip,u16 addr,u8 mask,u8 data)603 int rts51x_ep0_write_register(struct rts51x_chip *chip, u16 addr, u8 mask,
604 			      u8 data)
605 {
606 	int retval;
607 	u16 value = 0, index = 0;
608 
609 	value |= (u16) (3 & 0x03) << 14;
610 	value |= (u16) (addr & 0x3FFF);
611 	index |= (u16) mask << 8;
612 	index |= (u16) data;
613 
614 	retval = rts51x_ctrl_transfer(chip, SND_CTRL_PIPE(chip), 0x00, 0x40,
615 				      cpu_to_be16(value), cpu_to_be16(index),
616 				      NULL, 0, 100);
617 	if (retval != STATUS_SUCCESS)
618 		TRACE_RET(chip, retval);
619 
620 	return STATUS_SUCCESS;
621 }
622 
rts51x_ep0_read_register(struct rts51x_chip * chip,u16 addr,u8 * data)623 int rts51x_ep0_read_register(struct rts51x_chip *chip, u16 addr, u8 *data)
624 {
625 	int retval;
626 	u16 value = 0;
627 	u8 val;
628 
629 	if (data)
630 		*data = 0;
631 
632 	value |= (u16) (2 & 0x03) << 14;
633 	value |= (u16) (addr & 0x3FFF);
634 
635 	retval = rts51x_ctrl_transfer(chip, RCV_CTRL_PIPE(chip), 0x00, 0xC0,
636 				      cpu_to_be16(value), 0, &val, 1, 100);
637 	if (retval != STATUS_SUCCESS)
638 		TRACE_RET(chip, retval);
639 
640 	if (data)
641 		*data = val;
642 
643 	return STATUS_SUCCESS;
644 }
645 
rts51x_seq_write_register(struct rts51x_chip * chip,u16 addr,u16 len,u8 * data)646 int rts51x_seq_write_register(struct rts51x_chip *chip, u16 addr, u16 len,
647 			      u8 *data)
648 {
649 	int result;
650 	u16 cmd_len = len + 12;
651 
652 	if (!data)
653 		TRACE_RET(chip, STATUS_ERROR);
654 
655 	cmd_len = (cmd_len <= CMD_BUF_LEN) ? cmd_len : CMD_BUF_LEN;
656 
657 	/* cmd_len must aligned to dword */
658 	if (cmd_len % 4)
659 		cmd_len += (4 - cmd_len % 4);
660 
661 	chip->cmd_buf[0] = 'R';
662 	chip->cmd_buf[1] = 'T';
663 	chip->cmd_buf[2] = 'C';
664 	chip->cmd_buf[3] = 'R';
665 	chip->cmd_buf[PACKET_TYPE] = SEQ_WRITE;
666 	chip->cmd_buf[5] = (u8) (len >> 8);
667 	chip->cmd_buf[6] = (u8) len;
668 	chip->cmd_buf[STAGE_FLAG] = 0;
669 	chip->cmd_buf[8] = (u8) (addr >> 8);
670 	chip->cmd_buf[9] = (u8) addr;
671 
672 	memcpy(chip->cmd_buf + 12, data, len);
673 
674 	result = rts51x_transfer_data_rcc(chip, SND_BULK_PIPE(chip),
675 					  (void *)(chip->cmd_buf), cmd_len, 0,
676 					  NULL, 100, MODE_C);
677 	if (result != STATUS_SUCCESS)
678 		TRACE_RET(chip, result);
679 
680 	return STATUS_SUCCESS;
681 }
682 
rts51x_seq_read_register(struct rts51x_chip * chip,u16 addr,u16 len,u8 * data)683 int rts51x_seq_read_register(struct rts51x_chip *chip, u16 addr, u16 len,
684 			     u8 *data)
685 {
686 	int result;
687 	u16 rsp_len;
688 
689 	if (!data)
690 		TRACE_RET(chip, STATUS_ERROR);
691 	/* rsp_len must aligned to dword */
692 	if (len % 4)
693 		rsp_len = len + (4 - len % 4);
694 	else
695 		rsp_len = len;
696 
697 	chip->cmd_buf[0] = 'R';
698 	chip->cmd_buf[1] = 'T';
699 	chip->cmd_buf[2] = 'C';
700 	chip->cmd_buf[3] = 'R';
701 	chip->cmd_buf[PACKET_TYPE] = SEQ_READ;
702 	chip->cmd_buf[5] = (u8) (rsp_len >> 8);
703 	chip->cmd_buf[6] = (u8) rsp_len;
704 	chip->cmd_buf[STAGE_FLAG] = STAGE_R;
705 	chip->cmd_buf[8] = (u8) (addr >> 8);
706 	chip->cmd_buf[9] = (u8) addr;
707 
708 	result = rts51x_transfer_data_rcc(chip, SND_BULK_PIPE(chip),
709 					  (void *)(chip->cmd_buf), 12, 0, NULL,
710 					  100, MODE_C);
711 	if (result != STATUS_SUCCESS)
712 		TRACE_RET(chip, result);
713 
714 	result = rts51x_transfer_data_rcc(chip, RCV_BULK_PIPE(chip),
715 					  (void *)data, rsp_len, 0, NULL, 100,
716 					  STAGE_DI);
717 	if (result != STATUS_SUCCESS)
718 		TRACE_RET(chip, result);
719 
720 	return STATUS_SUCCESS;
721 }
722 
rts51x_read_ppbuf(struct rts51x_chip * chip,u8 * buf,int buf_len)723 int rts51x_read_ppbuf(struct rts51x_chip *chip, u8 *buf, int buf_len)
724 {
725 	int retval;
726 
727 	if (!buf)
728 		TRACE_RET(chip, STATUS_ERROR);
729 
730 	retval =
731 	    rts51x_seq_read_register(chip, PPBUF_BASE2, (u16) buf_len, buf);
732 	if (retval != STATUS_SUCCESS)
733 		TRACE_RET(chip, retval);
734 
735 	return STATUS_SUCCESS;
736 }
737 
rts51x_write_ppbuf(struct rts51x_chip * chip,u8 * buf,int buf_len)738 int rts51x_write_ppbuf(struct rts51x_chip *chip, u8 *buf, int buf_len)
739 {
740 	int retval;
741 
742 	if (!buf)
743 		TRACE_RET(chip, STATUS_ERROR);
744 
745 	retval =
746 	    rts51x_seq_write_register(chip, PPBUF_BASE2, (u16) buf_len, buf);
747 	if (retval != STATUS_SUCCESS)
748 		TRACE_RET(chip, retval);
749 
750 	return STATUS_SUCCESS;
751 }
752 
rts51x_write_phy_register(struct rts51x_chip * chip,u8 addr,u8 val)753 int rts51x_write_phy_register(struct rts51x_chip *chip, u8 addr, u8 val)
754 {
755 	int retval;
756 
757 	RTS51X_DEBUGP("Write 0x%x to phy register 0x%x\n", val, addr);
758 
759 	rts51x_init_cmd(chip);
760 
761 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VSTAIN, 0xFF, val);
762 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VCONTROL, 0xFF, addr & 0x0F);
763 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
764 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
765 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x01);
766 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VCONTROL, 0xFF,
767 		       (addr >> 4) & 0x0F);
768 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
769 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
770 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x01);
771 
772 	retval = rts51x_send_cmd(chip, MODE_C, 100);
773 	if (retval != STATUS_SUCCESS)
774 		TRACE_RET(chip, retval);
775 
776 	return STATUS_SUCCESS;
777 }
778 
rts51x_read_phy_register(struct rts51x_chip * chip,u8 addr,u8 * val)779 int rts51x_read_phy_register(struct rts51x_chip *chip, u8 addr, u8 *val)
780 {
781 	int retval;
782 
783 	RTS51X_DEBUGP("Read from phy register 0x%x\n", addr);
784 
785 	rts51x_init_cmd(chip);
786 
787 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VCONTROL, 0xFF, 0x07);
788 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
789 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
790 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x01);
791 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VCONTROL, 0xFF,
792 		       (addr >> 4) & 0x0F);
793 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
794 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
795 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x01);
796 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VCONTROL, 0xFF, addr & 0x0F);
797 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
798 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x00);
799 	rts51x_add_cmd(chip, WRITE_REG_CMD, HS_VLOADM, 0xFF, 0x01);
800 	rts51x_add_cmd(chip, READ_REG_CMD, HS_VSTAOUT, 0, 0);
801 
802 	retval = rts51x_send_cmd(chip, MODE_CR, 100);
803 	if (retval != STATUS_SUCCESS)
804 		TRACE_RET(chip, retval);
805 
806 	retval = rts51x_get_rsp(chip, 1, 100);
807 
808 	if (retval != STATUS_SUCCESS)
809 		TRACE_RET(chip, retval);
810 
811 	if (val)
812 		*val = chip->rsp_buf[0];
813 
814 	RTS51X_DEBUGP("Return value: 0x%x\n", chip->rsp_buf[0]);
815 
816 	return STATUS_SUCCESS;
817 }
818 
rts51x_do_before_power_down(struct rts51x_chip * chip)819 void rts51x_do_before_power_down(struct rts51x_chip *chip)
820 {
821 	RTS51X_DEBUGP("rts51x_do_before_power_down\n");
822 
823 	rts51x_prepare_run(chip);
824 
825 	rts51x_release_cards(chip);
826 	if (chip->rts5179)
827 		rts51x_ep0_write_register(chip, CARD_GPIO, 0x03, 0x00);
828 	else
829 		turn_off_led(chip, LED_GPIO);
830 
831 	chip->cur_clk = 0;
832 	chip->card_exist = 0;
833 	chip->cur_card = 0;
834 	if (chip->asic_code && !chip->option.ww_enable) {
835 		if (CHECK_PKG(chip, LQFP48)) {
836 			rts51x_write_register(chip, CARD_PULL_CTL3, 0x80, 0x00);
837 			rts51x_write_register(chip, CARD_PULL_CTL6, 0xf0, 0x50);
838 		} else {
839 			rts51x_write_register(chip, CARD_PULL_CTL1, 0x30, 0x10);
840 			rts51x_write_register(chip, CARD_PULL_CTL3, 0x80, 0x00);
841 			rts51x_write_register(chip, CARD_PULL_CTL6, 0x0c, 0x04);
842 		}
843 	}
844 	if (CHECK_PKG(chip, LQFP48))
845 		rts51x_write_register(chip, CARD_PWR_CTL, LDO3318_PWR_MASK,
846 				      LDO_OFF);
847 }
848 
rts51x_clear_hw_error(struct rts51x_chip * chip)849 void rts51x_clear_hw_error(struct rts51x_chip *chip)
850 {
851 	rts51x_ep0_write_register(chip, SFSM_ED, 0xf8, 0xf8);
852 }
853 
rts51x_prepare_run(struct rts51x_chip * chip)854 void rts51x_prepare_run(struct rts51x_chip *chip)
855 {
856 #ifdef CLOSE_SSC_POWER
857 	if (RTS51X_CHK_STAT(chip, STAT_IDLE) && (!chip->card_ready)) {
858 		rts51x_write_register(chip, FPDCTL, SSC_POWER_MASK,
859 				      SSC_POWER_ON);
860 		udelay(100);
861 		RTS51X_DEBUGP("Open SSC clock power.\n");
862 
863 		rts51x_write_register(chip, CLK_DIV, CLK_CHANGE, 0x00);
864 	}
865 #endif
866 #if 0
867 	if (chip->option.ss_en && RTS51X_CHK_STAT(chip, STAT_SS)) {
868 		rts51x_try_to_exit_ss(chip);
869 		wait_timeout(100);
870 		rts51x_init_chip(chip);
871 		rts51x_init_cards(chip);
872 	}
873 
874 	RTS51X_SET_STAT(chip, STAT_RUN);
875 #endif
876 }
877 
878 #ifdef _MSG_TRACE
rts51x_trace_msg(struct rts51x_chip * chip,unsigned char * buf,int clear)879 void rts51x_trace_msg(struct rts51x_chip *chip, unsigned char *buf, int clear)
880 {
881 	unsigned char *ptr;
882 	int i, msg_cnt;
883 
884 	if (!buf)
885 		return;
886 
887 	ptr = buf;
888 
889 	if (chip->trace_msg[chip->msg_idx].valid)
890 		msg_cnt = TRACE_ITEM_CNT;
891 	else
892 		msg_cnt = chip->msg_idx;
893 	*(ptr++) = (u8) (msg_cnt >> 24);
894 	*(ptr++) = (u8) (msg_cnt >> 16);
895 	*(ptr++) = (u8) (msg_cnt >> 8);
896 	*(ptr++) = (u8) msg_cnt;
897 	RTS51X_DEBUGP("Trace message count is %d\n", msg_cnt);
898 
899 	for (i = 1; i <= msg_cnt; i++) {
900 		int j, idx;
901 
902 		idx = chip->msg_idx - i;
903 		if (idx < 0)
904 			idx += TRACE_ITEM_CNT;
905 
906 		*(ptr++) = (u8) (chip->trace_msg[idx].line >> 8);
907 		*(ptr++) = (u8) (chip->trace_msg[idx].line);
908 		for (j = 0; j < MSG_FUNC_LEN; j++)
909 			*(ptr++) = chip->trace_msg[idx].func[j];
910 		for (j = 0; j < MSG_FILE_LEN; j++)
911 			*(ptr++) = chip->trace_msg[idx].file[j];
912 		for (j = 0; j < TIME_VAL_LEN; j++)
913 			*(ptr++) = chip->trace_msg[idx].timeval_buf[j];
914 	}
915 
916 	if (clear) {
917 		chip->msg_idx = 0;
918 		for (i = 0; i < TRACE_ITEM_CNT; i++)
919 			chip->trace_msg[i].valid = 0;
920 	}
921 }
922 #endif
923 
rts51x_pp_status(struct rts51x_chip * chip,unsigned int lun,u8 * status,u8 status_len)924 void rts51x_pp_status(struct rts51x_chip *chip, unsigned int lun, u8 *status,
925 		      u8 status_len)
926 {
927 	struct sd_info *sd_card = &(chip->sd_card);
928 	struct ms_info *ms_card = &(chip->ms_card);
929 	u8 card = get_lun_card(chip, lun);
930 #ifdef SUPPORT_OC
931 	u8 oc_now_mask = 0, oc_ever_mask = 0;
932 #endif
933 
934 	if (!status || (status_len < 32))
935 		return;
936 	/* IC Version */
937 	status[0] = (u8) RTS51X_GET_PID(chip);
938 	status[1] = (u8) (chip->ic_version);
939 
940 	/* Auto delink mode */
941 	if (chip->option.auto_delink_en)
942 		status[2] = 0x10;
943 	else
944 		status[2] = 0x00;
945 
946 	/* Spec version */
947 	status[3] = 20;
948 	status[4] = 10;
949 	status[5] = 05;
950 	status[6] = 21;
951 
952 	/* Card WP */
953 	if (chip->card_wp)
954 		status[7] = 0x20;
955 	else
956 		status[7] = 0x00;
957 
958 #ifdef SUPPORT_OC
959 	/* Over current status */
960 	status[8] = 0;
961 	oc_now_mask = MS_OCP_NOW;
962 	oc_ever_mask = MS_OCP_EVER;
963 
964 	if (chip->ocp_stat & oc_now_mask)
965 		status[8] |= 0x02;
966 	if (chip->ocp_stat & oc_ever_mask)
967 		status[8] |= 0x01;
968 #endif
969 
970 	if (card == SD_CARD) {
971 		if (CHK_SD(sd_card)) {
972 			if (CHK_SD_HCXC(sd_card)) {
973 				if (sd_card->capacity > 0x4000000)
974 					/* SDXC */
975 					status[0x0E] = 0x02;
976 				else /* SDHC */
977 					status[0x0E] = 0x01;
978 			} else { /* SDSC */
979 				status[0x0E] = 0x00;
980 			}
981 
982 			if (CHK_SD_SDR104(sd_card))
983 				status[0x0F] = 0x03;
984 			else if (CHK_SD_DDR50(sd_card))
985 				status[0x0F] = 0x04;
986 			else if (CHK_SD_SDR50(sd_card))
987 				status[0x0F] = 0x02;
988 			else if (CHK_SD_HS(sd_card))
989 				status[0x0F] = 0x01;
990 			else
991 				status[0x0F] = 0x00; /* Normal speed */
992 		} else {
993 			if (CHK_MMC_SECTOR_MODE(sd_card))
994 				status[0x0E] = 0x01; /* High capacity */
995 			else
996 				status[0x0E] = 0x00; /* Normal capacity */
997 
998 			if (CHK_MMC_DDR52(sd_card))
999 				status[0x0F] = 0x03; /* DDR 52M */
1000 			else if (CHK_MMC_52M(sd_card))
1001 				status[0x0F] = 0x02; /* SDR 52M */
1002 			else if (CHK_MMC_26M(sd_card))
1003 				status[0x0F] = 0x01; /* SDR 26M */
1004 			else
1005 				status[0x0F] = 0x00; /* Normal speed */
1006 		}
1007 	} else if (card == MS_CARD) {
1008 		if (CHK_MSPRO(ms_card)) {
1009 			if (CHK_MSXC(ms_card))
1010 				status[0x0E] = 0x01; /* XC */
1011 			else
1012 				status[0x0E] = 0x00;
1013 
1014 			if (CHK_HG8BIT(ms_card))
1015 				status[0x0F] = 0x01;
1016 			else
1017 				status[0x0F] = 0x00;
1018 		}
1019 	}
1020 #ifdef SUPPORT_SD_LOCK
1021 	/* SD Lock/Unlock */
1022 	if (card == SD_CARD) {
1023 		status[0x17] = 0x80;
1024 		if (sd_card->sd_erase_status)
1025 			status[0x17] |= 0x01; /* Under erasing */
1026 		if (sd_card->sd_lock_status & SD_LOCKED) {
1027 			status[0x17] |= 0x02; /* Locked */
1028 			status[0x07] |= 0x40; /* Read protected */
1029 		}
1030 		if (sd_card->sd_lock_status & SD_PWD_EXIST)
1031 			status[0x17] |= 0x04; /* Contain PWD */
1032 	} else {
1033 		status[0x17] = 0x00;
1034 	}
1035 
1036 	RTS51X_DEBUGP("status[0x17] = 0x%x\n", status[0x17]);
1037 #endif
1038 
1039 	/* Function 0
1040 	 * Support Magic Gate, CPRM and PhyRegister R/W */
1041 	status[0x18] = 0x8A;
1042 
1043 	/* Function 2
1044 	 * Support OC LUN status & WP LUN status */
1045 	status[0x1A] = 0x28;
1046 
1047 	/* Function 7 */
1048 #ifdef SUPPORT_SD_LOCK
1049 	/* Support SD Lock/Unlock */
1050 	status[0x1F] = 0x01;
1051 #endif
1052 
1053 	/* Function 2
1054 	 * Support OC LUN status & WP LUN status */
1055 	status[0x1A] = 0x28;
1056 }
1057 
rts51x_read_status(struct rts51x_chip * chip,unsigned int lun,u8 * rts51x_status,u8 status_len)1058 void rts51x_read_status(struct rts51x_chip *chip, unsigned int lun,
1059 			u8 *rts51x_status, u8 status_len)
1060 {
1061 	if (!rts51x_status || (status_len < 16))
1062 		return;
1063 	/* VID */
1064 	rts51x_status[0] = (u8) (RTS51X_GET_VID(chip) >> 8);
1065 	rts51x_status[1] = (u8) RTS51X_GET_VID(chip);
1066 
1067 	/* PID */
1068 	rts51x_status[2] = (u8) (RTS51X_GET_PID(chip) >> 8);
1069 	rts51x_status[3] = (u8) RTS51X_GET_PID(chip);
1070 
1071 	/* gbLUN */
1072 	rts51x_status[4] = (u8) lun;
1073 
1074 	/* Lun Card Number */
1075 	if (chip->card_exist) {
1076 		if (chip->card_exist & XD_CARD)
1077 			rts51x_status[5] = 4; /* xD Card */
1078 		else if (chip->card_exist & SD_CARD)
1079 			rts51x_status[5] = 2; /* SD Card */
1080 		else if (chip->card_exist & MS_CARD)
1081 			rts51x_status[5] = 3; /* MS Card */
1082 		else
1083 			rts51x_status[5] = 7; /* Multi */
1084 	} else {
1085 		rts51x_status[5] = 7;	/* Multi */
1086 	}
1087 
1088 	/* Total LUNs */
1089 	rts51x_status[6] = 1;
1090 
1091 	/* IC Version */
1092 	rts51x_status[7] = (u8) RTS51X_GET_PID(chip);
1093 	rts51x_status[8] = chip->ic_version;
1094 
1095 	/* Physical Exist */
1096 	if (check_card_exist(chip, lun))
1097 		rts51x_status[9] = 1;
1098 	else
1099 		rts51x_status[9] = 0;
1100 
1101 	/* Multi Flag */
1102 	rts51x_status[10] = 1;
1103 
1104 	/* LUN Valid Map */
1105 	rts51x_status[11] = XD_CARD | SD_CARD | MS_CARD;
1106 
1107 	/* Logical Exist */
1108 	if (check_card_ready(chip, lun))
1109 		rts51x_status[12] = 1;
1110 	else
1111 		rts51x_status[12] = 0;
1112 
1113 	/* Detailed Type */
1114 	if (get_lun_card(chip, lun) == XD_CARD) {
1115 		rts51x_status[13] = 0x40;
1116 	} else if (get_lun_card(chip, lun) == SD_CARD) {
1117 		struct sd_info *sd_card = &(chip->sd_card);
1118 
1119 		rts51x_status[13] = 0x20;
1120 		if (CHK_SD(sd_card)) {
1121 			if (CHK_SD_HCXC(sd_card))
1122 				rts51x_status[13] |= 0x04; /* Hi capacity SD */
1123 			if (CHK_SD_HS(sd_card))
1124 				rts51x_status[13] |= 0x02; /* Hi speed SD */
1125 		} else {
1126 			rts51x_status[13] |= 0x08; /* MMC card */
1127 			if (CHK_MMC_52M(sd_card))
1128 				rts51x_status[13] |= 0x02; /* Hi speed */
1129 			if (CHK_MMC_SECTOR_MODE(sd_card))
1130 				rts51x_status[13] |= 0x04; /* Hi capacity */
1131 		}
1132 	} else if (get_lun_card(chip, lun) == MS_CARD) {
1133 		struct ms_info *ms_card = &(chip->ms_card);
1134 
1135 		if (CHK_MSPRO(ms_card)) {
1136 			rts51x_status[13] = 0x38; /* MS Pro */
1137 			if (CHK_HG8BIT(ms_card))
1138 				rts51x_status[13] |= 0x04; /* HG */
1139 #ifdef SUPPORT_MSXC
1140 			if (CHK_MSXC(ms_card))
1141 				rts51x_status[13] |= 0x01; /* MSXC */
1142 #endif
1143 		} else {
1144 			rts51x_status[13] = 0x30;
1145 		}
1146 	} else {
1147 		rts51x_status[13] = 0x70;
1148 	}
1149 /* Support OC, auto delink, vendor r/w, get bus width */
1150 	rts51x_status[14] = 0x78;
1151 
1152 	rts51x_status[15] = 0x82;
1153 }
1154 
rts51x_transfer_data_rcc(struct rts51x_chip * chip,unsigned int pipe,void * buf,unsigned int len,int use_sg,unsigned int * act_len,int timeout,u8 stage_flag)1155 int rts51x_transfer_data_rcc(struct rts51x_chip *chip, unsigned int pipe,
1156 			     void *buf, unsigned int len, int use_sg,
1157 			     unsigned int *act_len, int timeout, u8 stage_flag)
1158 {
1159 	int retval;
1160 
1161 	retval =
1162 	    rts51x_transfer_data(chip, pipe, buf, len, use_sg, act_len,
1163 				 timeout);
1164 
1165 	return retval;
1166 
1167 }
1168