1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3 * Driver for Realtek PCI-Express card reader
4 *
5 * Copyright(c) 2009-2013 Realtek Semiconductor Corp. All rights reserved.
6 *
7 * Author:
8 * Wei WANG (wei_wang@realsil.com.cn)
9 * Micky Ching (micky_ching@realsil.com.cn)
10 */
11
12 #include <linux/blkdev.h>
13 #include <linux/kthread.h>
14 #include <linux/sched.h>
15 #include <linux/vmalloc.h>
16
17 #include "rtsx.h"
18 #include "sd.h"
19 #include "ms.h"
20 #include "spi.h"
21
scsi_show_command(struct rtsx_chip * chip)22 void scsi_show_command(struct rtsx_chip *chip)
23 {
24 struct scsi_cmnd *srb = chip->srb;
25 char *what = NULL;
26 bool unknown_cmd = false;
27 int len;
28
29 switch (srb->cmnd[0]) {
30 case TEST_UNIT_READY:
31 what = "TEST_UNIT_READY";
32 break;
33 case REZERO_UNIT:
34 what = "REZERO_UNIT";
35 break;
36 case REQUEST_SENSE:
37 what = "REQUEST_SENSE";
38 break;
39 case FORMAT_UNIT:
40 what = "FORMAT_UNIT";
41 break;
42 case READ_BLOCK_LIMITS:
43 what = "READ_BLOCK_LIMITS";
44 break;
45 case REASSIGN_BLOCKS:
46 what = "REASSIGN_BLOCKS";
47 break;
48 case READ_6:
49 what = "READ_6";
50 break;
51 case WRITE_6:
52 what = "WRITE_6";
53 break;
54 case SEEK_6:
55 what = "SEEK_6";
56 break;
57 case READ_REVERSE:
58 what = "READ_REVERSE";
59 break;
60 case WRITE_FILEMARKS:
61 what = "WRITE_FILEMARKS";
62 break;
63 case SPACE:
64 what = "SPACE";
65 break;
66 case INQUIRY:
67 what = "INQUIRY";
68 break;
69 case RECOVER_BUFFERED_DATA:
70 what = "RECOVER_BUFFERED_DATA";
71 break;
72 case MODE_SELECT:
73 what = "MODE_SELECT";
74 break;
75 case RESERVE:
76 what = "RESERVE";
77 break;
78 case RELEASE:
79 what = "RELEASE";
80 break;
81 case COPY:
82 what = "COPY";
83 break;
84 case ERASE:
85 what = "ERASE";
86 break;
87 case MODE_SENSE:
88 what = "MODE_SENSE";
89 break;
90 case START_STOP:
91 what = "START_STOP";
92 break;
93 case RECEIVE_DIAGNOSTIC:
94 what = "RECEIVE_DIAGNOSTIC";
95 break;
96 case SEND_DIAGNOSTIC:
97 what = "SEND_DIAGNOSTIC";
98 break;
99 case ALLOW_MEDIUM_REMOVAL:
100 what = "ALLOW_MEDIUM_REMOVAL";
101 break;
102 case SET_WINDOW:
103 what = "SET_WINDOW";
104 break;
105 case READ_CAPACITY:
106 what = "READ_CAPACITY";
107 break;
108 case READ_10:
109 what = "READ_10";
110 break;
111 case WRITE_10:
112 what = "WRITE_10";
113 break;
114 case SEEK_10:
115 what = "SEEK_10";
116 break;
117 case WRITE_VERIFY:
118 what = "WRITE_VERIFY";
119 break;
120 case VERIFY:
121 what = "VERIFY";
122 break;
123 case SEARCH_HIGH:
124 what = "SEARCH_HIGH";
125 break;
126 case SEARCH_EQUAL:
127 what = "SEARCH_EQUAL";
128 break;
129 case SEARCH_LOW:
130 what = "SEARCH_LOW";
131 break;
132 case SET_LIMITS:
133 what = "SET_LIMITS";
134 break;
135 case READ_POSITION:
136 what = "READ_POSITION";
137 break;
138 case SYNCHRONIZE_CACHE:
139 what = "SYNCHRONIZE_CACHE";
140 break;
141 case LOCK_UNLOCK_CACHE:
142 what = "LOCK_UNLOCK_CACHE";
143 break;
144 case READ_DEFECT_DATA:
145 what = "READ_DEFECT_DATA";
146 break;
147 case MEDIUM_SCAN:
148 what = "MEDIUM_SCAN";
149 break;
150 case COMPARE:
151 what = "COMPARE";
152 break;
153 case COPY_VERIFY:
154 what = "COPY_VERIFY";
155 break;
156 case WRITE_BUFFER:
157 what = "WRITE_BUFFER";
158 break;
159 case READ_BUFFER:
160 what = "READ_BUFFER";
161 break;
162 case UPDATE_BLOCK:
163 what = "UPDATE_BLOCK";
164 break;
165 case READ_LONG:
166 what = "READ_LONG";
167 break;
168 case WRITE_LONG:
169 what = "WRITE_LONG";
170 break;
171 case CHANGE_DEFINITION:
172 what = "CHANGE_DEFINITION";
173 break;
174 case WRITE_SAME:
175 what = "WRITE_SAME";
176 break;
177 case GPCMD_READ_SUBCHANNEL:
178 what = "READ SUBCHANNEL";
179 break;
180 case READ_TOC:
181 what = "READ_TOC";
182 break;
183 case GPCMD_READ_HEADER:
184 what = "READ HEADER";
185 break;
186 case GPCMD_PLAY_AUDIO_10:
187 what = "PLAY AUDIO (10)";
188 break;
189 case GPCMD_PLAY_AUDIO_MSF:
190 what = "PLAY AUDIO MSF";
191 break;
192 case GPCMD_GET_EVENT_STATUS_NOTIFICATION:
193 what = "GET EVENT/STATUS NOTIFICATION";
194 break;
195 case GPCMD_PAUSE_RESUME:
196 what = "PAUSE/RESUME";
197 break;
198 case LOG_SELECT:
199 what = "LOG_SELECT";
200 break;
201 case LOG_SENSE:
202 what = "LOG_SENSE";
203 break;
204 case GPCMD_STOP_PLAY_SCAN:
205 what = "STOP PLAY/SCAN";
206 break;
207 case GPCMD_READ_DISC_INFO:
208 what = "READ DISC INFORMATION";
209 break;
210 case GPCMD_READ_TRACK_RZONE_INFO:
211 what = "READ TRACK INFORMATION";
212 break;
213 case GPCMD_RESERVE_RZONE_TRACK:
214 what = "RESERVE TRACK";
215 break;
216 case GPCMD_SEND_OPC:
217 what = "SEND OPC";
218 break;
219 case MODE_SELECT_10:
220 what = "MODE_SELECT_10";
221 break;
222 case GPCMD_REPAIR_RZONE_TRACK:
223 what = "REPAIR TRACK";
224 break;
225 case 0x59:
226 what = "READ MASTER CUE";
227 break;
228 case MODE_SENSE_10:
229 what = "MODE_SENSE_10";
230 break;
231 case GPCMD_CLOSE_TRACK:
232 what = "CLOSE TRACK/SESSION";
233 break;
234 case 0x5C:
235 what = "READ BUFFER CAPACITY";
236 break;
237 case 0x5D:
238 what = "SEND CUE SHEET";
239 break;
240 case GPCMD_BLANK:
241 what = "BLANK";
242 break;
243 case REPORT_LUNS:
244 what = "REPORT LUNS";
245 break;
246 case MOVE_MEDIUM:
247 what = "MOVE_MEDIUM or PLAY AUDIO (12)";
248 break;
249 case READ_12:
250 what = "READ_12";
251 break;
252 case WRITE_12:
253 what = "WRITE_12";
254 break;
255 case WRITE_VERIFY_12:
256 what = "WRITE_VERIFY_12";
257 break;
258 case SEARCH_HIGH_12:
259 what = "SEARCH_HIGH_12";
260 break;
261 case SEARCH_EQUAL_12:
262 what = "SEARCH_EQUAL_12";
263 break;
264 case SEARCH_LOW_12:
265 what = "SEARCH_LOW_12";
266 break;
267 case SEND_VOLUME_TAG:
268 what = "SEND_VOLUME_TAG";
269 break;
270 case READ_ELEMENT_STATUS:
271 what = "READ_ELEMENT_STATUS";
272 break;
273 case GPCMD_READ_CD_MSF:
274 what = "READ CD MSF";
275 break;
276 case GPCMD_SCAN:
277 what = "SCAN";
278 break;
279 case GPCMD_SET_SPEED:
280 what = "SET CD SPEED";
281 break;
282 case GPCMD_MECHANISM_STATUS:
283 what = "MECHANISM STATUS";
284 break;
285 case GPCMD_READ_CD:
286 what = "READ CD";
287 break;
288 case 0xE1:
289 what = "WRITE CONTINUE";
290 break;
291 case WRITE_LONG_2:
292 what = "WRITE_LONG_2";
293 break;
294 case VENDOR_CMND:
295 what = "Realtek's vendor command";
296 break;
297 default:
298 what = "(unknown command)";
299 unknown_cmd = true;
300 break;
301 }
302
303 if (srb->cmnd[0] != TEST_UNIT_READY)
304 dev_dbg(rtsx_dev(chip), "Command %s (%d bytes)\n",
305 what, srb->cmd_len);
306
307 if (unknown_cmd) {
308 len = min_t(unsigned short, srb->cmd_len, 16);
309 dev_dbg(rtsx_dev(chip), "%*ph\n", len, srb->cmnd);
310 }
311 }
312
set_sense_type(struct rtsx_chip * chip,unsigned int lun,int sense_type)313 void set_sense_type(struct rtsx_chip *chip, unsigned int lun, int sense_type)
314 {
315 switch (sense_type) {
316 case SENSE_TYPE_MEDIA_CHANGE:
317 set_sense_data(chip, lun, CUR_ERR, 0x06, 0, 0x28, 0, 0, 0);
318 break;
319
320 case SENSE_TYPE_MEDIA_NOT_PRESENT:
321 set_sense_data(chip, lun, CUR_ERR, 0x02, 0, 0x3A, 0, 0, 0);
322 break;
323
324 case SENSE_TYPE_MEDIA_LBA_OVER_RANGE:
325 set_sense_data(chip, lun, CUR_ERR, 0x05, 0, 0x21, 0, 0, 0);
326 break;
327
328 case SENSE_TYPE_MEDIA_LUN_NOT_SUPPORT:
329 set_sense_data(chip, lun, CUR_ERR, 0x05, 0, 0x25, 0, 0, 0);
330 break;
331
332 case SENSE_TYPE_MEDIA_WRITE_PROTECT:
333 set_sense_data(chip, lun, CUR_ERR, 0x07, 0, 0x27, 0, 0, 0);
334 break;
335
336 case SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR:
337 set_sense_data(chip, lun, CUR_ERR, 0x03, 0, 0x11, 0, 0, 0);
338 break;
339
340 case SENSE_TYPE_MEDIA_WRITE_ERR:
341 set_sense_data(chip, lun, CUR_ERR, 0x03, 0, 0x0C, 0x02, 0, 0);
342 break;
343
344 case SENSE_TYPE_MEDIA_INVALID_CMD_FIELD:
345 set_sense_data(chip, lun, CUR_ERR, ILGAL_REQ, 0,
346 ASC_INVLD_CDB, ASCQ_INVLD_CDB, CDB_ILLEGAL, 1);
347 break;
348
349 case SENSE_TYPE_FORMAT_IN_PROGRESS:
350 set_sense_data(chip, lun, CUR_ERR, 0x02, 0, 0x04, 0x04, 0, 0);
351 break;
352
353 case SENSE_TYPE_FORMAT_CMD_FAILED:
354 set_sense_data(chip, lun, CUR_ERR, 0x03, 0, 0x31, 0x01, 0, 0);
355 break;
356
357 #ifdef SUPPORT_MAGIC_GATE
358 case SENSE_TYPE_MG_KEY_FAIL_NOT_ESTAB:
359 set_sense_data(chip, lun, CUR_ERR, 0x05, 0, 0x6F, 0x02, 0, 0);
360 break;
361
362 case SENSE_TYPE_MG_KEY_FAIL_NOT_AUTHEN:
363 set_sense_data(chip, lun, CUR_ERR, 0x05, 0, 0x6F, 0x00, 0, 0);
364 break;
365
366 case SENSE_TYPE_MG_INCOMPATIBLE_MEDIUM:
367 set_sense_data(chip, lun, CUR_ERR, 0x02, 0, 0x30, 0x00, 0, 0);
368 break;
369
370 case SENSE_TYPE_MG_WRITE_ERR:
371 set_sense_data(chip, lun, CUR_ERR, 0x03, 0, 0x0C, 0x00, 0, 0);
372 break;
373 #endif
374
375 #ifdef SUPPORT_SD_LOCK
376 case SENSE_TYPE_MEDIA_READ_FORBIDDEN:
377 set_sense_data(chip, lun, CUR_ERR, 0x07, 0, 0x11, 0x13, 0, 0);
378 break;
379 #endif
380
381 case SENSE_TYPE_NO_SENSE:
382 default:
383 set_sense_data(chip, lun, CUR_ERR, 0, 0, 0, 0, 0, 0);
384 break;
385 }
386 }
387
set_sense_data(struct rtsx_chip * chip,unsigned int lun,u8 err_code,u8 sense_key,u32 info,u8 asc,u8 ascq,u8 sns_key_info0,u16 sns_key_info1)388 void set_sense_data(struct rtsx_chip *chip, unsigned int lun, u8 err_code,
389 u8 sense_key, u32 info, u8 asc, u8 ascq, u8 sns_key_info0,
390 u16 sns_key_info1)
391 {
392 struct sense_data_t *sense = &chip->sense_buffer[lun];
393
394 sense->err_code = err_code;
395 sense->sense_key = sense_key;
396 sense->info[0] = (u8)(info >> 24);
397 sense->info[1] = (u8)(info >> 16);
398 sense->info[2] = (u8)(info >> 8);
399 sense->info[3] = (u8)info;
400
401 sense->ad_sense_len = sizeof(struct sense_data_t) - 8;
402 sense->asc = asc;
403 sense->ascq = ascq;
404 if (sns_key_info0 != 0) {
405 sense->sns_key_info[0] = SKSV | sns_key_info0;
406 sense->sns_key_info[1] = (sns_key_info1 & 0xf0) >> 4;
407 sense->sns_key_info[2] = sns_key_info1 & 0x0f;
408 }
409 }
410
test_unit_ready(struct scsi_cmnd * srb,struct rtsx_chip * chip)411 static int test_unit_ready(struct scsi_cmnd *srb, struct rtsx_chip *chip)
412 {
413 unsigned int lun = SCSI_LUN(srb);
414
415 if (!check_card_ready(chip, lun)) {
416 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
417 return TRANSPORT_FAILED;
418 }
419
420 if (!(CHK_BIT(chip->lun_mc, lun))) {
421 SET_BIT(chip->lun_mc, lun);
422 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_CHANGE);
423 return TRANSPORT_FAILED;
424 }
425
426 #ifdef SUPPORT_SD_LOCK
427 if (get_lun_card(chip, SCSI_LUN(srb)) == SD_CARD) {
428 struct sd_info *sd_card = &chip->sd_card;
429
430 if (sd_card->sd_lock_notify) {
431 sd_card->sd_lock_notify = 0;
432 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_CHANGE);
433 return TRANSPORT_FAILED;
434 } else if (sd_card->sd_lock_status & SD_LOCKED) {
435 set_sense_type(chip, lun,
436 SENSE_TYPE_MEDIA_READ_FORBIDDEN);
437 return TRANSPORT_FAILED;
438 }
439 }
440 #endif
441
442 return TRANSPORT_GOOD;
443 }
444
445 static unsigned char formatter_inquiry_str[20] = {
446 'M', 'E', 'M', 'O', 'R', 'Y', 'S', 'T', 'I', 'C', 'K',
447 #ifdef SUPPORT_MAGIC_GATE
448 '-', 'M', 'G', /* Byte[47:49] */
449 #else
450 0x20, 0x20, 0x20, /* Byte[47:49] */
451 #endif
452
453 #ifdef SUPPORT_MAGIC_GATE
454 0x0B, /* Byte[50]: MG, MS, MSPro, MSXC */
455 #else
456 0x09, /* Byte[50]: MS, MSPro, MSXC */
457 #endif
458 0x00, /* Byte[51]: Category Specific Commands */
459 0x00, /* Byte[52]: Access Control and feature */
460 0x20, 0x20, 0x20, /* Byte[53:55] */
461 };
462
inquiry(struct scsi_cmnd * srb,struct rtsx_chip * chip)463 static int inquiry(struct scsi_cmnd *srb, struct rtsx_chip *chip)
464 {
465 unsigned int lun = SCSI_LUN(srb);
466 char *inquiry_default = (char *)"Generic-xD/SD/M.S. 1.00";
467 char *inquiry_sdms = (char *)"Generic-SD/MemoryStick 1.00";
468 char *inquiry_sd = (char *)"Generic-SD/MMC 1.00";
469 char *inquiry_ms = (char *)"Generic-MemoryStick 1.00";
470 char *inquiry_string;
471 unsigned char sendbytes;
472 unsigned char *buf;
473 u8 card = get_lun_card(chip, lun);
474 bool pro_formatter_flag = false;
475 unsigned char inquiry_buf[] = {
476 QULIFIRE | DRCT_ACCESS_DEV,
477 RMB_DISC | 0x0D,
478 0x00,
479 0x01,
480 0x1f,
481 0x02,
482 0,
483 REL_ADR | WBUS_32 | WBUS_16 | SYNC | LINKED | CMD_QUE | SFT_RE,
484 };
485
486 if (CHECK_LUN_MODE(chip, SD_MS_2LUN)) {
487 if (chip->lun2card[lun] == SD_CARD)
488 inquiry_string = inquiry_sd;
489 else
490 inquiry_string = inquiry_ms;
491
492 } else if (CHECK_LUN_MODE(chip, SD_MS_1LUN)) {
493 inquiry_string = inquiry_sdms;
494 } else {
495 inquiry_string = inquiry_default;
496 }
497
498 buf = vmalloc(scsi_bufflen(srb));
499 if (!buf)
500 return TRANSPORT_ERROR;
501
502 #ifdef SUPPORT_MAGIC_GATE
503 if (chip->mspro_formatter_enable &&
504 (chip->lun2card[lun] & MS_CARD))
505 #else
506 if (chip->mspro_formatter_enable)
507 #endif
508 if (!card || card == MS_CARD)
509 pro_formatter_flag = true;
510
511 if (pro_formatter_flag) {
512 if (scsi_bufflen(srb) < 56)
513 sendbytes = (unsigned char)(scsi_bufflen(srb));
514 else
515 sendbytes = 56;
516
517 } else {
518 if (scsi_bufflen(srb) < 36)
519 sendbytes = (unsigned char)(scsi_bufflen(srb));
520 else
521 sendbytes = 36;
522 }
523
524 if (sendbytes > 8) {
525 memcpy(buf, inquiry_buf, 8);
526 memcpy(buf + 8, inquiry_string, min(sendbytes, 36) - 8);
527 if (pro_formatter_flag) {
528 /* Additional Length */
529 buf[4] = 0x33;
530 }
531 } else {
532 memcpy(buf, inquiry_buf, sendbytes);
533 }
534
535 if (pro_formatter_flag) {
536 if (sendbytes > 36)
537 memcpy(buf + 36, formatter_inquiry_str, sendbytes - 36);
538 }
539
540 scsi_set_resid(srb, 0);
541
542 rtsx_stor_set_xfer_buf(buf, scsi_bufflen(srb), srb);
543 vfree(buf);
544
545 return TRANSPORT_GOOD;
546 }
547
start_stop_unit(struct scsi_cmnd * srb,struct rtsx_chip * chip)548 static int start_stop_unit(struct scsi_cmnd *srb, struct rtsx_chip *chip)
549 {
550 unsigned int lun = SCSI_LUN(srb);
551
552 scsi_set_resid(srb, scsi_bufflen(srb));
553
554 if (srb->cmnd[1] == 1)
555 return TRANSPORT_GOOD;
556
557 switch (srb->cmnd[0x4]) {
558 case STOP_MEDIUM:
559 /* Media disabled */
560 return TRANSPORT_GOOD;
561
562 case UNLOAD_MEDIUM:
563 /* Media shall be unload */
564 if (check_card_ready(chip, lun))
565 eject_card(chip, lun);
566 return TRANSPORT_GOOD;
567
568 case MAKE_MEDIUM_READY:
569 case LOAD_MEDIUM:
570 if (check_card_ready(chip, lun))
571 return TRANSPORT_GOOD;
572 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
573 return TRANSPORT_FAILED;
574
575 break;
576 }
577
578 return TRANSPORT_ERROR;
579 }
580
allow_medium_removal(struct scsi_cmnd * srb,struct rtsx_chip * chip)581 static int allow_medium_removal(struct scsi_cmnd *srb, struct rtsx_chip *chip)
582 {
583 int prevent;
584
585 prevent = srb->cmnd[4] & 0x1;
586
587 scsi_set_resid(srb, 0);
588
589 if (prevent) {
590 set_sense_type(chip, SCSI_LUN(srb),
591 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
592 return TRANSPORT_FAILED;
593 }
594
595 return TRANSPORT_GOOD;
596 }
597
request_sense(struct scsi_cmnd * srb,struct rtsx_chip * chip)598 static int request_sense(struct scsi_cmnd *srb, struct rtsx_chip *chip)
599 {
600 struct sense_data_t *sense;
601 unsigned int lun = SCSI_LUN(srb);
602 struct ms_info *ms_card = &chip->ms_card;
603 unsigned char *tmp, *buf;
604
605 sense = &chip->sense_buffer[lun];
606
607 if ((get_lun_card(chip, lun) == MS_CARD) &&
608 ms_card->pro_under_formatting) {
609 if (ms_card->format_status == FORMAT_SUCCESS) {
610 set_sense_type(chip, lun, SENSE_TYPE_NO_SENSE);
611 ms_card->pro_under_formatting = 0;
612 ms_card->progress = 0;
613 } else if (ms_card->format_status == FORMAT_IN_PROGRESS) {
614 /* Logical Unit Not Ready Format in Progress */
615 set_sense_data(chip, lun, CUR_ERR, 0x02, 0, 0x04, 0x04,
616 0, (u16)(ms_card->progress));
617 } else {
618 /* Format Command Failed */
619 set_sense_type(chip, lun, SENSE_TYPE_FORMAT_CMD_FAILED);
620 ms_card->pro_under_formatting = 0;
621 ms_card->progress = 0;
622 }
623
624 rtsx_set_stat(chip, RTSX_STAT_RUN);
625 }
626
627 buf = vmalloc(scsi_bufflen(srb));
628 if (!buf)
629 return TRANSPORT_ERROR;
630
631 tmp = (unsigned char *)sense;
632 memcpy(buf, tmp, scsi_bufflen(srb));
633
634 rtsx_stor_set_xfer_buf(buf, scsi_bufflen(srb), srb);
635 vfree(buf);
636
637 scsi_set_resid(srb, 0);
638 /* Reset Sense Data */
639 set_sense_type(chip, lun, SENSE_TYPE_NO_SENSE);
640 return TRANSPORT_GOOD;
641 }
642
ms_mode_sense(struct rtsx_chip * chip,u8 cmd,int lun,u8 * buf,int buf_len)643 static void ms_mode_sense(struct rtsx_chip *chip, u8 cmd,
644 int lun, u8 *buf, int buf_len)
645 {
646 struct ms_info *ms_card = &chip->ms_card;
647 int sys_info_offset;
648 int data_size = buf_len;
649 bool support_format = false;
650 int i = 0;
651
652 if (cmd == MODE_SENSE) {
653 sys_info_offset = 8;
654 if (data_size > 0x68)
655 data_size = 0x68;
656
657 buf[i++] = 0x67; /* Mode Data Length */
658 } else {
659 sys_info_offset = 12;
660 if (data_size > 0x6C)
661 data_size = 0x6C;
662
663 buf[i++] = 0x00; /* Mode Data Length (MSB) */
664 buf[i++] = 0x6A; /* Mode Data Length (LSB) */
665 }
666
667 /* Medium Type Code */
668 if (check_card_ready(chip, lun)) {
669 if (CHK_MSXC(ms_card)) {
670 support_format = true;
671 buf[i++] = 0x40;
672 } else if (CHK_MSPRO(ms_card)) {
673 support_format = true;
674 buf[i++] = 0x20;
675 } else {
676 buf[i++] = 0x10;
677 }
678
679 /* WP */
680 if (check_card_wp(chip, lun))
681 buf[i++] = 0x80;
682 else
683 buf[i++] = 0x00;
684
685 } else {
686 buf[i++] = 0x00; /* MediaType */
687 buf[i++] = 0x00; /* WP */
688 }
689
690 buf[i++] = 0x00; /* Reserved */
691
692 if (cmd == MODE_SENSE_10) {
693 buf[i++] = 0x00; /* Reserved */
694 buf[i++] = 0x00; /* Block descriptor length(MSB) */
695 buf[i++] = 0x00; /* Block descriptor length(LSB) */
696
697 /* The Following Data is the content of "Page 0x20" */
698 if (data_size >= 9)
699 buf[i++] = 0x20; /* Page Code */
700 if (data_size >= 10)
701 buf[i++] = 0x62; /* Page Length */
702 if (data_size >= 11)
703 buf[i++] = 0x00; /* No Access Control */
704 if (data_size >= 12) {
705 if (support_format)
706 buf[i++] = 0xC0; /* SF, SGM */
707 else
708 buf[i++] = 0x00;
709 }
710 } else {
711 /* The Following Data is the content of "Page 0x20" */
712 if (data_size >= 5)
713 buf[i++] = 0x20; /* Page Code */
714 if (data_size >= 6)
715 buf[i++] = 0x62; /* Page Length */
716 if (data_size >= 7)
717 buf[i++] = 0x00; /* No Access Control */
718 if (data_size >= 8) {
719 if (support_format)
720 buf[i++] = 0xC0; /* SF, SGM */
721 else
722 buf[i++] = 0x00;
723 }
724 }
725
726 if (data_size > sys_info_offset) {
727 /* 96 Bytes Attribute Data */
728 int len = data_size - sys_info_offset;
729
730 len = (len < 96) ? len : 96;
731
732 memcpy(buf + sys_info_offset, ms_card->raw_sys_info, len);
733 }
734 }
735
mode_sense(struct scsi_cmnd * srb,struct rtsx_chip * chip)736 static int mode_sense(struct scsi_cmnd *srb, struct rtsx_chip *chip)
737 {
738 unsigned int lun = SCSI_LUN(srb);
739 unsigned int data_size;
740 int status;
741 bool pro_formatter_flag;
742 unsigned char page_code, *buf;
743 u8 card = get_lun_card(chip, lun);
744
745 #ifndef SUPPORT_MAGIC_GATE
746 if (!check_card_ready(chip, lun)) {
747 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
748 scsi_set_resid(srb, scsi_bufflen(srb));
749 return TRANSPORT_FAILED;
750 }
751 #endif
752
753 pro_formatter_flag = false;
754 data_size = 8;
755 #ifdef SUPPORT_MAGIC_GATE
756 if ((chip->lun2card[lun] & MS_CARD)) {
757 if (!card || card == MS_CARD) {
758 data_size = 108;
759 if (chip->mspro_formatter_enable)
760 pro_formatter_flag = true;
761 }
762 }
763 #else
764 if (card == MS_CARD) {
765 if (chip->mspro_formatter_enable) {
766 pro_formatter_flag = true;
767 data_size = 108;
768 }
769 }
770 #endif
771
772 buf = kmalloc(data_size, GFP_KERNEL);
773 if (!buf)
774 return TRANSPORT_ERROR;
775
776 page_code = srb->cmnd[2] & 0x3f;
777
778 if (page_code == 0x3F || page_code == 0x1C ||
779 page_code == 0x00 ||
780 (pro_formatter_flag && page_code == 0x20)) {
781 if (srb->cmnd[0] == MODE_SENSE) {
782 if (page_code == 0x3F || page_code == 0x20) {
783 ms_mode_sense(chip, srb->cmnd[0],
784 lun, buf, data_size);
785 } else {
786 data_size = 4;
787 buf[0] = 0x03;
788 buf[1] = 0x00;
789 if (check_card_wp(chip, lun))
790 buf[2] = 0x80;
791 else
792 buf[2] = 0x00;
793
794 buf[3] = 0x00;
795 }
796 } else {
797 if (page_code == 0x3F || page_code == 0x20) {
798 ms_mode_sense(chip, srb->cmnd[0],
799 lun, buf, data_size);
800 } else {
801 data_size = 8;
802 buf[0] = 0x00;
803 buf[1] = 0x06;
804 buf[2] = 0x00;
805 if (check_card_wp(chip, lun))
806 buf[3] = 0x80;
807 else
808 buf[3] = 0x00;
809 buf[4] = 0x00;
810 buf[5] = 0x00;
811 buf[6] = 0x00;
812 buf[7] = 0x00;
813 }
814 }
815 status = TRANSPORT_GOOD;
816 } else {
817 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
818 scsi_set_resid(srb, scsi_bufflen(srb));
819 status = TRANSPORT_FAILED;
820 }
821
822 if (status == TRANSPORT_GOOD) {
823 unsigned int len = min_t(unsigned int, scsi_bufflen(srb),
824 data_size);
825 rtsx_stor_set_xfer_buf(buf, len, srb);
826 scsi_set_resid(srb, scsi_bufflen(srb) - len);
827 }
828 kfree(buf);
829
830 return status;
831 }
832
read_write(struct scsi_cmnd * srb,struct rtsx_chip * chip)833 static int read_write(struct scsi_cmnd *srb, struct rtsx_chip *chip)
834 {
835 #ifdef SUPPORT_SD_LOCK
836 struct sd_info *sd_card = &chip->sd_card;
837 #endif
838 unsigned int lun = SCSI_LUN(srb);
839 int retval;
840 u32 start_sec;
841 u16 sec_cnt;
842
843 rtsx_disable_aspm(chip);
844
845 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
846 rtsx_exit_ss(chip);
847 wait_timeout(100);
848 }
849 rtsx_set_stat(chip, RTSX_STAT_RUN);
850
851 if (!check_card_ready(chip, lun) || (get_card_size(chip, lun) == 0)) {
852 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
853 return TRANSPORT_FAILED;
854 }
855
856 if (!(CHK_BIT(chip->lun_mc, lun))) {
857 SET_BIT(chip->lun_mc, lun);
858 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_CHANGE);
859 return TRANSPORT_FAILED;
860 }
861
862 #ifdef SUPPORT_SD_LOCK
863 if (sd_card->sd_erase_status) {
864 /* Accessing to any card is forbidden
865 * until the erase procedure of SD is completed
866 */
867 dev_dbg(rtsx_dev(chip), "SD card being erased!\n");
868 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_READ_FORBIDDEN);
869 return TRANSPORT_FAILED;
870 }
871
872 if (get_lun_card(chip, lun) == SD_CARD) {
873 if (sd_card->sd_lock_status & SD_LOCKED) {
874 dev_dbg(rtsx_dev(chip), "SD card locked!\n");
875 set_sense_type(chip, lun,
876 SENSE_TYPE_MEDIA_READ_FORBIDDEN);
877 return TRANSPORT_FAILED;
878 }
879 }
880 #endif
881
882 if (srb->cmnd[0] == READ_10 || srb->cmnd[0] == WRITE_10) {
883 start_sec = ((u32)srb->cmnd[2] << 24) |
884 ((u32)srb->cmnd[3] << 16) |
885 ((u32)srb->cmnd[4] << 8) | ((u32)srb->cmnd[5]);
886 sec_cnt = ((u16)(srb->cmnd[7]) << 8) | srb->cmnd[8];
887 } else if ((srb->cmnd[0] == READ_6) || (srb->cmnd[0] == WRITE_6)) {
888 start_sec = ((u32)(srb->cmnd[1] & 0x1F) << 16) |
889 ((u32)srb->cmnd[2] << 8) | ((u32)srb->cmnd[3]);
890 sec_cnt = srb->cmnd[4];
891 if (sec_cnt == 0)
892 sec_cnt = 256;
893 } else if ((srb->cmnd[0] == VENDOR_CMND) &&
894 (srb->cmnd[1] == SCSI_APP_CMD) &&
895 ((srb->cmnd[2] == PP_READ10) || (srb->cmnd[2] == PP_WRITE10))) {
896 start_sec = ((u32)srb->cmnd[4] << 24) |
897 ((u32)srb->cmnd[5] << 16) |
898 ((u32)srb->cmnd[6] << 8) | ((u32)srb->cmnd[7]);
899 sec_cnt = ((u16)(srb->cmnd[9]) << 8) | srb->cmnd[10];
900 } else {
901 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
902 return TRANSPORT_FAILED;
903 }
904
905 /* In some test, we will receive a start_sec like 0xFFFFFFFF.
906 * In this situation, start_sec + sec_cnt will overflow, so we
907 * need to judge start_sec at first
908 */
909 if (start_sec > get_card_size(chip, lun) ||
910 ((start_sec + sec_cnt) > get_card_size(chip, lun))) {
911 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_LBA_OVER_RANGE);
912 return TRANSPORT_FAILED;
913 }
914
915 if (sec_cnt == 0) {
916 scsi_set_resid(srb, 0);
917 return TRANSPORT_GOOD;
918 }
919
920 if (chip->rw_fail_cnt[lun] == 3) {
921 dev_dbg(rtsx_dev(chip), "read/write fail three times in succession\n");
922 if (srb->sc_data_direction == DMA_FROM_DEVICE)
923 set_sense_type(chip, lun,
924 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
925 else
926 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_WRITE_ERR);
927
928 return TRANSPORT_FAILED;
929 }
930
931 if (srb->sc_data_direction == DMA_TO_DEVICE) {
932 if (check_card_wp(chip, lun)) {
933 dev_dbg(rtsx_dev(chip), "Write protected card!\n");
934 set_sense_type(chip, lun,
935 SENSE_TYPE_MEDIA_WRITE_PROTECT);
936 return TRANSPORT_FAILED;
937 }
938 }
939
940 retval = card_rw(srb, chip, start_sec, sec_cnt);
941 if (retval != STATUS_SUCCESS) {
942 if (chip->need_release & chip->lun2card[lun]) {
943 chip->rw_fail_cnt[lun] = 0;
944 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
945 } else {
946 chip->rw_fail_cnt[lun]++;
947 if (srb->sc_data_direction == DMA_FROM_DEVICE)
948 set_sense_type
949 (chip, lun,
950 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
951 else
952 set_sense_type(chip, lun,
953 SENSE_TYPE_MEDIA_WRITE_ERR);
954 }
955 retval = TRANSPORT_FAILED;
956 goto exit;
957 } else {
958 chip->rw_fail_cnt[lun] = 0;
959 retval = TRANSPORT_GOOD;
960 }
961
962 scsi_set_resid(srb, 0);
963
964 exit:
965 return retval;
966 }
967
read_format_capacity(struct scsi_cmnd * srb,struct rtsx_chip * chip)968 static int read_format_capacity(struct scsi_cmnd *srb, struct rtsx_chip *chip)
969 {
970 unsigned char *buf;
971 unsigned int lun = SCSI_LUN(srb);
972 unsigned int buf_len;
973 u8 card = get_lun_card(chip, lun);
974 u32 card_size;
975 int desc_cnt;
976 int i = 0;
977
978 if (!check_card_ready(chip, lun)) {
979 if (!chip->mspro_formatter_enable) {
980 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
981 return TRANSPORT_FAILED;
982 }
983 }
984
985 buf_len = (scsi_bufflen(srb) > 12) ? 0x14 : 12;
986
987 buf = kmalloc(buf_len, GFP_KERNEL);
988 if (!buf)
989 return TRANSPORT_ERROR;
990
991 buf[i++] = 0;
992 buf[i++] = 0;
993 buf[i++] = 0;
994
995 /* Capacity List Length */
996 if (buf_len > 12 && chip->mspro_formatter_enable &&
997 (chip->lun2card[lun] & MS_CARD) &&
998 (!card || card == MS_CARD)) {
999 buf[i++] = 0x10;
1000 desc_cnt = 2;
1001 } else {
1002 buf[i++] = 0x08;
1003 desc_cnt = 1;
1004 }
1005
1006 while (desc_cnt) {
1007 if (check_card_ready(chip, lun)) {
1008 card_size = get_card_size(chip, lun);
1009 buf[i++] = (unsigned char)(card_size >> 24);
1010 buf[i++] = (unsigned char)(card_size >> 16);
1011 buf[i++] = (unsigned char)(card_size >> 8);
1012 buf[i++] = (unsigned char)card_size;
1013
1014 if (desc_cnt == 2)
1015 buf[i++] = 2;
1016 else
1017 buf[i++] = 0;
1018 } else {
1019 buf[i++] = 0xFF;
1020 buf[i++] = 0xFF;
1021 buf[i++] = 0xFF;
1022 buf[i++] = 0xFF;
1023
1024 if (desc_cnt == 2)
1025 buf[i++] = 3;
1026 else
1027 buf[i++] = 0;
1028 }
1029
1030 buf[i++] = 0x00;
1031 buf[i++] = 0x02;
1032 buf[i++] = 0x00;
1033
1034 desc_cnt--;
1035 }
1036
1037 buf_len = min_t(unsigned int, scsi_bufflen(srb), buf_len);
1038 rtsx_stor_set_xfer_buf(buf, buf_len, srb);
1039 kfree(buf);
1040
1041 scsi_set_resid(srb, scsi_bufflen(srb) - buf_len);
1042
1043 return TRANSPORT_GOOD;
1044 }
1045
read_capacity(struct scsi_cmnd * srb,struct rtsx_chip * chip)1046 static int read_capacity(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1047 {
1048 unsigned char *buf;
1049 unsigned int lun = SCSI_LUN(srb);
1050 u32 card_size;
1051
1052 if (!check_card_ready(chip, lun)) {
1053 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
1054 return TRANSPORT_FAILED;
1055 }
1056
1057 if (!(CHK_BIT(chip->lun_mc, lun))) {
1058 SET_BIT(chip->lun_mc, lun);
1059 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_CHANGE);
1060 return TRANSPORT_FAILED;
1061 }
1062
1063 buf = kmalloc(8, GFP_KERNEL);
1064 if (!buf)
1065 return TRANSPORT_ERROR;
1066
1067 card_size = get_card_size(chip, lun);
1068 buf[0] = (unsigned char)((card_size - 1) >> 24);
1069 buf[1] = (unsigned char)((card_size - 1) >> 16);
1070 buf[2] = (unsigned char)((card_size - 1) >> 8);
1071 buf[3] = (unsigned char)(card_size - 1);
1072
1073 buf[4] = 0x00;
1074 buf[5] = 0x00;
1075 buf[6] = 0x02;
1076 buf[7] = 0x00;
1077
1078 rtsx_stor_set_xfer_buf(buf, scsi_bufflen(srb), srb);
1079 kfree(buf);
1080
1081 scsi_set_resid(srb, 0);
1082
1083 return TRANSPORT_GOOD;
1084 }
1085
read_eeprom(struct scsi_cmnd * srb,struct rtsx_chip * chip)1086 static int read_eeprom(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1087 {
1088 unsigned short len, i;
1089 int retval;
1090 u8 *buf;
1091
1092 rtsx_disable_aspm(chip);
1093
1094 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1095 rtsx_exit_ss(chip);
1096 wait_timeout(100);
1097 }
1098 rtsx_set_stat(chip, RTSX_STAT_RUN);
1099
1100 len = ((u16)srb->cmnd[4] << 8) | srb->cmnd[5];
1101
1102 buf = vmalloc(len);
1103 if (!buf)
1104 return TRANSPORT_ERROR;
1105
1106 retval = rtsx_force_power_on(chip, SSC_PDCTL);
1107 if (retval != STATUS_SUCCESS) {
1108 vfree(buf);
1109 set_sense_type(chip, SCSI_LUN(srb),
1110 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
1111 return TRANSPORT_FAILED;
1112 }
1113
1114 for (i = 0; i < len; i++) {
1115 retval = spi_read_eeprom(chip, i, buf + i);
1116 if (retval != STATUS_SUCCESS) {
1117 vfree(buf);
1118 set_sense_type(chip, SCSI_LUN(srb),
1119 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
1120 return TRANSPORT_FAILED;
1121 }
1122 }
1123
1124 len = (unsigned short)min_t(unsigned int, scsi_bufflen(srb), len);
1125 rtsx_stor_set_xfer_buf(buf, len, srb);
1126 scsi_set_resid(srb, scsi_bufflen(srb) - len);
1127
1128 vfree(buf);
1129
1130 return TRANSPORT_GOOD;
1131 }
1132
write_eeprom(struct scsi_cmnd * srb,struct rtsx_chip * chip)1133 static int write_eeprom(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1134 {
1135 unsigned short len, i;
1136 int retval;
1137 u8 *buf;
1138
1139 rtsx_disable_aspm(chip);
1140
1141 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1142 rtsx_exit_ss(chip);
1143 wait_timeout(100);
1144 }
1145 rtsx_set_stat(chip, RTSX_STAT_RUN);
1146
1147 len = ((u16)srb->cmnd[4] << 8) | srb->cmnd[5];
1148
1149 retval = rtsx_force_power_on(chip, SSC_PDCTL);
1150 if (retval != STATUS_SUCCESS) {
1151 set_sense_type(chip, SCSI_LUN(srb), SENSE_TYPE_MEDIA_WRITE_ERR);
1152 return TRANSPORT_FAILED;
1153 }
1154
1155 if (len == 511) {
1156 retval = spi_erase_eeprom_chip(chip);
1157 if (retval != STATUS_SUCCESS) {
1158 set_sense_type(chip, SCSI_LUN(srb),
1159 SENSE_TYPE_MEDIA_WRITE_ERR);
1160 return TRANSPORT_FAILED;
1161 }
1162 } else {
1163 len = (unsigned short)min_t(unsigned int, scsi_bufflen(srb),
1164 len);
1165 buf = vmalloc(len);
1166 if (!buf)
1167 return TRANSPORT_ERROR;
1168
1169 rtsx_stor_get_xfer_buf(buf, len, srb);
1170 scsi_set_resid(srb, scsi_bufflen(srb) - len);
1171
1172 for (i = 0; i < len; i++) {
1173 retval = spi_write_eeprom(chip, i, buf[i]);
1174 if (retval != STATUS_SUCCESS) {
1175 vfree(buf);
1176 set_sense_type(chip, SCSI_LUN(srb),
1177 SENSE_TYPE_MEDIA_WRITE_ERR);
1178 return TRANSPORT_FAILED;
1179 }
1180 }
1181
1182 vfree(buf);
1183 }
1184
1185 return TRANSPORT_GOOD;
1186 }
1187
read_mem(struct scsi_cmnd * srb,struct rtsx_chip * chip)1188 static int read_mem(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1189 {
1190 unsigned short addr, len, i;
1191 int retval;
1192 u8 *buf;
1193
1194 rtsx_disable_aspm(chip);
1195
1196 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1197 rtsx_exit_ss(chip);
1198 wait_timeout(100);
1199 }
1200 rtsx_set_stat(chip, RTSX_STAT_RUN);
1201
1202 addr = ((u16)srb->cmnd[2] << 8) | srb->cmnd[3];
1203 len = ((u16)srb->cmnd[4] << 8) | srb->cmnd[5];
1204
1205 if (addr < 0xFC00) {
1206 set_sense_type(chip, SCSI_LUN(srb),
1207 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1208 return TRANSPORT_FAILED;
1209 }
1210
1211 buf = vmalloc(len);
1212 if (!buf)
1213 return TRANSPORT_ERROR;
1214
1215 retval = rtsx_force_power_on(chip, SSC_PDCTL);
1216 if (retval != STATUS_SUCCESS) {
1217 vfree(buf);
1218 set_sense_type(chip, SCSI_LUN(srb), SENSE_TYPE_MEDIA_WRITE_ERR);
1219 return TRANSPORT_FAILED;
1220 }
1221
1222 for (i = 0; i < len; i++) {
1223 retval = rtsx_read_register(chip, addr + i, buf + i);
1224 if (retval != STATUS_SUCCESS) {
1225 vfree(buf);
1226 set_sense_type(chip, SCSI_LUN(srb),
1227 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
1228 return TRANSPORT_FAILED;
1229 }
1230 }
1231
1232 len = (unsigned short)min_t(unsigned int, scsi_bufflen(srb), len);
1233 rtsx_stor_set_xfer_buf(buf, len, srb);
1234 scsi_set_resid(srb, scsi_bufflen(srb) - len);
1235
1236 vfree(buf);
1237
1238 return TRANSPORT_GOOD;
1239 }
1240
write_mem(struct scsi_cmnd * srb,struct rtsx_chip * chip)1241 static int write_mem(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1242 {
1243 unsigned short addr, len, i;
1244 int retval;
1245 u8 *buf;
1246
1247 rtsx_disable_aspm(chip);
1248
1249 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1250 rtsx_exit_ss(chip);
1251 wait_timeout(100);
1252 }
1253 rtsx_set_stat(chip, RTSX_STAT_RUN);
1254
1255 addr = ((u16)srb->cmnd[2] << 8) | srb->cmnd[3];
1256 len = ((u16)srb->cmnd[4] << 8) | srb->cmnd[5];
1257
1258 if (addr < 0xFC00) {
1259 set_sense_type(chip, SCSI_LUN(srb),
1260 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1261 return TRANSPORT_FAILED;
1262 }
1263
1264 len = (unsigned short)min_t(unsigned int, scsi_bufflen(srb), len);
1265 buf = vmalloc(len);
1266 if (!buf)
1267 return TRANSPORT_ERROR;
1268
1269 rtsx_stor_get_xfer_buf(buf, len, srb);
1270 scsi_set_resid(srb, scsi_bufflen(srb) - len);
1271
1272 retval = rtsx_force_power_on(chip, SSC_PDCTL);
1273 if (retval != STATUS_SUCCESS) {
1274 vfree(buf);
1275 set_sense_type(chip, SCSI_LUN(srb), SENSE_TYPE_MEDIA_WRITE_ERR);
1276 return TRANSPORT_FAILED;
1277 }
1278
1279 for (i = 0; i < len; i++) {
1280 retval = rtsx_write_register(chip, addr + i, 0xFF, buf[i]);
1281 if (retval != STATUS_SUCCESS) {
1282 vfree(buf);
1283 set_sense_type(chip, SCSI_LUN(srb),
1284 SENSE_TYPE_MEDIA_WRITE_ERR);
1285 return TRANSPORT_FAILED;
1286 }
1287 }
1288
1289 vfree(buf);
1290
1291 return TRANSPORT_GOOD;
1292 }
1293
get_sd_csd(struct scsi_cmnd * srb,struct rtsx_chip * chip)1294 static int get_sd_csd(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1295 {
1296 struct sd_info *sd_card = &chip->sd_card;
1297 unsigned int lun = SCSI_LUN(srb);
1298
1299 if (!check_card_ready(chip, lun)) {
1300 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
1301 return TRANSPORT_FAILED;
1302 }
1303
1304 if (get_lun_card(chip, lun) != SD_CARD) {
1305 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
1306 return TRANSPORT_FAILED;
1307 }
1308
1309 scsi_set_resid(srb, 0);
1310 rtsx_stor_set_xfer_buf(sd_card->raw_csd, scsi_bufflen(srb), srb);
1311
1312 return TRANSPORT_GOOD;
1313 }
1314
toggle_gpio_cmd(struct scsi_cmnd * srb,struct rtsx_chip * chip)1315 static int toggle_gpio_cmd(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1316 {
1317 u8 gpio = srb->cmnd[2];
1318
1319 rtsx_disable_aspm(chip);
1320
1321 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1322 rtsx_exit_ss(chip);
1323 wait_timeout(100);
1324 }
1325 rtsx_set_stat(chip, RTSX_STAT_RUN);
1326
1327 if (gpio > 3)
1328 gpio = 1;
1329 toggle_gpio(chip, gpio);
1330
1331 return TRANSPORT_GOOD;
1332 }
1333
read_host_reg(struct scsi_cmnd * srb,struct rtsx_chip * chip)1334 static int read_host_reg(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1335 {
1336 u8 addr, buf[4];
1337 u32 val;
1338 unsigned int len;
1339
1340 rtsx_disable_aspm(chip);
1341
1342 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1343 rtsx_exit_ss(chip);
1344 wait_timeout(100);
1345 }
1346 rtsx_set_stat(chip, RTSX_STAT_RUN);
1347
1348 addr = srb->cmnd[4];
1349
1350 val = rtsx_readl(chip, addr);
1351 dev_dbg(rtsx_dev(chip), "Host register (0x%x): 0x%x\n", addr, val);
1352
1353 buf[0] = (u8)(val >> 24);
1354 buf[1] = (u8)(val >> 16);
1355 buf[2] = (u8)(val >> 8);
1356 buf[3] = (u8)val;
1357
1358 len = min_t(unsigned int, scsi_bufflen(srb), 4);
1359 rtsx_stor_set_xfer_buf(buf, len, srb);
1360 scsi_set_resid(srb, scsi_bufflen(srb) - len);
1361
1362 return TRANSPORT_GOOD;
1363 }
1364
write_host_reg(struct scsi_cmnd * srb,struct rtsx_chip * chip)1365 static int write_host_reg(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1366 {
1367 u8 addr, buf[4];
1368 u32 val;
1369 unsigned int len;
1370
1371 rtsx_disable_aspm(chip);
1372
1373 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1374 rtsx_exit_ss(chip);
1375 wait_timeout(100);
1376 }
1377 rtsx_set_stat(chip, RTSX_STAT_RUN);
1378
1379 addr = srb->cmnd[4];
1380
1381 len = min_t(unsigned int, scsi_bufflen(srb), 4);
1382 rtsx_stor_get_xfer_buf(buf, len, srb);
1383 scsi_set_resid(srb, scsi_bufflen(srb) - len);
1384
1385 val = ((u32)buf[0] << 24) | ((u32)buf[1] << 16) | ((u32)buf[2]
1386 << 8) | buf[3];
1387
1388 rtsx_writel(chip, addr, val);
1389
1390 return TRANSPORT_GOOD;
1391 }
1392
set_variable(struct scsi_cmnd * srb,struct rtsx_chip * chip)1393 static int set_variable(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1394 {
1395 unsigned int lun = SCSI_LUN(srb);
1396
1397 if (srb->cmnd[3] == 1) {
1398 /* Variable Clock */
1399 struct xd_info *xd_card = &chip->xd_card;
1400 struct sd_info *sd_card = &chip->sd_card;
1401 struct ms_info *ms_card = &chip->ms_card;
1402
1403 switch (srb->cmnd[4]) {
1404 case XD_CARD:
1405 xd_card->xd_clock = srb->cmnd[5];
1406 break;
1407
1408 case SD_CARD:
1409 sd_card->sd_clock = srb->cmnd[5];
1410 break;
1411
1412 case MS_CARD:
1413 ms_card->ms_clock = srb->cmnd[5];
1414 break;
1415
1416 default:
1417 set_sense_type(chip, lun,
1418 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1419 return TRANSPORT_FAILED;
1420 }
1421 } else if (srb->cmnd[3] == 2) {
1422 if (srb->cmnd[4]) {
1423 chip->blink_led = 1;
1424 } else {
1425 int retval;
1426
1427 chip->blink_led = 0;
1428
1429 rtsx_disable_aspm(chip);
1430
1431 if (chip->ss_en &&
1432 (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1433 rtsx_exit_ss(chip);
1434 wait_timeout(100);
1435 }
1436 rtsx_set_stat(chip, RTSX_STAT_RUN);
1437
1438 retval = rtsx_force_power_on(chip, SSC_PDCTL);
1439 if (retval != STATUS_SUCCESS) {
1440 set_sense_type(chip, SCSI_LUN(srb),
1441 SENSE_TYPE_MEDIA_WRITE_ERR);
1442 return TRANSPORT_FAILED;
1443 }
1444
1445 turn_off_led(chip, LED_GPIO);
1446 }
1447 } else {
1448 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1449 return TRANSPORT_FAILED;
1450 }
1451
1452 return TRANSPORT_GOOD;
1453 }
1454
get_variable(struct scsi_cmnd * srb,struct rtsx_chip * chip)1455 static int get_variable(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1456 {
1457 unsigned int lun = SCSI_LUN(srb);
1458
1459 if (srb->cmnd[3] == 1) {
1460 struct xd_info *xd_card = &chip->xd_card;
1461 struct sd_info *sd_card = &chip->sd_card;
1462 struct ms_info *ms_card = &chip->ms_card;
1463 u8 tmp;
1464
1465 switch (srb->cmnd[4]) {
1466 case XD_CARD:
1467 tmp = (u8)(xd_card->xd_clock);
1468 break;
1469
1470 case SD_CARD:
1471 tmp = (u8)(sd_card->sd_clock);
1472 break;
1473
1474 case MS_CARD:
1475 tmp = (u8)(ms_card->ms_clock);
1476 break;
1477
1478 default:
1479 set_sense_type(chip, lun,
1480 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1481 return TRANSPORT_FAILED;
1482 }
1483
1484 rtsx_stor_set_xfer_buf(&tmp, 1, srb);
1485 } else if (srb->cmnd[3] == 2) {
1486 u8 tmp = chip->blink_led;
1487
1488 rtsx_stor_set_xfer_buf(&tmp, 1, srb);
1489 } else {
1490 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1491 return TRANSPORT_FAILED;
1492 }
1493
1494 return TRANSPORT_GOOD;
1495 }
1496
dma_access_ring_buffer(struct scsi_cmnd * srb,struct rtsx_chip * chip)1497 static int dma_access_ring_buffer(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1498 {
1499 int retval;
1500 unsigned int lun = SCSI_LUN(srb);
1501 u16 len;
1502
1503 rtsx_disable_aspm(chip);
1504
1505 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1506 rtsx_exit_ss(chip);
1507 wait_timeout(100);
1508 }
1509 rtsx_set_stat(chip, RTSX_STAT_RUN);
1510
1511 len = ((u16)(srb->cmnd[4]) << 8) | srb->cmnd[5];
1512 len = min_t(u16, len, scsi_bufflen(srb));
1513
1514 if (srb->sc_data_direction == DMA_FROM_DEVICE)
1515 dev_dbg(rtsx_dev(chip), "Read from device\n");
1516 else
1517 dev_dbg(rtsx_dev(chip), "Write to device\n");
1518
1519 retval = rtsx_transfer_data(chip, 0, scsi_sglist(srb), len,
1520 scsi_sg_count(srb), srb->sc_data_direction,
1521 1000);
1522 if (retval < 0) {
1523 if (srb->sc_data_direction == DMA_FROM_DEVICE)
1524 set_sense_type(chip, lun,
1525 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
1526 else
1527 set_sense_type(chip, lun,
1528 SENSE_TYPE_MEDIA_WRITE_ERR);
1529
1530 return TRANSPORT_FAILED;
1531 }
1532 scsi_set_resid(srb, 0);
1533
1534 return TRANSPORT_GOOD;
1535 }
1536
get_dev_status(struct scsi_cmnd * srb,struct rtsx_chip * chip)1537 static int get_dev_status(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1538 {
1539 struct sd_info *sd_card = &chip->sd_card;
1540 struct ms_info *ms_card = &chip->ms_card;
1541 int buf_len;
1542 unsigned int lun = SCSI_LUN(srb);
1543 u8 card = get_lun_card(chip, lun);
1544 u8 status[32];
1545 #ifdef SUPPORT_OCP
1546 u8 oc_now_mask = 0, oc_ever_mask = 0;
1547 #endif
1548
1549 memset(status, 0, 32);
1550
1551 status[0] = (u8)(chip->product_id);
1552 status[1] = chip->ic_version;
1553
1554 if (chip->auto_delink_en)
1555 status[2] = 0x10;
1556 else
1557 status[2] = 0x00;
1558
1559 status[3] = 20;
1560 status[4] = 10;
1561 status[5] = 05;
1562 status[6] = 21;
1563
1564 if (chip->card_wp)
1565 status[7] = 0x20;
1566 else
1567 status[7] = 0x00;
1568
1569 #ifdef SUPPORT_OCP
1570 status[8] = 0;
1571 if (CHECK_LUN_MODE(chip, SD_MS_2LUN) &&
1572 chip->lun2card[lun] == MS_CARD) {
1573 oc_now_mask = MS_OC_NOW;
1574 oc_ever_mask = MS_OC_EVER;
1575 } else {
1576 oc_now_mask = SD_OC_NOW;
1577 oc_ever_mask = SD_OC_EVER;
1578 }
1579
1580 if (chip->ocp_stat & oc_now_mask)
1581 status[8] |= 0x02;
1582
1583 if (chip->ocp_stat & oc_ever_mask)
1584 status[8] |= 0x01;
1585 #endif
1586
1587 if (card == SD_CARD) {
1588 if (CHK_SD(sd_card)) {
1589 if (CHK_SD_HCXC(sd_card)) {
1590 if (sd_card->capacity > 0x4000000)
1591 status[0x0E] = 0x02;
1592 else
1593 status[0x0E] = 0x01;
1594 } else {
1595 status[0x0E] = 0x00;
1596 }
1597
1598 if (CHK_SD_SDR104(sd_card))
1599 status[0x0F] = 0x03;
1600 else if (CHK_SD_DDR50(sd_card))
1601 status[0x0F] = 0x04;
1602 else if (CHK_SD_SDR50(sd_card))
1603 status[0x0F] = 0x02;
1604 else if (CHK_SD_HS(sd_card))
1605 status[0x0F] = 0x01;
1606 else
1607 status[0x0F] = 0x00;
1608 } else {
1609 if (CHK_MMC_SECTOR_MODE(sd_card))
1610 status[0x0E] = 0x01;
1611 else
1612 status[0x0E] = 0x00;
1613
1614 if (CHK_MMC_DDR52(sd_card))
1615 status[0x0F] = 0x03;
1616 else if (CHK_MMC_52M(sd_card))
1617 status[0x0F] = 0x02;
1618 else if (CHK_MMC_26M(sd_card))
1619 status[0x0F] = 0x01;
1620 else
1621 status[0x0F] = 0x00;
1622 }
1623 } else if (card == MS_CARD) {
1624 if (CHK_MSPRO(ms_card)) {
1625 if (CHK_MSXC(ms_card))
1626 status[0x0E] = 0x01;
1627 else
1628 status[0x0E] = 0x00;
1629
1630 if (CHK_HG8BIT(ms_card))
1631 status[0x0F] = 0x01;
1632 else
1633 status[0x0F] = 0x00;
1634 }
1635 }
1636
1637 #ifdef SUPPORT_SD_LOCK
1638 if (card == SD_CARD) {
1639 status[0x17] = 0x80;
1640 if (sd_card->sd_erase_status)
1641 status[0x17] |= 0x01;
1642 if (sd_card->sd_lock_status & SD_LOCKED) {
1643 status[0x17] |= 0x02;
1644 status[0x07] |= 0x40;
1645 }
1646 if (sd_card->sd_lock_status & SD_PWD_EXIST)
1647 status[0x17] |= 0x04;
1648 } else {
1649 status[0x17] = 0x00;
1650 }
1651
1652 dev_dbg(rtsx_dev(chip), "status[0x17] = 0x%x\n", status[0x17]);
1653 #endif
1654
1655 status[0x18] = 0x8A;
1656 status[0x1A] = 0x28;
1657 #ifdef SUPPORT_SD_LOCK
1658 status[0x1F] = 0x01;
1659 #endif
1660
1661 buf_len = min_t(unsigned int, scsi_bufflen(srb), sizeof(status));
1662 rtsx_stor_set_xfer_buf(status, buf_len, srb);
1663 scsi_set_resid(srb, scsi_bufflen(srb) - buf_len);
1664
1665 return TRANSPORT_GOOD;
1666 }
1667
set_chip_mode(struct scsi_cmnd * srb,struct rtsx_chip * chip)1668 static int set_chip_mode(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1669 {
1670 int phy_debug_mode;
1671 int retval;
1672 u16 reg;
1673
1674 if (!CHECK_PID(chip, 0x5208)) {
1675 set_sense_type(chip, SCSI_LUN(srb),
1676 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1677 return TRANSPORT_FAILED;
1678 }
1679
1680 phy_debug_mode = (int)(srb->cmnd[3]);
1681
1682 if (phy_debug_mode) {
1683 chip->phy_debug_mode = 1;
1684 retval = rtsx_write_register(chip, CDRESUMECTL, 0x77, 0);
1685 if (retval != STATUS_SUCCESS)
1686 return TRANSPORT_FAILED;
1687
1688 rtsx_disable_bus_int(chip);
1689
1690 retval = rtsx_read_phy_register(chip, 0x1C, ®);
1691 if (retval != STATUS_SUCCESS)
1692 return TRANSPORT_FAILED;
1693
1694 reg |= 0x0001;
1695 retval = rtsx_write_phy_register(chip, 0x1C, reg);
1696 if (retval != STATUS_SUCCESS)
1697 return TRANSPORT_FAILED;
1698 } else {
1699 chip->phy_debug_mode = 0;
1700 retval = rtsx_write_register(chip, CDRESUMECTL, 0x77, 0x77);
1701 if (retval != STATUS_SUCCESS)
1702 return TRANSPORT_FAILED;
1703
1704 rtsx_enable_bus_int(chip);
1705
1706 retval = rtsx_read_phy_register(chip, 0x1C, ®);
1707 if (retval != STATUS_SUCCESS)
1708 return TRANSPORT_FAILED;
1709
1710 reg &= 0xFFFE;
1711 retval = rtsx_write_phy_register(chip, 0x1C, reg);
1712 if (retval != STATUS_SUCCESS)
1713 return TRANSPORT_FAILED;
1714 }
1715
1716 return TRANSPORT_GOOD;
1717 }
1718
rw_mem_cmd_buf(struct scsi_cmnd * srb,struct rtsx_chip * chip)1719 static int rw_mem_cmd_buf(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1720 {
1721 int retval = STATUS_SUCCESS;
1722 unsigned int lun = SCSI_LUN(srb);
1723 u8 cmd_type, mask, value, idx;
1724 u16 addr;
1725
1726 rtsx_disable_aspm(chip);
1727
1728 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1729 rtsx_exit_ss(chip);
1730 wait_timeout(100);
1731 }
1732 rtsx_set_stat(chip, RTSX_STAT_RUN);
1733
1734 switch (srb->cmnd[3]) {
1735 case INIT_BATCHCMD:
1736 rtsx_init_cmd(chip);
1737 break;
1738
1739 case ADD_BATCHCMD:
1740 cmd_type = srb->cmnd[4];
1741 if (cmd_type > 2) {
1742 set_sense_type(chip, lun,
1743 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1744 return TRANSPORT_FAILED;
1745 }
1746 addr = (srb->cmnd[5] << 8) | srb->cmnd[6];
1747 mask = srb->cmnd[7];
1748 value = srb->cmnd[8];
1749 rtsx_add_cmd(chip, cmd_type, addr, mask, value);
1750 break;
1751
1752 case SEND_BATCHCMD:
1753 retval = rtsx_send_cmd(chip, 0, 1000);
1754 break;
1755
1756 case GET_BATCHRSP:
1757 idx = srb->cmnd[4];
1758 value = *(rtsx_get_cmd_data(chip) + idx);
1759 if (scsi_bufflen(srb) < 1) {
1760 set_sense_type(chip, lun,
1761 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1762 return TRANSPORT_FAILED;
1763 }
1764 rtsx_stor_set_xfer_buf(&value, 1, srb);
1765 scsi_set_resid(srb, 0);
1766 break;
1767
1768 default:
1769 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1770 return TRANSPORT_FAILED;
1771 }
1772
1773 if (retval != STATUS_SUCCESS) {
1774 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_WRITE_ERR);
1775 return TRANSPORT_FAILED;
1776 }
1777
1778 return TRANSPORT_GOOD;
1779 }
1780
suit_cmd(struct scsi_cmnd * srb,struct rtsx_chip * chip)1781 static int suit_cmd(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1782 {
1783 switch (srb->cmnd[3]) {
1784 case INIT_BATCHCMD:
1785 case ADD_BATCHCMD:
1786 case SEND_BATCHCMD:
1787 case GET_BATCHRSP:
1788 return rw_mem_cmd_buf(srb, chip);
1789 default:
1790 return TRANSPORT_ERROR;
1791 }
1792 }
1793
read_phy_register(struct scsi_cmnd * srb,struct rtsx_chip * chip)1794 static int read_phy_register(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1795 {
1796 unsigned short addr, len, i;
1797 int retval;
1798 u8 *buf;
1799 u16 val;
1800
1801 rtsx_disable_aspm(chip);
1802
1803 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1804 rtsx_exit_ss(chip);
1805 wait_timeout(100);
1806 }
1807 rtsx_set_stat(chip, RTSX_STAT_RUN);
1808
1809 addr = ((u16)srb->cmnd[4] << 8) | srb->cmnd[5];
1810 len = ((u16)srb->cmnd[6] << 8) | srb->cmnd[7];
1811
1812 if (len % 2)
1813 len -= len % 2;
1814
1815 if (len) {
1816 buf = vmalloc(len);
1817 if (!buf)
1818 return TRANSPORT_ERROR;
1819
1820 retval = rtsx_force_power_on(chip, SSC_PDCTL);
1821 if (retval != STATUS_SUCCESS) {
1822 vfree(buf);
1823 set_sense_type(chip, SCSI_LUN(srb),
1824 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
1825 return TRANSPORT_FAILED;
1826 }
1827
1828 for (i = 0; i < len / 2; i++) {
1829 retval = rtsx_read_phy_register(chip, addr + i, &val);
1830 if (retval != STATUS_SUCCESS) {
1831 vfree(buf);
1832 set_sense_type
1833 (chip, SCSI_LUN(srb),
1834 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
1835 return TRANSPORT_FAILED;
1836 }
1837
1838 buf[2 * i] = (u8)(val >> 8);
1839 buf[2 * i + 1] = (u8)val;
1840 }
1841
1842 len = (unsigned short)min_t(unsigned int, scsi_bufflen(srb),
1843 len);
1844 rtsx_stor_set_xfer_buf(buf, len, srb);
1845 scsi_set_resid(srb, scsi_bufflen(srb) - len);
1846
1847 vfree(buf);
1848 }
1849
1850 return TRANSPORT_GOOD;
1851 }
1852
write_phy_register(struct scsi_cmnd * srb,struct rtsx_chip * chip)1853 static int write_phy_register(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1854 {
1855 unsigned short addr, len, i;
1856 int retval;
1857 u8 *buf;
1858 u16 val;
1859
1860 rtsx_disable_aspm(chip);
1861
1862 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1863 rtsx_exit_ss(chip);
1864 wait_timeout(100);
1865 }
1866 rtsx_set_stat(chip, RTSX_STAT_RUN);
1867
1868 addr = ((u16)srb->cmnd[4] << 8) | srb->cmnd[5];
1869 len = ((u16)srb->cmnd[6] << 8) | srb->cmnd[7];
1870
1871 if (len % 2)
1872 len -= len % 2;
1873
1874 if (len) {
1875 len = (unsigned short)min_t(unsigned int, scsi_bufflen(srb),
1876 len);
1877
1878 buf = vmalloc(len);
1879 if (!buf)
1880 return TRANSPORT_ERROR;
1881
1882 rtsx_stor_get_xfer_buf(buf, len, srb);
1883 scsi_set_resid(srb, scsi_bufflen(srb) - len);
1884
1885 retval = rtsx_force_power_on(chip, SSC_PDCTL);
1886 if (retval != STATUS_SUCCESS) {
1887 vfree(buf);
1888 set_sense_type(chip, SCSI_LUN(srb),
1889 SENSE_TYPE_MEDIA_WRITE_ERR);
1890 return TRANSPORT_FAILED;
1891 }
1892
1893 for (i = 0; i < len / 2; i++) {
1894 val = ((u16)buf[2 * i] << 8) | buf[2 * i + 1];
1895 retval = rtsx_write_phy_register(chip, addr + i, val);
1896 if (retval != STATUS_SUCCESS) {
1897 vfree(buf);
1898 set_sense_type(chip, SCSI_LUN(srb),
1899 SENSE_TYPE_MEDIA_WRITE_ERR);
1900 return TRANSPORT_FAILED;
1901 }
1902 }
1903
1904 vfree(buf);
1905 }
1906
1907 return TRANSPORT_GOOD;
1908 }
1909
erase_eeprom2(struct scsi_cmnd * srb,struct rtsx_chip * chip)1910 static int erase_eeprom2(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1911 {
1912 unsigned short addr;
1913 int retval;
1914 u8 mode;
1915
1916 rtsx_disable_aspm(chip);
1917
1918 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1919 rtsx_exit_ss(chip);
1920 wait_timeout(100);
1921 }
1922 rtsx_set_stat(chip, RTSX_STAT_RUN);
1923
1924 retval = rtsx_force_power_on(chip, SSC_PDCTL);
1925 if (retval != STATUS_SUCCESS) {
1926 set_sense_type(chip, SCSI_LUN(srb), SENSE_TYPE_MEDIA_WRITE_ERR);
1927 return TRANSPORT_FAILED;
1928 }
1929
1930 mode = srb->cmnd[3];
1931 addr = ((u16)srb->cmnd[4] << 8) | srb->cmnd[5];
1932
1933 if (mode == 0) {
1934 retval = spi_erase_eeprom_chip(chip);
1935 if (retval != STATUS_SUCCESS) {
1936 set_sense_type(chip, SCSI_LUN(srb),
1937 SENSE_TYPE_MEDIA_WRITE_ERR);
1938 return TRANSPORT_FAILED;
1939 }
1940 } else if (mode == 1) {
1941 retval = spi_erase_eeprom_byte(chip, addr);
1942 if (retval != STATUS_SUCCESS) {
1943 set_sense_type(chip, SCSI_LUN(srb),
1944 SENSE_TYPE_MEDIA_WRITE_ERR);
1945 return TRANSPORT_FAILED;
1946 }
1947 } else {
1948 set_sense_type(chip, SCSI_LUN(srb),
1949 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
1950 return TRANSPORT_FAILED;
1951 }
1952
1953 return TRANSPORT_GOOD;
1954 }
1955
read_eeprom2(struct scsi_cmnd * srb,struct rtsx_chip * chip)1956 static int read_eeprom2(struct scsi_cmnd *srb, struct rtsx_chip *chip)
1957 {
1958 unsigned short addr, len, i;
1959 int retval;
1960 u8 *buf;
1961
1962 rtsx_disable_aspm(chip);
1963
1964 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
1965 rtsx_exit_ss(chip);
1966 wait_timeout(100);
1967 }
1968 rtsx_set_stat(chip, RTSX_STAT_RUN);
1969
1970 addr = ((u16)srb->cmnd[4] << 8) | srb->cmnd[5];
1971 len = ((u16)srb->cmnd[6] << 8) | srb->cmnd[7];
1972
1973 buf = vmalloc(len);
1974 if (!buf)
1975 return TRANSPORT_ERROR;
1976
1977 retval = rtsx_force_power_on(chip, SSC_PDCTL);
1978 if (retval != STATUS_SUCCESS) {
1979 vfree(buf);
1980 set_sense_type(chip, SCSI_LUN(srb),
1981 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
1982 return TRANSPORT_FAILED;
1983 }
1984
1985 for (i = 0; i < len; i++) {
1986 retval = spi_read_eeprom(chip, addr + i, buf + i);
1987 if (retval != STATUS_SUCCESS) {
1988 vfree(buf);
1989 set_sense_type(chip, SCSI_LUN(srb),
1990 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
1991 return TRANSPORT_FAILED;
1992 }
1993 }
1994
1995 len = (unsigned short)min_t(unsigned int, scsi_bufflen(srb), len);
1996 rtsx_stor_set_xfer_buf(buf, len, srb);
1997 scsi_set_resid(srb, scsi_bufflen(srb) - len);
1998
1999 vfree(buf);
2000
2001 return TRANSPORT_GOOD;
2002 }
2003
write_eeprom2(struct scsi_cmnd * srb,struct rtsx_chip * chip)2004 static int write_eeprom2(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2005 {
2006 unsigned short addr, len, i;
2007 int retval;
2008 u8 *buf;
2009
2010 rtsx_disable_aspm(chip);
2011
2012 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
2013 rtsx_exit_ss(chip);
2014 wait_timeout(100);
2015 }
2016 rtsx_set_stat(chip, RTSX_STAT_RUN);
2017
2018 addr = ((u16)srb->cmnd[4] << 8) | srb->cmnd[5];
2019 len = ((u16)srb->cmnd[6] << 8) | srb->cmnd[7];
2020
2021 len = (unsigned short)min_t(unsigned int, scsi_bufflen(srb), len);
2022 buf = vmalloc(len);
2023 if (!buf)
2024 return TRANSPORT_ERROR;
2025
2026 rtsx_stor_get_xfer_buf(buf, len, srb);
2027 scsi_set_resid(srb, scsi_bufflen(srb) - len);
2028
2029 retval = rtsx_force_power_on(chip, SSC_PDCTL);
2030 if (retval != STATUS_SUCCESS) {
2031 vfree(buf);
2032 set_sense_type(chip, SCSI_LUN(srb), SENSE_TYPE_MEDIA_WRITE_ERR);
2033 return TRANSPORT_FAILED;
2034 }
2035
2036 for (i = 0; i < len; i++) {
2037 retval = spi_write_eeprom(chip, addr + i, buf[i]);
2038 if (retval != STATUS_SUCCESS) {
2039 vfree(buf);
2040 set_sense_type(chip, SCSI_LUN(srb),
2041 SENSE_TYPE_MEDIA_WRITE_ERR);
2042 return TRANSPORT_FAILED;
2043 }
2044 }
2045
2046 vfree(buf);
2047
2048 return TRANSPORT_GOOD;
2049 }
2050
read_efuse(struct scsi_cmnd * srb,struct rtsx_chip * chip)2051 static int read_efuse(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2052 {
2053 int retval;
2054 u8 addr, len, i;
2055 u8 *buf;
2056
2057 rtsx_disable_aspm(chip);
2058
2059 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
2060 rtsx_exit_ss(chip);
2061 wait_timeout(100);
2062 }
2063 rtsx_set_stat(chip, RTSX_STAT_RUN);
2064
2065 addr = srb->cmnd[4];
2066 len = srb->cmnd[5];
2067
2068 buf = vmalloc(len);
2069 if (!buf)
2070 return TRANSPORT_ERROR;
2071
2072 retval = rtsx_force_power_on(chip, SSC_PDCTL);
2073 if (retval != STATUS_SUCCESS) {
2074 vfree(buf);
2075 set_sense_type(chip, SCSI_LUN(srb),
2076 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
2077 return TRANSPORT_FAILED;
2078 }
2079
2080 for (i = 0; i < len; i++) {
2081 retval = rtsx_read_efuse(chip, addr + i, buf + i);
2082 if (retval != STATUS_SUCCESS) {
2083 vfree(buf);
2084 set_sense_type(chip, SCSI_LUN(srb),
2085 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
2086 return TRANSPORT_FAILED;
2087 }
2088 }
2089
2090 len = (u8)min_t(unsigned int, scsi_bufflen(srb), len);
2091 rtsx_stor_set_xfer_buf(buf, len, srb);
2092 scsi_set_resid(srb, scsi_bufflen(srb) - len);
2093
2094 vfree(buf);
2095
2096 return TRANSPORT_GOOD;
2097 }
2098
write_efuse(struct scsi_cmnd * srb,struct rtsx_chip * chip)2099 static int write_efuse(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2100 {
2101 int retval, result = TRANSPORT_GOOD;
2102 u16 val;
2103 u8 addr, len, i;
2104 u8 *buf;
2105
2106 rtsx_disable_aspm(chip);
2107
2108 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
2109 rtsx_exit_ss(chip);
2110 wait_timeout(100);
2111 }
2112 rtsx_set_stat(chip, RTSX_STAT_RUN);
2113
2114 addr = srb->cmnd[4];
2115 len = srb->cmnd[5];
2116
2117 len = (u8)min_t(unsigned int, scsi_bufflen(srb), len);
2118 buf = vmalloc(len);
2119 if (!buf)
2120 return TRANSPORT_ERROR;
2121
2122 rtsx_stor_get_xfer_buf(buf, len, srb);
2123 scsi_set_resid(srb, scsi_bufflen(srb) - len);
2124
2125 retval = rtsx_force_power_on(chip, SSC_PDCTL);
2126 if (retval != STATUS_SUCCESS) {
2127 vfree(buf);
2128 return TRANSPORT_ERROR;
2129 }
2130
2131 if (chip->asic_code) {
2132 retval = rtsx_read_phy_register(chip, 0x08, &val);
2133 if (retval != STATUS_SUCCESS) {
2134 vfree(buf);
2135 return TRANSPORT_ERROR;
2136 }
2137
2138 retval = rtsx_write_register(chip, PWR_GATE_CTRL,
2139 LDO3318_PWR_MASK, LDO_OFF);
2140 if (retval != STATUS_SUCCESS) {
2141 vfree(buf);
2142 return TRANSPORT_ERROR;
2143 }
2144
2145 wait_timeout(600);
2146
2147 retval = rtsx_write_phy_register(chip, 0x08,
2148 0x4C00 | chip->phy_voltage);
2149 if (retval != STATUS_SUCCESS) {
2150 vfree(buf);
2151 return TRANSPORT_ERROR;
2152 }
2153
2154 retval = rtsx_write_register(chip, PWR_GATE_CTRL,
2155 LDO3318_PWR_MASK, LDO_ON);
2156 if (retval != STATUS_SUCCESS) {
2157 vfree(buf);
2158 return TRANSPORT_ERROR;
2159 }
2160
2161 wait_timeout(600);
2162 }
2163
2164 retval = card_power_on(chip, SPI_CARD);
2165 if (retval != STATUS_SUCCESS) {
2166 vfree(buf);
2167 return TRANSPORT_ERROR;
2168 }
2169
2170 wait_timeout(50);
2171
2172 for (i = 0; i < len; i++) {
2173 retval = rtsx_write_efuse(chip, addr + i, buf[i]);
2174 if (retval != STATUS_SUCCESS) {
2175 set_sense_type(chip, SCSI_LUN(srb),
2176 SENSE_TYPE_MEDIA_WRITE_ERR);
2177 result = TRANSPORT_FAILED;
2178 goto exit;
2179 }
2180 }
2181
2182 exit:
2183 vfree(buf);
2184
2185 retval = card_power_off(chip, SPI_CARD);
2186 if (retval != STATUS_SUCCESS)
2187 return TRANSPORT_ERROR;
2188
2189 if (chip->asic_code) {
2190 retval = rtsx_write_register(chip, PWR_GATE_CTRL,
2191 LDO3318_PWR_MASK, LDO_OFF);
2192 if (retval != STATUS_SUCCESS)
2193 return TRANSPORT_ERROR;
2194
2195 wait_timeout(600);
2196
2197 retval = rtsx_write_phy_register(chip, 0x08, val);
2198 if (retval != STATUS_SUCCESS)
2199 return TRANSPORT_ERROR;
2200
2201 retval = rtsx_write_register(chip, PWR_GATE_CTRL,
2202 LDO3318_PWR_MASK, LDO_ON);
2203 if (retval != STATUS_SUCCESS)
2204 return TRANSPORT_ERROR;
2205 }
2206
2207 return result;
2208 }
2209
read_cfg_byte(struct scsi_cmnd * srb,struct rtsx_chip * chip)2210 static int read_cfg_byte(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2211 {
2212 int retval;
2213 bool func_max;
2214 u8 func;
2215 u16 addr, len;
2216 u8 *buf;
2217
2218 rtsx_disable_aspm(chip);
2219
2220 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
2221 rtsx_exit_ss(chip);
2222 wait_timeout(100);
2223 }
2224 rtsx_set_stat(chip, RTSX_STAT_RUN);
2225
2226 func = srb->cmnd[3];
2227 addr = ((u16)(srb->cmnd[4]) << 8) | srb->cmnd[5];
2228 len = ((u16)(srb->cmnd[6]) << 8) | srb->cmnd[7];
2229
2230 dev_dbg(rtsx_dev(chip), "%s: func = %d, addr = 0x%x, len = %d\n",
2231 __func__, func, addr, len);
2232
2233 if (CHK_SDIO_EXIST(chip) && !CHK_SDIO_IGNORED(chip))
2234 func_max = true;
2235 else
2236 func_max = false;
2237
2238 if (func > func_max) {
2239 set_sense_type(chip, SCSI_LUN(srb),
2240 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2241 return TRANSPORT_FAILED;
2242 }
2243
2244 buf = vmalloc(len);
2245 if (!buf)
2246 return TRANSPORT_ERROR;
2247
2248 retval = rtsx_read_cfg_seq(chip, func, addr, buf, len);
2249 if (retval != STATUS_SUCCESS) {
2250 set_sense_type(chip, SCSI_LUN(srb),
2251 SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
2252 vfree(buf);
2253 return TRANSPORT_FAILED;
2254 }
2255
2256 len = (u16)min_t(unsigned int, scsi_bufflen(srb), len);
2257 rtsx_stor_set_xfer_buf(buf, len, srb);
2258 scsi_set_resid(srb, scsi_bufflen(srb) - len);
2259
2260 vfree(buf);
2261
2262 return TRANSPORT_GOOD;
2263 }
2264
write_cfg_byte(struct scsi_cmnd * srb,struct rtsx_chip * chip)2265 static int write_cfg_byte(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2266 {
2267 int retval;
2268 bool func_max;
2269 u8 func;
2270 u16 addr, len;
2271 u8 *buf;
2272
2273 rtsx_disable_aspm(chip);
2274
2275 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
2276 rtsx_exit_ss(chip);
2277 wait_timeout(100);
2278 }
2279 rtsx_set_stat(chip, RTSX_STAT_RUN);
2280
2281 func = srb->cmnd[3];
2282 addr = ((u16)(srb->cmnd[4]) << 8) | srb->cmnd[5];
2283 len = ((u16)(srb->cmnd[6]) << 8) | srb->cmnd[7];
2284
2285 dev_dbg(rtsx_dev(chip), "%s: func = %d, addr = 0x%x\n",
2286 __func__, func, addr);
2287
2288 if (CHK_SDIO_EXIST(chip) && !CHK_SDIO_IGNORED(chip))
2289 func_max = true;
2290 else
2291 func_max = false;
2292
2293 if (func > func_max) {
2294 set_sense_type(chip, SCSI_LUN(srb),
2295 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2296 return TRANSPORT_FAILED;
2297 }
2298
2299 len = (unsigned short)min_t(unsigned int, scsi_bufflen(srb), len);
2300 buf = vmalloc(len);
2301 if (!buf)
2302 return TRANSPORT_ERROR;
2303
2304 rtsx_stor_get_xfer_buf(buf, len, srb);
2305 scsi_set_resid(srb, scsi_bufflen(srb) - len);
2306
2307 retval = rtsx_write_cfg_seq(chip, func, addr, buf, len);
2308 if (retval != STATUS_SUCCESS) {
2309 set_sense_type(chip, SCSI_LUN(srb), SENSE_TYPE_MEDIA_WRITE_ERR);
2310 vfree(buf);
2311 return TRANSPORT_FAILED;
2312 }
2313
2314 vfree(buf);
2315
2316 return TRANSPORT_GOOD;
2317 }
2318
app_cmd(struct scsi_cmnd * srb,struct rtsx_chip * chip)2319 static int app_cmd(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2320 {
2321 int result;
2322
2323 switch (srb->cmnd[2]) {
2324 case PP_READ10:
2325 case PP_WRITE10:
2326 result = read_write(srb, chip);
2327 break;
2328
2329 case READ_HOST_REG:
2330 result = read_host_reg(srb, chip);
2331 break;
2332
2333 case WRITE_HOST_REG:
2334 result = write_host_reg(srb, chip);
2335 break;
2336
2337 case GET_VAR:
2338 result = get_variable(srb, chip);
2339 break;
2340
2341 case SET_VAR:
2342 result = set_variable(srb, chip);
2343 break;
2344
2345 case DMA_READ:
2346 case DMA_WRITE:
2347 result = dma_access_ring_buffer(srb, chip);
2348 break;
2349
2350 case READ_PHY:
2351 result = read_phy_register(srb, chip);
2352 break;
2353
2354 case WRITE_PHY:
2355 result = write_phy_register(srb, chip);
2356 break;
2357
2358 case ERASE_EEPROM2:
2359 result = erase_eeprom2(srb, chip);
2360 break;
2361
2362 case READ_EEPROM2:
2363 result = read_eeprom2(srb, chip);
2364 break;
2365
2366 case WRITE_EEPROM2:
2367 result = write_eeprom2(srb, chip);
2368 break;
2369
2370 case READ_EFUSE:
2371 result = read_efuse(srb, chip);
2372 break;
2373
2374 case WRITE_EFUSE:
2375 result = write_efuse(srb, chip);
2376 break;
2377
2378 case READ_CFG:
2379 result = read_cfg_byte(srb, chip);
2380 break;
2381
2382 case WRITE_CFG:
2383 result = write_cfg_byte(srb, chip);
2384 break;
2385
2386 case SET_CHIP_MODE:
2387 result = set_chip_mode(srb, chip);
2388 break;
2389
2390 case SUIT_CMD:
2391 result = suit_cmd(srb, chip);
2392 break;
2393
2394 case GET_DEV_STATUS:
2395 result = get_dev_status(srb, chip);
2396 break;
2397
2398 default:
2399 set_sense_type(chip, SCSI_LUN(srb),
2400 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2401 return TRANSPORT_FAILED;
2402 }
2403
2404 return result;
2405 }
2406
read_status(struct scsi_cmnd * srb,struct rtsx_chip * chip)2407 static int read_status(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2408 {
2409 u8 rtsx_status[16];
2410 int buf_len;
2411 unsigned int lun = SCSI_LUN(srb);
2412
2413 rtsx_status[0] = (u8)(chip->vendor_id >> 8);
2414 rtsx_status[1] = (u8)(chip->vendor_id);
2415
2416 rtsx_status[2] = (u8)(chip->product_id >> 8);
2417 rtsx_status[3] = (u8)(chip->product_id);
2418
2419 rtsx_status[4] = (u8)lun;
2420
2421 if (CHECK_LUN_MODE(chip, SD_MS_2LUN)) {
2422 if (chip->lun2card[lun] == SD_CARD)
2423 rtsx_status[5] = 2;
2424 else
2425 rtsx_status[5] = 3;
2426 } else {
2427 if (chip->card_exist) {
2428 if (chip->card_exist & XD_CARD)
2429 rtsx_status[5] = 4;
2430 else if (chip->card_exist & SD_CARD)
2431 rtsx_status[5] = 2;
2432 else if (chip->card_exist & MS_CARD)
2433 rtsx_status[5] = 3;
2434 else
2435 rtsx_status[5] = 7;
2436 } else {
2437 rtsx_status[5] = 7;
2438 }
2439 }
2440
2441 if (CHECK_LUN_MODE(chip, SD_MS_2LUN))
2442 rtsx_status[6] = 2;
2443 else
2444 rtsx_status[6] = 1;
2445
2446 rtsx_status[7] = (u8)(chip->product_id);
2447 rtsx_status[8] = chip->ic_version;
2448
2449 if (check_card_exist(chip, lun))
2450 rtsx_status[9] = 1;
2451 else
2452 rtsx_status[9] = 0;
2453
2454 if (CHECK_LUN_MODE(chip, SD_MS_2LUN))
2455 rtsx_status[10] = 0;
2456 else
2457 rtsx_status[10] = 1;
2458
2459 if (CHECK_LUN_MODE(chip, SD_MS_2LUN)) {
2460 if (chip->lun2card[lun] == SD_CARD)
2461 rtsx_status[11] = SD_CARD;
2462 else
2463 rtsx_status[11] = MS_CARD;
2464 } else {
2465 rtsx_status[11] = XD_CARD | SD_CARD | MS_CARD;
2466 }
2467
2468 if (check_card_ready(chip, lun))
2469 rtsx_status[12] = 1;
2470 else
2471 rtsx_status[12] = 0;
2472
2473 if (get_lun_card(chip, lun) == XD_CARD) {
2474 rtsx_status[13] = 0x40;
2475 } else if (get_lun_card(chip, lun) == SD_CARD) {
2476 struct sd_info *sd_card = &chip->sd_card;
2477
2478 rtsx_status[13] = 0x20;
2479 if (CHK_SD(sd_card)) {
2480 if (CHK_SD_HCXC(sd_card))
2481 rtsx_status[13] |= 0x04;
2482 if (CHK_SD_HS(sd_card))
2483 rtsx_status[13] |= 0x02;
2484 } else {
2485 rtsx_status[13] |= 0x08;
2486 if (CHK_MMC_52M(sd_card))
2487 rtsx_status[13] |= 0x02;
2488 if (CHK_MMC_SECTOR_MODE(sd_card))
2489 rtsx_status[13] |= 0x04;
2490 }
2491 } else if (get_lun_card(chip, lun) == MS_CARD) {
2492 struct ms_info *ms_card = &chip->ms_card;
2493
2494 if (CHK_MSPRO(ms_card)) {
2495 rtsx_status[13] = 0x38;
2496 if (CHK_HG8BIT(ms_card))
2497 rtsx_status[13] |= 0x04;
2498 #ifdef SUPPORT_MSXC
2499 if (CHK_MSXC(ms_card))
2500 rtsx_status[13] |= 0x01;
2501 #endif
2502 } else {
2503 rtsx_status[13] = 0x30;
2504 }
2505 } else {
2506 if (CHECK_LUN_MODE(chip, DEFAULT_SINGLE)) {
2507 #ifdef SUPPORT_SDIO
2508 if (chip->sd_io && chip->sd_int)
2509 rtsx_status[13] = 0x60;
2510 else
2511 rtsx_status[13] = 0x70;
2512 #else
2513 rtsx_status[13] = 0x70;
2514 #endif
2515 } else {
2516 if (chip->lun2card[lun] == SD_CARD)
2517 rtsx_status[13] = 0x20;
2518 else
2519 rtsx_status[13] = 0x30;
2520 }
2521 }
2522
2523 rtsx_status[14] = 0x78;
2524 if (CHK_SDIO_EXIST(chip) && !CHK_SDIO_IGNORED(chip))
2525 rtsx_status[15] = 0x83;
2526 else
2527 rtsx_status[15] = 0x82;
2528
2529 buf_len = min_t(unsigned int, scsi_bufflen(srb), sizeof(rtsx_status));
2530 rtsx_stor_set_xfer_buf(rtsx_status, buf_len, srb);
2531 scsi_set_resid(srb, scsi_bufflen(srb) - buf_len);
2532
2533 return TRANSPORT_GOOD;
2534 }
2535
get_card_bus_width(struct scsi_cmnd * srb,struct rtsx_chip * chip)2536 static int get_card_bus_width(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2537 {
2538 unsigned int lun = SCSI_LUN(srb);
2539 u8 card, bus_width;
2540
2541 if (!check_card_ready(chip, lun)) {
2542 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
2543 return TRANSPORT_FAILED;
2544 }
2545
2546 card = get_lun_card(chip, lun);
2547 if (card == SD_CARD || card == MS_CARD) {
2548 bus_width = chip->card_bus_width[lun];
2549 } else {
2550 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_UNRECOVER_READ_ERR);
2551 return TRANSPORT_FAILED;
2552 }
2553
2554 scsi_set_resid(srb, 0);
2555 rtsx_stor_set_xfer_buf(&bus_width, scsi_bufflen(srb), srb);
2556
2557 return TRANSPORT_GOOD;
2558 }
2559
spi_vendor_cmd(struct scsi_cmnd * srb,struct rtsx_chip * chip)2560 static int spi_vendor_cmd(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2561 {
2562 int result;
2563 unsigned int lun = SCSI_LUN(srb);
2564 u8 gpio_dir;
2565
2566 if (CHECK_PID(chip, 0x5208) || CHECK_PID(chip, 0x5288)) {
2567 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2568 return TRANSPORT_FAILED;
2569 }
2570
2571 rtsx_disable_aspm(chip);
2572
2573 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
2574 rtsx_exit_ss(chip);
2575 wait_timeout(100);
2576 }
2577 rtsx_set_stat(chip, RTSX_STAT_RUN);
2578
2579 rtsx_force_power_on(chip, SSC_PDCTL);
2580
2581 rtsx_read_register(chip, CARD_GPIO_DIR, &gpio_dir);
2582 rtsx_write_register(chip, CARD_GPIO_DIR, 0x07, gpio_dir & 0x06);
2583
2584 switch (srb->cmnd[2]) {
2585 case SCSI_SPI_GETSTATUS:
2586 result = spi_get_status(srb, chip);
2587 break;
2588
2589 case SCSI_SPI_SETPARAMETER:
2590 result = spi_set_parameter(srb, chip);
2591 break;
2592
2593 case SCSI_SPI_READFALSHID:
2594 result = spi_read_flash_id(srb, chip);
2595 break;
2596
2597 case SCSI_SPI_READFLASH:
2598 result = spi_read_flash(srb, chip);
2599 break;
2600
2601 case SCSI_SPI_WRITEFLASH:
2602 result = spi_write_flash(srb, chip);
2603 break;
2604
2605 case SCSI_SPI_WRITEFLASHSTATUS:
2606 result = spi_write_flash_status(srb, chip);
2607 break;
2608
2609 case SCSI_SPI_ERASEFLASH:
2610 result = spi_erase_flash(srb, chip);
2611 break;
2612
2613 default:
2614 rtsx_write_register(chip, CARD_GPIO_DIR, 0x07, gpio_dir);
2615
2616 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2617 return TRANSPORT_FAILED;
2618 }
2619
2620 rtsx_write_register(chip, CARD_GPIO_DIR, 0x07, gpio_dir);
2621
2622 if (result != STATUS_SUCCESS)
2623 return TRANSPORT_FAILED;
2624
2625 return TRANSPORT_GOOD;
2626 }
2627
vendor_cmnd(struct scsi_cmnd * srb,struct rtsx_chip * chip)2628 static int vendor_cmnd(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2629 {
2630 int result;
2631
2632 switch (srb->cmnd[1]) {
2633 case READ_STATUS:
2634 result = read_status(srb, chip);
2635 break;
2636
2637 case READ_MEM:
2638 result = read_mem(srb, chip);
2639 break;
2640
2641 case WRITE_MEM:
2642 result = write_mem(srb, chip);
2643 break;
2644
2645 case READ_EEPROM:
2646 result = read_eeprom(srb, chip);
2647 break;
2648
2649 case WRITE_EEPROM:
2650 result = write_eeprom(srb, chip);
2651 break;
2652
2653 case TOGGLE_GPIO:
2654 result = toggle_gpio_cmd(srb, chip);
2655 break;
2656
2657 case GET_SD_CSD:
2658 result = get_sd_csd(srb, chip);
2659 break;
2660
2661 case GET_BUS_WIDTH:
2662 result = get_card_bus_width(srb, chip);
2663 break;
2664
2665 case SCSI_APP_CMD:
2666 result = app_cmd(srb, chip);
2667 break;
2668
2669 case SPI_VENDOR_COMMAND:
2670 result = spi_vendor_cmd(srb, chip);
2671 break;
2672
2673 default:
2674 set_sense_type(chip, SCSI_LUN(srb),
2675 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2676 return TRANSPORT_FAILED;
2677 }
2678
2679 return result;
2680 }
2681
2682 #if !defined(LED_AUTO_BLINK) && !defined(REGULAR_BLINK)
led_shine(struct scsi_cmnd * srb,struct rtsx_chip * chip)2683 void led_shine(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2684 {
2685 unsigned int lun = SCSI_LUN(srb);
2686 u16 sec_cnt;
2687
2688 if (srb->cmnd[0] == READ_10 || srb->cmnd[0] == WRITE_10) {
2689 sec_cnt = ((u16)(srb->cmnd[7]) << 8) | srb->cmnd[8];
2690 } else if ((srb->cmnd[0] == READ_6) || (srb->cmnd[0] == WRITE_6)) {
2691 sec_cnt = srb->cmnd[4];
2692 if (sec_cnt == 0)
2693 sec_cnt = 256;
2694 } else {
2695 return;
2696 }
2697
2698 if (chip->rw_cap[lun] >= GPIO_TOGGLE_THRESHOLD) {
2699 toggle_gpio(chip, LED_GPIO);
2700 chip->rw_cap[lun] = 0;
2701 } else {
2702 chip->rw_cap[lun] += sec_cnt;
2703 }
2704 }
2705 #endif
2706
ms_format_cmnd(struct scsi_cmnd * srb,struct rtsx_chip * chip)2707 static int ms_format_cmnd(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2708 {
2709 struct ms_info *ms_card = &chip->ms_card;
2710 unsigned int lun = SCSI_LUN(srb);
2711 bool quick_format;
2712 int retval;
2713
2714 if (get_lun_card(chip, lun) != MS_CARD) {
2715 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_LUN_NOT_SUPPORT);
2716 return TRANSPORT_FAILED;
2717 }
2718
2719 if (srb->cmnd[3] != 0x4D || srb->cmnd[4] != 0x47 ||
2720 srb->cmnd[5] != 0x66 || srb->cmnd[6] != 0x6D ||
2721 srb->cmnd[7] != 0x74) {
2722 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2723 return TRANSPORT_FAILED;
2724 }
2725
2726 rtsx_disable_aspm(chip);
2727
2728 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
2729 rtsx_exit_ss(chip);
2730 wait_timeout(100);
2731
2732 if (!check_card_ready(chip, lun) ||
2733 (get_card_size(chip, lun) == 0)) {
2734 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
2735 return TRANSPORT_FAILED;
2736 }
2737 }
2738 rtsx_set_stat(chip, RTSX_STAT_RUN);
2739
2740 if (srb->cmnd[8] & 0x01)
2741 quick_format = false;
2742 else
2743 quick_format = true;
2744
2745 if (!(chip->card_ready & MS_CARD)) {
2746 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
2747 return TRANSPORT_FAILED;
2748 }
2749
2750 if (chip->card_wp & MS_CARD) {
2751 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_WRITE_PROTECT);
2752 return TRANSPORT_FAILED;
2753 }
2754
2755 if (!CHK_MSPRO(ms_card)) {
2756 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_LUN_NOT_SUPPORT);
2757 return TRANSPORT_FAILED;
2758 }
2759
2760 retval = mspro_format(srb, chip, MS_SHORT_DATA_LEN, quick_format);
2761 if (retval != STATUS_SUCCESS) {
2762 set_sense_type(chip, lun, SENSE_TYPE_FORMAT_CMD_FAILED);
2763 return TRANSPORT_FAILED;
2764 }
2765
2766 scsi_set_resid(srb, 0);
2767 return TRANSPORT_GOOD;
2768 }
2769
2770 #ifdef SUPPORT_PCGL_1P18
get_ms_information(struct scsi_cmnd * srb,struct rtsx_chip * chip)2771 static int get_ms_information(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2772 {
2773 struct ms_info *ms_card = &chip->ms_card;
2774 unsigned int lun = SCSI_LUN(srb);
2775 u8 dev_info_id, data_len;
2776 u8 *buf;
2777 unsigned int buf_len;
2778 int i;
2779
2780 if (!check_card_ready(chip, lun)) {
2781 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
2782 return TRANSPORT_FAILED;
2783 }
2784 if (get_lun_card(chip, lun) != MS_CARD) {
2785 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_LUN_NOT_SUPPORT);
2786 return TRANSPORT_FAILED;
2787 }
2788
2789 if (srb->cmnd[2] != 0xB0 || srb->cmnd[4] != 0x4D ||
2790 srb->cmnd[5] != 0x53 || srb->cmnd[6] != 0x49 ||
2791 srb->cmnd[7] != 0x44) {
2792 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2793 return TRANSPORT_FAILED;
2794 }
2795
2796 dev_info_id = srb->cmnd[3];
2797 if ((CHK_MSXC(ms_card) && dev_info_id == 0x10) ||
2798 (!CHK_MSXC(ms_card) && dev_info_id == 0x13) ||
2799 !CHK_MSPRO(ms_card)) {
2800 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2801 return TRANSPORT_FAILED;
2802 }
2803
2804 if (dev_info_id == 0x15) {
2805 buf_len = 0x3C;
2806 data_len = 0x3A;
2807 } else {
2808 buf_len = 0x6C;
2809 data_len = 0x6A;
2810 }
2811
2812 buf = kmalloc(buf_len, GFP_KERNEL);
2813 if (!buf)
2814 return TRANSPORT_ERROR;
2815
2816 i = 0;
2817 /* GET Memory Stick Media Information Response Header */
2818 buf[i++] = 0x00; /* Data length MSB */
2819 buf[i++] = data_len; /* Data length LSB */
2820 /* Device Information Type Code */
2821 if (CHK_MSXC(ms_card))
2822 buf[i++] = 0x03;
2823 else
2824 buf[i++] = 0x02;
2825
2826 /* SGM bit */
2827 buf[i++] = 0x01;
2828 /* Reserved */
2829 buf[i++] = 0x00;
2830 buf[i++] = 0x00;
2831 buf[i++] = 0x00;
2832 /* Number of Device Information */
2833 buf[i++] = 0x01;
2834
2835 /* Device Information Body */
2836
2837 /* Device Information ID Number */
2838 buf[i++] = dev_info_id;
2839 /* Device Information Length */
2840 if (dev_info_id == 0x15)
2841 data_len = 0x31;
2842 else
2843 data_len = 0x61;
2844
2845 buf[i++] = 0x00; /* Data length MSB */
2846 buf[i++] = data_len; /* Data length LSB */
2847 /* Valid Bit */
2848 buf[i++] = 0x80;
2849 if (dev_info_id == 0x10 || dev_info_id == 0x13) {
2850 /* System Information */
2851 memcpy(buf + i, ms_card->raw_sys_info, 96);
2852 } else {
2853 /* Model Name */
2854 memcpy(buf + i, ms_card->raw_model_name, 48);
2855 }
2856
2857 rtsx_stor_set_xfer_buf(buf, buf_len, srb);
2858 scsi_set_resid(srb, scsi_bufflen(srb) - buf_len);
2859
2860 kfree(buf);
2861 return STATUS_SUCCESS;
2862 }
2863 #endif
2864
ms_sp_cmnd(struct scsi_cmnd * srb,struct rtsx_chip * chip)2865 static int ms_sp_cmnd(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2866 {
2867 int retval = TRANSPORT_ERROR;
2868
2869 if (srb->cmnd[2] == MS_FORMAT)
2870 retval = ms_format_cmnd(srb, chip);
2871 #ifdef SUPPORT_PCGL_1P18
2872 else if (srb->cmnd[2] == GET_MS_INFORMATION)
2873 retval = get_ms_information(srb, chip);
2874 #endif
2875
2876 return retval;
2877 }
2878
2879 #ifdef SUPPORT_CPRM
sd_extension_cmnd(struct scsi_cmnd * srb,struct rtsx_chip * chip)2880 static int sd_extension_cmnd(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2881 {
2882 unsigned int lun = SCSI_LUN(srb);
2883 int result;
2884
2885 rtsx_disable_aspm(chip);
2886
2887 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
2888 rtsx_exit_ss(chip);
2889 wait_timeout(100);
2890 }
2891 rtsx_set_stat(chip, RTSX_STAT_RUN);
2892
2893 sd_cleanup_work(chip);
2894
2895 if (!check_card_ready(chip, lun)) {
2896 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
2897 return TRANSPORT_FAILED;
2898 }
2899 if (get_lun_card(chip, lun) != SD_CARD) {
2900 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_LUN_NOT_SUPPORT);
2901 return TRANSPORT_FAILED;
2902 }
2903
2904 switch (srb->cmnd[0]) {
2905 case SD_PASS_THRU_MODE:
2906 result = sd_pass_thru_mode(srb, chip);
2907 break;
2908
2909 case SD_EXECUTE_NO_DATA:
2910 result = sd_execute_no_data(srb, chip);
2911 break;
2912
2913 case SD_EXECUTE_READ:
2914 result = sd_execute_read_data(srb, chip);
2915 break;
2916
2917 case SD_EXECUTE_WRITE:
2918 result = sd_execute_write_data(srb, chip);
2919 break;
2920
2921 case SD_GET_RSP:
2922 result = sd_get_cmd_rsp(srb, chip);
2923 break;
2924
2925 case SD_HW_RST:
2926 result = sd_hw_rst(srb, chip);
2927 break;
2928
2929 default:
2930 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2931 return TRANSPORT_FAILED;
2932 }
2933
2934 return result;
2935 }
2936 #endif
2937
2938 #ifdef SUPPORT_MAGIC_GATE
mg_report_key(struct scsi_cmnd * srb,struct rtsx_chip * chip)2939 static int mg_report_key(struct scsi_cmnd *srb, struct rtsx_chip *chip)
2940 {
2941 struct ms_info *ms_card = &chip->ms_card;
2942 unsigned int lun = SCSI_LUN(srb);
2943 int retval;
2944 u8 key_format;
2945
2946 rtsx_disable_aspm(chip);
2947
2948 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
2949 rtsx_exit_ss(chip);
2950 wait_timeout(100);
2951 }
2952 rtsx_set_stat(chip, RTSX_STAT_RUN);
2953
2954 ms_cleanup_work(chip);
2955
2956 if (!check_card_ready(chip, lun)) {
2957 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
2958 return TRANSPORT_FAILED;
2959 }
2960 if (get_lun_card(chip, lun) != MS_CARD) {
2961 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_LUN_NOT_SUPPORT);
2962 return TRANSPORT_FAILED;
2963 }
2964
2965 if (srb->cmnd[7] != KC_MG_R_PRO) {
2966 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2967 return TRANSPORT_FAILED;
2968 }
2969
2970 if (!CHK_MSPRO(ms_card)) {
2971 set_sense_type(chip, lun, SENSE_TYPE_MG_INCOMPATIBLE_MEDIUM);
2972 return TRANSPORT_FAILED;
2973 }
2974
2975 key_format = srb->cmnd[10] & 0x3F;
2976 dev_dbg(rtsx_dev(chip), "key_format = 0x%x\n", key_format);
2977
2978 switch (key_format) {
2979 case KF_GET_LOC_EKB:
2980 if ((scsi_bufflen(srb) == 0x41C) &&
2981 srb->cmnd[8] == 0x04 &&
2982 srb->cmnd[9] == 0x1C) {
2983 retval = mg_get_local_EKB(srb, chip);
2984 if (retval != STATUS_SUCCESS)
2985 return TRANSPORT_FAILED;
2986
2987 } else {
2988 set_sense_type(chip, lun,
2989 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
2990 return TRANSPORT_FAILED;
2991 }
2992 break;
2993
2994 case KF_RSP_CHG:
2995 if ((scsi_bufflen(srb) == 0x24) &&
2996 srb->cmnd[8] == 0x00 &&
2997 srb->cmnd[9] == 0x24) {
2998 retval = mg_get_rsp_chg(srb, chip);
2999 if (retval != STATUS_SUCCESS)
3000 return TRANSPORT_FAILED;
3001
3002 } else {
3003 set_sense_type(chip, lun,
3004 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3005 return TRANSPORT_FAILED;
3006 }
3007 break;
3008
3009 case KF_GET_ICV:
3010 ms_card->mg_entry_num = srb->cmnd[5];
3011 if ((scsi_bufflen(srb) == 0x404) &&
3012 srb->cmnd[8] == 0x04 &&
3013 srb->cmnd[9] == 0x04 &&
3014 srb->cmnd[2] == 0x00 &&
3015 srb->cmnd[3] == 0x00 &&
3016 srb->cmnd[4] == 0x00 &&
3017 srb->cmnd[5] < 32) {
3018 retval = mg_get_ICV(srb, chip);
3019 if (retval != STATUS_SUCCESS)
3020 return TRANSPORT_FAILED;
3021
3022 } else {
3023 set_sense_type(chip, lun,
3024 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3025 return TRANSPORT_FAILED;
3026 }
3027 break;
3028
3029 default:
3030 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3031 return TRANSPORT_FAILED;
3032 }
3033
3034 scsi_set_resid(srb, 0);
3035 return TRANSPORT_GOOD;
3036 }
3037
mg_send_key(struct scsi_cmnd * srb,struct rtsx_chip * chip)3038 static int mg_send_key(struct scsi_cmnd *srb, struct rtsx_chip *chip)
3039 {
3040 struct ms_info *ms_card = &chip->ms_card;
3041 unsigned int lun = SCSI_LUN(srb);
3042 int retval;
3043 u8 key_format;
3044
3045 rtsx_disable_aspm(chip);
3046
3047 if (chip->ss_en && (rtsx_get_stat(chip) == RTSX_STAT_SS)) {
3048 rtsx_exit_ss(chip);
3049 wait_timeout(100);
3050 }
3051 rtsx_set_stat(chip, RTSX_STAT_RUN);
3052
3053 ms_cleanup_work(chip);
3054
3055 if (!check_card_ready(chip, lun)) {
3056 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_NOT_PRESENT);
3057 return TRANSPORT_FAILED;
3058 }
3059 if (check_card_wp(chip, lun)) {
3060 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_WRITE_PROTECT);
3061 return TRANSPORT_FAILED;
3062 }
3063 if (get_lun_card(chip, lun) != MS_CARD) {
3064 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_LUN_NOT_SUPPORT);
3065 return TRANSPORT_FAILED;
3066 }
3067
3068 if (srb->cmnd[7] != KC_MG_R_PRO) {
3069 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3070 return TRANSPORT_FAILED;
3071 }
3072
3073 if (!CHK_MSPRO(ms_card)) {
3074 set_sense_type(chip, lun, SENSE_TYPE_MG_INCOMPATIBLE_MEDIUM);
3075 return TRANSPORT_FAILED;
3076 }
3077
3078 key_format = srb->cmnd[10] & 0x3F;
3079 dev_dbg(rtsx_dev(chip), "key_format = 0x%x\n", key_format);
3080
3081 switch (key_format) {
3082 case KF_SET_LEAF_ID:
3083 if ((scsi_bufflen(srb) == 0x0C) &&
3084 srb->cmnd[8] == 0x00 &&
3085 srb->cmnd[9] == 0x0C) {
3086 retval = mg_set_leaf_id(srb, chip);
3087 if (retval != STATUS_SUCCESS)
3088 return TRANSPORT_FAILED;
3089
3090 } else {
3091 set_sense_type(chip, lun,
3092 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3093 return TRANSPORT_FAILED;
3094 }
3095 break;
3096
3097 case KF_CHG_HOST:
3098 if ((scsi_bufflen(srb) == 0x0C) &&
3099 srb->cmnd[8] == 0x00 &&
3100 srb->cmnd[9] == 0x0C) {
3101 retval = mg_chg(srb, chip);
3102 if (retval != STATUS_SUCCESS)
3103 return TRANSPORT_FAILED;
3104
3105 } else {
3106 set_sense_type(chip, lun,
3107 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3108 return TRANSPORT_FAILED;
3109 }
3110 break;
3111
3112 case KF_RSP_HOST:
3113 if ((scsi_bufflen(srb) == 0x0C) &&
3114 srb->cmnd[8] == 0x00 &&
3115 srb->cmnd[9] == 0x0C) {
3116 retval = mg_rsp(srb, chip);
3117 if (retval != STATUS_SUCCESS)
3118 return TRANSPORT_FAILED;
3119
3120 } else {
3121 set_sense_type(chip, lun,
3122 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3123 return TRANSPORT_FAILED;
3124 }
3125 break;
3126
3127 case KF_SET_ICV:
3128 ms_card->mg_entry_num = srb->cmnd[5];
3129 if ((scsi_bufflen(srb) == 0x404) &&
3130 srb->cmnd[8] == 0x04 &&
3131 srb->cmnd[9] == 0x04 &&
3132 srb->cmnd[2] == 0x00 &&
3133 srb->cmnd[3] == 0x00 &&
3134 srb->cmnd[4] == 0x00 &&
3135 srb->cmnd[5] < 32) {
3136 retval = mg_set_ICV(srb, chip);
3137 if (retval != STATUS_SUCCESS)
3138 return TRANSPORT_FAILED;
3139
3140 } else {
3141 set_sense_type(chip, lun,
3142 SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3143 return TRANSPORT_FAILED;
3144 }
3145 break;
3146
3147 default:
3148 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3149 return TRANSPORT_FAILED;
3150 }
3151
3152 scsi_set_resid(srb, 0);
3153 return TRANSPORT_GOOD;
3154 }
3155 #endif
3156
rtsx_scsi_handler(struct scsi_cmnd * srb,struct rtsx_chip * chip)3157 int rtsx_scsi_handler(struct scsi_cmnd *srb, struct rtsx_chip *chip)
3158 {
3159 #ifdef SUPPORT_SD_LOCK
3160 struct sd_info *sd_card = &chip->sd_card;
3161 #endif
3162 struct ms_info *ms_card = &chip->ms_card;
3163 unsigned int lun = SCSI_LUN(srb);
3164 int result;
3165
3166 #ifdef SUPPORT_SD_LOCK
3167 if (sd_card->sd_erase_status) {
3168 /* Block all SCSI command except for
3169 * REQUEST_SENSE and rs_ppstatus
3170 */
3171 if (!(srb->cmnd[0] == VENDOR_CMND &&
3172 srb->cmnd[1] == SCSI_APP_CMD &&
3173 srb->cmnd[2] == GET_DEV_STATUS) &&
3174 srb->cmnd[0] != REQUEST_SENSE) {
3175 /* Logical Unit Not Ready Format in Progress */
3176 set_sense_data(chip, lun, CUR_ERR,
3177 0x02, 0, 0x04, 0x04, 0, 0);
3178 return TRANSPORT_FAILED;
3179 }
3180 }
3181 #endif
3182
3183 if ((get_lun_card(chip, lun) == MS_CARD) &&
3184 ms_card->format_status == FORMAT_IN_PROGRESS) {
3185 if (srb->cmnd[0] != REQUEST_SENSE &&
3186 srb->cmnd[0] != INQUIRY) {
3187 /* Logical Unit Not Ready Format in Progress */
3188 set_sense_data(chip, lun, CUR_ERR, 0x02, 0, 0x04, 0x04,
3189 0, (u16)(ms_card->progress));
3190 return TRANSPORT_FAILED;
3191 }
3192 }
3193
3194 switch (srb->cmnd[0]) {
3195 case READ_10:
3196 case WRITE_10:
3197 case READ_6:
3198 case WRITE_6:
3199 result = read_write(srb, chip);
3200 #if !defined(LED_AUTO_BLINK) && !defined(REGULAR_BLINK)
3201 led_shine(srb, chip);
3202 #endif
3203 break;
3204
3205 case TEST_UNIT_READY:
3206 result = test_unit_ready(srb, chip);
3207 break;
3208
3209 case INQUIRY:
3210 result = inquiry(srb, chip);
3211 break;
3212
3213 case READ_CAPACITY:
3214 result = read_capacity(srb, chip);
3215 break;
3216
3217 case START_STOP:
3218 result = start_stop_unit(srb, chip);
3219 break;
3220
3221 case ALLOW_MEDIUM_REMOVAL:
3222 result = allow_medium_removal(srb, chip);
3223 break;
3224
3225 case REQUEST_SENSE:
3226 result = request_sense(srb, chip);
3227 break;
3228
3229 case MODE_SENSE:
3230 case MODE_SENSE_10:
3231 result = mode_sense(srb, chip);
3232 break;
3233
3234 case 0x23:
3235 result = read_format_capacity(srb, chip);
3236 break;
3237
3238 case VENDOR_CMND:
3239 result = vendor_cmnd(srb, chip);
3240 break;
3241
3242 case MS_SP_CMND:
3243 result = ms_sp_cmnd(srb, chip);
3244 break;
3245
3246 #ifdef SUPPORT_CPRM
3247 case SD_PASS_THRU_MODE:
3248 case SD_EXECUTE_NO_DATA:
3249 case SD_EXECUTE_READ:
3250 case SD_EXECUTE_WRITE:
3251 case SD_GET_RSP:
3252 case SD_HW_RST:
3253 result = sd_extension_cmnd(srb, chip);
3254 break;
3255 #endif
3256
3257 #ifdef SUPPORT_MAGIC_GATE
3258 case CMD_MSPRO_MG_RKEY:
3259 result = mg_report_key(srb, chip);
3260 break;
3261
3262 case CMD_MSPRO_MG_SKEY:
3263 result = mg_send_key(srb, chip);
3264 break;
3265 #endif
3266
3267 case FORMAT_UNIT:
3268 case MODE_SELECT:
3269 case VERIFY:
3270 result = TRANSPORT_GOOD;
3271 break;
3272
3273 default:
3274 set_sense_type(chip, lun, SENSE_TYPE_MEDIA_INVALID_CMD_FIELD);
3275 result = TRANSPORT_FAILED;
3276 }
3277
3278 return result;
3279 }
3280