1 // SPDX-License-Identifier: GPL-2.0+
2 #include <linux/jiffies.h>
3 #include <linux/errno.h>
4 #include <linux/module.h>
5 #include <linux/slab.h>
8 #include <scsi/scsi_cmnd.h>
10 #include <linux/firmware.h>
13 #include "transport.h"
18 #define SD_INIT1_FIRMWARE "ene-ub6250/sd_init1.bin"
19 #define SD_INIT2_FIRMWARE "ene-ub6250/sd_init2.bin"
20 #define SD_RW_FIRMWARE "ene-ub6250/sd_rdwr.bin"
21 #define MS_INIT_FIRMWARE "ene-ub6250/ms_init.bin"
22 #define MSP_RW_FIRMWARE "ene-ub6250/msp_rdwr.bin"
23 #define MS_RW_FIRMWARE "ene-ub6250/ms_rdwr.bin"
25 #define DRV_NAME "ums_eneub6250"
27 MODULE_DESCRIPTION("Driver for ENE UB6250 reader");
28 MODULE_LICENSE("GPL");
29 MODULE_IMPORT_NS(USB_STORAGE
);
30 MODULE_FIRMWARE(SD_INIT1_FIRMWARE
);
31 MODULE_FIRMWARE(SD_INIT2_FIRMWARE
);
32 MODULE_FIRMWARE(SD_RW_FIRMWARE
);
33 MODULE_FIRMWARE(MS_INIT_FIRMWARE
);
34 MODULE_FIRMWARE(MSP_RW_FIRMWARE
);
35 MODULE_FIRMWARE(MS_RW_FIRMWARE
);
38 * The table of devices
40 #define UNUSUAL_DEV(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax, \
41 vendorName, productName, useProtocol, useTransport, \
42 initFunction, flags) \
43 { USB_DEVICE_VER(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax), \
44 .driver_info = (flags)}
46 static struct usb_device_id ene_ub6250_usb_ids
[] = {
47 # include "unusual_ene_ub6250.h"
48 { } /* Terminating entry */
50 MODULE_DEVICE_TABLE(usb
, ene_ub6250_usb_ids
);
57 #define UNUSUAL_DEV(idVendor, idProduct, bcdDeviceMin, bcdDeviceMax, \
58 vendor_name, product_name, use_protocol, use_transport, \
59 init_function, Flags) \
61 .vendorName = vendor_name, \
62 .productName = product_name, \
63 .useProtocol = use_protocol, \
64 .useTransport = use_transport, \
65 .initFunction = init_function, \
68 static struct us_unusual_dev ene_ub6250_unusual_dev_list
[] = {
69 # include "unusual_ene_ub6250.h"
70 { } /* Terminating entry */
77 /* ENE bin code len */
78 #define ENE_BIN_CODE_LEN 0x800
80 #define REG_CARD_STATUS 0xFF83
81 #define REG_HW_TRAP1 0xFF89
84 #define SS_SUCCESS 0x000000 /* No Sense */
85 #define SS_NOT_READY 0x023A00 /* Medium not present */
86 #define SS_MEDIUM_ERR 0x031100 /* Unrecovered read error */
87 #define SS_HW_ERR 0x040800 /* Communication failure */
88 #define SS_ILLEGAL_REQUEST 0x052000 /* Invalid command */
89 #define SS_UNIT_ATTENTION 0x062900 /* Reset occurred */
91 /* ENE Load FW Pattern */
92 #define SD_INIT1_PATTERN 1
93 #define SD_INIT2_PATTERN 2
94 #define SD_RW_PATTERN 3
95 #define MS_INIT_PATTERN 4
96 #define MSP_RW_PATTERN 5
97 #define MS_RW_PATTERN 6
98 #define SM_INIT_PATTERN 7
99 #define SM_RW_PATTERN 8
106 /* Status Register 1 */
107 #define MS_REG_ST1_MB 0x80 /* media busy */
108 #define MS_REG_ST1_FB1 0x40 /* flush busy 1 */
109 #define MS_REG_ST1_DTER 0x20 /* error on data(corrected) */
110 #define MS_REG_ST1_UCDT 0x10 /* unable to correct data */
111 #define MS_REG_ST1_EXER 0x08 /* error on extra(corrected) */
112 #define MS_REG_ST1_UCEX 0x04 /* unable to correct extra */
113 #define MS_REG_ST1_FGER 0x02 /* error on overwrite flag(corrected) */
114 #define MS_REG_ST1_UCFG 0x01 /* unable to correct overwrite flag */
115 #define MS_REG_ST1_DEFAULT (MS_REG_ST1_MB | MS_REG_ST1_FB1 | MS_REG_ST1_DTER | MS_REG_ST1_UCDT | MS_REG_ST1_EXER | MS_REG_ST1_UCEX | MS_REG_ST1_FGER | MS_REG_ST1_UCFG)
118 #define MS_REG_OVR_BKST 0x80 /* block status */
119 #define MS_REG_OVR_BKST_OK MS_REG_OVR_BKST /* OK */
120 #define MS_REG_OVR_BKST_NG 0x00 /* NG */
121 #define MS_REG_OVR_PGST0 0x40 /* page status */
122 #define MS_REG_OVR_PGST1 0x20
123 #define MS_REG_OVR_PGST_MASK (MS_REG_OVR_PGST0 | MS_REG_OVR_PGST1)
124 #define MS_REG_OVR_PGST_OK (MS_REG_OVR_PGST0 | MS_REG_OVR_PGST1) /* OK */
125 #define MS_REG_OVR_PGST_NG MS_REG_OVR_PGST1 /* NG */
126 #define MS_REG_OVR_PGST_DATA_ERROR 0x00 /* data error */
127 #define MS_REG_OVR_UDST 0x10 /* update status */
128 #define MS_REG_OVR_UDST_UPDATING 0x00 /* updating */
129 #define MS_REG_OVR_UDST_NO_UPDATE MS_REG_OVR_UDST
130 #define MS_REG_OVR_RESERVED 0x08
131 #define MS_REG_OVR_DEFAULT (MS_REG_OVR_BKST_OK | MS_REG_OVR_PGST_OK | MS_REG_OVR_UDST_NO_UPDATE | MS_REG_OVR_RESERVED)
133 /* Management Flag */
134 #define MS_REG_MNG_SCMS0 0x20 /* serial copy management system */
135 #define MS_REG_MNG_SCMS1 0x10
136 #define MS_REG_MNG_SCMS_MASK (MS_REG_MNG_SCMS0 | MS_REG_MNG_SCMS1)
137 #define MS_REG_MNG_SCMS_COPY_OK (MS_REG_MNG_SCMS0 | MS_REG_MNG_SCMS1)
138 #define MS_REG_MNG_SCMS_ONE_COPY MS_REG_MNG_SCMS1
139 #define MS_REG_MNG_SCMS_NO_COPY 0x00
140 #define MS_REG_MNG_ATFLG 0x08 /* address transfer table flag */
141 #define MS_REG_MNG_ATFLG_OTHER MS_REG_MNG_ATFLG /* other */
142 #define MS_REG_MNG_ATFLG_ATTBL 0x00 /* address transfer table */
143 #define MS_REG_MNG_SYSFLG 0x04 /* system flag */
144 #define MS_REG_MNG_SYSFLG_USER MS_REG_MNG_SYSFLG /* user block */
145 #define MS_REG_MNG_SYSFLG_BOOT 0x00 /* system block */
146 #define MS_REG_MNG_RESERVED 0xc3
147 #define MS_REG_MNG_DEFAULT (MS_REG_MNG_SCMS_COPY_OK | MS_REG_MNG_ATFLG_OTHER | MS_REG_MNG_SYSFLG_USER | MS_REG_MNG_RESERVED)
150 #define MS_MAX_PAGES_PER_BLOCK 32
151 #define MS_MAX_INITIAL_ERROR_BLOCKS 10
152 #define MS_LIB_BITS_PER_BYTE 8
154 #define MS_SYSINF_FORMAT_FAT 1
155 #define MS_SYSINF_USAGE_GENERAL 0
157 #define MS_SYSINF_MSCLASS_TYPE_1 1
158 #define MS_SYSINF_PAGE_SIZE MS_BYTES_PER_PAGE /* fixed */
160 #define MS_SYSINF_CARDTYPE_RDONLY 1
161 #define MS_SYSINF_CARDTYPE_RDWR 2
162 #define MS_SYSINF_CARDTYPE_HYBRID 3
163 #define MS_SYSINF_SECURITY 0x01
164 #define MS_SYSINF_SECURITY_NO_SUPPORT MS_SYSINF_SECURITY
165 #define MS_SYSINF_SECURITY_SUPPORT 0
167 #define MS_SYSINF_RESERVED1 1
168 #define MS_SYSINF_RESERVED2 1
170 #define MS_SYSENT_TYPE_INVALID_BLOCK 0x01
171 #define MS_SYSENT_TYPE_CIS_IDI 0x0a /* CIS/IDI */
173 #define SIZE_OF_KIRO 1024
174 #define BYTE_MASK 0xff
177 #define MS_STATUS_WRITE_PROTECT 0x0106
178 #define MS_STATUS_SUCCESS 0x0000
179 #define MS_ERROR_FLASH_READ 0x8003
180 #define MS_ERROR_FLASH_ERASE 0x8005
181 #define MS_LB_ERROR 0xfff0
182 #define MS_LB_BOOT_BLOCK 0xfff1
183 #define MS_LB_INITIAL_ERROR 0xfff2
184 #define MS_STATUS_SUCCESS_WITH_ECC 0xfff3
185 #define MS_LB_ACQUIRED_ERROR 0xfff4
186 #define MS_LB_NOT_USED_ERASED 0xfff5
187 #define MS_NOCARD_ERROR 0xfff8
188 #define MS_NO_MEMORY_ERROR 0xfff9
189 #define MS_STATUS_INT_ERROR 0xfffa
190 #define MS_STATUS_ERROR 0xfffe
191 #define MS_LB_NOT_USED 0xffff
193 #define MS_REG_MNG_SYSFLG 0x04 /* system flag */
194 #define MS_REG_MNG_SYSFLG_USER MS_REG_MNG_SYSFLG /* user block */
196 #define MS_BOOT_BLOCK_ID 0x0001
197 #define MS_BOOT_BLOCK_FORMAT_VERSION 0x0100
198 #define MS_BOOT_BLOCK_DATA_ENTRIES 2
200 #define MS_NUMBER_OF_SYSTEM_ENTRY 4
201 #define MS_NUMBER_OF_BOOT_BLOCK 2
202 #define MS_BYTES_PER_PAGE 512
203 #define MS_LOGICAL_BLOCKS_PER_SEGMENT 496
204 #define MS_LOGICAL_BLOCKS_IN_1ST_SEGMENT 494
206 #define MS_PHYSICAL_BLOCKS_PER_SEGMENT 0x200 /* 512 */
207 #define MS_PHYSICAL_BLOCKS_PER_SEGMENT_MASK 0x1ff
210 #define MS_REG_OVR_BKST 0x80 /* block status */
211 #define MS_REG_OVR_BKST_OK MS_REG_OVR_BKST /* OK */
212 #define MS_REG_OVR_BKST_NG 0x00 /* NG */
214 /* Status Register 1 */
215 #define MS_REG_ST1_DTER 0x20 /* error on data(corrected) */
216 #define MS_REG_ST1_EXER 0x08 /* error on extra(corrected) */
217 #define MS_REG_ST1_FGER 0x02 /* error on overwrite flag(corrected) */
219 /* MemoryStick Register */
220 /* Status Register 0 */
221 #define MS_REG_ST0_WP 0x01 /* write protected */
222 #define MS_REG_ST0_WP_ON MS_REG_ST0_WP
224 #define MS_LIB_CTRL_RDONLY 0
225 #define MS_LIB_CTRL_WRPROTECT 1
228 #define ms_libconv_to_logical(pdx, PhyBlock) (((PhyBlock) >= (pdx)->MS_Lib.NumberOfPhyBlock) ? MS_STATUS_ERROR : (pdx)->MS_Lib.Phy2LogMap[PhyBlock])
229 #define ms_libconv_to_physical(pdx, LogBlock) (((LogBlock) >= (pdx)->MS_Lib.NumberOfLogBlock) ? MS_STATUS_ERROR : (pdx)->MS_Lib.Log2PhyMap[LogBlock])
231 #define ms_lib_ctrl_set(pdx, Flag) ((pdx)->MS_Lib.flags |= (1 << (Flag)))
232 #define ms_lib_ctrl_reset(pdx, Flag) ((pdx)->MS_Lib.flags &= ~(1 << (Flag)))
233 #define ms_lib_ctrl_check(pdx, Flag) ((pdx)->MS_Lib.flags & (1 << (Flag)))
235 #define ms_lib_iswritable(pdx) ((ms_lib_ctrl_check((pdx), MS_LIB_CTRL_RDONLY) == 0) && (ms_lib_ctrl_check(pdx, MS_LIB_CTRL_WRPROTECT) == 0))
236 #define ms_lib_clear_pagemap(pdx) memset((pdx)->MS_Lib.pagemap, 0, sizeof((pdx)->MS_Lib.pagemap))
237 #define memstick_logaddr(logadr1, logadr0) ((((u16)(logadr1)) << 8) | (logadr0))
271 struct ms_bootblock_cis
{
272 u8 bCistplDEVICE
[6]; /* 0 */
273 u8 bCistplDEVICE0C
[6]; /* 6 */
274 u8 bCistplJEDECC
[4]; /* 12 */
275 u8 bCistplMANFID
[6]; /* 16 */
276 u8 bCistplVER1
[32]; /* 22 */
277 u8 bCistplFUNCID
[4]; /* 54 */
278 u8 bCistplFUNCE0
[4]; /* 58 */
279 u8 bCistplFUNCE1
[5]; /* 62 */
280 u8 bCistplCONF
[7]; /* 67 */
281 u8 bCistplCFTBLENT0
[10];/* 74 */
282 u8 bCistplCFTBLENT1
[8]; /* 84 */
283 u8 bCistplCFTBLENT2
[12];/* 92 */
284 u8 bCistplCFTBLENT3
[8]; /* 104 */
285 u8 bCistplCFTBLENT4
[17];/* 112 */
286 u8 bCistplCFTBLENT5
[8]; /* 129 */
287 u8 bCistplCFTBLENT6
[17];/* 137 */
288 u8 bCistplCFTBLENT7
[8]; /* 154 */
289 u8 bCistplNOLINK
[3]; /* 162 */
292 struct ms_bootblock_idi
{
293 #define MS_IDI_GENERAL_CONF 0x848A
294 u16 wIDIgeneralConfiguration
; /* 0 */
295 u16 wIDInumberOfCylinder
; /* 1 */
296 u16 wIDIreserved0
; /* 2 */
297 u16 wIDInumberOfHead
; /* 3 */
298 u16 wIDIbytesPerTrack
; /* 4 */
299 u16 wIDIbytesPerSector
; /* 5 */
300 u16 wIDIsectorsPerTrack
; /* 6 */
301 u16 wIDItotalSectors
[2]; /* 7-8 high,low */
302 u16 wIDIreserved1
[11]; /* 9-19 */
303 u16 wIDIbufferType
; /* 20 */
304 u16 wIDIbufferSize
; /* 21 */
305 u16 wIDIlongCmdECC
; /* 22 */
306 u16 wIDIfirmVersion
[4]; /* 23-26 */
307 u16 wIDImodelName
[20]; /* 27-46 */
308 u16 wIDIreserved2
; /* 47 */
309 u16 wIDIlongWordSupported
; /* 48 */
310 u16 wIDIdmaSupported
; /* 49 */
311 u16 wIDIreserved3
; /* 50 */
312 u16 wIDIpioTiming
; /* 51 */
313 u16 wIDIdmaTiming
; /* 52 */
314 u16 wIDItransferParameter
; /* 53 */
315 u16 wIDIformattedCylinder
; /* 54 */
316 u16 wIDIformattedHead
; /* 55 */
317 u16 wIDIformattedSectorsPerTrack
;/* 56 */
318 u16 wIDIformattedTotalSectors
[2];/* 57-58 */
319 u16 wIDImultiSector
; /* 59 */
320 u16 wIDIlbaSectors
[2]; /* 60-61 */
321 u16 wIDIsingleWordDMA
; /* 62 */
322 u16 wIDImultiWordDMA
; /* 63 */
323 u16 wIDIreserved4
[192]; /* 64-255 */
326 struct ms_bootblock_sysent_rec
{
333 struct ms_bootblock_sysent
{
334 struct ms_bootblock_sysent_rec entry
[MS_NUMBER_OF_SYSTEM_ENTRY
];
337 struct ms_bootblock_sysinf
{
338 u8 bMsClass
; /* must be 1 */
339 u8 bCardType
; /* see below */
340 u16 wBlockSize
; /* n KB */
341 u16 wBlockNumber
; /* number of physical block */
342 u16 wTotalBlockNumber
; /* number of logical block */
343 u16 wPageSize
; /* must be 0x200 */
344 u8 bExtraSize
; /* 0x10 */
348 u8 bAssemblyMakerCode
;
349 u8 bAssemblyMachineCode
[3];
350 u16 wMemoryMakerCode
;
351 u16 wMemoryDeviceCode
;
357 u16 wControllerChipNumber
;
358 u16 wControllerFunction
; /* New MS */
359 u8 bReserved3
[9]; /* New MS */
360 u8 bParallelSupport
; /* New MS */
361 u16 wFormatValue
; /* New MS */
371 struct ms_bootblock_header
{
375 u8 bNumberOfDataEntry
;
379 struct ms_bootblock_page0
{
380 struct ms_bootblock_header header
;
381 struct ms_bootblock_sysent sysent
;
382 struct ms_bootblock_sysinf sysinf
;
385 struct ms_bootblock_cis_idi
{
387 struct ms_bootblock_cis cis
;
392 struct ms_bootblock_idi idi
;
398 /* ENE MS Lib struct */
399 struct ms_lib_type_extdat
{
412 u32 NumberOfCylinder
;
413 u32 SectorsPerCylinder
;
414 u16 cardType
; /* R/W, RO, Hybrid */
417 u16 NumberOfPhyBlock
;
418 u16 NumberOfLogBlock
;
420 u16
*Phy2LogMap
; /* phy2log table */
421 u16
*Log2PhyMap
; /* log2phy table */
423 unsigned char *pagemap
[(MS_MAX_PAGES_PER_BLOCK
+ (MS_LIB_BITS_PER_BYTE
-1)) / MS_LIB_BITS_PER_BYTE
];
424 unsigned char *blkpag
;
425 struct ms_lib_type_extdat
*blkext
;
426 unsigned char copybuf
[512];
430 /* SD Block Length */
431 /* 2^9 = 512 Bytes, The HW maximum read/write data length */
432 #define SD_BLOCK_LEN 9
434 struct ene_ub6250_info
{
436 /* I/O bounce buffer */
440 struct SD_STATUS SD_Status
;
441 struct MS_STATUS MS_Status
;
442 struct SM_STATUS SM_Status
;
444 /* ----- SD Control Data ---------------- */
445 /*SD_REGISTER SD_Regs; */
451 /* SD/MMC New spec. */
454 u8 SD20_HIGH_CAPACITY
;
458 u8 MMC_HIGH_CAPACITY
;
460 /*----- MS Control Data ---------------- */
463 struct ms_lib_ctrl MS_Lib
;
467 /*----- SM Control Data ---------------- */
471 unsigned char *testbuf
;
476 /*------Power Managerment ---------------*/
480 static int ene_sd_init(struct us_data
*us
);
481 static int ene_ms_init(struct us_data
*us
);
482 static int ene_load_bincode(struct us_data
*us
, unsigned char flag
);
484 static void ene_ub6250_info_destructor(void *extra
)
486 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) extra
;
493 static int ene_send_scsi_cmd(struct us_data
*us
, u8 fDir
, void *buf
, int use_sg
)
495 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
496 struct bulk_cs_wrap
*bcs
= (struct bulk_cs_wrap
*) us
->iobuf
;
499 unsigned int residue
;
500 unsigned int cswlen
= 0, partial
= 0;
501 unsigned int transfer_length
= bcb
->DataTransferLength
;
503 /* usb_stor_dbg(us, "transport --- ene_send_scsi_cmd\n"); */
504 /* send cmd to out endpoint */
505 result
= usb_stor_bulk_transfer_buf(us
, us
->send_bulk_pipe
,
506 bcb
, US_BULK_CB_WRAP_LEN
, NULL
);
507 if (result
!= USB_STOR_XFER_GOOD
) {
508 usb_stor_dbg(us
, "send cmd to out endpoint fail ---\n");
509 return USB_STOR_TRANSPORT_ERROR
;
513 unsigned int pipe
= fDir
;
515 if (fDir
== FDIR_READ
)
516 pipe
= us
->recv_bulk_pipe
;
518 pipe
= us
->send_bulk_pipe
;
522 result
= usb_stor_bulk_srb(us
, pipe
, us
->srb
);
524 result
= usb_stor_bulk_transfer_sg(us
, pipe
, buf
,
525 transfer_length
, 0, &partial
);
527 if (result
!= USB_STOR_XFER_GOOD
) {
528 usb_stor_dbg(us
, "data transfer fail ---\n");
529 return USB_STOR_TRANSPORT_ERROR
;
533 /* Get CSW for device status */
534 result
= usb_stor_bulk_transfer_buf(us
, us
->recv_bulk_pipe
, bcs
,
535 US_BULK_CS_WRAP_LEN
, &cswlen
);
537 if (result
== USB_STOR_XFER_SHORT
&& cswlen
== 0) {
538 usb_stor_dbg(us
, "Received 0-length CSW; retrying...\n");
539 result
= usb_stor_bulk_transfer_buf(us
, us
->recv_bulk_pipe
,
540 bcs
, US_BULK_CS_WRAP_LEN
, &cswlen
);
543 if (result
== USB_STOR_XFER_STALLED
) {
544 /* get the status again */
545 usb_stor_dbg(us
, "Attempting to get CSW (2nd try)...\n");
546 result
= usb_stor_bulk_transfer_buf(us
, us
->recv_bulk_pipe
,
547 bcs
, US_BULK_CS_WRAP_LEN
, NULL
);
550 if (result
!= USB_STOR_XFER_GOOD
)
551 return USB_STOR_TRANSPORT_ERROR
;
553 /* check bulk status */
554 residue
= le32_to_cpu(bcs
->Residue
);
557 * try to compute the actual residue, based on how much data
558 * was really transferred and what the device tells us
560 if (residue
&& !(us
->fflags
& US_FL_IGNORE_RESIDUE
)) {
561 residue
= min(residue
, transfer_length
);
563 scsi_set_resid(us
->srb
, max(scsi_get_resid(us
->srb
),
567 if (bcs
->Status
!= US_BULK_STAT_OK
)
568 return USB_STOR_TRANSPORT_ERROR
;
570 return USB_STOR_TRANSPORT_GOOD
;
573 static int do_scsi_request_sense(struct us_data
*us
, struct scsi_cmnd
*srb
)
575 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
576 unsigned char buf
[18];
579 buf
[0] = 0x70; /* Current error */
580 buf
[2] = info
->SrbStatus
>> 16; /* Sense key */
581 buf
[7] = 10; /* Additional length */
582 buf
[12] = info
->SrbStatus
>> 8; /* ASC */
583 buf
[13] = info
->SrbStatus
; /* ASCQ */
585 usb_stor_set_xfer_buf(buf
, sizeof(buf
), srb
);
586 return USB_STOR_TRANSPORT_GOOD
;
589 static int do_scsi_inquiry(struct us_data
*us
, struct scsi_cmnd
*srb
)
591 unsigned char data_ptr
[36] = {
592 0x00, 0x00, 0x02, 0x00, 0x1F, 0x00, 0x00, 0x00, 0x55,
593 0x53, 0x42, 0x32, 0x2E, 0x30, 0x20, 0x20, 0x43, 0x61,
594 0x72, 0x64, 0x52, 0x65, 0x61, 0x64, 0x65, 0x72, 0x20,
595 0x20, 0x20, 0x20, 0x20, 0x20, 0x30, 0x31, 0x30, 0x30 };
597 usb_stor_set_xfer_buf(data_ptr
, 36, srb
);
598 return USB_STOR_TRANSPORT_GOOD
;
601 static int sd_scsi_test_unit_ready(struct us_data
*us
, struct scsi_cmnd
*srb
)
603 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
605 if (info
->SD_Status
.Insert
&& info
->SD_Status
.Ready
)
606 return USB_STOR_TRANSPORT_GOOD
;
609 return USB_STOR_TRANSPORT_GOOD
;
612 return USB_STOR_TRANSPORT_GOOD
;
615 static int sd_scsi_mode_sense(struct us_data
*us
, struct scsi_cmnd
*srb
)
617 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
618 unsigned char mediaNoWP
[12] = {
619 0x0b, 0x00, 0x00, 0x08, 0x00, 0x00,
620 0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
621 unsigned char mediaWP
[12] = {
622 0x0b, 0x00, 0x80, 0x08, 0x00, 0x00,
623 0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
625 if (info
->SD_Status
.WtP
)
626 usb_stor_set_xfer_buf(mediaWP
, 12, srb
);
628 usb_stor_set_xfer_buf(mediaNoWP
, 12, srb
);
631 return USB_STOR_TRANSPORT_GOOD
;
634 static int sd_scsi_read_capacity(struct us_data
*us
, struct scsi_cmnd
*srb
)
638 unsigned int offset
= 0;
639 unsigned char buf
[8];
640 struct scatterlist
*sg
= NULL
;
641 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
643 usb_stor_dbg(us
, "sd_scsi_read_capacity\n");
644 if (info
->SD_Status
.HiCapacity
) {
646 if (info
->SD_Status
.IsMMC
)
647 bl_num
= info
->HC_C_SIZE
-1;
649 bl_num
= (info
->HC_C_SIZE
+ 1) * 1024 - 1;
651 bl_len
= 1 << (info
->SD_READ_BL_LEN
);
652 bl_num
= info
->SD_Block_Mult
* (info
->SD_C_SIZE
+ 1)
653 * (1 << (info
->SD_C_SIZE_MULT
+ 2)) - 1;
655 info
->bl_num
= bl_num
;
656 usb_stor_dbg(us
, "bl_len = %x\n", bl_len
);
657 usb_stor_dbg(us
, "bl_num = %x\n", bl_num
);
659 /*srb->request_bufflen = 8; */
660 buf
[0] = (bl_num
>> 24) & 0xff;
661 buf
[1] = (bl_num
>> 16) & 0xff;
662 buf
[2] = (bl_num
>> 8) & 0xff;
663 buf
[3] = (bl_num
>> 0) & 0xff;
664 buf
[4] = (bl_len
>> 24) & 0xff;
665 buf
[5] = (bl_len
>> 16) & 0xff;
666 buf
[6] = (bl_len
>> 8) & 0xff;
667 buf
[7] = (bl_len
>> 0) & 0xff;
669 usb_stor_access_xfer_buf(buf
, 8, srb
, &sg
, &offset
, TO_XFER_BUF
);
671 return USB_STOR_TRANSPORT_GOOD
;
674 static int sd_scsi_read(struct us_data
*us
, struct scsi_cmnd
*srb
)
677 unsigned char *cdb
= srb
->cmnd
;
678 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
679 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
681 u32 bn
= ((cdb
[2] << 24) & 0xff000000) | ((cdb
[3] << 16) & 0x00ff0000) |
682 ((cdb
[4] << 8) & 0x0000ff00) | ((cdb
[5] << 0) & 0x000000ff);
683 u16 blen
= ((cdb
[7] << 8) & 0xff00) | ((cdb
[8] << 0) & 0x00ff);
684 u32 bnByte
= bn
* 0x200;
685 u32 blenByte
= blen
* 0x200;
687 if (bn
> info
->bl_num
)
688 return USB_STOR_TRANSPORT_ERROR
;
690 result
= ene_load_bincode(us
, SD_RW_PATTERN
);
691 if (result
!= USB_STOR_XFER_GOOD
) {
692 usb_stor_dbg(us
, "Load SD RW pattern Fail !!\n");
693 return USB_STOR_TRANSPORT_ERROR
;
696 if (info
->SD_Status
.HiCapacity
)
699 /* set up the command wrapper */
700 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
701 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
702 bcb
->DataTransferLength
= blenByte
;
703 bcb
->Flags
= US_BULK_FLAG_IN
;
705 bcb
->CDB
[5] = (unsigned char)(bnByte
);
706 bcb
->CDB
[4] = (unsigned char)(bnByte
>>8);
707 bcb
->CDB
[3] = (unsigned char)(bnByte
>>16);
708 bcb
->CDB
[2] = (unsigned char)(bnByte
>>24);
710 result
= ene_send_scsi_cmd(us
, FDIR_READ
, scsi_sglist(srb
), 1);
714 static int sd_scsi_write(struct us_data
*us
, struct scsi_cmnd
*srb
)
717 unsigned char *cdb
= srb
->cmnd
;
718 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
719 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
721 u32 bn
= ((cdb
[2] << 24) & 0xff000000) | ((cdb
[3] << 16) & 0x00ff0000) |
722 ((cdb
[4] << 8) & 0x0000ff00) | ((cdb
[5] << 0) & 0x000000ff);
723 u16 blen
= ((cdb
[7] << 8) & 0xff00) | ((cdb
[8] << 0) & 0x00ff);
724 u32 bnByte
= bn
* 0x200;
725 u32 blenByte
= blen
* 0x200;
727 if (bn
> info
->bl_num
)
728 return USB_STOR_TRANSPORT_ERROR
;
730 result
= ene_load_bincode(us
, SD_RW_PATTERN
);
731 if (result
!= USB_STOR_XFER_GOOD
) {
732 usb_stor_dbg(us
, "Load SD RW pattern Fail !!\n");
733 return USB_STOR_TRANSPORT_ERROR
;
736 if (info
->SD_Status
.HiCapacity
)
739 /* set up the command wrapper */
740 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
741 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
742 bcb
->DataTransferLength
= blenByte
;
745 bcb
->CDB
[5] = (unsigned char)(bnByte
);
746 bcb
->CDB
[4] = (unsigned char)(bnByte
>>8);
747 bcb
->CDB
[3] = (unsigned char)(bnByte
>>16);
748 bcb
->CDB
[2] = (unsigned char)(bnByte
>>24);
750 result
= ene_send_scsi_cmd(us
, FDIR_WRITE
, scsi_sglist(srb
), 1);
758 static int ms_lib_set_logicalpair(struct us_data
*us
, u16 logblk
, u16 phyblk
)
760 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
762 if ((logblk
>= info
->MS_Lib
.NumberOfLogBlock
) || (phyblk
>= info
->MS_Lib
.NumberOfPhyBlock
))
765 info
->MS_Lib
.Phy2LogMap
[phyblk
] = logblk
;
766 info
->MS_Lib
.Log2PhyMap
[logblk
] = phyblk
;
771 static int ms_lib_set_logicalblockmark(struct us_data
*us
, u16 phyblk
, u16 mark
)
773 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
775 if (phyblk
>= info
->MS_Lib
.NumberOfPhyBlock
)
778 info
->MS_Lib
.Phy2LogMap
[phyblk
] = mark
;
783 static int ms_lib_set_initialerrorblock(struct us_data
*us
, u16 phyblk
)
785 return ms_lib_set_logicalblockmark(us
, phyblk
, MS_LB_INITIAL_ERROR
);
788 static int ms_lib_set_bootblockmark(struct us_data
*us
, u16 phyblk
)
790 return ms_lib_set_logicalblockmark(us
, phyblk
, MS_LB_BOOT_BLOCK
);
793 static int ms_lib_free_logicalmap(struct us_data
*us
)
795 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
797 kfree(info
->MS_Lib
.Phy2LogMap
);
798 info
->MS_Lib
.Phy2LogMap
= NULL
;
800 kfree(info
->MS_Lib
.Log2PhyMap
);
801 info
->MS_Lib
.Log2PhyMap
= NULL
;
806 static int ms_lib_alloc_logicalmap(struct us_data
*us
)
809 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
811 info
->MS_Lib
.Phy2LogMap
= kmalloc_array(info
->MS_Lib
.NumberOfPhyBlock
,
814 info
->MS_Lib
.Log2PhyMap
= kmalloc_array(info
->MS_Lib
.NumberOfLogBlock
,
818 if ((info
->MS_Lib
.Phy2LogMap
== NULL
) || (info
->MS_Lib
.Log2PhyMap
== NULL
)) {
819 ms_lib_free_logicalmap(us
);
823 for (i
= 0; i
< info
->MS_Lib
.NumberOfPhyBlock
; i
++)
824 info
->MS_Lib
.Phy2LogMap
[i
] = MS_LB_NOT_USED
;
826 for (i
= 0; i
< info
->MS_Lib
.NumberOfLogBlock
; i
++)
827 info
->MS_Lib
.Log2PhyMap
[i
] = MS_LB_NOT_USED
;
832 static void ms_lib_clear_writebuf(struct us_data
*us
)
835 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
837 info
->MS_Lib
.wrtblk
= (u16
)-1;
838 ms_lib_clear_pagemap(info
);
840 if (info
->MS_Lib
.blkpag
)
841 memset(info
->MS_Lib
.blkpag
, 0xff, info
->MS_Lib
.PagesPerBlock
* info
->MS_Lib
.BytesPerSector
);
843 if (info
->MS_Lib
.blkext
) {
844 for (i
= 0; i
< info
->MS_Lib
.PagesPerBlock
; i
++) {
845 info
->MS_Lib
.blkext
[i
].status1
= MS_REG_ST1_DEFAULT
;
846 info
->MS_Lib
.blkext
[i
].ovrflg
= MS_REG_OVR_DEFAULT
;
847 info
->MS_Lib
.blkext
[i
].mngflg
= MS_REG_MNG_DEFAULT
;
848 info
->MS_Lib
.blkext
[i
].logadr
= MS_LB_NOT_USED
;
853 static int ms_count_freeblock(struct us_data
*us
, u16 PhyBlock
)
856 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
858 Ende
= PhyBlock
+ MS_PHYSICAL_BLOCKS_PER_SEGMENT
;
859 for (Count
= 0; PhyBlock
< Ende
; PhyBlock
++) {
860 switch (info
->MS_Lib
.Phy2LogMap
[PhyBlock
]) {
862 case MS_LB_NOT_USED_ERASED
:
872 static int ms_read_readpage(struct us_data
*us
, u32 PhyBlockAddr
,
873 u8 PageNum
, u32
*PageBuf
, struct ms_lib_type_extdat
*ExtraDat
)
875 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
876 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
877 u8
*bbuf
= info
->bbuf
;
879 u32 bn
= PhyBlockAddr
* 0x20 + PageNum
;
881 result
= ene_load_bincode(us
, MS_RW_PATTERN
);
882 if (result
!= USB_STOR_XFER_GOOD
)
883 return USB_STOR_TRANSPORT_ERROR
;
886 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
887 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
888 bcb
->DataTransferLength
= 0x200;
889 bcb
->Flags
= US_BULK_FLAG_IN
;
892 bcb
->CDB
[1] = 0x02; /* in init.c ENE_MSInit() is 0x01 */
894 bcb
->CDB
[5] = (unsigned char)(bn
);
895 bcb
->CDB
[4] = (unsigned char)(bn
>>8);
896 bcb
->CDB
[3] = (unsigned char)(bn
>>16);
897 bcb
->CDB
[2] = (unsigned char)(bn
>>24);
899 result
= ene_send_scsi_cmd(us
, FDIR_READ
, PageBuf
, 0);
900 if (result
!= USB_STOR_XFER_GOOD
)
901 return USB_STOR_TRANSPORT_ERROR
;
904 /* Read Extra Data */
905 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
906 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
907 bcb
->DataTransferLength
= 0x4;
908 bcb
->Flags
= US_BULK_FLAG_IN
;
912 bcb
->CDB
[5] = (unsigned char)(PageNum
);
913 bcb
->CDB
[4] = (unsigned char)(PhyBlockAddr
);
914 bcb
->CDB
[3] = (unsigned char)(PhyBlockAddr
>>8);
915 bcb
->CDB
[2] = (unsigned char)(PhyBlockAddr
>>16);
918 result
= ene_send_scsi_cmd(us
, FDIR_READ
, bbuf
, 0);
919 if (result
!= USB_STOR_XFER_GOOD
)
920 return USB_STOR_TRANSPORT_ERROR
;
922 ExtraDat
->reserved
= 0;
923 ExtraDat
->intr
= 0x80; /* Not yet,fireware support */
924 ExtraDat
->status0
= 0x10; /* Not yet,fireware support */
926 ExtraDat
->status1
= 0x00; /* Not yet,fireware support */
927 ExtraDat
->ovrflg
= bbuf
[0];
928 ExtraDat
->mngflg
= bbuf
[1];
929 ExtraDat
->logadr
= memstick_logaddr(bbuf
[2], bbuf
[3]);
931 return USB_STOR_TRANSPORT_GOOD
;
934 static int ms_lib_process_bootblock(struct us_data
*us
, u16 PhyBlock
, u8
*PageData
)
936 struct ms_bootblock_sysent
*SysEntry
;
937 struct ms_bootblock_sysinf
*SysInfo
;
941 struct ms_lib_type_extdat ExtraData
;
942 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
944 PageBuffer
= kmalloc(MS_BYTES_PER_PAGE
, GFP_KERNEL
);
945 if (PageBuffer
== NULL
)
950 SysInfo
= &(((struct ms_bootblock_page0
*)PageData
)->sysinf
);
952 if ((SysInfo
->bMsClass
!= MS_SYSINF_MSCLASS_TYPE_1
) ||
953 (be16_to_cpu(SysInfo
->wPageSize
) != MS_SYSINF_PAGE_SIZE
) ||
954 ((SysInfo
->bSecuritySupport
& MS_SYSINF_SECURITY
) == MS_SYSINF_SECURITY_SUPPORT
) ||
955 (SysInfo
->bReserved1
!= MS_SYSINF_RESERVED1
) ||
956 (SysInfo
->bReserved2
!= MS_SYSINF_RESERVED2
) ||
957 (SysInfo
->bFormatType
!= MS_SYSINF_FORMAT_FAT
) ||
958 (SysInfo
->bUsage
!= MS_SYSINF_USAGE_GENERAL
))
961 switch (info
->MS_Lib
.cardType
= SysInfo
->bCardType
) {
962 case MS_SYSINF_CARDTYPE_RDONLY
:
963 ms_lib_ctrl_set(info
, MS_LIB_CTRL_RDONLY
);
965 case MS_SYSINF_CARDTYPE_RDWR
:
966 ms_lib_ctrl_reset(info
, MS_LIB_CTRL_RDONLY
);
968 case MS_SYSINF_CARDTYPE_HYBRID
:
973 info
->MS_Lib
.blockSize
= be16_to_cpu(SysInfo
->wBlockSize
);
974 info
->MS_Lib
.NumberOfPhyBlock
= be16_to_cpu(SysInfo
->wBlockNumber
);
975 info
->MS_Lib
.NumberOfLogBlock
= be16_to_cpu(SysInfo
->wTotalBlockNumber
)-2;
976 info
->MS_Lib
.PagesPerBlock
= info
->MS_Lib
.blockSize
* SIZE_OF_KIRO
/ MS_BYTES_PER_PAGE
;
977 info
->MS_Lib
.NumberOfSegment
= info
->MS_Lib
.NumberOfPhyBlock
/ MS_PHYSICAL_BLOCKS_PER_SEGMENT
;
978 info
->MS_Model
= be16_to_cpu(SysInfo
->wMemorySize
);
980 /*Allocate to all number of logicalblock and physicalblock */
981 if (ms_lib_alloc_logicalmap(us
))
984 /* Mark the book block */
985 ms_lib_set_bootblockmark(us
, PhyBlock
);
987 SysEntry
= &(((struct ms_bootblock_page0
*)PageData
)->sysent
);
989 for (i
= 0; i
< MS_NUMBER_OF_SYSTEM_ENTRY
; i
++) {
990 u32 EntryOffset
, EntrySize
;
992 EntryOffset
= be32_to_cpu(SysEntry
->entry
[i
].dwStart
);
994 if (EntryOffset
== 0xffffff)
996 EntrySize
= be32_to_cpu(SysEntry
->entry
[i
].dwSize
);
1001 if (EntryOffset
+ MS_BYTES_PER_PAGE
+ EntrySize
> info
->MS_Lib
.blockSize
* (u32
)SIZE_OF_KIRO
)
1005 u8 PrevPageNumber
= 0;
1008 if (SysEntry
->entry
[i
].bType
!= MS_SYSENT_TYPE_INVALID_BLOCK
)
1011 while (EntrySize
> 0) {
1013 PageNumber
= (u8
)(EntryOffset
/ MS_BYTES_PER_PAGE
+ 1);
1014 if (PageNumber
!= PrevPageNumber
) {
1015 switch (ms_read_readpage(us
, PhyBlock
, PageNumber
, (u32
*)PageBuffer
, &ExtraData
)) {
1016 case MS_STATUS_SUCCESS
:
1018 case MS_STATUS_WRITE_PROTECT
:
1019 case MS_ERROR_FLASH_READ
:
1020 case MS_STATUS_ERROR
:
1025 PrevPageNumber
= PageNumber
;
1028 phyblk
= be16_to_cpu(*(u16
*)(PageBuffer
+ (EntryOffset
% MS_BYTES_PER_PAGE
)));
1029 if (phyblk
< 0x0fff)
1030 ms_lib_set_initialerrorblock(us
, phyblk
);
1035 } else if (i
== 1) { /* CIS/IDI */
1036 struct ms_bootblock_idi
*idi
;
1038 if (SysEntry
->entry
[i
].bType
!= MS_SYSENT_TYPE_CIS_IDI
)
1041 switch (ms_read_readpage(us
, PhyBlock
, (u8
)(EntryOffset
/ MS_BYTES_PER_PAGE
+ 1), (u32
*)PageBuffer
, &ExtraData
)) {
1042 case MS_STATUS_SUCCESS
:
1044 case MS_STATUS_WRITE_PROTECT
:
1045 case MS_ERROR_FLASH_READ
:
1046 case MS_STATUS_ERROR
:
1051 idi
= &((struct ms_bootblock_cis_idi
*)(PageBuffer
+ (EntryOffset
% MS_BYTES_PER_PAGE
)))->idi
.idi
;
1052 if (le16_to_cpu(idi
->wIDIgeneralConfiguration
) != MS_IDI_GENERAL_CONF
)
1055 info
->MS_Lib
.BytesPerSector
= le16_to_cpu(idi
->wIDIbytesPerSector
);
1056 if (info
->MS_Lib
.BytesPerSector
!= MS_BYTES_PER_PAGE
)
1065 ms_lib_free_logicalmap(us
);
1073 static void ms_lib_free_writebuf(struct us_data
*us
)
1075 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1076 info
->MS_Lib
.wrtblk
= (u16
)-1; /* set to -1 */
1078 /* memset((fdoExt)->MS_Lib.pagemap, 0, sizeof((fdoExt)->MS_Lib.pagemap)) */
1080 ms_lib_clear_pagemap(info
); /* (pdx)->MS_Lib.pagemap memset 0 in ms.h */
1082 if (info
->MS_Lib
.blkpag
) {
1083 kfree(info
->MS_Lib
.blkpag
); /* Arnold test ... */
1084 info
->MS_Lib
.blkpag
= NULL
;
1087 if (info
->MS_Lib
.blkext
) {
1088 kfree(info
->MS_Lib
.blkext
); /* Arnold test ... */
1089 info
->MS_Lib
.blkext
= NULL
;
1094 static void ms_lib_free_allocatedarea(struct us_data
*us
)
1096 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1098 ms_lib_free_writebuf(us
); /* Free MS_Lib.pagemap */
1099 ms_lib_free_logicalmap(us
); /* kfree MS_Lib.Phy2LogMap and MS_Lib.Log2PhyMap */
1101 /* set struct us point flag to 0 */
1102 info
->MS_Lib
.flags
= 0;
1103 info
->MS_Lib
.BytesPerSector
= 0;
1104 info
->MS_Lib
.SectorsPerCylinder
= 0;
1106 info
->MS_Lib
.cardType
= 0;
1107 info
->MS_Lib
.blockSize
= 0;
1108 info
->MS_Lib
.PagesPerBlock
= 0;
1110 info
->MS_Lib
.NumberOfPhyBlock
= 0;
1111 info
->MS_Lib
.NumberOfLogBlock
= 0;
1115 static int ms_lib_alloc_writebuf(struct us_data
*us
)
1117 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1119 info
->MS_Lib
.wrtblk
= (u16
)-1;
1121 info
->MS_Lib
.blkpag
= kmalloc_array(info
->MS_Lib
.PagesPerBlock
,
1122 info
->MS_Lib
.BytesPerSector
,
1124 info
->MS_Lib
.blkext
= kmalloc_array(info
->MS_Lib
.PagesPerBlock
,
1125 sizeof(struct ms_lib_type_extdat
),
1128 if ((info
->MS_Lib
.blkpag
== NULL
) || (info
->MS_Lib
.blkext
== NULL
)) {
1129 ms_lib_free_writebuf(us
);
1133 ms_lib_clear_writebuf(us
);
1138 static int ms_lib_force_setlogical_pair(struct us_data
*us
, u16 logblk
, u16 phyblk
)
1140 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1142 if (logblk
== MS_LB_NOT_USED
)
1145 if ((logblk
>= info
->MS_Lib
.NumberOfLogBlock
) ||
1146 (phyblk
>= info
->MS_Lib
.NumberOfPhyBlock
))
1149 info
->MS_Lib
.Phy2LogMap
[phyblk
] = logblk
;
1150 info
->MS_Lib
.Log2PhyMap
[logblk
] = phyblk
;
1155 static int ms_read_copyblock(struct us_data
*us
, u16 oldphy
, u16 newphy
,
1156 u16 PhyBlockAddr
, u8 PageNum
, unsigned char *buf
, u16 len
)
1158 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
1161 result
= ene_load_bincode(us
, MS_RW_PATTERN
);
1162 if (result
!= USB_STOR_XFER_GOOD
)
1163 return USB_STOR_TRANSPORT_ERROR
;
1165 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1166 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1167 bcb
->DataTransferLength
= 0x200*len
;
1171 bcb
->CDB
[4] = (unsigned char)(oldphy
);
1172 bcb
->CDB
[3] = (unsigned char)(oldphy
>>8);
1173 bcb
->CDB
[2] = 0; /* (BYTE)(oldphy>>16) */
1174 bcb
->CDB
[7] = (unsigned char)(newphy
);
1175 bcb
->CDB
[6] = (unsigned char)(newphy
>>8);
1176 bcb
->CDB
[5] = 0; /* (BYTE)(newphy>>16) */
1177 bcb
->CDB
[9] = (unsigned char)(PhyBlockAddr
);
1178 bcb
->CDB
[8] = (unsigned char)(PhyBlockAddr
>>8);
1179 bcb
->CDB
[10] = PageNum
;
1181 result
= ene_send_scsi_cmd(us
, FDIR_WRITE
, buf
, 0);
1182 if (result
!= USB_STOR_XFER_GOOD
)
1183 return USB_STOR_TRANSPORT_ERROR
;
1185 return USB_STOR_TRANSPORT_GOOD
;
1188 static int ms_read_eraseblock(struct us_data
*us
, u32 PhyBlockAddr
)
1190 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
1192 u32 bn
= PhyBlockAddr
;
1194 result
= ene_load_bincode(us
, MS_RW_PATTERN
);
1195 if (result
!= USB_STOR_XFER_GOOD
)
1196 return USB_STOR_TRANSPORT_ERROR
;
1198 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1199 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1200 bcb
->DataTransferLength
= 0x200;
1201 bcb
->Flags
= US_BULK_FLAG_IN
;
1204 bcb
->CDB
[4] = (unsigned char)(bn
);
1205 bcb
->CDB
[3] = (unsigned char)(bn
>>8);
1206 bcb
->CDB
[2] = (unsigned char)(bn
>>16);
1208 result
= ene_send_scsi_cmd(us
, FDIR_READ
, NULL
, 0);
1209 if (result
!= USB_STOR_XFER_GOOD
)
1210 return USB_STOR_TRANSPORT_ERROR
;
1212 return USB_STOR_TRANSPORT_GOOD
;
1215 static int ms_lib_check_disableblock(struct us_data
*us
, u16 PhyBlock
)
1217 unsigned char *PageBuf
= NULL
;
1218 u16 result
= MS_STATUS_SUCCESS
;
1220 struct ms_lib_type_extdat extdat
;
1221 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1223 PageBuf
= kmalloc(MS_BYTES_PER_PAGE
, GFP_KERNEL
);
1224 if (PageBuf
== NULL
) {
1225 result
= MS_NO_MEMORY_ERROR
;
1229 ms_read_readpage(us
, PhyBlock
, 1, (u32
*)PageBuf
, &extdat
);
1231 blk
= be16_to_cpu(PageBuf
[index
]);
1232 if (blk
== MS_LB_NOT_USED
)
1234 if (blk
== info
->MS_Lib
.Log2PhyMap
[0]) {
1235 result
= MS_ERROR_FLASH_READ
;
1246 static int ms_lib_setacquired_errorblock(struct us_data
*us
, u16 phyblk
)
1249 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1251 if (phyblk
>= info
->MS_Lib
.NumberOfPhyBlock
)
1254 log
= info
->MS_Lib
.Phy2LogMap
[phyblk
];
1256 if (log
< info
->MS_Lib
.NumberOfLogBlock
)
1257 info
->MS_Lib
.Log2PhyMap
[log
] = MS_LB_NOT_USED
;
1259 if (info
->MS_Lib
.Phy2LogMap
[phyblk
] != MS_LB_INITIAL_ERROR
)
1260 info
->MS_Lib
.Phy2LogMap
[phyblk
] = MS_LB_ACQUIRED_ERROR
;
1265 static int ms_lib_overwrite_extra(struct us_data
*us
, u32 PhyBlockAddr
,
1266 u8 PageNum
, u8 OverwriteFlag
)
1268 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
1271 result
= ene_load_bincode(us
, MS_RW_PATTERN
);
1272 if (result
!= USB_STOR_XFER_GOOD
)
1273 return USB_STOR_TRANSPORT_ERROR
;
1275 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1276 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1277 bcb
->DataTransferLength
= 0x4;
1278 bcb
->Flags
= US_BULK_FLAG_IN
;
1281 bcb
->CDB
[5] = (unsigned char)(PageNum
);
1282 bcb
->CDB
[4] = (unsigned char)(PhyBlockAddr
);
1283 bcb
->CDB
[3] = (unsigned char)(PhyBlockAddr
>>8);
1284 bcb
->CDB
[2] = (unsigned char)(PhyBlockAddr
>>16);
1285 bcb
->CDB
[6] = OverwriteFlag
;
1290 result
= ene_send_scsi_cmd(us
, FDIR_READ
, NULL
, 0);
1291 if (result
!= USB_STOR_XFER_GOOD
)
1292 return USB_STOR_TRANSPORT_ERROR
;
1294 return USB_STOR_TRANSPORT_GOOD
;
1297 static int ms_lib_error_phyblock(struct us_data
*us
, u16 phyblk
)
1299 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1301 if (phyblk
>= info
->MS_Lib
.NumberOfPhyBlock
)
1302 return MS_STATUS_ERROR
;
1304 ms_lib_setacquired_errorblock(us
, phyblk
);
1306 if (ms_lib_iswritable(info
))
1307 return ms_lib_overwrite_extra(us
, phyblk
, 0, (u8
)(~MS_REG_OVR_BKST
& BYTE_MASK
));
1309 return MS_STATUS_SUCCESS
;
1312 static int ms_lib_erase_phyblock(struct us_data
*us
, u16 phyblk
)
1315 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1317 if (phyblk
>= info
->MS_Lib
.NumberOfPhyBlock
)
1318 return MS_STATUS_ERROR
;
1320 log
= info
->MS_Lib
.Phy2LogMap
[phyblk
];
1322 if (log
< info
->MS_Lib
.NumberOfLogBlock
)
1323 info
->MS_Lib
.Log2PhyMap
[log
] = MS_LB_NOT_USED
;
1325 info
->MS_Lib
.Phy2LogMap
[phyblk
] = MS_LB_NOT_USED
;
1327 if (ms_lib_iswritable(info
)) {
1328 switch (ms_read_eraseblock(us
, phyblk
)) {
1329 case MS_STATUS_SUCCESS
:
1330 info
->MS_Lib
.Phy2LogMap
[phyblk
] = MS_LB_NOT_USED_ERASED
;
1331 return MS_STATUS_SUCCESS
;
1332 case MS_ERROR_FLASH_ERASE
:
1333 case MS_STATUS_INT_ERROR
:
1334 ms_lib_error_phyblock(us
, phyblk
);
1335 return MS_ERROR_FLASH_ERASE
;
1336 case MS_STATUS_ERROR
:
1338 ms_lib_ctrl_set(info
, MS_LIB_CTRL_RDONLY
); /* MS_LibCtrlSet will used by ENE_MSInit ,need check, and why us to info*/
1339 ms_lib_setacquired_errorblock(us
, phyblk
);
1340 return MS_STATUS_ERROR
;
1344 ms_lib_setacquired_errorblock(us
, phyblk
);
1346 return MS_STATUS_SUCCESS
;
1349 static int ms_lib_read_extra(struct us_data
*us
, u32 PhyBlock
,
1350 u8 PageNum
, struct ms_lib_type_extdat
*ExtraDat
)
1352 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
1353 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1354 u8
*bbuf
= info
->bbuf
;
1357 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1358 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1359 bcb
->DataTransferLength
= 0x4;
1360 bcb
->Flags
= US_BULK_FLAG_IN
;
1363 bcb
->CDB
[5] = (unsigned char)(PageNum
);
1364 bcb
->CDB
[4] = (unsigned char)(PhyBlock
);
1365 bcb
->CDB
[3] = (unsigned char)(PhyBlock
>>8);
1366 bcb
->CDB
[2] = (unsigned char)(PhyBlock
>>16);
1369 result
= ene_send_scsi_cmd(us
, FDIR_READ
, bbuf
, 0);
1370 if (result
!= USB_STOR_XFER_GOOD
)
1371 return USB_STOR_TRANSPORT_ERROR
;
1373 ExtraDat
->reserved
= 0;
1374 ExtraDat
->intr
= 0x80; /* Not yet, waiting for fireware support */
1375 ExtraDat
->status0
= 0x10; /* Not yet, waiting for fireware support */
1376 ExtraDat
->status1
= 0x00; /* Not yet, waiting for fireware support */
1377 ExtraDat
->ovrflg
= bbuf
[0];
1378 ExtraDat
->mngflg
= bbuf
[1];
1379 ExtraDat
->logadr
= memstick_logaddr(bbuf
[2], bbuf
[3]);
1381 return USB_STOR_TRANSPORT_GOOD
;
1384 static int ms_libsearch_block_from_physical(struct us_data
*us
, u16 phyblk
)
1387 struct ms_lib_type_extdat extdat
; /* need check */
1388 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1391 if (phyblk
>= info
->MS_Lib
.NumberOfPhyBlock
)
1394 for (blk
= phyblk
+ 1; blk
!= phyblk
; blk
++) {
1395 if ((blk
& MS_PHYSICAL_BLOCKS_PER_SEGMENT_MASK
) == 0)
1396 blk
-= MS_PHYSICAL_BLOCKS_PER_SEGMENT
;
1398 if (info
->MS_Lib
.Phy2LogMap
[blk
] == MS_LB_NOT_USED_ERASED
) {
1400 } else if (info
->MS_Lib
.Phy2LogMap
[blk
] == MS_LB_NOT_USED
) {
1401 switch (ms_lib_read_extra(us
, blk
, 0, &extdat
)) {
1402 case MS_STATUS_SUCCESS
:
1403 case MS_STATUS_SUCCESS_WITH_ECC
:
1405 case MS_NOCARD_ERROR
:
1406 return MS_NOCARD_ERROR
;
1407 case MS_STATUS_INT_ERROR
:
1409 case MS_ERROR_FLASH_READ
:
1411 ms_lib_setacquired_errorblock(us
, blk
);
1415 if ((extdat
.ovrflg
& MS_REG_OVR_BKST
) != MS_REG_OVR_BKST_OK
) {
1416 ms_lib_setacquired_errorblock(us
, blk
);
1420 switch (ms_lib_erase_phyblock(us
, blk
)) {
1421 case MS_STATUS_SUCCESS
:
1423 case MS_STATUS_ERROR
:
1425 case MS_ERROR_FLASH_ERASE
:
1427 ms_lib_error_phyblock(us
, blk
);
1435 static int ms_libsearch_block_from_logical(struct us_data
*us
, u16 logblk
)
1438 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1440 phyblk
= ms_libconv_to_physical(info
, logblk
);
1441 if (phyblk
>= MS_LB_ERROR
) {
1442 if (logblk
>= info
->MS_Lib
.NumberOfLogBlock
)
1445 phyblk
= (logblk
+ MS_NUMBER_OF_BOOT_BLOCK
) / MS_LOGICAL_BLOCKS_PER_SEGMENT
;
1446 phyblk
*= MS_PHYSICAL_BLOCKS_PER_SEGMENT
;
1447 phyblk
+= MS_PHYSICAL_BLOCKS_PER_SEGMENT
- 1;
1450 return ms_libsearch_block_from_physical(us
, phyblk
);
1453 static int ms_scsi_test_unit_ready(struct us_data
*us
, struct scsi_cmnd
*srb
)
1455 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*)(us
->extra
);
1457 /* pr_info("MS_SCSI_Test_Unit_Ready\n"); */
1458 if (info
->MS_Status
.Insert
&& info
->MS_Status
.Ready
) {
1459 return USB_STOR_TRANSPORT_GOOD
;
1462 return USB_STOR_TRANSPORT_GOOD
;
1465 return USB_STOR_TRANSPORT_GOOD
;
1468 static int ms_scsi_mode_sense(struct us_data
*us
, struct scsi_cmnd
*srb
)
1470 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1471 unsigned char mediaNoWP
[12] = {
1472 0x0b, 0x00, 0x00, 0x08, 0x00, 0x00,
1473 0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
1474 unsigned char mediaWP
[12] = {
1475 0x0b, 0x00, 0x80, 0x08, 0x00, 0x00,
1476 0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
1478 if (info
->MS_Status
.WtP
)
1479 usb_stor_set_xfer_buf(mediaWP
, 12, srb
);
1481 usb_stor_set_xfer_buf(mediaNoWP
, 12, srb
);
1483 return USB_STOR_TRANSPORT_GOOD
;
1486 static int ms_scsi_read_capacity(struct us_data
*us
, struct scsi_cmnd
*srb
)
1490 unsigned int offset
= 0;
1491 unsigned char buf
[8];
1492 struct scatterlist
*sg
= NULL
;
1493 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1495 usb_stor_dbg(us
, "ms_scsi_read_capacity\n");
1497 if (info
->MS_Status
.IsMSPro
)
1498 bl_num
= info
->MSP_TotalBlock
- 1;
1500 bl_num
= info
->MS_Lib
.NumberOfLogBlock
* info
->MS_Lib
.blockSize
* 2 - 1;
1502 info
->bl_num
= bl_num
;
1503 usb_stor_dbg(us
, "bl_len = %x\n", bl_len
);
1504 usb_stor_dbg(us
, "bl_num = %x\n", bl_num
);
1506 /*srb->request_bufflen = 8; */
1507 buf
[0] = (bl_num
>> 24) & 0xff;
1508 buf
[1] = (bl_num
>> 16) & 0xff;
1509 buf
[2] = (bl_num
>> 8) & 0xff;
1510 buf
[3] = (bl_num
>> 0) & 0xff;
1511 buf
[4] = (bl_len
>> 24) & 0xff;
1512 buf
[5] = (bl_len
>> 16) & 0xff;
1513 buf
[6] = (bl_len
>> 8) & 0xff;
1514 buf
[7] = (bl_len
>> 0) & 0xff;
1516 usb_stor_access_xfer_buf(buf
, 8, srb
, &sg
, &offset
, TO_XFER_BUF
);
1518 return USB_STOR_TRANSPORT_GOOD
;
1521 static void ms_lib_phy_to_log_range(u16 PhyBlock
, u16
*LogStart
, u16
*LogEnde
)
1523 PhyBlock
/= MS_PHYSICAL_BLOCKS_PER_SEGMENT
;
1526 *LogStart
= MS_LOGICAL_BLOCKS_IN_1ST_SEGMENT
+ (PhyBlock
- 1) * MS_LOGICAL_BLOCKS_PER_SEGMENT
;/*496*/
1527 *LogEnde
= *LogStart
+ MS_LOGICAL_BLOCKS_PER_SEGMENT
;/*496*/
1530 *LogEnde
= MS_LOGICAL_BLOCKS_IN_1ST_SEGMENT
;/*494*/
1534 static int ms_lib_read_extrablock(struct us_data
*us
, u32 PhyBlock
,
1535 u8 PageNum
, u8 blen
, void *buf
)
1537 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
1540 /* Read Extra Data */
1541 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1542 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1543 bcb
->DataTransferLength
= 0x4 * blen
;
1544 bcb
->Flags
= US_BULK_FLAG_IN
;
1547 bcb
->CDB
[5] = (unsigned char)(PageNum
);
1548 bcb
->CDB
[4] = (unsigned char)(PhyBlock
);
1549 bcb
->CDB
[3] = (unsigned char)(PhyBlock
>>8);
1550 bcb
->CDB
[2] = (unsigned char)(PhyBlock
>>16);
1553 result
= ene_send_scsi_cmd(us
, FDIR_READ
, buf
, 0);
1554 if (result
!= USB_STOR_XFER_GOOD
)
1555 return USB_STOR_TRANSPORT_ERROR
;
1557 return USB_STOR_TRANSPORT_GOOD
;
1560 static int ms_lib_scan_logicalblocknumber(struct us_data
*us
, u16 btBlk1st
)
1562 u16 PhyBlock
, newblk
, i
;
1563 u16 LogStart
, LogEnde
;
1564 struct ms_lib_type_extdat extdat
;
1565 u32 count
= 0, index
= 0;
1566 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1567 u8
*bbuf
= info
->bbuf
;
1569 for (PhyBlock
= 0; PhyBlock
< info
->MS_Lib
.NumberOfPhyBlock
;) {
1570 ms_lib_phy_to_log_range(PhyBlock
, &LogStart
, &LogEnde
);
1572 for (i
= 0; i
< MS_PHYSICAL_BLOCKS_PER_SEGMENT
; i
++, PhyBlock
++) {
1573 switch (ms_libconv_to_logical(info
, PhyBlock
)) {
1574 case MS_STATUS_ERROR
:
1580 if (count
== PhyBlock
) {
1581 ms_lib_read_extrablock(us
, PhyBlock
, 0, 0x80,
1585 index
= (PhyBlock
% 0x80) * 4;
1587 extdat
.ovrflg
= bbuf
[index
];
1588 extdat
.mngflg
= bbuf
[index
+1];
1589 extdat
.logadr
= memstick_logaddr(bbuf
[index
+2],
1592 if ((extdat
.ovrflg
& MS_REG_OVR_BKST
) != MS_REG_OVR_BKST_OK
) {
1593 ms_lib_setacquired_errorblock(us
, PhyBlock
);
1597 if ((extdat
.mngflg
& MS_REG_MNG_ATFLG
) == MS_REG_MNG_ATFLG_ATTBL
) {
1598 ms_lib_erase_phyblock(us
, PhyBlock
);
1602 if (extdat
.logadr
!= MS_LB_NOT_USED
) {
1603 if ((extdat
.logadr
< LogStart
) || (LogEnde
<= extdat
.logadr
)) {
1604 ms_lib_erase_phyblock(us
, PhyBlock
);
1608 newblk
= ms_libconv_to_physical(info
, extdat
.logadr
);
1610 if (newblk
!= MS_LB_NOT_USED
) {
1611 if (extdat
.logadr
== 0) {
1612 ms_lib_set_logicalpair(us
, extdat
.logadr
, PhyBlock
);
1613 if (ms_lib_check_disableblock(us
, btBlk1st
)) {
1614 ms_lib_set_logicalpair(us
, extdat
.logadr
, newblk
);
1619 ms_lib_read_extra(us
, newblk
, 0, &extdat
);
1620 if ((extdat
.ovrflg
& MS_REG_OVR_UDST
) == MS_REG_OVR_UDST_UPDATING
) {
1621 ms_lib_erase_phyblock(us
, PhyBlock
);
1624 ms_lib_erase_phyblock(us
, newblk
);
1628 ms_lib_set_logicalpair(us
, extdat
.logadr
, PhyBlock
);
1633 return MS_STATUS_SUCCESS
;
1637 static int ms_scsi_read(struct us_data
*us
, struct scsi_cmnd
*srb
)
1640 unsigned char *cdb
= srb
->cmnd
;
1641 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
1642 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1644 u32 bn
= ((cdb
[2] << 24) & 0xff000000) | ((cdb
[3] << 16) & 0x00ff0000) |
1645 ((cdb
[4] << 8) & 0x0000ff00) | ((cdb
[5] << 0) & 0x000000ff);
1646 u16 blen
= ((cdb
[7] << 8) & 0xff00) | ((cdb
[8] << 0) & 0x00ff);
1647 u32 blenByte
= blen
* 0x200;
1649 if (bn
> info
->bl_num
)
1650 return USB_STOR_TRANSPORT_ERROR
;
1652 if (info
->MS_Status
.IsMSPro
) {
1653 result
= ene_load_bincode(us
, MSP_RW_PATTERN
);
1654 if (result
!= USB_STOR_XFER_GOOD
) {
1655 usb_stor_dbg(us
, "Load MPS RW pattern Fail !!\n");
1656 return USB_STOR_TRANSPORT_ERROR
;
1659 /* set up the command wrapper */
1660 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1661 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1662 bcb
->DataTransferLength
= blenByte
;
1663 bcb
->Flags
= US_BULK_FLAG_IN
;
1666 bcb
->CDB
[5] = (unsigned char)(bn
);
1667 bcb
->CDB
[4] = (unsigned char)(bn
>>8);
1668 bcb
->CDB
[3] = (unsigned char)(bn
>>16);
1669 bcb
->CDB
[2] = (unsigned char)(bn
>>24);
1671 result
= ene_send_scsi_cmd(us
, FDIR_READ
, scsi_sglist(srb
), 1);
1680 buf
= kmalloc(blenByte
, GFP_KERNEL
);
1682 return USB_STOR_TRANSPORT_ERROR
;
1684 result
= ene_load_bincode(us
, MS_RW_PATTERN
);
1685 if (result
!= USB_STOR_XFER_GOOD
) {
1686 pr_info("Load MS RW pattern Fail !!\n");
1687 result
= USB_STOR_TRANSPORT_ERROR
;
1691 logblk
= (u16
)(bn
/ info
->MS_Lib
.PagesPerBlock
);
1692 PageNum
= (u8
)(bn
% info
->MS_Lib
.PagesPerBlock
);
1695 if (blen
> (info
->MS_Lib
.PagesPerBlock
-PageNum
))
1696 len
= info
->MS_Lib
.PagesPerBlock
-PageNum
;
1700 phyblk
= ms_libconv_to_physical(info
, logblk
);
1701 blkno
= phyblk
* 0x20 + PageNum
;
1703 /* set up the command wrapper */
1704 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1705 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1706 bcb
->DataTransferLength
= 0x200 * len
;
1707 bcb
->Flags
= US_BULK_FLAG_IN
;
1710 bcb
->CDB
[5] = (unsigned char)(blkno
);
1711 bcb
->CDB
[4] = (unsigned char)(blkno
>>8);
1712 bcb
->CDB
[3] = (unsigned char)(blkno
>>16);
1713 bcb
->CDB
[2] = (unsigned char)(blkno
>>24);
1715 result
= ene_send_scsi_cmd(us
, FDIR_READ
, buf
+offset
, 0);
1716 if (result
!= USB_STOR_XFER_GOOD
) {
1717 pr_info("MS_SCSI_Read --- result = %x\n", result
);
1718 result
= USB_STOR_TRANSPORT_ERROR
;
1727 offset
+= MS_BYTES_PER_PAGE
*len
;
1729 usb_stor_set_xfer_buf(buf
, blenByte
, srb
);
1736 static int ms_scsi_write(struct us_data
*us
, struct scsi_cmnd
*srb
)
1739 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
1740 unsigned char *cdb
= srb
->cmnd
;
1741 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1743 u32 bn
= ((cdb
[2] << 24) & 0xff000000) |
1744 ((cdb
[3] << 16) & 0x00ff0000) |
1745 ((cdb
[4] << 8) & 0x0000ff00) |
1746 ((cdb
[5] << 0) & 0x000000ff);
1747 u16 blen
= ((cdb
[7] << 8) & 0xff00) | ((cdb
[8] << 0) & 0x00ff);
1748 u32 blenByte
= blen
* 0x200;
1750 if (bn
> info
->bl_num
)
1751 return USB_STOR_TRANSPORT_ERROR
;
1753 if (info
->MS_Status
.IsMSPro
) {
1754 result
= ene_load_bincode(us
, MSP_RW_PATTERN
);
1755 if (result
!= USB_STOR_XFER_GOOD
) {
1756 pr_info("Load MSP RW pattern Fail !!\n");
1757 return USB_STOR_TRANSPORT_ERROR
;
1760 /* set up the command wrapper */
1761 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1762 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1763 bcb
->DataTransferLength
= blenByte
;
1767 bcb
->CDB
[5] = (unsigned char)(bn
);
1768 bcb
->CDB
[4] = (unsigned char)(bn
>>8);
1769 bcb
->CDB
[3] = (unsigned char)(bn
>>16);
1770 bcb
->CDB
[2] = (unsigned char)(bn
>>24);
1772 result
= ene_send_scsi_cmd(us
, FDIR_WRITE
, scsi_sglist(srb
), 1);
1778 u16 len
, oldphy
, newphy
;
1780 buf
= kmalloc(blenByte
, GFP_KERNEL
);
1782 return USB_STOR_TRANSPORT_ERROR
;
1783 usb_stor_set_xfer_buf(buf
, blenByte
, srb
);
1785 result
= ene_load_bincode(us
, MS_RW_PATTERN
);
1786 if (result
!= USB_STOR_XFER_GOOD
) {
1787 pr_info("Load MS RW pattern Fail !!\n");
1788 result
= USB_STOR_TRANSPORT_ERROR
;
1792 PhyBlockAddr
= (u16
)(bn
/ info
->MS_Lib
.PagesPerBlock
);
1793 PageNum
= (u8
)(bn
% info
->MS_Lib
.PagesPerBlock
);
1796 if (blen
> (info
->MS_Lib
.PagesPerBlock
-PageNum
))
1797 len
= info
->MS_Lib
.PagesPerBlock
-PageNum
;
1801 oldphy
= ms_libconv_to_physical(info
, PhyBlockAddr
); /* need check us <-> info */
1802 newphy
= ms_libsearch_block_from_logical(us
, PhyBlockAddr
);
1804 result
= ms_read_copyblock(us
, oldphy
, newphy
, PhyBlockAddr
, PageNum
, buf
+offset
, len
);
1806 if (result
!= USB_STOR_XFER_GOOD
) {
1807 pr_info("MS_SCSI_Write --- result = %x\n", result
);
1808 result
= USB_STOR_TRANSPORT_ERROR
;
1812 info
->MS_Lib
.Phy2LogMap
[oldphy
] = MS_LB_NOT_USED_ERASED
;
1813 ms_lib_force_setlogical_pair(us
, PhyBlockAddr
, newphy
);
1820 offset
+= MS_BYTES_PER_PAGE
*len
;
1832 static int ene_get_card_type(struct us_data
*us
, u16 index
, void *buf
)
1834 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
1837 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1838 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1839 bcb
->DataTransferLength
= 0x01;
1840 bcb
->Flags
= US_BULK_FLAG_IN
;
1842 bcb
->CDB
[2] = (unsigned char)(index
>>8);
1843 bcb
->CDB
[3] = (unsigned char)index
;
1845 result
= ene_send_scsi_cmd(us
, FDIR_READ
, buf
, 0);
1849 static int ene_get_card_status(struct us_data
*us
, u8
*buf
)
1853 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1855 /*usb_stor_dbg(us, "transport --- ENE_ReadSDReg\n");*/
1856 reg4b
= *(u32
*)&buf
[0x18];
1857 info
->SD_READ_BL_LEN
= (u8
)((reg4b
>> 8) & 0x0f);
1859 tmpreg
= (u16
) reg4b
;
1860 reg4b
= *(u32
*)(&buf
[0x14]);
1861 if (info
->SD_Status
.HiCapacity
&& !info
->SD_Status
.IsMMC
)
1862 info
->HC_C_SIZE
= (reg4b
>> 8) & 0x3fffff;
1864 info
->SD_C_SIZE
= ((tmpreg
& 0x03) << 10) | (u16
)(reg4b
>> 22);
1865 info
->SD_C_SIZE_MULT
= (u8
)(reg4b
>> 7) & 0x07;
1866 if (info
->SD_Status
.HiCapacity
&& info
->SD_Status
.IsMMC
)
1867 info
->HC_C_SIZE
= *(u32
*)(&buf
[0x100]);
1869 if (info
->SD_READ_BL_LEN
> SD_BLOCK_LEN
) {
1870 info
->SD_Block_Mult
= 1 << (info
->SD_READ_BL_LEN
-SD_BLOCK_LEN
);
1871 info
->SD_READ_BL_LEN
= SD_BLOCK_LEN
;
1873 info
->SD_Block_Mult
= 1;
1876 return USB_STOR_TRANSPORT_GOOD
;
1879 static int ene_load_bincode(struct us_data
*us
, unsigned char flag
)
1882 char *fw_name
= NULL
;
1883 unsigned char *buf
= NULL
;
1884 const struct firmware
*sd_fw
= NULL
;
1885 int result
= USB_STOR_TRANSPORT_ERROR
;
1886 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
1887 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1889 if (info
->BIN_FLAG
== flag
)
1890 return USB_STOR_TRANSPORT_GOOD
;
1894 case SD_INIT1_PATTERN
:
1895 usb_stor_dbg(us
, "SD_INIT1_PATTERN\n");
1896 fw_name
= SD_INIT1_FIRMWARE
;
1898 case SD_INIT2_PATTERN
:
1899 usb_stor_dbg(us
, "SD_INIT2_PATTERN\n");
1900 fw_name
= SD_INIT2_FIRMWARE
;
1903 usb_stor_dbg(us
, "SD_RW_PATTERN\n");
1904 fw_name
= SD_RW_FIRMWARE
;
1907 case MS_INIT_PATTERN
:
1908 usb_stor_dbg(us
, "MS_INIT_PATTERN\n");
1909 fw_name
= MS_INIT_FIRMWARE
;
1911 case MSP_RW_PATTERN
:
1912 usb_stor_dbg(us
, "MSP_RW_PATTERN\n");
1913 fw_name
= MSP_RW_FIRMWARE
;
1916 usb_stor_dbg(us
, "MS_RW_PATTERN\n");
1917 fw_name
= MS_RW_FIRMWARE
;
1920 usb_stor_dbg(us
, "----------- Unknown PATTERN ----------\n");
1924 err
= request_firmware(&sd_fw
, fw_name
, &us
->pusb_dev
->dev
);
1926 usb_stor_dbg(us
, "load firmware %s failed\n", fw_name
);
1929 buf
= kmemdup(sd_fw
->data
, sd_fw
->size
, GFP_KERNEL
);
1933 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
1934 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
1935 bcb
->DataTransferLength
= sd_fw
->size
;
1939 result
= ene_send_scsi_cmd(us
, FDIR_WRITE
, buf
, 0);
1940 if (us
->srb
!= NULL
)
1941 scsi_set_resid(us
->srb
, 0);
1942 info
->BIN_FLAG
= flag
;
1946 release_firmware(sd_fw
);
1950 static int ms_card_init(struct us_data
*us
)
1954 unsigned char *PageBuffer0
= NULL
, *PageBuffer1
= NULL
;
1955 struct ms_lib_type_extdat extdat
;
1956 u16 btBlk1st
, btBlk2nd
;
1958 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
1960 printk(KERN_INFO
"MS_CardInit start\n");
1962 ms_lib_free_allocatedarea(us
); /* Clean buffer and set struct us_data flag to 0 */
1964 /* get two PageBuffer */
1965 PageBuffer0
= kmalloc(MS_BYTES_PER_PAGE
, GFP_KERNEL
);
1966 PageBuffer1
= kmalloc(MS_BYTES_PER_PAGE
, GFP_KERNEL
);
1967 if ((PageBuffer0
== NULL
) || (PageBuffer1
== NULL
)) {
1968 result
= MS_NO_MEMORY_ERROR
;
1972 btBlk1st
= btBlk2nd
= MS_LB_NOT_USED
;
1975 for (TmpBlock
= 0; TmpBlock
< MS_MAX_INITIAL_ERROR_BLOCKS
+2; TmpBlock
++) {
1977 switch (ms_read_readpage(us
, TmpBlock
, 0, (u32
*)PageBuffer0
, &extdat
)) {
1978 case MS_STATUS_SUCCESS
:
1980 case MS_STATUS_INT_ERROR
:
1982 case MS_STATUS_ERROR
:
1987 if ((extdat
.ovrflg
& MS_REG_OVR_BKST
) == MS_REG_OVR_BKST_NG
)
1990 if (((extdat
.mngflg
& MS_REG_MNG_SYSFLG
) == MS_REG_MNG_SYSFLG_USER
) ||
1991 (be16_to_cpu(((struct ms_bootblock_page0
*)PageBuffer0
)->header
.wBlockID
) != MS_BOOT_BLOCK_ID
) ||
1992 (be16_to_cpu(((struct ms_bootblock_page0
*)PageBuffer0
)->header
.wFormatVersion
) != MS_BOOT_BLOCK_FORMAT_VERSION
) ||
1993 (((struct ms_bootblock_page0
*)PageBuffer0
)->header
.bNumberOfDataEntry
!= MS_BOOT_BLOCK_DATA_ENTRIES
))
1996 if (btBlk1st
!= MS_LB_NOT_USED
) {
1997 btBlk2nd
= TmpBlock
;
2001 btBlk1st
= TmpBlock
;
2002 memcpy(PageBuffer1
, PageBuffer0
, MS_BYTES_PER_PAGE
);
2003 if (extdat
.status1
& (MS_REG_ST1_DTER
| MS_REG_ST1_EXER
| MS_REG_ST1_FGER
))
2007 if (btBlk1st
== MS_LB_NOT_USED
) {
2008 result
= MS_STATUS_ERROR
;
2013 if ((extdat
.status0
& MS_REG_ST0_WP
) == MS_REG_ST0_WP_ON
)
2014 ms_lib_ctrl_set(info
, MS_LIB_CTRL_WRPROTECT
);
2016 result
= MS_STATUS_ERROR
;
2017 /* 1st Boot Block */
2018 if (btBlk1stErred
== 0)
2019 result
= ms_lib_process_bootblock(us
, btBlk1st
, PageBuffer1
);
2021 /* 2nd Boot Block */
2022 if (result
&& (btBlk2nd
!= MS_LB_NOT_USED
))
2023 result
= ms_lib_process_bootblock(us
, btBlk2nd
, PageBuffer0
);
2026 result
= MS_STATUS_ERROR
;
2030 for (TmpBlock
= 0; TmpBlock
< btBlk1st
; TmpBlock
++)
2031 info
->MS_Lib
.Phy2LogMap
[TmpBlock
] = MS_LB_INITIAL_ERROR
;
2033 info
->MS_Lib
.Phy2LogMap
[btBlk1st
] = MS_LB_BOOT_BLOCK
;
2035 if (btBlk2nd
!= MS_LB_NOT_USED
) {
2036 for (TmpBlock
= btBlk1st
+ 1; TmpBlock
< btBlk2nd
; TmpBlock
++)
2037 info
->MS_Lib
.Phy2LogMap
[TmpBlock
] = MS_LB_INITIAL_ERROR
;
2039 info
->MS_Lib
.Phy2LogMap
[btBlk2nd
] = MS_LB_BOOT_BLOCK
;
2042 result
= ms_lib_scan_logicalblocknumber(us
, btBlk1st
);
2046 for (TmpBlock
= MS_PHYSICAL_BLOCKS_PER_SEGMENT
;
2047 TmpBlock
< info
->MS_Lib
.NumberOfPhyBlock
;
2048 TmpBlock
+= MS_PHYSICAL_BLOCKS_PER_SEGMENT
) {
2049 if (ms_count_freeblock(us
, TmpBlock
) == 0) {
2050 ms_lib_ctrl_set(info
, MS_LIB_CTRL_WRPROTECT
);
2056 if (ms_lib_alloc_writebuf(us
)) {
2057 result
= MS_NO_MEMORY_ERROR
;
2061 result
= MS_STATUS_SUCCESS
;
2067 printk(KERN_INFO
"MS_CardInit end\n");
2071 static int ene_ms_init(struct us_data
*us
)
2073 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
2075 u16 MSP_BlockSize
, MSP_UserAreaBlocks
;
2076 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
2077 u8
*bbuf
= info
->bbuf
;
2079 printk(KERN_INFO
"transport --- ENE_MSInit\n");
2081 /* the same part to test ENE */
2083 result
= ene_load_bincode(us
, MS_INIT_PATTERN
);
2084 if (result
!= USB_STOR_XFER_GOOD
) {
2085 printk(KERN_ERR
"Load MS Init Code Fail !!\n");
2086 return USB_STOR_TRANSPORT_ERROR
;
2089 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
2090 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
2091 bcb
->DataTransferLength
= 0x200;
2092 bcb
->Flags
= US_BULK_FLAG_IN
;
2096 result
= ene_send_scsi_cmd(us
, FDIR_READ
, bbuf
, 0);
2097 if (result
!= USB_STOR_XFER_GOOD
) {
2098 printk(KERN_ERR
"Execution MS Init Code Fail !!\n");
2099 return USB_STOR_TRANSPORT_ERROR
;
2101 /* the same part to test ENE */
2102 info
->MS_Status
= *(struct MS_STATUS
*) bbuf
;
2104 if (info
->MS_Status
.Insert
&& info
->MS_Status
.Ready
) {
2105 printk(KERN_INFO
"Insert = %x\n", info
->MS_Status
.Insert
);
2106 printk(KERN_INFO
"Ready = %x\n", info
->MS_Status
.Ready
);
2107 printk(KERN_INFO
"IsMSPro = %x\n", info
->MS_Status
.IsMSPro
);
2108 printk(KERN_INFO
"IsMSPHG = %x\n", info
->MS_Status
.IsMSPHG
);
2109 printk(KERN_INFO
"WtP= %x\n", info
->MS_Status
.WtP
);
2110 if (info
->MS_Status
.IsMSPro
) {
2111 MSP_BlockSize
= (bbuf
[6] << 8) | bbuf
[7];
2112 MSP_UserAreaBlocks
= (bbuf
[10] << 8) | bbuf
[11];
2113 info
->MSP_TotalBlock
= MSP_BlockSize
* MSP_UserAreaBlocks
;
2115 ms_card_init(us
); /* Card is MS (to ms.c)*/
2117 usb_stor_dbg(us
, "MS Init Code OK !!\n");
2119 usb_stor_dbg(us
, "MS Card Not Ready --- %x\n", bbuf
[0]);
2120 return USB_STOR_TRANSPORT_ERROR
;
2123 return USB_STOR_TRANSPORT_GOOD
;
2126 static int ene_sd_init(struct us_data
*us
)
2129 struct bulk_cb_wrap
*bcb
= (struct bulk_cb_wrap
*) us
->iobuf
;
2130 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*) us
->extra
;
2131 u8
*bbuf
= info
->bbuf
;
2133 usb_stor_dbg(us
, "transport --- ENE_SDInit\n");
2134 /* SD Init Part-1 */
2135 result
= ene_load_bincode(us
, SD_INIT1_PATTERN
);
2136 if (result
!= USB_STOR_XFER_GOOD
) {
2137 usb_stor_dbg(us
, "Load SD Init Code Part-1 Fail !!\n");
2138 return USB_STOR_TRANSPORT_ERROR
;
2141 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
2142 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
2143 bcb
->Flags
= US_BULK_FLAG_IN
;
2146 result
= ene_send_scsi_cmd(us
, FDIR_READ
, NULL
, 0);
2147 if (result
!= USB_STOR_XFER_GOOD
) {
2148 usb_stor_dbg(us
, "Execution SD Init Code Fail !!\n");
2149 return USB_STOR_TRANSPORT_ERROR
;
2152 /* SD Init Part-2 */
2153 result
= ene_load_bincode(us
, SD_INIT2_PATTERN
);
2154 if (result
!= USB_STOR_XFER_GOOD
) {
2155 usb_stor_dbg(us
, "Load SD Init Code Part-2 Fail !!\n");
2156 return USB_STOR_TRANSPORT_ERROR
;
2159 memset(bcb
, 0, sizeof(struct bulk_cb_wrap
));
2160 bcb
->Signature
= cpu_to_le32(US_BULK_CB_SIGN
);
2161 bcb
->DataTransferLength
= 0x200;
2162 bcb
->Flags
= US_BULK_FLAG_IN
;
2165 result
= ene_send_scsi_cmd(us
, FDIR_READ
, bbuf
, 0);
2166 if (result
!= USB_STOR_XFER_GOOD
) {
2167 usb_stor_dbg(us
, "Execution SD Init Code Fail !!\n");
2168 return USB_STOR_TRANSPORT_ERROR
;
2171 info
->SD_Status
= *(struct SD_STATUS
*) bbuf
;
2172 if (info
->SD_Status
.Insert
&& info
->SD_Status
.Ready
) {
2173 struct SD_STATUS
*s
= &info
->SD_Status
;
2175 ene_get_card_status(us
, bbuf
);
2176 usb_stor_dbg(us
, "Insert = %x\n", s
->Insert
);
2177 usb_stor_dbg(us
, "Ready = %x\n", s
->Ready
);
2178 usb_stor_dbg(us
, "IsMMC = %x\n", s
->IsMMC
);
2179 usb_stor_dbg(us
, "HiCapacity = %x\n", s
->HiCapacity
);
2180 usb_stor_dbg(us
, "HiSpeed = %x\n", s
->HiSpeed
);
2181 usb_stor_dbg(us
, "WtP = %x\n", s
->WtP
);
2183 usb_stor_dbg(us
, "SD Card Not Ready --- %x\n", bbuf
[0]);
2184 return USB_STOR_TRANSPORT_ERROR
;
2186 return USB_STOR_TRANSPORT_GOOD
;
2190 static int ene_init(struct us_data
*us
)
2194 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*)(us
->extra
);
2195 u8
*bbuf
= info
->bbuf
;
2197 result
= ene_get_card_type(us
, REG_CARD_STATUS
, bbuf
);
2198 if (result
!= USB_STOR_XFER_GOOD
)
2199 return USB_STOR_TRANSPORT_ERROR
;
2201 misc_reg03
= bbuf
[0];
2202 if (misc_reg03
& 0x01) {
2203 if (!info
->SD_Status
.Ready
) {
2204 result
= ene_sd_init(us
);
2205 if (result
!= USB_STOR_XFER_GOOD
)
2206 return USB_STOR_TRANSPORT_ERROR
;
2209 if (misc_reg03
& 0x02) {
2210 if (!info
->MS_Status
.Ready
) {
2211 result
= ene_ms_init(us
);
2212 if (result
!= USB_STOR_XFER_GOOD
)
2213 return USB_STOR_TRANSPORT_ERROR
;
2219 /*----- sd_scsi_irp() ---------*/
2220 static int sd_scsi_irp(struct us_data
*us
, struct scsi_cmnd
*srb
)
2223 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*)us
->extra
;
2225 switch (srb
->cmnd
[0]) {
2226 case TEST_UNIT_READY
:
2227 result
= sd_scsi_test_unit_ready(us
, srb
);
2230 result
= do_scsi_request_sense(us
, srb
);
2233 result
= do_scsi_inquiry(us
, srb
);
2236 result
= sd_scsi_mode_sense(us
, srb
);
2240 result = SD_SCSI_Start_Stop(us, srb);
2244 result
= sd_scsi_read_capacity(us
, srb
);
2247 result
= sd_scsi_read(us
, srb
);
2250 result
= sd_scsi_write(us
, srb
);
2253 info
->SrbStatus
= SS_ILLEGAL_REQUEST
;
2254 result
= USB_STOR_TRANSPORT_FAILED
;
2257 if (result
== USB_STOR_TRANSPORT_GOOD
)
2258 info
->SrbStatus
= SS_SUCCESS
;
2265 static int ms_scsi_irp(struct us_data
*us
, struct scsi_cmnd
*srb
)
2268 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*)us
->extra
;
2270 switch (srb
->cmnd
[0]) {
2271 case TEST_UNIT_READY
:
2272 result
= ms_scsi_test_unit_ready(us
, srb
);
2275 result
= do_scsi_request_sense(us
, srb
);
2278 result
= do_scsi_inquiry(us
, srb
);
2281 result
= ms_scsi_mode_sense(us
, srb
);
2284 result
= ms_scsi_read_capacity(us
, srb
);
2287 result
= ms_scsi_read(us
, srb
);
2290 result
= ms_scsi_write(us
, srb
);
2293 info
->SrbStatus
= SS_ILLEGAL_REQUEST
;
2294 result
= USB_STOR_TRANSPORT_FAILED
;
2297 if (result
== USB_STOR_TRANSPORT_GOOD
)
2298 info
->SrbStatus
= SS_SUCCESS
;
2302 static int ene_transport(struct scsi_cmnd
*srb
, struct us_data
*us
)
2304 int result
= USB_STOR_XFER_GOOD
;
2305 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*)(us
->extra
);
2307 /*US_DEBUG(usb_stor_show_command(us, srb)); */
2308 scsi_set_resid(srb
, 0);
2309 if (unlikely(!(info
->SD_Status
.Ready
|| info
->MS_Status
.Ready
)))
2310 result
= ene_init(us
);
2311 if (result
== USB_STOR_XFER_GOOD
) {
2312 result
= USB_STOR_TRANSPORT_ERROR
;
2313 if (info
->SD_Status
.Ready
)
2314 result
= sd_scsi_irp(us
, srb
);
2316 if (info
->MS_Status
.Ready
)
2317 result
= ms_scsi_irp(us
, srb
);
2322 static struct scsi_host_template ene_ub6250_host_template
;
2324 static int ene_ub6250_probe(struct usb_interface
*intf
,
2325 const struct usb_device_id
*id
)
2330 struct ene_ub6250_info
*info
;
2332 result
= usb_stor_probe1(&us
, intf
, id
,
2333 (id
- ene_ub6250_usb_ids
) + ene_ub6250_unusual_dev_list
,
2334 &ene_ub6250_host_template
);
2338 /* FIXME: where should the code alloc extra buf ? */
2339 us
->extra
= kzalloc(sizeof(struct ene_ub6250_info
), GFP_KERNEL
);
2342 us
->extra_destructor
= ene_ub6250_info_destructor
;
2344 info
= (struct ene_ub6250_info
*)(us
->extra
);
2345 info
->bbuf
= kmalloc(512, GFP_KERNEL
);
2351 us
->transport_name
= "ene_ub6250";
2352 us
->transport
= ene_transport
;
2355 result
= usb_stor_probe2(us
);
2359 /* probe card type */
2360 result
= ene_get_card_type(us
, REG_CARD_STATUS
, info
->bbuf
);
2361 if (result
!= USB_STOR_XFER_GOOD
) {
2362 usb_stor_disconnect(intf
);
2363 return USB_STOR_TRANSPORT_ERROR
;
2366 misc_reg03
= info
->bbuf
[0];
2367 if (!(misc_reg03
& 0x01)) {
2368 pr_info("ums_eneub6250: This driver only supports SD/MS cards. "
2369 "It does not support SM cards.\n");
2378 static int ene_ub6250_resume(struct usb_interface
*iface
)
2381 struct us_data
*us
= usb_get_intfdata(iface
);
2382 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*)(us
->extra
);
2384 mutex_lock(&us
->dev_mutex
);
2386 if (us
->suspend_resume_hook
)
2387 (us
->suspend_resume_hook
)(us
, US_RESUME
);
2389 mutex_unlock(&us
->dev_mutex
);
2391 info
->Power_IsResum
= true;
2392 /*info->SD_Status.Ready = 0; */
2393 info
->SD_Status
= *(struct SD_STATUS
*)&tmp
;
2394 info
->MS_Status
= *(struct MS_STATUS
*)&tmp
;
2395 info
->SM_Status
= *(struct SM_STATUS
*)&tmp
;
2400 static int ene_ub6250_reset_resume(struct usb_interface
*iface
)
2403 struct us_data
*us
= usb_get_intfdata(iface
);
2404 struct ene_ub6250_info
*info
= (struct ene_ub6250_info
*)(us
->extra
);
2406 /* Report the reset to the SCSI core */
2407 usb_stor_reset_resume(iface
);
2410 * FIXME: Notify the subdrivers that they need to reinitialize
2413 info
->Power_IsResum
= true;
2414 /*info->SD_Status.Ready = 0; */
2415 info
->SD_Status
= *(struct SD_STATUS
*)&tmp
;
2416 info
->MS_Status
= *(struct MS_STATUS
*)&tmp
;
2417 info
->SM_Status
= *(struct SM_STATUS
*)&tmp
;
2424 #define ene_ub6250_resume NULL
2425 #define ene_ub6250_reset_resume NULL
2429 static struct usb_driver ene_ub6250_driver
= {
2431 .probe
= ene_ub6250_probe
,
2432 .disconnect
= usb_stor_disconnect
,
2433 .suspend
= usb_stor_suspend
,
2434 .resume
= ene_ub6250_resume
,
2435 .reset_resume
= ene_ub6250_reset_resume
,
2436 .pre_reset
= usb_stor_pre_reset
,
2437 .post_reset
= usb_stor_post_reset
,
2438 .id_table
= ene_ub6250_usb_ids
,
2443 module_usb_stor_driver(ene_ub6250_driver
, ene_ub6250_host_template
, DRV_NAME
);