Linux Audio

Check our new training course

Loading...
v6.13.7
   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>
   6
   7#include <scsi/scsi.h>
   8#include <scsi/scsi_cmnd.h>
   9
  10#include <linux/firmware.h>
  11
  12#include "usb.h"
  13#include "transport.h"
  14#include "protocol.h"
  15#include "debug.h"
  16#include "scsiglue.h"
  17
  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"
  24
  25#define DRV_NAME "ums_eneub6250"
  26
  27MODULE_DESCRIPTION("Driver for ENE UB6250 reader");
  28MODULE_LICENSE("GPL");
  29MODULE_IMPORT_NS("USB_STORAGE");
  30MODULE_FIRMWARE(SD_INIT1_FIRMWARE);
  31MODULE_FIRMWARE(SD_INIT2_FIRMWARE);
  32MODULE_FIRMWARE(SD_RW_FIRMWARE);
  33MODULE_FIRMWARE(MS_INIT_FIRMWARE);
  34MODULE_FIRMWARE(MSP_RW_FIRMWARE);
  35MODULE_FIRMWARE(MS_RW_FIRMWARE);
  36
  37/*
  38 * The table of devices
  39 */
  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)}
  45
  46static const struct usb_device_id ene_ub6250_usb_ids[] = {
  47#	include "unusual_ene_ub6250.h"
  48	{ }		/* Terminating entry */
  49};
  50MODULE_DEVICE_TABLE(usb, ene_ub6250_usb_ids);
  51
  52#undef UNUSUAL_DEV
  53
  54/*
  55 * The flags table
  56 */
  57#define UNUSUAL_DEV(idVendor, idProduct, bcdDeviceMin, bcdDeviceMax, \
  58		    vendor_name, product_name, use_protocol, use_transport, \
  59		    init_function, Flags) \
  60{ \
  61	.vendorName = vendor_name,	\
  62	.productName = product_name,	\
  63	.useProtocol = use_protocol,	\
  64	.useTransport = use_transport,	\
  65	.initFunction = init_function,	\
  66}
  67
  68static const struct us_unusual_dev ene_ub6250_unusual_dev_list[] = {
  69#	include "unusual_ene_ub6250.h"
  70	{ }		/* Terminating entry */
  71};
  72
  73#undef UNUSUAL_DEV
  74
  75
  76
  77/* ENE bin code len */
  78#define ENE_BIN_CODE_LEN    0x800
  79/* EnE HW Register */
  80#define REG_CARD_STATUS     0xFF83
  81#define REG_HW_TRAP1        0xFF89
  82
  83/* SRB Status */
  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 */
  90
  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
 100
 101#define FDIR_WRITE         0
 102#define FDIR_READ          1
 103
 104/* For MS Card */
 105
 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)
 116
 117/* Overwrite Area */
 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)
 132
 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)
 148
 149
 150#define MS_MAX_PAGES_PER_BLOCK		32
 151#define MS_MAX_INITIAL_ERROR_BLOCKS 	10
 152#define MS_LIB_BITS_PER_BYTE		8
 153
 154#define MS_SYSINF_FORMAT_FAT		1
 155#define MS_SYSINF_USAGE_GENERAL		0
 156
 157#define MS_SYSINF_MSCLASS_TYPE_1	1
 158#define MS_SYSINF_PAGE_SIZE		MS_BYTES_PER_PAGE /* fixed */
 159
 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
 166
 167#define MS_SYSINF_RESERVED1		1
 168#define MS_SYSINF_RESERVED2		1
 169
 170#define MS_SYSENT_TYPE_INVALID_BLOCK	0x01
 171#define MS_SYSENT_TYPE_CIS_IDI		0x0a    /* CIS/IDI */
 172
 173#define SIZE_OF_KIRO		1024
 174#define BYTE_MASK		0xff
 175
 176/* ms error code */
 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
 192
 193#define MS_REG_MNG_SYSFLG	0x04    /* system flag */
 194#define MS_REG_MNG_SYSFLG_USER	MS_REG_MNG_SYSFLG   /* user block */
 195
 196#define MS_BOOT_BLOCK_ID                        0x0001
 197#define MS_BOOT_BLOCK_FORMAT_VERSION            0x0100
 198#define MS_BOOT_BLOCK_DATA_ENTRIES              2
 199
 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
 205
 206#define MS_PHYSICAL_BLOCKS_PER_SEGMENT		0x200 /* 512 */
 207#define MS_PHYSICAL_BLOCKS_PER_SEGMENT_MASK     0x1ff
 208
 209/* overwrite area */
 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 */
 213
 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) */
 218
 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
 223
 224#define MS_LIB_CTRL_RDONLY      0
 225#define MS_LIB_CTRL_WRPROTECT   1
 226
 227/*dphy->log table */
 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])
 230
 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)))
 234
 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))
 238
 239
 240/* SD_STATUS bits */
 241#define SD_Insert	BIT(0)
 242#define SD_Ready	BIT(1)
 243#define SD_MediaChange	BIT(2)
 244#define SD_IsMMC	BIT(3)
 245#define SD_HiCapacity	BIT(4)
 246#define SD_HiSpeed	BIT(5)
 247#define SD_WtP		BIT(6)
 248			/* Bit 7 reserved */
 249
 250/* MS_STATUS bits */
 251#define MS_Insert	BIT(0)
 252#define MS_Ready	BIT(1)
 253#define MS_MediaChange	BIT(2)
 254#define MS_IsMSPro	BIT(3)
 255#define MS_IsMSPHG	BIT(4)
 256			/* Bit 5 reserved */
 257#define MS_WtP		BIT(6)
 258			/* Bit 7 reserved */
 259
 260/* SM_STATUS bits */
 261#define SM_Insert	BIT(0)
 262#define SM_Ready	BIT(1)
 263#define SM_MediaChange	BIT(2)
 264			/* Bits 3-5 reserved */
 265#define SM_WtP		BIT(6)
 266#define SM_IsMS		BIT(7)
 
 
 
 267
 268struct ms_bootblock_cis {
 269	u8 bCistplDEVICE[6];    /* 0 */
 270	u8 bCistplDEVICE0C[6];  /* 6 */
 271	u8 bCistplJEDECC[4];    /* 12 */
 272	u8 bCistplMANFID[6];    /* 16 */
 273	u8 bCistplVER1[32];     /* 22 */
 274	u8 bCistplFUNCID[4];    /* 54 */
 275	u8 bCistplFUNCE0[4];    /* 58 */
 276	u8 bCistplFUNCE1[5];    /* 62 */
 277	u8 bCistplCONF[7];      /* 67 */
 278	u8 bCistplCFTBLENT0[10];/* 74 */
 279	u8 bCistplCFTBLENT1[8]; /* 84 */
 280	u8 bCistplCFTBLENT2[12];/* 92 */
 281	u8 bCistplCFTBLENT3[8]; /* 104 */
 282	u8 bCistplCFTBLENT4[17];/* 112 */
 283	u8 bCistplCFTBLENT5[8]; /* 129 */
 284	u8 bCistplCFTBLENT6[17];/* 137 */
 285	u8 bCistplCFTBLENT7[8]; /* 154 */
 286	u8 bCistplNOLINK[3];    /* 162 */
 287} ;
 288
 289struct ms_bootblock_idi {
 290#define MS_IDI_GENERAL_CONF 0x848A
 291	u16 wIDIgeneralConfiguration;	/* 0 */
 292	u16 wIDInumberOfCylinder;	/* 1 */
 293	u16 wIDIreserved0;		/* 2 */
 294	u16 wIDInumberOfHead;		/* 3 */
 295	u16 wIDIbytesPerTrack;		/* 4 */
 296	u16 wIDIbytesPerSector;		/* 5 */
 297	u16 wIDIsectorsPerTrack;	/* 6 */
 298	u16 wIDItotalSectors[2];	/* 7-8  high,low */
 299	u16 wIDIreserved1[11];		/* 9-19 */
 300	u16 wIDIbufferType;		/* 20 */
 301	u16 wIDIbufferSize;		/* 21 */
 302	u16 wIDIlongCmdECC;		/* 22 */
 303	u16 wIDIfirmVersion[4];		/* 23-26 */
 304	u16 wIDImodelName[20];		/* 27-46 */
 305	u16 wIDIreserved2;		/* 47 */
 306	u16 wIDIlongWordSupported;	/* 48 */
 307	u16 wIDIdmaSupported;		/* 49 */
 308	u16 wIDIreserved3;		/* 50 */
 309	u16 wIDIpioTiming;		/* 51 */
 310	u16 wIDIdmaTiming;		/* 52 */
 311	u16 wIDItransferParameter;	/* 53 */
 312	u16 wIDIformattedCylinder;	/* 54 */
 313	u16 wIDIformattedHead;		/* 55 */
 314	u16 wIDIformattedSectorsPerTrack;/* 56 */
 315	u16 wIDIformattedTotalSectors[2];/* 57-58 */
 316	u16 wIDImultiSector;		/* 59 */
 317	u16 wIDIlbaSectors[2];		/* 60-61 */
 318	u16 wIDIsingleWordDMA;		/* 62 */
 319	u16 wIDImultiWordDMA;		/* 63 */
 320	u16 wIDIreserved4[192];		/* 64-255 */
 321};
 322
 323struct ms_bootblock_sysent_rec {
 324	u32 dwStart;
 325	u32 dwSize;
 326	u8 bType;
 327	u8 bReserved[3];
 328};
 329
 330struct ms_bootblock_sysent {
 331	struct ms_bootblock_sysent_rec entry[MS_NUMBER_OF_SYSTEM_ENTRY];
 332};
 333
 334struct ms_bootblock_sysinf {
 335	u8 bMsClass;			/* must be 1 */
 336	u8 bCardType;			/* see below */
 337	u16 wBlockSize;			/* n KB */
 338	u16 wBlockNumber;		/* number of physical block */
 339	u16 wTotalBlockNumber;		/* number of logical block */
 340	u16 wPageSize;			/* must be 0x200 */
 341	u8 bExtraSize;			/* 0x10 */
 342	u8 bSecuritySupport;
 343	u8 bAssemblyDate[8];
 344	u8 bFactoryArea[4];
 345	u8 bAssemblyMakerCode;
 346	u8 bAssemblyMachineCode[3];
 347	u16 wMemoryMakerCode;
 348	u16 wMemoryDeviceCode;
 349	u16 wMemorySize;
 350	u8 bReserved1;
 351	u8 bReserved2;
 352	u8 bVCC;
 353	u8 bVPP;
 354	u16 wControllerChipNumber;
 355	u16 wControllerFunction;	/* New MS */
 356	u8 bReserved3[9];		/* New MS */
 357	u8 bParallelSupport;		/* New MS */
 358	u16 wFormatValue;		/* New MS */
 359	u8 bFormatType;
 360	u8 bUsage;
 361	u8 bDeviceType;
 362	u8 bReserved4[22];
 363	u8 bFUValue3;
 364	u8 bFUValue4;
 365	u8 bReserved5[15];
 366};
 367
 368struct ms_bootblock_header {
 369	u16 wBlockID;
 370	u16 wFormatVersion;
 371	u8 bReserved1[184];
 372	u8 bNumberOfDataEntry;
 373	u8 bReserved2[179];
 374};
 375
 376struct ms_bootblock_page0 {
 377	struct ms_bootblock_header header;
 378	struct ms_bootblock_sysent sysent;
 379	struct ms_bootblock_sysinf sysinf;
 380};
 381
 382struct ms_bootblock_cis_idi {
 383	union {
 384		struct ms_bootblock_cis cis;
 385		u8 dmy[256];
 386	} cis;
 387
 388	union {
 389		struct ms_bootblock_idi idi;
 390		u8 dmy[256];
 391	} idi;
 392
 393};
 394
 395/* ENE MS Lib struct */
 396struct ms_lib_type_extdat {
 397	u8 reserved;
 398	u8 intr;
 399	u8 status0;
 400	u8 status1;
 401	u8 ovrflg;
 402	u8 mngflg;
 403	u16 logadr;
 404};
 405
 406struct ms_lib_ctrl {
 407	u32 flags;
 408	u32 BytesPerSector;
 409	u32 NumberOfCylinder;
 410	u32 SectorsPerCylinder;
 411	u16 cardType;			/* R/W, RO, Hybrid */
 412	u16 blockSize;
 413	u16 PagesPerBlock;
 414	u16 NumberOfPhyBlock;
 415	u16 NumberOfLogBlock;
 416	u16 NumberOfSegment;
 417	u16 *Phy2LogMap;		/* phy2log table */
 418	u16 *Log2PhyMap;		/* log2phy table */
 419	u16 wrtblk;
 420	unsigned char *pagemap[(MS_MAX_PAGES_PER_BLOCK + (MS_LIB_BITS_PER_BYTE-1)) / MS_LIB_BITS_PER_BYTE];
 421	unsigned char *blkpag;
 422	struct ms_lib_type_extdat *blkext;
 423	unsigned char copybuf[512];
 424};
 425
 426
 427/* SD Block Length */
 428/* 2^9 = 512 Bytes, The HW maximum read/write data length */
 429#define SD_BLOCK_LEN  9
 430
 431struct ene_ub6250_info {
 432
 433	/* I/O bounce buffer */
 434	u8		*bbuf;
 435
 436	/* for 6250 code */
 437	u8		SD_Status;
 438	u8		MS_Status;
 439	u8		SM_Status;
 440
 441	/* ----- SD Control Data ---------------- */
 442	/*SD_REGISTER SD_Regs; */
 443	u16		SD_Block_Mult;
 444	u8		SD_READ_BL_LEN;
 445	u16		SD_C_SIZE;
 446	u8		SD_C_SIZE_MULT;
 447
 448	/* SD/MMC New spec. */
 449	u8		SD_SPEC_VER;
 450	u8		SD_CSD_VER;
 451	u8		SD20_HIGH_CAPACITY;
 452	u32		HC_C_SIZE;
 453	u8		MMC_SPEC_VER;
 454	u8		MMC_BusWidth;
 455	u8		MMC_HIGH_CAPACITY;
 456
 457	/*----- MS Control Data ---------------- */
 458	bool		MS_SWWP;
 459	u32		MSP_TotalBlock;
 460	struct ms_lib_ctrl MS_Lib;
 461	bool		MS_IsRWPage;
 462	u16		MS_Model;
 463
 464	/*----- SM Control Data ---------------- */
 465	u8		SM_DeviceID;
 466	u8		SM_CardID;
 467
 468	unsigned char	*testbuf;
 469	u8		BIN_FLAG;
 470	u32		bl_num;
 471	int		SrbStatus;
 472
 473	/*------Power Managerment ---------------*/
 474	bool		Power_IsResum;
 475};
 476
 477static int ene_sd_init(struct us_data *us);
 478static int ene_ms_init(struct us_data *us);
 479static int ene_load_bincode(struct us_data *us, unsigned char flag);
 480
 481static void ene_ub6250_info_destructor(void *extra)
 482{
 483	struct ene_ub6250_info *info = (struct ene_ub6250_info *) extra;
 484
 485	if (!extra)
 486		return;
 487	kfree(info->bbuf);
 488}
 489
 490static int ene_send_scsi_cmd(struct us_data *us, u8 fDir, void *buf, int use_sg)
 491{
 492	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
 493	struct bulk_cs_wrap *bcs = (struct bulk_cs_wrap *) us->iobuf;
 494
 495	int result;
 496	unsigned int residue;
 497	unsigned int cswlen = 0, partial = 0;
 498	unsigned int transfer_length = bcb->DataTransferLength;
 499
 500	/* usb_stor_dbg(us, "transport --- ene_send_scsi_cmd\n"); */
 501	/* send cmd to out endpoint */
 502	result = usb_stor_bulk_transfer_buf(us, us->send_bulk_pipe,
 503					    bcb, US_BULK_CB_WRAP_LEN, NULL);
 504	if (result != USB_STOR_XFER_GOOD) {
 505		usb_stor_dbg(us, "send cmd to out endpoint fail ---\n");
 506		return USB_STOR_TRANSPORT_ERROR;
 507	}
 508
 509	if (buf) {
 510		unsigned int pipe = fDir;
 511
 512		if (fDir  == FDIR_READ)
 513			pipe = us->recv_bulk_pipe;
 514		else
 515			pipe = us->send_bulk_pipe;
 516
 517		/* Bulk */
 518		if (use_sg) {
 519			result = usb_stor_bulk_srb(us, pipe, us->srb);
 520		} else {
 521			result = usb_stor_bulk_transfer_sg(us, pipe, buf,
 522						transfer_length, 0, &partial);
 523		}
 524		if (result != USB_STOR_XFER_GOOD) {
 525			usb_stor_dbg(us, "data transfer fail ---\n");
 526			return USB_STOR_TRANSPORT_ERROR;
 527		}
 528	}
 529
 530	/* Get CSW for device status */
 531	result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe, bcs,
 532					    US_BULK_CS_WRAP_LEN, &cswlen);
 533
 534	if (result == USB_STOR_XFER_SHORT && cswlen == 0) {
 535		usb_stor_dbg(us, "Received 0-length CSW; retrying...\n");
 536		result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
 537					    bcs, US_BULK_CS_WRAP_LEN, &cswlen);
 538	}
 539
 540	if (result == USB_STOR_XFER_STALLED) {
 541		/* get the status again */
 542		usb_stor_dbg(us, "Attempting to get CSW (2nd try)...\n");
 543		result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
 544						bcs, US_BULK_CS_WRAP_LEN, NULL);
 545	}
 546
 547	if (result != USB_STOR_XFER_GOOD)
 548		return USB_STOR_TRANSPORT_ERROR;
 549
 550	/* check bulk status */
 551	residue = le32_to_cpu(bcs->Residue);
 552
 553	/*
 554	 * try to compute the actual residue, based on how much data
 555	 * was really transferred and what the device tells us
 556	 */
 557	if (residue && !(us->fflags & US_FL_IGNORE_RESIDUE)) {
 558		residue = min(residue, transfer_length);
 559		if (us->srb != NULL)
 560			scsi_set_resid(us->srb, max(scsi_get_resid(us->srb),
 561								residue));
 562	}
 563
 564	if (bcs->Status != US_BULK_STAT_OK)
 565		return USB_STOR_TRANSPORT_ERROR;
 566
 567	return USB_STOR_TRANSPORT_GOOD;
 568}
 569
 570static int do_scsi_request_sense(struct us_data *us, struct scsi_cmnd *srb)
 571{
 572	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 573	unsigned char buf[18];
 574
 575	memset(buf, 0, 18);
 576	buf[0] = 0x70;				/* Current error */
 577	buf[2] = info->SrbStatus >> 16;		/* Sense key */
 578	buf[7] = 10;				/* Additional length */
 579	buf[12] = info->SrbStatus >> 8;		/* ASC */
 580	buf[13] = info->SrbStatus;		/* ASCQ */
 581
 582	usb_stor_set_xfer_buf(buf, sizeof(buf), srb);
 583	return USB_STOR_TRANSPORT_GOOD;
 584}
 585
 586static int do_scsi_inquiry(struct us_data *us, struct scsi_cmnd *srb)
 587{
 588	unsigned char data_ptr[36] = {
 589		0x00, 0x00, 0x02, 0x00, 0x1F, 0x00, 0x00, 0x00, 0x55,
 590		0x53, 0x42, 0x32, 0x2E, 0x30, 0x20, 0x20, 0x43, 0x61,
 591		0x72, 0x64, 0x52, 0x65, 0x61, 0x64, 0x65, 0x72, 0x20,
 592		0x20, 0x20, 0x20, 0x20, 0x20, 0x30, 0x31, 0x30, 0x30 };
 593
 594	usb_stor_set_xfer_buf(data_ptr, 36, srb);
 595	return USB_STOR_TRANSPORT_GOOD;
 596}
 597
 598static int sd_scsi_test_unit_ready(struct us_data *us, struct scsi_cmnd *srb)
 599{
 600	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 601
 602	if ((info->SD_Status & SD_Insert) && (info->SD_Status & SD_Ready))
 603		return USB_STOR_TRANSPORT_GOOD;
 604	else {
 605		ene_sd_init(us);
 606		return USB_STOR_TRANSPORT_GOOD;
 607	}
 608
 609	return USB_STOR_TRANSPORT_GOOD;
 610}
 611
 612static int sd_scsi_mode_sense(struct us_data *us, struct scsi_cmnd *srb)
 613{
 614	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 615	unsigned char mediaNoWP[12] = {
 616		0x0b, 0x00, 0x00, 0x08, 0x00, 0x00,
 617		0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
 618	unsigned char mediaWP[12]   = {
 619		0x0b, 0x00, 0x80, 0x08, 0x00, 0x00,
 620		0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
 621
 622	if (info->SD_Status & SD_WtP)
 623		usb_stor_set_xfer_buf(mediaWP, 12, srb);
 624	else
 625		usb_stor_set_xfer_buf(mediaNoWP, 12, srb);
 626
 627
 628	return USB_STOR_TRANSPORT_GOOD;
 629}
 630
 631static int sd_scsi_read_capacity(struct us_data *us, struct scsi_cmnd *srb)
 632{
 633	u32	bl_num;
 634	u32	bl_len;
 635	unsigned int offset = 0;
 636	unsigned char    buf[8];
 637	struct scatterlist *sg = NULL;
 638	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 639
 640	usb_stor_dbg(us, "sd_scsi_read_capacity\n");
 641	if (info->SD_Status & SD_HiCapacity) {
 642		bl_len = 0x200;
 643		if (info->SD_Status & SD_IsMMC)
 644			bl_num = info->HC_C_SIZE-1;
 645		else
 646			bl_num = (info->HC_C_SIZE + 1) * 1024 - 1;
 647	} else {
 648		bl_len = 1 << (info->SD_READ_BL_LEN);
 649		bl_num = info->SD_Block_Mult * (info->SD_C_SIZE + 1)
 650				* (1 << (info->SD_C_SIZE_MULT + 2)) - 1;
 651	}
 652	info->bl_num = bl_num;
 653	usb_stor_dbg(us, "bl_len = %x\n", bl_len);
 654	usb_stor_dbg(us, "bl_num = %x\n", bl_num);
 655
 656	/*srb->request_bufflen = 8; */
 657	buf[0] = (bl_num >> 24) & 0xff;
 658	buf[1] = (bl_num >> 16) & 0xff;
 659	buf[2] = (bl_num >> 8) & 0xff;
 660	buf[3] = (bl_num >> 0) & 0xff;
 661	buf[4] = (bl_len >> 24) & 0xff;
 662	buf[5] = (bl_len >> 16) & 0xff;
 663	buf[6] = (bl_len >> 8) & 0xff;
 664	buf[7] = (bl_len >> 0) & 0xff;
 665
 666	usb_stor_access_xfer_buf(buf, 8, srb, &sg, &offset, TO_XFER_BUF);
 667
 668	return USB_STOR_TRANSPORT_GOOD;
 669}
 670
 671static int sd_scsi_read(struct us_data *us, struct scsi_cmnd *srb)
 672{
 673	int result;
 674	unsigned char *cdb = srb->cmnd;
 675	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
 676	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 677
 678	u32 bn = ((cdb[2] << 24) & 0xff000000) | ((cdb[3] << 16) & 0x00ff0000) |
 679		 ((cdb[4] << 8) & 0x0000ff00) | ((cdb[5] << 0) & 0x000000ff);
 680	u16 blen = ((cdb[7] << 8) & 0xff00) | ((cdb[8] << 0) & 0x00ff);
 681	u32 bnByte = bn * 0x200;
 682	u32 blenByte = blen * 0x200;
 683
 684	if (bn > info->bl_num)
 685		return USB_STOR_TRANSPORT_ERROR;
 686
 687	result = ene_load_bincode(us, SD_RW_PATTERN);
 688	if (result != USB_STOR_XFER_GOOD) {
 689		usb_stor_dbg(us, "Load SD RW pattern Fail !!\n");
 690		return USB_STOR_TRANSPORT_ERROR;
 691	}
 692
 693	if (info->SD_Status & SD_HiCapacity)
 694		bnByte = bn;
 695
 696	/* set up the command wrapper */
 697	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
 698	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
 699	bcb->DataTransferLength = blenByte;
 700	bcb->Flags  = US_BULK_FLAG_IN;
 701	bcb->CDB[0] = 0xF1;
 702	bcb->CDB[5] = (unsigned char)(bnByte);
 703	bcb->CDB[4] = (unsigned char)(bnByte>>8);
 704	bcb->CDB[3] = (unsigned char)(bnByte>>16);
 705	bcb->CDB[2] = (unsigned char)(bnByte>>24);
 706
 707	result = ene_send_scsi_cmd(us, FDIR_READ, scsi_sglist(srb), 1);
 708	return result;
 709}
 710
 711static int sd_scsi_write(struct us_data *us, struct scsi_cmnd *srb)
 712{
 713	int result;
 714	unsigned char *cdb = srb->cmnd;
 715	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
 716	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 717
 718	u32 bn = ((cdb[2] << 24) & 0xff000000) | ((cdb[3] << 16) & 0x00ff0000) |
 719		 ((cdb[4] << 8) & 0x0000ff00) | ((cdb[5] << 0) & 0x000000ff);
 720	u16 blen = ((cdb[7] << 8) & 0xff00) | ((cdb[8] << 0) & 0x00ff);
 721	u32 bnByte = bn * 0x200;
 722	u32 blenByte = blen * 0x200;
 723
 724	if (bn > info->bl_num)
 725		return USB_STOR_TRANSPORT_ERROR;
 726
 727	result = ene_load_bincode(us, SD_RW_PATTERN);
 728	if (result != USB_STOR_XFER_GOOD) {
 729		usb_stor_dbg(us, "Load SD RW pattern Fail !!\n");
 730		return USB_STOR_TRANSPORT_ERROR;
 731	}
 732
 733	if (info->SD_Status & SD_HiCapacity)
 734		bnByte = bn;
 735
 736	/* set up the command wrapper */
 737	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
 738	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
 739	bcb->DataTransferLength = blenByte;
 740	bcb->Flags  = US_BULK_FLAG_OUT;
 741	bcb->CDB[0] = 0xF0;
 742	bcb->CDB[5] = (unsigned char)(bnByte);
 743	bcb->CDB[4] = (unsigned char)(bnByte>>8);
 744	bcb->CDB[3] = (unsigned char)(bnByte>>16);
 745	bcb->CDB[2] = (unsigned char)(bnByte>>24);
 746
 747	result = ene_send_scsi_cmd(us, FDIR_WRITE, scsi_sglist(srb), 1);
 748	return result;
 749}
 750
 751/*
 752 * ENE MS Card
 753 */
 754
 755static int ms_lib_set_logicalpair(struct us_data *us, u16 logblk, u16 phyblk)
 756{
 757	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 758
 759	if ((logblk >= info->MS_Lib.NumberOfLogBlock) || (phyblk >= info->MS_Lib.NumberOfPhyBlock))
 760		return (u32)-1;
 761
 762	info->MS_Lib.Phy2LogMap[phyblk] = logblk;
 763	info->MS_Lib.Log2PhyMap[logblk] = phyblk;
 764
 765	return 0;
 766}
 767
 768static int ms_lib_set_logicalblockmark(struct us_data *us, u16 phyblk, u16 mark)
 769{
 770	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 771
 772	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
 773		return (u32)-1;
 774
 775	info->MS_Lib.Phy2LogMap[phyblk] = mark;
 776
 777	return 0;
 778}
 779
 780static int ms_lib_set_initialerrorblock(struct us_data *us, u16 phyblk)
 781{
 782	return ms_lib_set_logicalblockmark(us, phyblk, MS_LB_INITIAL_ERROR);
 783}
 784
 785static int ms_lib_set_bootblockmark(struct us_data *us, u16 phyblk)
 786{
 787	return ms_lib_set_logicalblockmark(us, phyblk, MS_LB_BOOT_BLOCK);
 788}
 789
 790static int ms_lib_free_logicalmap(struct us_data *us)
 791{
 792	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 793
 794	kfree(info->MS_Lib.Phy2LogMap);
 795	info->MS_Lib.Phy2LogMap = NULL;
 796
 797	kfree(info->MS_Lib.Log2PhyMap);
 798	info->MS_Lib.Log2PhyMap = NULL;
 799
 800	return 0;
 801}
 802
 803static int ms_lib_alloc_logicalmap(struct us_data *us)
 804{
 805	u32  i;
 806	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 807
 808	info->MS_Lib.Phy2LogMap = kmalloc_array(info->MS_Lib.NumberOfPhyBlock,
 809						sizeof(u16),
 810						GFP_KERNEL);
 811	info->MS_Lib.Log2PhyMap = kmalloc_array(info->MS_Lib.NumberOfLogBlock,
 812						sizeof(u16),
 813						GFP_KERNEL);
 814
 815	if ((info->MS_Lib.Phy2LogMap == NULL) || (info->MS_Lib.Log2PhyMap == NULL)) {
 816		ms_lib_free_logicalmap(us);
 817		return (u32)-1;
 818	}
 819
 820	for (i = 0; i < info->MS_Lib.NumberOfPhyBlock; i++)
 821		info->MS_Lib.Phy2LogMap[i] = MS_LB_NOT_USED;
 822
 823	for (i = 0; i < info->MS_Lib.NumberOfLogBlock; i++)
 824		info->MS_Lib.Log2PhyMap[i] = MS_LB_NOT_USED;
 825
 826	return 0;
 827}
 828
 829static void ms_lib_clear_writebuf(struct us_data *us)
 830{
 831	int i;
 832	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 833
 834	info->MS_Lib.wrtblk = (u16)-1;
 835	ms_lib_clear_pagemap(info);
 836
 837	if (info->MS_Lib.blkpag)
 838		memset(info->MS_Lib.blkpag, 0xff, info->MS_Lib.PagesPerBlock * info->MS_Lib.BytesPerSector);
 839
 840	if (info->MS_Lib.blkext) {
 841		for (i = 0; i < info->MS_Lib.PagesPerBlock; i++) {
 842			info->MS_Lib.blkext[i].status1 = MS_REG_ST1_DEFAULT;
 843			info->MS_Lib.blkext[i].ovrflg = MS_REG_OVR_DEFAULT;
 844			info->MS_Lib.blkext[i].mngflg = MS_REG_MNG_DEFAULT;
 845			info->MS_Lib.blkext[i].logadr = MS_LB_NOT_USED;
 846		}
 847	}
 848}
 849
 850static int ms_count_freeblock(struct us_data *us, u16 PhyBlock)
 851{
 852	u32 Ende, Count;
 853	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 854
 855	Ende = PhyBlock + MS_PHYSICAL_BLOCKS_PER_SEGMENT;
 856	for (Count = 0; PhyBlock < Ende; PhyBlock++) {
 857		switch (info->MS_Lib.Phy2LogMap[PhyBlock]) {
 858		case MS_LB_NOT_USED:
 859		case MS_LB_NOT_USED_ERASED:
 860			Count++;
 861			break;
 862		default:
 863			break;
 864		}
 865	}
 866
 867	return Count;
 868}
 869
 870static int ms_read_readpage(struct us_data *us, u32 PhyBlockAddr,
 871		u8 PageNum, u32 *PageBuf, struct ms_lib_type_extdat *ExtraDat)
 872{
 873	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
 874	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 875	u8 *bbuf = info->bbuf;
 876	int result;
 
 877	u32 bn = PhyBlockAddr * 0x20 + PageNum;
 878
 
 
 
 879	result = ene_load_bincode(us, MS_RW_PATTERN);
 880	if (result != USB_STOR_XFER_GOOD)
 881		return USB_STOR_TRANSPORT_ERROR;
 882
 883	/* Read Page Data */
 884	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
 885	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
 886	bcb->DataTransferLength = 0x200;
 887	bcb->Flags      = US_BULK_FLAG_IN;
 888	bcb->CDB[0]     = 0xF1;
 889
 890	bcb->CDB[1]     = 0x02; /* in init.c ENE_MSInit() is 0x01 */
 891
 892	bcb->CDB[5]     = (unsigned char)(bn);
 893	bcb->CDB[4]     = (unsigned char)(bn>>8);
 894	bcb->CDB[3]     = (unsigned char)(bn>>16);
 895	bcb->CDB[2]     = (unsigned char)(bn>>24);
 896
 897	result = ene_send_scsi_cmd(us, FDIR_READ, PageBuf, 0);
 898	if (result != USB_STOR_XFER_GOOD)
 899		return USB_STOR_TRANSPORT_ERROR;
 900
 901
 902	/* Read Extra Data */
 903	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
 904	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
 905	bcb->DataTransferLength = 0x4;
 906	bcb->Flags      = US_BULK_FLAG_IN;
 907	bcb->CDB[0]     = 0xF1;
 908	bcb->CDB[1]     = 0x03;
 909
 910	bcb->CDB[5]     = (unsigned char)(PageNum);
 911	bcb->CDB[4]     = (unsigned char)(PhyBlockAddr);
 912	bcb->CDB[3]     = (unsigned char)(PhyBlockAddr>>8);
 913	bcb->CDB[2]     = (unsigned char)(PhyBlockAddr>>16);
 914	bcb->CDB[6]     = 0x01;
 915
 916	result = ene_send_scsi_cmd(us, FDIR_READ, bbuf, 0);
 917	if (result != USB_STOR_XFER_GOOD)
 918		return USB_STOR_TRANSPORT_ERROR;
 919
 920	ExtraDat->reserved = 0;
 921	ExtraDat->intr     = 0x80;  /* Not yet,fireware support */
 922	ExtraDat->status0  = 0x10;  /* Not yet,fireware support */
 923
 924	ExtraDat->status1  = 0x00;  /* Not yet,fireware support */
 925	ExtraDat->ovrflg   = bbuf[0];
 926	ExtraDat->mngflg   = bbuf[1];
 927	ExtraDat->logadr   = memstick_logaddr(bbuf[2], bbuf[3]);
 928
 929	return USB_STOR_TRANSPORT_GOOD;
 930}
 931
 932static int ms_lib_process_bootblock(struct us_data *us, u16 PhyBlock, u8 *PageData)
 933{
 934	struct ms_bootblock_sysent *SysEntry;
 935	struct ms_bootblock_sysinf *SysInfo;
 936	u32 i, result;
 937	u8 PageNumber;
 938	u8 *PageBuffer;
 939	struct ms_lib_type_extdat ExtraData;
 940	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 941
 942	PageBuffer = kzalloc(MS_BYTES_PER_PAGE * 2, GFP_KERNEL);
 943	if (PageBuffer == NULL)
 944		return (u32)-1;
 945
 946	result = (u32)-1;
 947
 948	SysInfo = &(((struct ms_bootblock_page0 *)PageData)->sysinf);
 949
 950	if ((SysInfo->bMsClass != MS_SYSINF_MSCLASS_TYPE_1) ||
 951		(be16_to_cpu(SysInfo->wPageSize) != MS_SYSINF_PAGE_SIZE) ||
 952		((SysInfo->bSecuritySupport & MS_SYSINF_SECURITY) == MS_SYSINF_SECURITY_SUPPORT) ||
 953		(SysInfo->bReserved1 != MS_SYSINF_RESERVED1) ||
 954		(SysInfo->bReserved2 != MS_SYSINF_RESERVED2) ||
 955		(SysInfo->bFormatType != MS_SYSINF_FORMAT_FAT) ||
 956		(SysInfo->bUsage != MS_SYSINF_USAGE_GENERAL))
 957		goto exit;
 958		/* */
 959	switch (info->MS_Lib.cardType = SysInfo->bCardType) {
 960	case MS_SYSINF_CARDTYPE_RDONLY:
 961		ms_lib_ctrl_set(info, MS_LIB_CTRL_RDONLY);
 962		break;
 963	case MS_SYSINF_CARDTYPE_RDWR:
 964		ms_lib_ctrl_reset(info, MS_LIB_CTRL_RDONLY);
 965		break;
 966	case MS_SYSINF_CARDTYPE_HYBRID:
 967	default:
 968		goto exit;
 969	}
 970
 971	info->MS_Lib.blockSize = be16_to_cpu(SysInfo->wBlockSize);
 972	info->MS_Lib.NumberOfPhyBlock = be16_to_cpu(SysInfo->wBlockNumber);
 973	info->MS_Lib.NumberOfLogBlock = be16_to_cpu(SysInfo->wTotalBlockNumber)-2;
 974	info->MS_Lib.PagesPerBlock = info->MS_Lib.blockSize * SIZE_OF_KIRO / MS_BYTES_PER_PAGE;
 975	info->MS_Lib.NumberOfSegment = info->MS_Lib.NumberOfPhyBlock / MS_PHYSICAL_BLOCKS_PER_SEGMENT;
 976	info->MS_Model = be16_to_cpu(SysInfo->wMemorySize);
 977
 978	/*Allocate to all number of logicalblock and physicalblock */
 979	if (ms_lib_alloc_logicalmap(us))
 980		goto exit;
 981
 982	/* Mark the book block */
 983	ms_lib_set_bootblockmark(us, PhyBlock);
 984
 985	SysEntry = &(((struct ms_bootblock_page0 *)PageData)->sysent);
 986
 987	for (i = 0; i < MS_NUMBER_OF_SYSTEM_ENTRY; i++) {
 988		u32  EntryOffset, EntrySize;
 989
 990		EntryOffset = be32_to_cpu(SysEntry->entry[i].dwStart);
 991
 992		if (EntryOffset == 0xffffff)
 993			continue;
 994		EntrySize = be32_to_cpu(SysEntry->entry[i].dwSize);
 995
 996		if (EntrySize == 0)
 997			continue;
 998
 999		if (EntryOffset + MS_BYTES_PER_PAGE + EntrySize > info->MS_Lib.blockSize * (u32)SIZE_OF_KIRO)
1000			continue;
1001
1002		if (i == 0) {
1003			u8 PrevPageNumber = 0;
1004			u16 phyblk;
1005
1006			if (SysEntry->entry[i].bType != MS_SYSENT_TYPE_INVALID_BLOCK)
1007				goto exit;
1008
1009			while (EntrySize > 0) {
1010
1011				PageNumber = (u8)(EntryOffset / MS_BYTES_PER_PAGE + 1);
1012				if (PageNumber != PrevPageNumber) {
1013					switch (ms_read_readpage(us, PhyBlock, PageNumber, (u32 *)PageBuffer, &ExtraData)) {
1014					case MS_STATUS_SUCCESS:
1015						break;
1016					case MS_STATUS_WRITE_PROTECT:
1017					case MS_ERROR_FLASH_READ:
1018					case MS_STATUS_ERROR:
1019					default:
1020						goto exit;
1021					}
1022
1023					PrevPageNumber = PageNumber;
1024				}
1025
1026				phyblk = be16_to_cpu(*(u16 *)(PageBuffer + (EntryOffset % MS_BYTES_PER_PAGE)));
1027				if (phyblk < 0x0fff)
1028					ms_lib_set_initialerrorblock(us, phyblk);
1029
1030				EntryOffset += 2;
1031				EntrySize -= 2;
1032			}
1033		} else if (i == 1) {  /* CIS/IDI */
1034			struct ms_bootblock_idi *idi;
1035
1036			if (SysEntry->entry[i].bType != MS_SYSENT_TYPE_CIS_IDI)
1037				goto exit;
1038
1039			switch (ms_read_readpage(us, PhyBlock, (u8)(EntryOffset / MS_BYTES_PER_PAGE + 1), (u32 *)PageBuffer, &ExtraData)) {
1040			case MS_STATUS_SUCCESS:
1041				break;
1042			case MS_STATUS_WRITE_PROTECT:
1043			case MS_ERROR_FLASH_READ:
1044			case MS_STATUS_ERROR:
1045			default:
1046				goto exit;
1047			}
1048
1049			idi = &((struct ms_bootblock_cis_idi *)(PageBuffer + (EntryOffset % MS_BYTES_PER_PAGE)))->idi.idi;
1050			if (le16_to_cpu(idi->wIDIgeneralConfiguration) != MS_IDI_GENERAL_CONF)
1051				goto exit;
1052
1053			info->MS_Lib.BytesPerSector = le16_to_cpu(idi->wIDIbytesPerSector);
1054			if (info->MS_Lib.BytesPerSector != MS_BYTES_PER_PAGE)
1055				goto exit;
1056		}
1057	} /* End for .. */
1058
1059	result = 0;
1060
1061exit:
1062	if (result)
1063		ms_lib_free_logicalmap(us);
1064
1065	kfree(PageBuffer);
1066
1067	result = 0;
1068	return result;
1069}
1070
1071static void ms_lib_free_writebuf(struct us_data *us)
1072{
1073	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1074	info->MS_Lib.wrtblk = (u16)-1; /* set to -1 */
1075
1076	/* memset((fdoExt)->MS_Lib.pagemap, 0, sizeof((fdoExt)->MS_Lib.pagemap)) */
1077
1078	ms_lib_clear_pagemap(info); /* (pdx)->MS_Lib.pagemap memset 0 in ms.h */
1079
1080	if (info->MS_Lib.blkpag) {
1081		kfree(info->MS_Lib.blkpag);  /* Arnold test ... */
1082		info->MS_Lib.blkpag = NULL;
1083	}
1084
1085	if (info->MS_Lib.blkext) {
1086		kfree(info->MS_Lib.blkext);  /* Arnold test ... */
1087		info->MS_Lib.blkext = NULL;
1088	}
1089}
1090
1091
1092static void ms_lib_free_allocatedarea(struct us_data *us)
1093{
1094	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1095
1096	ms_lib_free_writebuf(us); /* Free MS_Lib.pagemap */
1097	ms_lib_free_logicalmap(us); /* kfree MS_Lib.Phy2LogMap and MS_Lib.Log2PhyMap */
1098
1099	/* set struct us point flag to 0 */
1100	info->MS_Lib.flags = 0;
1101	info->MS_Lib.BytesPerSector = 0;
1102	info->MS_Lib.SectorsPerCylinder = 0;
1103
1104	info->MS_Lib.cardType = 0;
1105	info->MS_Lib.blockSize = 0;
1106	info->MS_Lib.PagesPerBlock = 0;
1107
1108	info->MS_Lib.NumberOfPhyBlock = 0;
1109	info->MS_Lib.NumberOfLogBlock = 0;
1110}
1111
1112
1113static int ms_lib_alloc_writebuf(struct us_data *us)
1114{
1115	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1116
1117	info->MS_Lib.wrtblk = (u16)-1;
1118
1119	info->MS_Lib.blkpag = kmalloc_array(info->MS_Lib.PagesPerBlock,
1120					    info->MS_Lib.BytesPerSector,
1121					    GFP_KERNEL);
1122	info->MS_Lib.blkext = kmalloc_array(info->MS_Lib.PagesPerBlock,
1123					    sizeof(struct ms_lib_type_extdat),
1124					    GFP_KERNEL);
1125
1126	if ((info->MS_Lib.blkpag == NULL) || (info->MS_Lib.blkext == NULL)) {
1127		ms_lib_free_writebuf(us);
1128		return (u32)-1;
1129	}
1130
1131	ms_lib_clear_writebuf(us);
1132
1133	return 0;
1134}
1135
1136static int ms_lib_force_setlogical_pair(struct us_data *us, u16 logblk, u16 phyblk)
1137{
1138	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1139
1140	if (logblk == MS_LB_NOT_USED)
1141		return 0;
1142
1143	if ((logblk >= info->MS_Lib.NumberOfLogBlock) ||
1144		(phyblk >= info->MS_Lib.NumberOfPhyBlock))
1145		return (u32)-1;
1146
1147	info->MS_Lib.Phy2LogMap[phyblk] = logblk;
1148	info->MS_Lib.Log2PhyMap[logblk] = phyblk;
1149
1150	return 0;
1151}
1152
1153static int ms_read_copyblock(struct us_data *us, u16 oldphy, u16 newphy,
1154			u16 PhyBlockAddr, u8 PageNum, unsigned char *buf, u16 len)
1155{
1156	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1157	int result;
1158
 
 
1159	result = ene_load_bincode(us, MS_RW_PATTERN);
1160	if (result != USB_STOR_XFER_GOOD)
1161		return USB_STOR_TRANSPORT_ERROR;
1162
1163	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1164	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1165	bcb->DataTransferLength = 0x200*len;
1166	bcb->Flags = US_BULK_FLAG_OUT;
1167	bcb->CDB[0] = 0xF0;
1168	bcb->CDB[1] = 0x08;
1169	bcb->CDB[4] = (unsigned char)(oldphy);
1170	bcb->CDB[3] = (unsigned char)(oldphy>>8);
1171	bcb->CDB[2] = 0; /* (BYTE)(oldphy>>16) */
1172	bcb->CDB[7] = (unsigned char)(newphy);
1173	bcb->CDB[6] = (unsigned char)(newphy>>8);
1174	bcb->CDB[5] = 0; /* (BYTE)(newphy>>16) */
1175	bcb->CDB[9] = (unsigned char)(PhyBlockAddr);
1176	bcb->CDB[8] = (unsigned char)(PhyBlockAddr>>8);
1177	bcb->CDB[10] = PageNum;
1178
1179	result = ene_send_scsi_cmd(us, FDIR_WRITE, buf, 0);
1180	if (result != USB_STOR_XFER_GOOD)
1181		return USB_STOR_TRANSPORT_ERROR;
1182
1183	return USB_STOR_TRANSPORT_GOOD;
1184}
1185
1186static int ms_read_eraseblock(struct us_data *us, u32 PhyBlockAddr)
1187{
1188	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1189	int result;
1190	u32 bn = PhyBlockAddr;
1191
 
 
1192	result = ene_load_bincode(us, MS_RW_PATTERN);
1193	if (result != USB_STOR_XFER_GOOD)
1194		return USB_STOR_TRANSPORT_ERROR;
1195
1196	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1197	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1198	bcb->DataTransferLength = 0x200;
1199	bcb->Flags = US_BULK_FLAG_IN;
1200	bcb->CDB[0] = 0xF2;
1201	bcb->CDB[1] = 0x06;
1202	bcb->CDB[4] = (unsigned char)(bn);
1203	bcb->CDB[3] = (unsigned char)(bn>>8);
1204	bcb->CDB[2] = (unsigned char)(bn>>16);
1205
1206	result = ene_send_scsi_cmd(us, FDIR_READ, NULL, 0);
1207	if (result != USB_STOR_XFER_GOOD)
1208		return USB_STOR_TRANSPORT_ERROR;
1209
1210	return USB_STOR_TRANSPORT_GOOD;
1211}
1212
1213static int ms_lib_check_disableblock(struct us_data *us, u16 PhyBlock)
1214{
1215	unsigned char *PageBuf = NULL;
1216	u16 result = MS_STATUS_SUCCESS;
1217	u16 blk, index = 0;
1218	struct ms_lib_type_extdat extdat;
1219	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1220
1221	PageBuf = kmalloc(MS_BYTES_PER_PAGE, GFP_KERNEL);
1222	if (PageBuf == NULL) {
1223		result = MS_NO_MEMORY_ERROR;
1224		goto exit;
1225	}
1226
1227	ms_read_readpage(us, PhyBlock, 1, (u32 *)PageBuf, &extdat);
1228	do {
1229		blk = be16_to_cpu(PageBuf[index]);
1230		if (blk == MS_LB_NOT_USED)
1231			break;
1232		if (blk == info->MS_Lib.Log2PhyMap[0]) {
1233			result = MS_ERROR_FLASH_READ;
1234			break;
1235		}
1236		index++;
1237	} while (1);
1238
1239exit:
1240	kfree(PageBuf);
1241	return result;
1242}
1243
1244static int ms_lib_setacquired_errorblock(struct us_data *us, u16 phyblk)
1245{
1246	u16 log;
1247	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1248
1249	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
1250		return (u32)-1;
1251
1252	log = info->MS_Lib.Phy2LogMap[phyblk];
1253
1254	if (log < info->MS_Lib.NumberOfLogBlock)
1255		info->MS_Lib.Log2PhyMap[log] = MS_LB_NOT_USED;
1256
1257	if (info->MS_Lib.Phy2LogMap[phyblk] != MS_LB_INITIAL_ERROR)
1258		info->MS_Lib.Phy2LogMap[phyblk] = MS_LB_ACQUIRED_ERROR;
1259
1260	return 0;
1261}
1262
1263static int ms_lib_overwrite_extra(struct us_data *us, u32 PhyBlockAddr,
1264				u8 PageNum, u8 OverwriteFlag)
1265{
1266	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1267	int result;
1268
 
 
1269	result = ene_load_bincode(us, MS_RW_PATTERN);
1270	if (result != USB_STOR_XFER_GOOD)
1271		return USB_STOR_TRANSPORT_ERROR;
1272
1273	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1274	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1275	bcb->DataTransferLength = 0x4;
1276	bcb->Flags = US_BULK_FLAG_IN;
1277	bcb->CDB[0] = 0xF2;
1278	bcb->CDB[1] = 0x05;
1279	bcb->CDB[5] = (unsigned char)(PageNum);
1280	bcb->CDB[4] = (unsigned char)(PhyBlockAddr);
1281	bcb->CDB[3] = (unsigned char)(PhyBlockAddr>>8);
1282	bcb->CDB[2] = (unsigned char)(PhyBlockAddr>>16);
1283	bcb->CDB[6] = OverwriteFlag;
1284	bcb->CDB[7] = 0xFF;
1285	bcb->CDB[8] = 0xFF;
1286	bcb->CDB[9] = 0xFF;
1287
1288	result = ene_send_scsi_cmd(us, FDIR_READ, NULL, 0);
1289	if (result != USB_STOR_XFER_GOOD)
1290		return USB_STOR_TRANSPORT_ERROR;
1291
1292	return USB_STOR_TRANSPORT_GOOD;
1293}
1294
1295static int ms_lib_error_phyblock(struct us_data *us, u16 phyblk)
1296{
1297	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1298
1299	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
1300		return MS_STATUS_ERROR;
1301
1302	ms_lib_setacquired_errorblock(us, phyblk);
1303
1304	if (ms_lib_iswritable(info))
1305		return ms_lib_overwrite_extra(us, phyblk, 0, (u8)(~MS_REG_OVR_BKST & BYTE_MASK));
1306
1307	return MS_STATUS_SUCCESS;
1308}
1309
1310static int ms_lib_erase_phyblock(struct us_data *us, u16 phyblk)
1311{
1312	u16 log;
1313	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1314
1315	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
1316		return MS_STATUS_ERROR;
1317
1318	log = info->MS_Lib.Phy2LogMap[phyblk];
1319
1320	if (log < info->MS_Lib.NumberOfLogBlock)
1321		info->MS_Lib.Log2PhyMap[log] = MS_LB_NOT_USED;
1322
1323	info->MS_Lib.Phy2LogMap[phyblk] = MS_LB_NOT_USED;
1324
1325	if (ms_lib_iswritable(info)) {
1326		switch (ms_read_eraseblock(us, phyblk)) {
1327		case MS_STATUS_SUCCESS:
1328			info->MS_Lib.Phy2LogMap[phyblk] = MS_LB_NOT_USED_ERASED;
1329			return MS_STATUS_SUCCESS;
1330		case MS_ERROR_FLASH_ERASE:
1331		case MS_STATUS_INT_ERROR:
1332			ms_lib_error_phyblock(us, phyblk);
1333			return MS_ERROR_FLASH_ERASE;
1334		case MS_STATUS_ERROR:
1335		default:
1336			ms_lib_ctrl_set(info, MS_LIB_CTRL_RDONLY); /* MS_LibCtrlSet will used by ENE_MSInit ,need check, and why us to info*/
1337			ms_lib_setacquired_errorblock(us, phyblk);
1338			return MS_STATUS_ERROR;
1339		}
1340	}
1341
1342	ms_lib_setacquired_errorblock(us, phyblk);
1343
1344	return MS_STATUS_SUCCESS;
1345}
1346
1347static int ms_lib_read_extra(struct us_data *us, u32 PhyBlock,
1348				u8 PageNum, struct ms_lib_type_extdat *ExtraDat)
1349{
1350	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1351	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1352	u8 *bbuf = info->bbuf;
1353	int result;
 
1354
 
1355	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1356	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1357	bcb->DataTransferLength = 0x4;
1358	bcb->Flags      = US_BULK_FLAG_IN;
1359	bcb->CDB[0]     = 0xF1;
1360	bcb->CDB[1]     = 0x03;
1361	bcb->CDB[5]     = (unsigned char)(PageNum);
1362	bcb->CDB[4]     = (unsigned char)(PhyBlock);
1363	bcb->CDB[3]     = (unsigned char)(PhyBlock>>8);
1364	bcb->CDB[2]     = (unsigned char)(PhyBlock>>16);
1365	bcb->CDB[6]     = 0x01;
1366
1367	result = ene_send_scsi_cmd(us, FDIR_READ, bbuf, 0);
1368	if (result != USB_STOR_XFER_GOOD)
1369		return USB_STOR_TRANSPORT_ERROR;
1370
1371	ExtraDat->reserved = 0;
1372	ExtraDat->intr     = 0x80;  /* Not yet, waiting for fireware support */
1373	ExtraDat->status0  = 0x10;  /* Not yet, waiting for fireware support */
1374	ExtraDat->status1  = 0x00;  /* Not yet, waiting for fireware support */
1375	ExtraDat->ovrflg   = bbuf[0];
1376	ExtraDat->mngflg   = bbuf[1];
1377	ExtraDat->logadr   = memstick_logaddr(bbuf[2], bbuf[3]);
1378
1379	return USB_STOR_TRANSPORT_GOOD;
1380}
1381
1382static int ms_libsearch_block_from_physical(struct us_data *us, u16 phyblk)
1383{
 
1384	u16 blk;
1385	struct ms_lib_type_extdat extdat; /* need check */
1386	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1387
1388
1389	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
1390		return MS_LB_ERROR;
1391
1392	for (blk = phyblk + 1; blk != phyblk; blk++) {
1393		if ((blk & MS_PHYSICAL_BLOCKS_PER_SEGMENT_MASK) == 0)
1394			blk -= MS_PHYSICAL_BLOCKS_PER_SEGMENT;
1395
 
1396		if (info->MS_Lib.Phy2LogMap[blk] == MS_LB_NOT_USED_ERASED) {
1397			return blk;
1398		} else if (info->MS_Lib.Phy2LogMap[blk] == MS_LB_NOT_USED) {
1399			switch (ms_lib_read_extra(us, blk, 0, &extdat)) {
1400			case MS_STATUS_SUCCESS:
1401			case MS_STATUS_SUCCESS_WITH_ECC:
1402				break;
1403			case MS_NOCARD_ERROR:
1404				return MS_NOCARD_ERROR;
1405			case MS_STATUS_INT_ERROR:
1406				return MS_LB_ERROR;
1407			case MS_ERROR_FLASH_READ:
1408			default:
1409				ms_lib_setacquired_errorblock(us, blk);
1410				continue;
1411			} /* End switch */
1412
1413			if ((extdat.ovrflg & MS_REG_OVR_BKST) != MS_REG_OVR_BKST_OK) {
1414				ms_lib_setacquired_errorblock(us, blk);
1415				continue;
1416			}
1417
1418			switch (ms_lib_erase_phyblock(us, blk)) {
1419			case MS_STATUS_SUCCESS:
1420				return blk;
1421			case MS_STATUS_ERROR:
1422				return MS_LB_ERROR;
1423			case MS_ERROR_FLASH_ERASE:
1424			default:
1425				ms_lib_error_phyblock(us, blk);
1426				break;
1427			}
1428		}
1429	} /* End for */
1430
1431	return MS_LB_ERROR;
1432}
1433static int ms_libsearch_block_from_logical(struct us_data *us, u16 logblk)
1434{
1435	u16 phyblk;
1436	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1437
1438	phyblk = ms_libconv_to_physical(info, logblk);
1439	if (phyblk >= MS_LB_ERROR) {
1440		if (logblk >= info->MS_Lib.NumberOfLogBlock)
1441			return MS_LB_ERROR;
1442
1443		phyblk = (logblk + MS_NUMBER_OF_BOOT_BLOCK) / MS_LOGICAL_BLOCKS_PER_SEGMENT;
1444		phyblk *= MS_PHYSICAL_BLOCKS_PER_SEGMENT;
1445		phyblk += MS_PHYSICAL_BLOCKS_PER_SEGMENT - 1;
1446	}
1447
1448	return ms_libsearch_block_from_physical(us, phyblk);
1449}
1450
1451static int ms_scsi_test_unit_ready(struct us_data *us, struct scsi_cmnd *srb)
1452{
1453	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
1454
1455	/* pr_info("MS_SCSI_Test_Unit_Ready\n"); */
1456	if ((info->MS_Status & MS_Insert) && (info->MS_Status & MS_Ready)) {
1457		return USB_STOR_TRANSPORT_GOOD;
1458	} else {
1459		ene_ms_init(us);
1460		return USB_STOR_TRANSPORT_GOOD;
1461	}
1462
1463	return USB_STOR_TRANSPORT_GOOD;
1464}
1465
 
 
 
 
 
 
 
 
 
 
 
 
 
1466static int ms_scsi_mode_sense(struct us_data *us, struct scsi_cmnd *srb)
1467{
1468	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1469	unsigned char mediaNoWP[12] = {
1470		0x0b, 0x00, 0x00, 0x08, 0x00, 0x00,
1471		0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
1472	unsigned char mediaWP[12]   = {
1473		0x0b, 0x00, 0x80, 0x08, 0x00, 0x00,
1474		0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
1475
1476	if (info->MS_Status & MS_WtP)
1477		usb_stor_set_xfer_buf(mediaWP, 12, srb);
1478	else
1479		usb_stor_set_xfer_buf(mediaNoWP, 12, srb);
1480
1481	return USB_STOR_TRANSPORT_GOOD;
1482}
1483
1484static int ms_scsi_read_capacity(struct us_data *us, struct scsi_cmnd *srb)
1485{
1486	u32   bl_num;
1487	u32    bl_len;
1488	unsigned int offset = 0;
1489	unsigned char    buf[8];
1490	struct scatterlist *sg = NULL;
1491	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1492
1493	usb_stor_dbg(us, "ms_scsi_read_capacity\n");
1494	bl_len = 0x200;
1495	if (info->MS_Status & MS_IsMSPro)
1496		bl_num = info->MSP_TotalBlock - 1;
1497	else
1498		bl_num = info->MS_Lib.NumberOfLogBlock * info->MS_Lib.blockSize * 2 - 1;
1499
1500	info->bl_num = bl_num;
1501	usb_stor_dbg(us, "bl_len = %x\n", bl_len);
1502	usb_stor_dbg(us, "bl_num = %x\n", bl_num);
1503
1504	/*srb->request_bufflen = 8; */
1505	buf[0] = (bl_num >> 24) & 0xff;
1506	buf[1] = (bl_num >> 16) & 0xff;
1507	buf[2] = (bl_num >> 8) & 0xff;
1508	buf[3] = (bl_num >> 0) & 0xff;
1509	buf[4] = (bl_len >> 24) & 0xff;
1510	buf[5] = (bl_len >> 16) & 0xff;
1511	buf[6] = (bl_len >> 8) & 0xff;
1512	buf[7] = (bl_len >> 0) & 0xff;
1513
1514	usb_stor_access_xfer_buf(buf, 8, srb, &sg, &offset, TO_XFER_BUF);
1515
1516	return USB_STOR_TRANSPORT_GOOD;
1517}
1518
1519static void ms_lib_phy_to_log_range(u16 PhyBlock, u16 *LogStart, u16 *LogEnde)
1520{
1521	PhyBlock /= MS_PHYSICAL_BLOCKS_PER_SEGMENT;
1522
1523	if (PhyBlock) {
1524		*LogStart = MS_LOGICAL_BLOCKS_IN_1ST_SEGMENT + (PhyBlock - 1) * MS_LOGICAL_BLOCKS_PER_SEGMENT;/*496*/
1525		*LogEnde = *LogStart + MS_LOGICAL_BLOCKS_PER_SEGMENT;/*496*/
1526	} else {
1527		*LogStart = 0;
1528		*LogEnde = MS_LOGICAL_BLOCKS_IN_1ST_SEGMENT;/*494*/
1529	}
1530}
1531
1532static int ms_lib_read_extrablock(struct us_data *us, u32 PhyBlock,
1533	u8 PageNum, u8 blen, void *buf)
1534{
1535	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1536	int     result;
1537
 
 
 
1538	/* Read Extra Data */
1539	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1540	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1541	bcb->DataTransferLength = 0x4 * blen;
1542	bcb->Flags      = US_BULK_FLAG_IN;
1543	bcb->CDB[0]     = 0xF1;
1544	bcb->CDB[1]     = 0x03;
1545	bcb->CDB[5]     = (unsigned char)(PageNum);
1546	bcb->CDB[4]     = (unsigned char)(PhyBlock);
1547	bcb->CDB[3]     = (unsigned char)(PhyBlock>>8);
1548	bcb->CDB[2]     = (unsigned char)(PhyBlock>>16);
1549	bcb->CDB[6]     = blen;
1550
1551	result = ene_send_scsi_cmd(us, FDIR_READ, buf, 0);
1552	if (result != USB_STOR_XFER_GOOD)
1553		return USB_STOR_TRANSPORT_ERROR;
1554
1555	return USB_STOR_TRANSPORT_GOOD;
1556}
1557
1558static int ms_lib_scan_logicalblocknumber(struct us_data *us, u16 btBlk1st)
1559{
1560	u16 PhyBlock, newblk, i;
1561	u16 LogStart, LogEnde;
1562	struct ms_lib_type_extdat extdat;
 
1563	u32 count = 0, index = 0;
1564	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1565	u8 *bbuf = info->bbuf;
1566
1567	for (PhyBlock = 0; PhyBlock < info->MS_Lib.NumberOfPhyBlock;) {
1568		ms_lib_phy_to_log_range(PhyBlock, &LogStart, &LogEnde);
1569
1570		for (i = 0; i < MS_PHYSICAL_BLOCKS_PER_SEGMENT; i++, PhyBlock++) {
1571			switch (ms_libconv_to_logical(info, PhyBlock)) {
1572			case MS_STATUS_ERROR:
1573				continue;
1574			default:
1575				break;
1576			}
1577
1578			if (count == PhyBlock) {
1579				ms_lib_read_extrablock(us, PhyBlock, 0, 0x80,
1580						bbuf);
1581				count += 0x80;
1582			}
1583			index = (PhyBlock % 0x80) * 4;
1584
1585			extdat.ovrflg = bbuf[index];
1586			extdat.mngflg = bbuf[index+1];
1587			extdat.logadr = memstick_logaddr(bbuf[index+2],
1588					bbuf[index+3]);
1589
1590			if ((extdat.ovrflg & MS_REG_OVR_BKST) != MS_REG_OVR_BKST_OK) {
1591				ms_lib_setacquired_errorblock(us, PhyBlock);
1592				continue;
1593			}
1594
1595			if ((extdat.mngflg & MS_REG_MNG_ATFLG) == MS_REG_MNG_ATFLG_ATTBL) {
1596				ms_lib_erase_phyblock(us, PhyBlock);
1597				continue;
1598			}
1599
1600			if (extdat.logadr != MS_LB_NOT_USED) {
1601				if ((extdat.logadr < LogStart) || (LogEnde <= extdat.logadr)) {
1602					ms_lib_erase_phyblock(us, PhyBlock);
1603					continue;
1604				}
1605
1606				newblk = ms_libconv_to_physical(info, extdat.logadr);
1607
1608				if (newblk != MS_LB_NOT_USED) {
1609					if (extdat.logadr == 0) {
1610						ms_lib_set_logicalpair(us, extdat.logadr, PhyBlock);
1611						if (ms_lib_check_disableblock(us, btBlk1st)) {
1612							ms_lib_set_logicalpair(us, extdat.logadr, newblk);
1613							continue;
1614						}
1615					}
1616
1617					ms_lib_read_extra(us, newblk, 0, &extdat);
1618					if ((extdat.ovrflg & MS_REG_OVR_UDST) == MS_REG_OVR_UDST_UPDATING) {
1619						ms_lib_erase_phyblock(us, PhyBlock);
1620						continue;
1621					} else {
1622						ms_lib_erase_phyblock(us, newblk);
1623					}
1624				}
1625
1626				ms_lib_set_logicalpair(us, extdat.logadr, PhyBlock);
1627			}
1628		}
1629	} /* End for ... */
1630
1631	return MS_STATUS_SUCCESS;
1632}
1633
1634
1635static int ms_scsi_read(struct us_data *us, struct scsi_cmnd *srb)
1636{
1637	int result;
1638	unsigned char *cdb = srb->cmnd;
1639	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1640	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1641
1642	u32 bn = ((cdb[2] << 24) & 0xff000000) | ((cdb[3] << 16) & 0x00ff0000) |
1643		((cdb[4] << 8) & 0x0000ff00) | ((cdb[5] << 0) & 0x000000ff);
1644	u16 blen = ((cdb[7] << 8) & 0xff00) | ((cdb[8] << 0) & 0x00ff);
1645	u32 blenByte = blen * 0x200;
1646
1647	if (bn > info->bl_num)
1648		return USB_STOR_TRANSPORT_ERROR;
1649
1650	if (info->MS_Status & MS_IsMSPro) {
1651		result = ene_load_bincode(us, MSP_RW_PATTERN);
1652		if (result != USB_STOR_XFER_GOOD) {
1653			usb_stor_dbg(us, "Load MPS RW pattern Fail !!\n");
1654			return USB_STOR_TRANSPORT_ERROR;
1655		}
1656
1657		/* set up the command wrapper */
1658		memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1659		bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1660		bcb->DataTransferLength = blenByte;
1661		bcb->Flags  = US_BULK_FLAG_IN;
1662		bcb->CDB[0] = 0xF1;
1663		bcb->CDB[1] = 0x02;
1664		bcb->CDB[5] = (unsigned char)(bn);
1665		bcb->CDB[4] = (unsigned char)(bn>>8);
1666		bcb->CDB[3] = (unsigned char)(bn>>16);
1667		bcb->CDB[2] = (unsigned char)(bn>>24);
1668
1669		result = ene_send_scsi_cmd(us, FDIR_READ, scsi_sglist(srb), 1);
1670	} else {
1671		void *buf;
1672		int offset = 0;
1673		u16 phyblk, logblk;
1674		u8 PageNum;
1675		u16 len;
1676		u32 blkno;
1677
1678		buf = kmalloc(blenByte, GFP_KERNEL);
1679		if (buf == NULL)
1680			return USB_STOR_TRANSPORT_ERROR;
1681
1682		result = ene_load_bincode(us, MS_RW_PATTERN);
1683		if (result != USB_STOR_XFER_GOOD) {
1684			pr_info("Load MS RW pattern Fail !!\n");
1685			result = USB_STOR_TRANSPORT_ERROR;
1686			goto exit;
1687		}
1688
1689		logblk  = (u16)(bn / info->MS_Lib.PagesPerBlock);
1690		PageNum = (u8)(bn % info->MS_Lib.PagesPerBlock);
1691
1692		while (1) {
1693			if (blen > (info->MS_Lib.PagesPerBlock-PageNum))
1694				len = info->MS_Lib.PagesPerBlock-PageNum;
1695			else
1696				len = blen;
1697
1698			phyblk = ms_libconv_to_physical(info, logblk);
1699			blkno  = phyblk * 0x20 + PageNum;
1700
1701			/* set up the command wrapper */
1702			memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1703			bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1704			bcb->DataTransferLength = 0x200 * len;
1705			bcb->Flags  = US_BULK_FLAG_IN;
1706			bcb->CDB[0] = 0xF1;
1707			bcb->CDB[1] = 0x02;
1708			bcb->CDB[5] = (unsigned char)(blkno);
1709			bcb->CDB[4] = (unsigned char)(blkno>>8);
1710			bcb->CDB[3] = (unsigned char)(blkno>>16);
1711			bcb->CDB[2] = (unsigned char)(blkno>>24);
1712
1713			result = ene_send_scsi_cmd(us, FDIR_READ, buf+offset, 0);
1714			if (result != USB_STOR_XFER_GOOD) {
1715				pr_info("MS_SCSI_Read --- result = %x\n", result);
1716				result = USB_STOR_TRANSPORT_ERROR;
1717				goto exit;
1718			}
1719
1720			blen -= len;
1721			if (blen <= 0)
1722				break;
1723			logblk++;
1724			PageNum = 0;
1725			offset += MS_BYTES_PER_PAGE*len;
1726		}
1727		usb_stor_set_xfer_buf(buf, blenByte, srb);
1728exit:
1729		kfree(buf);
1730	}
1731	return result;
1732}
1733
1734static int ms_scsi_write(struct us_data *us, struct scsi_cmnd *srb)
1735{
1736	int result;
1737	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1738	unsigned char *cdb = srb->cmnd;
1739	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1740
1741	u32 bn = ((cdb[2] << 24) & 0xff000000) |
1742			((cdb[3] << 16) & 0x00ff0000) |
1743			((cdb[4] << 8) & 0x0000ff00) |
1744			((cdb[5] << 0) & 0x000000ff);
1745	u16 blen = ((cdb[7] << 8) & 0xff00) | ((cdb[8] << 0) & 0x00ff);
1746	u32 blenByte = blen * 0x200;
1747
1748	if (bn > info->bl_num)
1749		return USB_STOR_TRANSPORT_ERROR;
1750
1751	if (info->MS_Status & MS_IsMSPro) {
1752		result = ene_load_bincode(us, MSP_RW_PATTERN);
1753		if (result != USB_STOR_XFER_GOOD) {
1754			pr_info("Load MSP RW pattern Fail !!\n");
1755			return USB_STOR_TRANSPORT_ERROR;
1756		}
1757
1758		/* set up the command wrapper */
1759		memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1760		bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1761		bcb->DataTransferLength = blenByte;
1762		bcb->Flags  = US_BULK_FLAG_OUT;
1763		bcb->CDB[0] = 0xF0;
1764		bcb->CDB[1] = 0x04;
1765		bcb->CDB[5] = (unsigned char)(bn);
1766		bcb->CDB[4] = (unsigned char)(bn>>8);
1767		bcb->CDB[3] = (unsigned char)(bn>>16);
1768		bcb->CDB[2] = (unsigned char)(bn>>24);
1769
1770		result = ene_send_scsi_cmd(us, FDIR_WRITE, scsi_sglist(srb), 1);
1771	} else {
1772		void *buf;
1773		int offset = 0;
1774		u16 PhyBlockAddr;
1775		u8 PageNum;
1776		u16 len, oldphy, newphy;
1777
1778		buf = kmalloc(blenByte, GFP_KERNEL);
1779		if (buf == NULL)
1780			return USB_STOR_TRANSPORT_ERROR;
1781		usb_stor_set_xfer_buf(buf, blenByte, srb);
1782
1783		result = ene_load_bincode(us, MS_RW_PATTERN);
1784		if (result != USB_STOR_XFER_GOOD) {
1785			pr_info("Load MS RW pattern Fail !!\n");
1786			result = USB_STOR_TRANSPORT_ERROR;
1787			goto exit;
1788		}
1789
1790		PhyBlockAddr = (u16)(bn / info->MS_Lib.PagesPerBlock);
1791		PageNum      = (u8)(bn % info->MS_Lib.PagesPerBlock);
1792
1793		while (1) {
1794			if (blen > (info->MS_Lib.PagesPerBlock-PageNum))
1795				len = info->MS_Lib.PagesPerBlock-PageNum;
1796			else
1797				len = blen;
1798
1799			oldphy = ms_libconv_to_physical(info, PhyBlockAddr); /* need check us <-> info */
1800			newphy = ms_libsearch_block_from_logical(us, PhyBlockAddr);
1801
1802			result = ms_read_copyblock(us, oldphy, newphy, PhyBlockAddr, PageNum, buf+offset, len);
1803
1804			if (result != USB_STOR_XFER_GOOD) {
1805				pr_info("MS_SCSI_Write --- result = %x\n", result);
1806				result =  USB_STOR_TRANSPORT_ERROR;
1807				goto exit;
1808			}
1809
1810			info->MS_Lib.Phy2LogMap[oldphy] = MS_LB_NOT_USED_ERASED;
1811			ms_lib_force_setlogical_pair(us, PhyBlockAddr, newphy);
1812
1813			blen -= len;
1814			if (blen <= 0)
1815				break;
1816			PhyBlockAddr++;
1817			PageNum = 0;
1818			offset += MS_BYTES_PER_PAGE*len;
1819		}
1820exit:
1821		kfree(buf);
1822	}
1823	return result;
1824}
1825
1826/*
1827 * ENE MS Card
1828 */
1829
1830static int ene_get_card_type(struct us_data *us, u16 index, void *buf)
1831{
1832	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1833	int result;
1834
1835	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1836	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1837	bcb->DataTransferLength	= 0x01;
1838	bcb->Flags			= US_BULK_FLAG_IN;
1839	bcb->CDB[0]			= 0xED;
1840	bcb->CDB[2]			= (unsigned char)(index>>8);
1841	bcb->CDB[3]			= (unsigned char)index;
1842
1843	result = ene_send_scsi_cmd(us, FDIR_READ, buf, 0);
1844	return result;
1845}
1846
1847static int ene_get_card_status(struct us_data *us, u8 *buf)
1848{
1849	u16 tmpreg;
1850	u32 reg4b;
1851	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1852
1853	/*usb_stor_dbg(us, "transport --- ENE_ReadSDReg\n");*/
1854	reg4b = *(u32 *)&buf[0x18];
1855	info->SD_READ_BL_LEN = (u8)((reg4b >> 8) & 0x0f);
1856
1857	tmpreg = (u16) reg4b;
1858	reg4b = *(u32 *)(&buf[0x14]);
1859	if ((info->SD_Status & SD_HiCapacity) && !(info->SD_Status & SD_IsMMC))
1860		info->HC_C_SIZE = (reg4b >> 8) & 0x3fffff;
1861
1862	info->SD_C_SIZE = ((tmpreg & 0x03) << 10) | (u16)(reg4b >> 22);
1863	info->SD_C_SIZE_MULT = (u8)(reg4b >> 7)  & 0x07;
1864	if ((info->SD_Status & SD_HiCapacity) && (info->SD_Status & SD_IsMMC))
1865		info->HC_C_SIZE = *(u32 *)(&buf[0x100]);
1866
1867	if (info->SD_READ_BL_LEN > SD_BLOCK_LEN) {
1868		info->SD_Block_Mult = 1 << (info->SD_READ_BL_LEN-SD_BLOCK_LEN);
1869		info->SD_READ_BL_LEN = SD_BLOCK_LEN;
1870	} else {
1871		info->SD_Block_Mult = 1;
1872	}
1873
1874	return USB_STOR_TRANSPORT_GOOD;
1875}
1876
1877static int ene_load_bincode(struct us_data *us, unsigned char flag)
1878{
1879	int err;
1880	char *fw_name = NULL;
1881	unsigned char *buf = NULL;
1882	const struct firmware *sd_fw = NULL;
1883	int result = USB_STOR_TRANSPORT_ERROR;
1884	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1885	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1886
1887	if (info->BIN_FLAG == flag)
1888		return USB_STOR_TRANSPORT_GOOD;
1889
1890	switch (flag) {
1891	/* For SD */
1892	case SD_INIT1_PATTERN:
1893		usb_stor_dbg(us, "SD_INIT1_PATTERN\n");
1894		fw_name = SD_INIT1_FIRMWARE;
1895		break;
1896	case SD_INIT2_PATTERN:
1897		usb_stor_dbg(us, "SD_INIT2_PATTERN\n");
1898		fw_name = SD_INIT2_FIRMWARE;
1899		break;
1900	case SD_RW_PATTERN:
1901		usb_stor_dbg(us, "SD_RW_PATTERN\n");
1902		fw_name = SD_RW_FIRMWARE;
1903		break;
1904	/* For MS */
1905	case MS_INIT_PATTERN:
1906		usb_stor_dbg(us, "MS_INIT_PATTERN\n");
1907		fw_name = MS_INIT_FIRMWARE;
1908		break;
1909	case MSP_RW_PATTERN:
1910		usb_stor_dbg(us, "MSP_RW_PATTERN\n");
1911		fw_name = MSP_RW_FIRMWARE;
1912		break;
1913	case MS_RW_PATTERN:
1914		usb_stor_dbg(us, "MS_RW_PATTERN\n");
1915		fw_name = MS_RW_FIRMWARE;
1916		break;
1917	default:
1918		usb_stor_dbg(us, "----------- Unknown PATTERN ----------\n");
1919		goto nofw;
1920	}
1921
1922	err = request_firmware(&sd_fw, fw_name, &us->pusb_dev->dev);
1923	if (err) {
1924		usb_stor_dbg(us, "load firmware %s failed\n", fw_name);
1925		goto nofw;
1926	}
1927	buf = kmemdup(sd_fw->data, sd_fw->size, GFP_KERNEL);
1928	if (buf == NULL)
 
1929		goto nofw;
1930
 
1931	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1932	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1933	bcb->DataTransferLength = sd_fw->size;
1934	bcb->Flags = US_BULK_FLAG_OUT;
1935	bcb->CDB[0] = 0xEF;
1936
1937	result = ene_send_scsi_cmd(us, FDIR_WRITE, buf, 0);
1938	if (us->srb != NULL)
1939		scsi_set_resid(us->srb, 0);
1940	info->BIN_FLAG = flag;
1941	kfree(buf);
1942
1943nofw:
1944	release_firmware(sd_fw);
1945	return result;
1946}
1947
1948static int ms_card_init(struct us_data *us)
1949{
1950	u32 result;
1951	u16 TmpBlock;
1952	unsigned char *PageBuffer0 = NULL, *PageBuffer1 = NULL;
1953	struct ms_lib_type_extdat extdat;
1954	u16 btBlk1st, btBlk2nd;
1955	u32 btBlk1stErred;
1956	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1957
1958	printk(KERN_INFO "MS_CardInit start\n");
1959
1960	ms_lib_free_allocatedarea(us); /* Clean buffer and set struct us_data flag to 0 */
1961
1962	/* get two PageBuffer */
1963	PageBuffer0 = kmalloc(MS_BYTES_PER_PAGE, GFP_KERNEL);
1964	PageBuffer1 = kmalloc(MS_BYTES_PER_PAGE, GFP_KERNEL);
1965	if ((PageBuffer0 == NULL) || (PageBuffer1 == NULL)) {
1966		result = MS_NO_MEMORY_ERROR;
1967		goto exit;
1968	}
1969
1970	btBlk1st = btBlk2nd = MS_LB_NOT_USED;
1971	btBlk1stErred = 0;
1972
1973	for (TmpBlock = 0; TmpBlock < MS_MAX_INITIAL_ERROR_BLOCKS+2; TmpBlock++) {
1974
1975		switch (ms_read_readpage(us, TmpBlock, 0, (u32 *)PageBuffer0, &extdat)) {
1976		case MS_STATUS_SUCCESS:
1977			break;
1978		case MS_STATUS_INT_ERROR:
1979			break;
1980		case MS_STATUS_ERROR:
1981		default:
1982			continue;
1983		}
1984
1985		if ((extdat.ovrflg & MS_REG_OVR_BKST) == MS_REG_OVR_BKST_NG)
1986			continue;
1987
1988		if (((extdat.mngflg & MS_REG_MNG_SYSFLG) == MS_REG_MNG_SYSFLG_USER) ||
1989			(be16_to_cpu(((struct ms_bootblock_page0 *)PageBuffer0)->header.wBlockID) != MS_BOOT_BLOCK_ID) ||
1990			(be16_to_cpu(((struct ms_bootblock_page0 *)PageBuffer0)->header.wFormatVersion) != MS_BOOT_BLOCK_FORMAT_VERSION) ||
1991			(((struct ms_bootblock_page0 *)PageBuffer0)->header.bNumberOfDataEntry != MS_BOOT_BLOCK_DATA_ENTRIES))
1992				continue;
1993
1994		if (btBlk1st != MS_LB_NOT_USED) {
1995			btBlk2nd = TmpBlock;
1996			break;
1997		}
1998
1999		btBlk1st = TmpBlock;
2000		memcpy(PageBuffer1, PageBuffer0, MS_BYTES_PER_PAGE);
2001		if (extdat.status1 & (MS_REG_ST1_DTER | MS_REG_ST1_EXER | MS_REG_ST1_FGER))
2002			btBlk1stErred = 1;
2003	}
2004
2005	if (btBlk1st == MS_LB_NOT_USED) {
2006		result = MS_STATUS_ERROR;
2007		goto exit;
2008	}
2009
2010	/* write protect */
2011	if ((extdat.status0 & MS_REG_ST0_WP) == MS_REG_ST0_WP_ON)
2012		ms_lib_ctrl_set(info, MS_LIB_CTRL_WRPROTECT);
2013
2014	result = MS_STATUS_ERROR;
2015	/* 1st Boot Block */
2016	if (btBlk1stErred == 0)
2017		result = ms_lib_process_bootblock(us, btBlk1st, PageBuffer1);
2018		/* 1st */
2019	/* 2nd Boot Block */
2020	if (result && (btBlk2nd != MS_LB_NOT_USED))
2021		result = ms_lib_process_bootblock(us, btBlk2nd, PageBuffer0);
2022
2023	if (result) {
2024		result = MS_STATUS_ERROR;
2025		goto exit;
2026	}
2027
2028	for (TmpBlock = 0; TmpBlock < btBlk1st; TmpBlock++)
2029		info->MS_Lib.Phy2LogMap[TmpBlock] = MS_LB_INITIAL_ERROR;
2030
2031	info->MS_Lib.Phy2LogMap[btBlk1st] = MS_LB_BOOT_BLOCK;
2032
2033	if (btBlk2nd != MS_LB_NOT_USED) {
2034		for (TmpBlock = btBlk1st + 1; TmpBlock < btBlk2nd; TmpBlock++)
2035			info->MS_Lib.Phy2LogMap[TmpBlock] = MS_LB_INITIAL_ERROR;
2036
2037		info->MS_Lib.Phy2LogMap[btBlk2nd] = MS_LB_BOOT_BLOCK;
2038	}
2039
2040	result = ms_lib_scan_logicalblocknumber(us, btBlk1st);
2041	if (result)
2042		goto exit;
2043
2044	for (TmpBlock = MS_PHYSICAL_BLOCKS_PER_SEGMENT;
2045		TmpBlock < info->MS_Lib.NumberOfPhyBlock;
2046		TmpBlock += MS_PHYSICAL_BLOCKS_PER_SEGMENT) {
2047		if (ms_count_freeblock(us, TmpBlock) == 0) {
2048			ms_lib_ctrl_set(info, MS_LIB_CTRL_WRPROTECT);
2049			break;
2050		}
2051	}
2052
2053	/* write */
2054	if (ms_lib_alloc_writebuf(us)) {
2055		result = MS_NO_MEMORY_ERROR;
2056		goto exit;
2057	}
2058
2059	result = MS_STATUS_SUCCESS;
2060
2061exit:
2062	kfree(PageBuffer1);
2063	kfree(PageBuffer0);
2064
2065	printk(KERN_INFO "MS_CardInit end\n");
2066	return result;
2067}
2068
2069static int ene_ms_init(struct us_data *us)
2070{
2071	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
2072	int result;
 
2073	u16 MSP_BlockSize, MSP_UserAreaBlocks;
2074	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
2075	u8 *bbuf = info->bbuf;
2076	unsigned int s;
2077
2078	printk(KERN_INFO "transport --- ENE_MSInit\n");
2079
2080	/* the same part to test ENE */
2081
2082	result = ene_load_bincode(us, MS_INIT_PATTERN);
2083	if (result != USB_STOR_XFER_GOOD) {
2084		printk(KERN_ERR "Load MS Init Code Fail !!\n");
2085		return USB_STOR_TRANSPORT_ERROR;
2086	}
2087
2088	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
2089	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
2090	bcb->DataTransferLength = 0x200;
2091	bcb->Flags      = US_BULK_FLAG_IN;
2092	bcb->CDB[0]     = 0xF1;
2093	bcb->CDB[1]     = 0x01;
2094
2095	result = ene_send_scsi_cmd(us, FDIR_READ, bbuf, 0);
2096	if (result != USB_STOR_XFER_GOOD) {
2097		printk(KERN_ERR "Execution MS Init Code Fail !!\n");
2098		return USB_STOR_TRANSPORT_ERROR;
2099	}
2100	/* the same part to test ENE */
2101	info->MS_Status = bbuf[0];
2102
2103	s = info->MS_Status;
2104	if ((s & MS_Insert) && (s & MS_Ready)) {
2105		printk(KERN_INFO "Insert     = %x\n", !!(s & MS_Insert));
2106		printk(KERN_INFO "Ready      = %x\n", !!(s & MS_Ready));
2107		printk(KERN_INFO "IsMSPro    = %x\n", !!(s & MS_IsMSPro));
2108		printk(KERN_INFO "IsMSPHG    = %x\n", !!(s & MS_IsMSPHG));
2109		printk(KERN_INFO "WtP= %x\n", !!(s & MS_WtP));
2110		if (s & MS_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;
2114		} else {
2115			ms_card_init(us); /* Card is MS (to ms.c)*/
2116		}
2117		usb_stor_dbg(us, "MS Init Code OK !!\n");
2118	} else {
2119		usb_stor_dbg(us, "MS Card Not Ready --- %x\n", bbuf[0]);
2120		return USB_STOR_TRANSPORT_ERROR;
2121	}
2122
2123	return USB_STOR_TRANSPORT_GOOD;
2124}
2125
2126static int ene_sd_init(struct us_data *us)
2127{
2128	int result;
 
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;
2132
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;
2139	}
2140
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;
2144	bcb->CDB[0] = 0xF2;
2145
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;
2150	}
2151
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;
2157	}
2158
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;
2163	bcb->CDB[0]             = 0xF1;
2164
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;
2169	}
2170
2171	info->SD_Status = bbuf[0];
2172	if ((info->SD_Status & SD_Insert) && (info->SD_Status & SD_Ready)) {
2173		unsigned int s = info->SD_Status;
2174
2175		ene_get_card_status(us, bbuf);
2176		usb_stor_dbg(us, "Insert     = %x\n", !!(s & SD_Insert));
2177		usb_stor_dbg(us, "Ready      = %x\n", !!(s & SD_Ready));
2178		usb_stor_dbg(us, "IsMMC      = %x\n", !!(s & SD_IsMMC));
2179		usb_stor_dbg(us, "HiCapacity = %x\n", !!(s & SD_HiCapacity));
2180		usb_stor_dbg(us, "HiSpeed    = %x\n", !!(s & SD_HiSpeed));
2181		usb_stor_dbg(us, "WtP        = %x\n", !!(s & SD_WtP));
2182	} else {
2183		usb_stor_dbg(us, "SD Card Not Ready --- %x\n", bbuf[0]);
2184		return USB_STOR_TRANSPORT_ERROR;
2185	}
2186	return USB_STOR_TRANSPORT_GOOD;
2187}
2188
2189
2190static int ene_init(struct us_data *us)
2191{
2192	int result;
2193	u8  misc_reg03;
2194	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
2195	u8 *bbuf = info->bbuf;
2196
2197	result = ene_get_card_type(us, REG_CARD_STATUS, bbuf);
2198	if (result != USB_STOR_XFER_GOOD)
2199		return USB_STOR_TRANSPORT_ERROR;
2200
2201	misc_reg03 = bbuf[0];
2202	if (misc_reg03 & 0x01) {
2203		if (!(info->SD_Status & SD_Ready)) {
2204			result = ene_sd_init(us);
2205			if (result != USB_STOR_XFER_GOOD)
2206				return USB_STOR_TRANSPORT_ERROR;
2207		}
2208	}
2209	if (misc_reg03 & 0x02) {
2210		if (!(info->MS_Status & MS_Ready)) {
2211			result = ene_ms_init(us);
2212			if (result != USB_STOR_XFER_GOOD)
2213				return USB_STOR_TRANSPORT_ERROR;
2214		}
2215	}
2216	return result;
2217}
2218
2219/*----- sd_scsi_irp() ---------*/
2220static int sd_scsi_irp(struct us_data *us, struct scsi_cmnd *srb)
2221{
2222	int    result;
2223	struct ene_ub6250_info *info = (struct ene_ub6250_info *)us->extra;
2224
 
2225	switch (srb->cmnd[0]) {
2226	case TEST_UNIT_READY:
2227		result = sd_scsi_test_unit_ready(us, srb);
2228		break; /* 0x00 */
2229	case REQUEST_SENSE:
2230		result = do_scsi_request_sense(us, srb);
2231		break; /* 0x03 */
2232	case INQUIRY:
2233		result = do_scsi_inquiry(us, srb);
2234		break; /* 0x12 */
2235	case MODE_SENSE:
2236		result = sd_scsi_mode_sense(us, srb);
2237		break; /* 0x1A */
2238	/*
2239	case START_STOP:
2240		result = SD_SCSI_Start_Stop(us, srb);
2241		break; //0x1B
2242	*/
2243	case READ_CAPACITY:
2244		result = sd_scsi_read_capacity(us, srb);
2245		break; /* 0x25 */
2246	case READ_10:
2247		result = sd_scsi_read(us, srb);
2248		break; /* 0x28 */
2249	case WRITE_10:
2250		result = sd_scsi_write(us, srb);
2251		break; /* 0x2A */
2252	default:
2253		info->SrbStatus = SS_ILLEGAL_REQUEST;
2254		result = USB_STOR_TRANSPORT_FAILED;
2255		break;
2256	}
2257	if (result == USB_STOR_TRANSPORT_GOOD)
2258		info->SrbStatus = SS_SUCCESS;
2259	return result;
2260}
2261
2262/*
2263 * ms_scsi_irp()
2264 */
2265static int ms_scsi_irp(struct us_data *us, struct scsi_cmnd *srb)
2266{
2267	int result;
2268	struct ene_ub6250_info *info = (struct ene_ub6250_info *)us->extra;
2269
2270	switch (srb->cmnd[0]) {
2271	case TEST_UNIT_READY:
2272		result = ms_scsi_test_unit_ready(us, srb);
2273		break; /* 0x00 */
2274	case REQUEST_SENSE:
2275		result = do_scsi_request_sense(us, srb);
2276		break; /* 0x03 */
2277	case INQUIRY:
2278		result = do_scsi_inquiry(us, srb);
2279		break; /* 0x12 */
2280	case MODE_SENSE:
2281		result = ms_scsi_mode_sense(us, srb);
2282		break; /* 0x1A */
2283	case READ_CAPACITY:
2284		result = ms_scsi_read_capacity(us, srb);
2285		break; /* 0x25 */
2286	case READ_10:
2287		result = ms_scsi_read(us, srb);
2288		break; /* 0x28 */
2289	case WRITE_10:
2290		result = ms_scsi_write(us, srb);
2291		break;  /* 0x2A */
2292	default:
2293		info->SrbStatus = SS_ILLEGAL_REQUEST;
2294		result = USB_STOR_TRANSPORT_FAILED;
2295		break;
2296	}
2297	if (result == USB_STOR_TRANSPORT_GOOD)
2298		info->SrbStatus = SS_SUCCESS;
2299	return result;
2300}
2301
2302static int ene_transport(struct scsi_cmnd *srb, struct us_data *us)
2303{
2304	int result = USB_STOR_XFER_GOOD;
2305	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
2306
2307	/*US_DEBUG(usb_stor_show_command(us, srb)); */
2308	scsi_set_resid(srb, 0);
2309	if (unlikely(!(info->SD_Status & SD_Ready) || (info->MS_Status & MS_Ready)))
2310		result = ene_init(us);
2311	if (result == USB_STOR_XFER_GOOD) {
2312		result = USB_STOR_TRANSPORT_ERROR;
2313		if (info->SD_Status & SD_Ready)
2314			result = sd_scsi_irp(us, srb);
2315
2316		if (info->MS_Status & MS_Ready)
2317			result = ms_scsi_irp(us, srb);
2318	}
2319	return result;
2320}
2321
2322static struct scsi_host_template ene_ub6250_host_template;
2323
2324static int ene_ub6250_probe(struct usb_interface *intf,
2325			 const struct usb_device_id *id)
2326{
2327	int result;
2328	u8  misc_reg03;
2329	struct us_data *us;
2330	struct ene_ub6250_info *info;
2331
2332	result = usb_stor_probe1(&us, intf, id,
2333		   (id - ene_ub6250_usb_ids) + ene_ub6250_unusual_dev_list,
2334		   &ene_ub6250_host_template);
2335	if (result)
2336		return result;
2337
2338	/* FIXME: where should the code alloc extra buf ? */
2339	us->extra = kzalloc(sizeof(struct ene_ub6250_info), GFP_KERNEL);
2340	if (!us->extra)
2341		return -ENOMEM;
2342	us->extra_destructor = ene_ub6250_info_destructor;
2343
2344	info = (struct ene_ub6250_info *)(us->extra);
2345	info->bbuf = kmalloc(512, GFP_KERNEL);
2346	if (!info->bbuf) {
2347		kfree(us->extra);
2348		return -ENOMEM;
2349	}
2350
2351	us->transport_name = "ene_ub6250";
2352	us->transport = ene_transport;
2353	us->max_lun = 0;
2354
2355	result = usb_stor_probe2(us);
2356	if (result)
2357		return result;
2358
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;
2364	}
2365
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");
2370	}
2371
2372	return result;
2373}
2374
2375
2376#ifdef CONFIG_PM
2377
2378static int ene_ub6250_resume(struct usb_interface *iface)
2379{
 
2380	struct us_data *us = usb_get_intfdata(iface);
2381	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
2382
2383	mutex_lock(&us->dev_mutex);
2384
 
2385	if (us->suspend_resume_hook)
2386		(us->suspend_resume_hook)(us, US_RESUME);
2387
2388	mutex_unlock(&us->dev_mutex);
2389
2390	info->Power_IsResum = true;
2391	/* info->SD_Status &= ~SD_Ready; */
2392	info->SD_Status = 0;
2393	info->MS_Status = 0;
2394	info->SM_Status = 0;
2395
2396	return 0;
2397}
2398
2399static int ene_ub6250_reset_resume(struct usb_interface *iface)
2400{
 
2401	struct us_data *us = usb_get_intfdata(iface);
2402	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
2403
2404	/* Report the reset to the SCSI core */
2405	usb_stor_reset_resume(iface);
2406
2407	/*
2408	 * FIXME: Notify the subdrivers that they need to reinitialize
2409	 * the device
2410	 */
2411	info->Power_IsResum = true;
2412	/* info->SD_Status &= ~SD_Ready; */
2413	info->SD_Status = 0;
2414	info->MS_Status = 0;
2415	info->SM_Status = 0;
2416
2417	return 0;
2418}
2419
2420#else
2421
2422#define ene_ub6250_resume		NULL
2423#define ene_ub6250_reset_resume		NULL
2424
2425#endif
2426
2427static struct usb_driver ene_ub6250_driver = {
2428	.name =		DRV_NAME,
2429	.probe =	ene_ub6250_probe,
2430	.disconnect =	usb_stor_disconnect,
2431	.suspend =	usb_stor_suspend,
2432	.resume =	ene_ub6250_resume,
2433	.reset_resume =	ene_ub6250_reset_resume,
2434	.pre_reset =	usb_stor_pre_reset,
2435	.post_reset =	usb_stor_post_reset,
2436	.id_table =	ene_ub6250_usb_ids,
2437	.soft_unbind =	1,
2438	.no_dynamic_id = 1,
2439};
2440
2441module_usb_stor_driver(ene_ub6250_driver, ene_ub6250_host_template, DRV_NAME);
v3.5.6
   1/*
   2 *
   3 * This program is free software; you can redistribute it and/or modify it
   4 * under the terms of the GNU General Public License as published by the
   5 * Free Software Foundation; either version 2, or (at your option) any
   6 * later version.
   7 *
   8 * This program is distributed in the hope that it will be useful, but
   9 * WITHOUT ANY WARRANTY; without even the implied warranty of
  10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  11 * General Public License for more details.
  12 *
  13 * You should have received a copy of the GNU General Public License along
  14 * with this program; if not, write to the Free Software Foundation, Inc.,
  15 * 675 Mass Ave, Cambridge, MA 02139, USA.
  16 */
  17#include <linux/jiffies.h>
  18#include <linux/errno.h>
  19#include <linux/module.h>
  20#include <linux/slab.h>
  21
  22#include <scsi/scsi.h>
  23#include <scsi/scsi_cmnd.h>
  24
  25#include <linux/firmware.h>
  26
  27#include "usb.h"
  28#include "transport.h"
  29#include "protocol.h"
  30#include "debug.h"
 
 
 
 
 
 
 
 
 
 
  31
  32MODULE_DESCRIPTION("Driver for ENE UB6250 reader");
  33MODULE_LICENSE("GPL");
  34
 
 
 
 
 
 
  35
  36/*
  37 * The table of devices
  38 */
  39#define UNUSUAL_DEV(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax, \
  40		    vendorName, productName, useProtocol, useTransport, \
  41		    initFunction, flags) \
  42{ USB_DEVICE_VER(id_vendor, id_product, bcdDeviceMin, bcdDeviceMax), \
  43	.driver_info = (flags)|(USB_US_TYPE_STOR<<24) }
  44
  45static struct usb_device_id ene_ub6250_usb_ids[] = {
  46#	include "unusual_ene_ub6250.h"
  47	{ }		/* Terminating entry */
  48};
  49MODULE_DEVICE_TABLE(usb, ene_ub6250_usb_ids);
  50
  51#undef UNUSUAL_DEV
  52
  53/*
  54 * The flags table
  55 */
  56#define UNUSUAL_DEV(idVendor, idProduct, bcdDeviceMin, bcdDeviceMax, \
  57		    vendor_name, product_name, use_protocol, use_transport, \
  58		    init_function, Flags) \
  59{ \
  60	.vendorName = vendor_name,	\
  61	.productName = product_name,	\
  62	.useProtocol = use_protocol,	\
  63	.useTransport = use_transport,	\
  64	.initFunction = init_function,	\
  65}
  66
  67static struct us_unusual_dev ene_ub6250_unusual_dev_list[] = {
  68#	include "unusual_ene_ub6250.h"
  69	{ }		/* Terminating entry */
  70};
  71
  72#undef UNUSUAL_DEV
  73
  74
  75
  76/* ENE bin code len */
  77#define ENE_BIN_CODE_LEN    0x800
  78/* EnE HW Register */
  79#define REG_CARD_STATUS     0xFF83
  80#define REG_HW_TRAP1        0xFF89
  81
  82/* SRB Status */
  83#define SS_SUCCESS                  0x00      /* No Sense */
  84#define SS_NOT_READY                0x02
  85#define SS_MEDIUM_ERR               0x03
  86#define SS_HW_ERR                   0x04
  87#define SS_ILLEGAL_REQUEST          0x05
  88#define SS_UNIT_ATTENTION           0x06
  89
  90/* ENE Load FW Pattern */
  91#define SD_INIT1_PATTERN   1
  92#define SD_INIT2_PATTERN   2
  93#define SD_RW_PATTERN      3
  94#define MS_INIT_PATTERN    4
  95#define MSP_RW_PATTERN     5
  96#define MS_RW_PATTERN      6
  97#define SM_INIT_PATTERN    7
  98#define SM_RW_PATTERN      8
  99
 100#define FDIR_WRITE         0
 101#define FDIR_READ          1
 102
 103/* For MS Card */
 104
 105/* Status Register 1 */
 106#define MS_REG_ST1_MB           0x80    /* media busy */
 107#define MS_REG_ST1_FB1          0x40    /* flush busy 1 */
 108#define MS_REG_ST1_DTER         0x20    /* error on data(corrected) */
 109#define MS_REG_ST1_UCDT         0x10    /* unable to correct data */
 110#define MS_REG_ST1_EXER         0x08    /* error on extra(corrected) */
 111#define MS_REG_ST1_UCEX         0x04    /* unable to correct extra */
 112#define MS_REG_ST1_FGER         0x02    /* error on overwrite flag(corrected) */
 113#define MS_REG_ST1_UCFG         0x01    /* unable to correct overwrite flag */
 114#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)
 115
 116/* Overwrite Area */
 117#define MS_REG_OVR_BKST		0x80            /* block status */
 118#define MS_REG_OVR_BKST_OK	MS_REG_OVR_BKST     /* OK */
 119#define MS_REG_OVR_BKST_NG	0x00            /* NG */
 120#define MS_REG_OVR_PGST0	0x40            /* page status */
 121#define MS_REG_OVR_PGST1	0x20
 122#define MS_REG_OVR_PGST_MASK	(MS_REG_OVR_PGST0 | MS_REG_OVR_PGST1)
 123#define MS_REG_OVR_PGST_OK	(MS_REG_OVR_PGST0 | MS_REG_OVR_PGST1) /* OK */
 124#define MS_REG_OVR_PGST_NG	MS_REG_OVR_PGST1                      /* NG */
 125#define MS_REG_OVR_PGST_DATA_ERROR	0x00        /* data error */
 126#define MS_REG_OVR_UDST			0x10        /* update status */
 127#define MS_REG_OVR_UDST_UPDATING	0x00        /* updating */
 128#define MS_REG_OVR_UDST_NO_UPDATE	MS_REG_OVR_UDST
 129#define MS_REG_OVR_RESERVED	0x08
 130#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)
 131
 132/* Management Flag */
 133#define MS_REG_MNG_SCMS0	0x20    /* serial copy management system */
 134#define MS_REG_MNG_SCMS1	0x10
 135#define MS_REG_MNG_SCMS_MASK		(MS_REG_MNG_SCMS0 | MS_REG_MNG_SCMS1)
 136#define MS_REG_MNG_SCMS_COPY_OK		(MS_REG_MNG_SCMS0 | MS_REG_MNG_SCMS1)
 137#define MS_REG_MNG_SCMS_ONE_COPY	MS_REG_MNG_SCMS1
 138#define MS_REG_MNG_SCMS_NO_COPY	0x00
 139#define MS_REG_MNG_ATFLG	0x08    /* address transfer table flag */
 140#define MS_REG_MNG_ATFLG_OTHER	MS_REG_MNG_ATFLG    /* other */
 141#define MS_REG_MNG_ATFLG_ATTBL	0x00	/* address transfer table */
 142#define MS_REG_MNG_SYSFLG	0x04	/* system flag */
 143#define MS_REG_MNG_SYSFLG_USER	MS_REG_MNG_SYSFLG   /* user block */
 144#define MS_REG_MNG_SYSFLG_BOOT	0x00	/* system block */
 145#define MS_REG_MNG_RESERVED	0xc3
 146#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)
 147
 148
 149#define MS_MAX_PAGES_PER_BLOCK		32
 150#define MS_MAX_INITIAL_ERROR_BLOCKS 	10
 151#define MS_LIB_BITS_PER_BYTE		8
 152
 153#define MS_SYSINF_FORMAT_FAT		1
 154#define MS_SYSINF_USAGE_GENERAL		0
 155
 156#define MS_SYSINF_MSCLASS_TYPE_1	1
 157#define MS_SYSINF_PAGE_SIZE		MS_BYTES_PER_PAGE /* fixed */
 158
 159#define MS_SYSINF_CARDTYPE_RDONLY	1
 160#define MS_SYSINF_CARDTYPE_RDWR		2
 161#define MS_SYSINF_CARDTYPE_HYBRID	3
 162#define MS_SYSINF_SECURITY		0x01
 163#define MS_SYSINF_SECURITY_NO_SUPPORT	MS_SYSINF_SECURITY
 164#define MS_SYSINF_SECURITY_SUPPORT	0
 165
 166#define MS_SYSINF_RESERVED1		1
 167#define MS_SYSINF_RESERVED2		1
 168
 169#define MS_SYSENT_TYPE_INVALID_BLOCK	0x01
 170#define MS_SYSENT_TYPE_CIS_IDI		0x0a    /* CIS/IDI */
 171
 172#define SIZE_OF_KIRO		1024
 173#define BYTE_MASK		0xff
 174
 175/* ms error code */
 176#define MS_STATUS_WRITE_PROTECT	0x0106
 177#define MS_STATUS_SUCCESS	0x0000
 178#define MS_ERROR_FLASH_READ	0x8003
 179#define MS_ERROR_FLASH_ERASE	0x8005
 180#define MS_LB_ERROR		0xfff0
 181#define MS_LB_BOOT_BLOCK	0xfff1
 182#define MS_LB_INITIAL_ERROR	0xfff2
 183#define MS_STATUS_SUCCESS_WITH_ECC 0xfff3
 184#define MS_LB_ACQUIRED_ERROR	0xfff4
 185#define MS_LB_NOT_USED_ERASED	0xfff5
 186#define MS_NOCARD_ERROR		0xfff8
 187#define MS_NO_MEMORY_ERROR	0xfff9
 188#define MS_STATUS_INT_ERROR	0xfffa
 189#define MS_STATUS_ERROR		0xfffe
 190#define MS_LB_NOT_USED		0xffff
 191
 192#define MS_REG_MNG_SYSFLG	0x04    /* system flag */
 193#define MS_REG_MNG_SYSFLG_USER	MS_REG_MNG_SYSFLG   /* user block */
 194
 195#define MS_BOOT_BLOCK_ID                        0x0001
 196#define MS_BOOT_BLOCK_FORMAT_VERSION            0x0100
 197#define MS_BOOT_BLOCK_DATA_ENTRIES              2
 198
 199#define MS_NUMBER_OF_SYSTEM_ENTRY       	4
 200#define MS_NUMBER_OF_BOOT_BLOCK			2
 201#define MS_BYTES_PER_PAGE			512
 202#define MS_LOGICAL_BLOCKS_PER_SEGMENT		496
 203#define MS_LOGICAL_BLOCKS_IN_1ST_SEGMENT        494
 204
 205#define MS_PHYSICAL_BLOCKS_PER_SEGMENT		0x200 /* 512 */
 206#define MS_PHYSICAL_BLOCKS_PER_SEGMENT_MASK     0x1ff
 207
 208/* overwrite area */
 209#define MS_REG_OVR_BKST		0x80		/* block status */
 210#define MS_REG_OVR_BKST_OK	MS_REG_OVR_BKST	/* OK */
 211#define MS_REG_OVR_BKST_NG	0x00            /* NG */
 212
 213/* Status Register 1 */
 214#define MS_REG_ST1_DTER		0x20	/* error on data(corrected) */
 215#define MS_REG_ST1_EXER		0x08	/* error on extra(corrected) */
 216#define MS_REG_ST1_FGER		0x02	/* error on overwrite flag(corrected) */
 217
 218/* MemoryStick Register */
 219/* Status Register 0 */
 220#define MS_REG_ST0_WP		0x01	/* write protected */
 221#define MS_REG_ST0_WP_ON	MS_REG_ST0_WP
 222
 223#define MS_LIB_CTRL_RDONLY      0
 224#define MS_LIB_CTRL_WRPROTECT   1
 225
 226/*dphy->log table */
 227#define ms_libconv_to_logical(pdx, PhyBlock) (((PhyBlock) >= (pdx)->MS_Lib.NumberOfPhyBlock) ? MS_STATUS_ERROR : (pdx)->MS_Lib.Phy2LogMap[PhyBlock])
 228#define ms_libconv_to_physical(pdx, LogBlock) (((LogBlock) >= (pdx)->MS_Lib.NumberOfLogBlock) ? MS_STATUS_ERROR : (pdx)->MS_Lib.Log2PhyMap[LogBlock])
 229
 230#define ms_lib_ctrl_set(pdx, Flag)	((pdx)->MS_Lib.flags |= (1 << (Flag)))
 231#define ms_lib_ctrl_reset(pdx, Flag)	((pdx)->MS_Lib.flags &= ~(1 << (Flag)))
 232#define ms_lib_ctrl_check(pdx, Flag)	((pdx)->MS_Lib.flags & (1 << (Flag)))
 233
 234#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))
 235#define ms_lib_clear_pagemap(pdx) memset((pdx)->MS_Lib.pagemap, 0, sizeof((pdx)->MS_Lib.pagemap))
 236#define memstick_logaddr(logadr1, logadr0) ((((u16)(logadr1)) << 8) | (logadr0))
 237
 238
 239struct SD_STATUS {
 240	u8    Insert:1;
 241	u8    Ready:1;
 242	u8    MediaChange:1;
 243	u8    IsMMC:1;
 244	u8    HiCapacity:1;
 245	u8    HiSpeed:1;
 246	u8    WtP:1;
 247	u8    Reserved:1;
 248};
 249
 250struct MS_STATUS {
 251	u8    Insert:1;
 252	u8    Ready:1;
 253	u8    MediaChange:1;
 254	u8    IsMSPro:1;
 255	u8    IsMSPHG:1;
 256	u8    Reserved1:1;
 257	u8    WtP:1;
 258	u8    Reserved2:1;
 259};
 260
 261struct SM_STATUS {
 262	u8    Insert:1;
 263	u8    Ready:1;
 264	u8    MediaChange:1;
 265	u8    Reserved:3;
 266	u8    WtP:1;
 267	u8    IsMS:1;
 268};
 269
 270struct ms_bootblock_cis {
 271	u8 bCistplDEVICE[6];    /* 0 */
 272	u8 bCistplDEVICE0C[6];  /* 6 */
 273	u8 bCistplJEDECC[4];    /* 12 */
 274	u8 bCistplMANFID[6];    /* 16 */
 275	u8 bCistplVER1[32];     /* 22 */
 276	u8 bCistplFUNCID[4];    /* 54 */
 277	u8 bCistplFUNCE0[4];    /* 58 */
 278	u8 bCistplFUNCE1[5];    /* 62 */
 279	u8 bCistplCONF[7];      /* 67 */
 280	u8 bCistplCFTBLENT0[10];/* 74 */
 281	u8 bCistplCFTBLENT1[8]; /* 84 */
 282	u8 bCistplCFTBLENT2[12];/* 92 */
 283	u8 bCistplCFTBLENT3[8]; /* 104 */
 284	u8 bCistplCFTBLENT4[17];/* 112 */
 285	u8 bCistplCFTBLENT5[8]; /* 129 */
 286	u8 bCistplCFTBLENT6[17];/* 137 */
 287	u8 bCistplCFTBLENT7[8]; /* 154 */
 288	u8 bCistplNOLINK[3];    /* 162 */
 289} ;
 290
 291struct ms_bootblock_idi {
 292#define MS_IDI_GENERAL_CONF 0x848A
 293	u16 wIDIgeneralConfiguration;	/* 0 */
 294	u16 wIDInumberOfCylinder;	/* 1 */
 295	u16 wIDIreserved0;		/* 2 */
 296	u16 wIDInumberOfHead;		/* 3 */
 297	u16 wIDIbytesPerTrack;		/* 4 */
 298	u16 wIDIbytesPerSector;		/* 5 */
 299	u16 wIDIsectorsPerTrack;	/* 6 */
 300	u16 wIDItotalSectors[2];	/* 7-8  high,low */
 301	u16 wIDIreserved1[11];		/* 9-19 */
 302	u16 wIDIbufferType;		/* 20 */
 303	u16 wIDIbufferSize;		/* 21 */
 304	u16 wIDIlongCmdECC;		/* 22 */
 305	u16 wIDIfirmVersion[4];		/* 23-26 */
 306	u16 wIDImodelName[20];		/* 27-46 */
 307	u16 wIDIreserved2;		/* 47 */
 308	u16 wIDIlongWordSupported;	/* 48 */
 309	u16 wIDIdmaSupported;		/* 49 */
 310	u16 wIDIreserved3;		/* 50 */
 311	u16 wIDIpioTiming;		/* 51 */
 312	u16 wIDIdmaTiming;		/* 52 */
 313	u16 wIDItransferParameter;	/* 53 */
 314	u16 wIDIformattedCylinder;	/* 54 */
 315	u16 wIDIformattedHead;		/* 55 */
 316	u16 wIDIformattedSectorsPerTrack;/* 56 */
 317	u16 wIDIformattedTotalSectors[2];/* 57-58 */
 318	u16 wIDImultiSector;		/* 59 */
 319	u16 wIDIlbaSectors[2];		/* 60-61 */
 320	u16 wIDIsingleWordDMA;		/* 62 */
 321	u16 wIDImultiWordDMA;		/* 63 */
 322	u16 wIDIreserved4[192];		/* 64-255 */
 323};
 324
 325struct ms_bootblock_sysent_rec {
 326	u32 dwStart;
 327	u32 dwSize;
 328	u8 bType;
 329	u8 bReserved[3];
 330};
 331
 332struct ms_bootblock_sysent {
 333	struct ms_bootblock_sysent_rec entry[MS_NUMBER_OF_SYSTEM_ENTRY];
 334};
 335
 336struct ms_bootblock_sysinf {
 337	u8 bMsClass;			/* must be 1 */
 338	u8 bCardType;			/* see below */
 339	u16 wBlockSize;			/* n KB */
 340	u16 wBlockNumber;		/* number of physical block */
 341	u16 wTotalBlockNumber;		/* number of logical block */
 342	u16 wPageSize;			/* must be 0x200 */
 343	u8 bExtraSize;			/* 0x10 */
 344	u8 bSecuritySupport;
 345	u8 bAssemblyDate[8];
 346	u8 bFactoryArea[4];
 347	u8 bAssemblyMakerCode;
 348	u8 bAssemblyMachineCode[3];
 349	u16 wMemoryMakerCode;
 350	u16 wMemoryDeviceCode;
 351	u16 wMemorySize;
 352	u8 bReserved1;
 353	u8 bReserved2;
 354	u8 bVCC;
 355	u8 bVPP;
 356	u16 wControllerChipNumber;
 357	u16 wControllerFunction;	/* New MS */
 358	u8 bReserved3[9];		/* New MS */
 359	u8 bParallelSupport;		/* New MS */
 360	u16 wFormatValue;		/* New MS */
 361	u8 bFormatType;
 362	u8 bUsage;
 363	u8 bDeviceType;
 364	u8 bReserved4[22];
 365	u8 bFUValue3;
 366	u8 bFUValue4;
 367	u8 bReserved5[15];
 368};
 369
 370struct ms_bootblock_header {
 371	u16 wBlockID;
 372	u16 wFormatVersion;
 373	u8 bReserved1[184];
 374	u8 bNumberOfDataEntry;
 375	u8 bReserved2[179];
 376};
 377
 378struct ms_bootblock_page0 {
 379	struct ms_bootblock_header header;
 380	struct ms_bootblock_sysent sysent;
 381	struct ms_bootblock_sysinf sysinf;
 382};
 383
 384struct ms_bootblock_cis_idi {
 385	union {
 386		struct ms_bootblock_cis cis;
 387		u8 dmy[256];
 388	} cis;
 389
 390	union {
 391		struct ms_bootblock_idi idi;
 392		u8 dmy[256];
 393	} idi;
 394
 395};
 396
 397/* ENE MS Lib struct */
 398struct ms_lib_type_extdat {
 399	u8 reserved;
 400	u8 intr;
 401	u8 status0;
 402	u8 status1;
 403	u8 ovrflg;
 404	u8 mngflg;
 405	u16 logadr;
 406};
 407
 408struct ms_lib_ctrl {
 409	u32 flags;
 410	u32 BytesPerSector;
 411	u32 NumberOfCylinder;
 412	u32 SectorsPerCylinder;
 413	u16 cardType;			/* R/W, RO, Hybrid */
 414	u16 blockSize;
 415	u16 PagesPerBlock;
 416	u16 NumberOfPhyBlock;
 417	u16 NumberOfLogBlock;
 418	u16 NumberOfSegment;
 419	u16 *Phy2LogMap;		/* phy2log table */
 420	u16 *Log2PhyMap;		/* log2phy table */
 421	u16 wrtblk;
 422	unsigned char *pagemap[(MS_MAX_PAGES_PER_BLOCK + (MS_LIB_BITS_PER_BYTE-1)) / MS_LIB_BITS_PER_BYTE];
 423	unsigned char *blkpag;
 424	struct ms_lib_type_extdat *blkext;
 425	unsigned char copybuf[512];
 426};
 427
 428
 429/* SD Block Length */
 430/* 2^9 = 512 Bytes, The HW maximum read/write data length */
 431#define SD_BLOCK_LEN  9
 432
 433struct ene_ub6250_info {
 
 
 
 
 434	/* for 6250 code */
 435	struct SD_STATUS	SD_Status;
 436	struct MS_STATUS	MS_Status;
 437	struct SM_STATUS	SM_Status;
 438
 439	/* ----- SD Control Data ---------------- */
 440	/*SD_REGISTER SD_Regs; */
 441	u16		SD_Block_Mult;
 442	u8		SD_READ_BL_LEN;
 443	u16		SD_C_SIZE;
 444	u8		SD_C_SIZE_MULT;
 445
 446	/* SD/MMC New spec. */
 447	u8		SD_SPEC_VER;
 448	u8		SD_CSD_VER;
 449	u8		SD20_HIGH_CAPACITY;
 450	u32		HC_C_SIZE;
 451	u8		MMC_SPEC_VER;
 452	u8		MMC_BusWidth;
 453	u8		MMC_HIGH_CAPACITY;
 454
 455	/*----- MS Control Data ---------------- */
 456	bool		MS_SWWP;
 457	u32		MSP_TotalBlock;
 458	struct ms_lib_ctrl MS_Lib;
 459	bool		MS_IsRWPage;
 460	u16		MS_Model;
 461
 462	/*----- SM Control Data ---------------- */
 463	u8		SM_DeviceID;
 464	u8		SM_CardID;
 465
 466	unsigned char	*testbuf;
 467	u8		BIN_FLAG;
 468	u32		bl_num;
 469	int		SrbStatus;
 470
 471	/*------Power Managerment ---------------*/
 472	bool		Power_IsResum;
 473};
 474
 475static int ene_sd_init(struct us_data *us);
 476static int ene_ms_init(struct us_data *us);
 477static int ene_load_bincode(struct us_data *us, unsigned char flag);
 478
 479static void ene_ub6250_info_destructor(void *extra)
 480{
 
 
 481	if (!extra)
 482		return;
 
 483}
 484
 485static int ene_send_scsi_cmd(struct us_data *us, u8 fDir, void *buf, int use_sg)
 486{
 487	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
 488	struct bulk_cs_wrap *bcs = (struct bulk_cs_wrap *) us->iobuf;
 489
 490	int result;
 491	unsigned int residue;
 492	unsigned int cswlen = 0, partial = 0;
 493	unsigned int transfer_length = bcb->DataTransferLength;
 494
 495	/* US_DEBUGP("transport --- ene_send_scsi_cmd\n"); */
 496	/* send cmd to out endpoint */
 497	result = usb_stor_bulk_transfer_buf(us, us->send_bulk_pipe,
 498					    bcb, US_BULK_CB_WRAP_LEN, NULL);
 499	if (result != USB_STOR_XFER_GOOD) {
 500		US_DEBUGP("send cmd to out endpoint fail ---\n");
 501		return USB_STOR_TRANSPORT_ERROR;
 502	}
 503
 504	if (buf) {
 505		unsigned int pipe = fDir;
 506
 507		if (fDir  == FDIR_READ)
 508			pipe = us->recv_bulk_pipe;
 509		else
 510			pipe = us->send_bulk_pipe;
 511
 512		/* Bulk */
 513		if (use_sg) {
 514			result = usb_stor_bulk_srb(us, pipe, us->srb);
 515		} else {
 516			result = usb_stor_bulk_transfer_sg(us, pipe, buf,
 517						transfer_length, 0, &partial);
 518		}
 519		if (result != USB_STOR_XFER_GOOD) {
 520			US_DEBUGP("data transfer fail ---\n");
 521			return USB_STOR_TRANSPORT_ERROR;
 522		}
 523	}
 524
 525	/* Get CSW for device status */
 526	result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe, bcs,
 527					    US_BULK_CS_WRAP_LEN, &cswlen);
 528
 529	if (result == USB_STOR_XFER_SHORT && cswlen == 0) {
 530		US_DEBUGP("Received 0-length CSW; retrying...\n");
 531		result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
 532					    bcs, US_BULK_CS_WRAP_LEN, &cswlen);
 533	}
 534
 535	if (result == USB_STOR_XFER_STALLED) {
 536		/* get the status again */
 537		US_DEBUGP("Attempting to get CSW (2nd try)...\n");
 538		result = usb_stor_bulk_transfer_buf(us, us->recv_bulk_pipe,
 539						bcs, US_BULK_CS_WRAP_LEN, NULL);
 540	}
 541
 542	if (result != USB_STOR_XFER_GOOD)
 543		return USB_STOR_TRANSPORT_ERROR;
 544
 545	/* check bulk status */
 546	residue = le32_to_cpu(bcs->Residue);
 547
 548	/* try to compute the actual residue, based on how much data
 549	 * was really transferred and what the device tells us */
 
 
 550	if (residue && !(us->fflags & US_FL_IGNORE_RESIDUE)) {
 551		residue = min(residue, transfer_length);
 552		if (us->srb != NULL)
 553			scsi_set_resid(us->srb, max(scsi_get_resid(us->srb),
 554								(int)residue));
 555	}
 556
 557	if (bcs->Status != US_BULK_STAT_OK)
 558		return USB_STOR_TRANSPORT_ERROR;
 559
 560	return USB_STOR_TRANSPORT_GOOD;
 561}
 562
 563static int sd_scsi_test_unit_ready(struct us_data *us, struct scsi_cmnd *srb)
 564{
 565	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 
 566
 567	if (info->SD_Status.Insert && info->SD_Status.Ready)
 568		return USB_STOR_TRANSPORT_GOOD;
 569	else {
 570		ene_sd_init(us);
 571		return USB_STOR_TRANSPORT_GOOD;
 572	}
 573
 
 574	return USB_STOR_TRANSPORT_GOOD;
 575}
 576
 577static int sd_scsi_inquiry(struct us_data *us, struct scsi_cmnd *srb)
 578{
 579	unsigned char data_ptr[36] = {
 580		0x00, 0x80, 0x02, 0x00, 0x1F, 0x00, 0x00, 0x00, 0x55,
 581		0x53, 0x42, 0x32, 0x2E, 0x30, 0x20, 0x20, 0x43, 0x61,
 582		0x72, 0x64, 0x52, 0x65, 0x61, 0x64, 0x65, 0x72, 0x20,
 583		0x20, 0x20, 0x20, 0x20, 0x20, 0x30, 0x31, 0x30, 0x30 };
 584
 585	usb_stor_set_xfer_buf(data_ptr, 36, srb);
 586	return USB_STOR_TRANSPORT_GOOD;
 587}
 588
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 589static int sd_scsi_mode_sense(struct us_data *us, struct scsi_cmnd *srb)
 590{
 591	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 592	unsigned char mediaNoWP[12] = {
 593		0x0b, 0x00, 0x00, 0x08, 0x00, 0x00,
 594		0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
 595	unsigned char mediaWP[12]   = {
 596		0x0b, 0x00, 0x80, 0x08, 0x00, 0x00,
 597		0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
 598
 599	if (info->SD_Status.WtP)
 600		usb_stor_set_xfer_buf(mediaWP, 12, srb);
 601	else
 602		usb_stor_set_xfer_buf(mediaNoWP, 12, srb);
 603
 604
 605	return USB_STOR_TRANSPORT_GOOD;
 606}
 607
 608static int sd_scsi_read_capacity(struct us_data *us, struct scsi_cmnd *srb)
 609{
 610	u32	bl_num;
 611	u32	bl_len;
 612	unsigned int offset = 0;
 613	unsigned char    buf[8];
 614	struct scatterlist *sg = NULL;
 615	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 616
 617	US_DEBUGP("sd_scsi_read_capacity\n");
 618	if (info->SD_Status.HiCapacity) {
 619		bl_len = 0x200;
 620		if (info->SD_Status.IsMMC)
 621			bl_num = info->HC_C_SIZE-1;
 622		else
 623			bl_num = (info->HC_C_SIZE + 1) * 1024 - 1;
 624	} else {
 625		bl_len = 1 << (info->SD_READ_BL_LEN);
 626		bl_num = info->SD_Block_Mult * (info->SD_C_SIZE + 1)
 627				* (1 << (info->SD_C_SIZE_MULT + 2)) - 1;
 628	}
 629	info->bl_num = bl_num;
 630	US_DEBUGP("bl_len = %x\n", bl_len);
 631	US_DEBUGP("bl_num = %x\n", bl_num);
 632
 633	/*srb->request_bufflen = 8; */
 634	buf[0] = (bl_num >> 24) & 0xff;
 635	buf[1] = (bl_num >> 16) & 0xff;
 636	buf[2] = (bl_num >> 8) & 0xff;
 637	buf[3] = (bl_num >> 0) & 0xff;
 638	buf[4] = (bl_len >> 24) & 0xff;
 639	buf[5] = (bl_len >> 16) & 0xff;
 640	buf[6] = (bl_len >> 8) & 0xff;
 641	buf[7] = (bl_len >> 0) & 0xff;
 642
 643	usb_stor_access_xfer_buf(buf, 8, srb, &sg, &offset, TO_XFER_BUF);
 644
 645	return USB_STOR_TRANSPORT_GOOD;
 646}
 647
 648static int sd_scsi_read(struct us_data *us, struct scsi_cmnd *srb)
 649{
 650	int result;
 651	unsigned char *cdb = srb->cmnd;
 652	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
 653	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 654
 655	u32 bn = ((cdb[2] << 24) & 0xff000000) | ((cdb[3] << 16) & 0x00ff0000) |
 656		 ((cdb[4] << 8) & 0x0000ff00) | ((cdb[5] << 0) & 0x000000ff);
 657	u16 blen = ((cdb[7] << 8) & 0xff00) | ((cdb[8] << 0) & 0x00ff);
 658	u32 bnByte = bn * 0x200;
 659	u32 blenByte = blen * 0x200;
 660
 661	if (bn > info->bl_num)
 662		return USB_STOR_TRANSPORT_ERROR;
 663
 664	result = ene_load_bincode(us, SD_RW_PATTERN);
 665	if (result != USB_STOR_XFER_GOOD) {
 666		US_DEBUGP("Load SD RW pattern Fail !!\n");
 667		return USB_STOR_TRANSPORT_ERROR;
 668	}
 669
 670	if (info->SD_Status.HiCapacity)
 671		bnByte = bn;
 672
 673	/* set up the command wrapper */
 674	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
 675	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
 676	bcb->DataTransferLength = blenByte;
 677	bcb->Flags  = US_BULK_FLAG_IN;
 678	bcb->CDB[0] = 0xF1;
 679	bcb->CDB[5] = (unsigned char)(bnByte);
 680	bcb->CDB[4] = (unsigned char)(bnByte>>8);
 681	bcb->CDB[3] = (unsigned char)(bnByte>>16);
 682	bcb->CDB[2] = (unsigned char)(bnByte>>24);
 683
 684	result = ene_send_scsi_cmd(us, FDIR_READ, scsi_sglist(srb), 1);
 685	return result;
 686}
 687
 688static int sd_scsi_write(struct us_data *us, struct scsi_cmnd *srb)
 689{
 690	int result;
 691	unsigned char *cdb = srb->cmnd;
 692	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
 693	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 694
 695	u32 bn = ((cdb[2] << 24) & 0xff000000) | ((cdb[3] << 16) & 0x00ff0000) |
 696		 ((cdb[4] << 8) & 0x0000ff00) | ((cdb[5] << 0) & 0x000000ff);
 697	u16 blen = ((cdb[7] << 8) & 0xff00) | ((cdb[8] << 0) & 0x00ff);
 698	u32 bnByte = bn * 0x200;
 699	u32 blenByte = blen * 0x200;
 700
 701	if (bn > info->bl_num)
 702		return USB_STOR_TRANSPORT_ERROR;
 703
 704	result = ene_load_bincode(us, SD_RW_PATTERN);
 705	if (result != USB_STOR_XFER_GOOD) {
 706		US_DEBUGP("Load SD RW pattern Fail !!\n");
 707		return USB_STOR_TRANSPORT_ERROR;
 708	}
 709
 710	if (info->SD_Status.HiCapacity)
 711		bnByte = bn;
 712
 713	/* set up the command wrapper */
 714	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
 715	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
 716	bcb->DataTransferLength = blenByte;
 717	bcb->Flags  = 0x00;
 718	bcb->CDB[0] = 0xF0;
 719	bcb->CDB[5] = (unsigned char)(bnByte);
 720	bcb->CDB[4] = (unsigned char)(bnByte>>8);
 721	bcb->CDB[3] = (unsigned char)(bnByte>>16);
 722	bcb->CDB[2] = (unsigned char)(bnByte>>24);
 723
 724	result = ene_send_scsi_cmd(us, FDIR_WRITE, scsi_sglist(srb), 1);
 725	return result;
 726}
 727
 728/*
 729 * ENE MS Card
 730 */
 731
 732static int ms_lib_set_logicalpair(struct us_data *us, u16 logblk, u16 phyblk)
 733{
 734	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 735
 736	if ((logblk >= info->MS_Lib.NumberOfLogBlock) || (phyblk >= info->MS_Lib.NumberOfPhyBlock))
 737		return (u32)-1;
 738
 739	info->MS_Lib.Phy2LogMap[phyblk] = logblk;
 740	info->MS_Lib.Log2PhyMap[logblk] = phyblk;
 741
 742	return 0;
 743}
 744
 745static int ms_lib_set_logicalblockmark(struct us_data *us, u16 phyblk, u16 mark)
 746{
 747	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 748
 749	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
 750		return (u32)-1;
 751
 752	info->MS_Lib.Phy2LogMap[phyblk] = mark;
 753
 754	return 0;
 755}
 756
 757static int ms_lib_set_initialerrorblock(struct us_data *us, u16 phyblk)
 758{
 759	return ms_lib_set_logicalblockmark(us, phyblk, MS_LB_INITIAL_ERROR);
 760}
 761
 762static int ms_lib_set_bootblockmark(struct us_data *us, u16 phyblk)
 763{
 764	return ms_lib_set_logicalblockmark(us, phyblk, MS_LB_BOOT_BLOCK);
 765}
 766
 767static int ms_lib_free_logicalmap(struct us_data *us)
 768{
 769	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 770
 771	kfree(info->MS_Lib.Phy2LogMap);
 772	info->MS_Lib.Phy2LogMap = NULL;
 773
 774	kfree(info->MS_Lib.Log2PhyMap);
 775	info->MS_Lib.Log2PhyMap = NULL;
 776
 777	return 0;
 778}
 779
 780static int ms_lib_alloc_logicalmap(struct us_data *us)
 781{
 782	u32  i;
 783	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 784
 785	info->MS_Lib.Phy2LogMap = kmalloc(info->MS_Lib.NumberOfPhyBlock * sizeof(u16), GFP_KERNEL);
 786	info->MS_Lib.Log2PhyMap = kmalloc(info->MS_Lib.NumberOfLogBlock * sizeof(u16), GFP_KERNEL);
 
 
 
 
 787
 788	if ((info->MS_Lib.Phy2LogMap == NULL) || (info->MS_Lib.Log2PhyMap == NULL)) {
 789		ms_lib_free_logicalmap(us);
 790		return (u32)-1;
 791	}
 792
 793	for (i = 0; i < info->MS_Lib.NumberOfPhyBlock; i++)
 794		info->MS_Lib.Phy2LogMap[i] = MS_LB_NOT_USED;
 795
 796	for (i = 0; i < info->MS_Lib.NumberOfLogBlock; i++)
 797		info->MS_Lib.Log2PhyMap[i] = MS_LB_NOT_USED;
 798
 799	return 0;
 800}
 801
 802static void ms_lib_clear_writebuf(struct us_data *us)
 803{
 804	int i;
 805	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 806
 807	info->MS_Lib.wrtblk = (u16)-1;
 808	ms_lib_clear_pagemap(info);
 809
 810	if (info->MS_Lib.blkpag)
 811		memset(info->MS_Lib.blkpag, 0xff, info->MS_Lib.PagesPerBlock * info->MS_Lib.BytesPerSector);
 812
 813	if (info->MS_Lib.blkext) {
 814		for (i = 0; i < info->MS_Lib.PagesPerBlock; i++) {
 815			info->MS_Lib.blkext[i].status1 = MS_REG_ST1_DEFAULT;
 816			info->MS_Lib.blkext[i].ovrflg = MS_REG_OVR_DEFAULT;
 817			info->MS_Lib.blkext[i].mngflg = MS_REG_MNG_DEFAULT;
 818			info->MS_Lib.blkext[i].logadr = MS_LB_NOT_USED;
 819		}
 820	}
 821}
 822
 823static int ms_count_freeblock(struct us_data *us, u16 PhyBlock)
 824{
 825	u32 Ende, Count;
 826	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 827
 828	Ende = PhyBlock + MS_PHYSICAL_BLOCKS_PER_SEGMENT;
 829	for (Count = 0; PhyBlock < Ende; PhyBlock++) {
 830		switch (info->MS_Lib.Phy2LogMap[PhyBlock]) {
 831		case MS_LB_NOT_USED:
 832		case MS_LB_NOT_USED_ERASED:
 833			Count++;
 
 834		default:
 835			break;
 836		}
 837	}
 838
 839	return Count;
 840}
 841
 842static int ms_read_readpage(struct us_data *us, u32 PhyBlockAddr,
 843		u8 PageNum, u32 *PageBuf, struct ms_lib_type_extdat *ExtraDat)
 844{
 845	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
 
 
 846	int result;
 847	u8 ExtBuf[4];
 848	u32 bn = PhyBlockAddr * 0x20 + PageNum;
 849
 850	/* printk(KERN_INFO "MS --- MS_ReaderReadPage,
 851	PhyBlockAddr = %x, PageNum = %x\n", PhyBlockAddr, PageNum); */
 852
 853	result = ene_load_bincode(us, MS_RW_PATTERN);
 854	if (result != USB_STOR_XFER_GOOD)
 855		return USB_STOR_TRANSPORT_ERROR;
 856
 857	/* Read Page Data */
 858	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
 859	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
 860	bcb->DataTransferLength = 0x200;
 861	bcb->Flags      = US_BULK_FLAG_IN;
 862	bcb->CDB[0]     = 0xF1;
 863
 864	bcb->CDB[1]     = 0x02; /* in init.c ENE_MSInit() is 0x01 */
 865
 866	bcb->CDB[5]     = (unsigned char)(bn);
 867	bcb->CDB[4]     = (unsigned char)(bn>>8);
 868	bcb->CDB[3]     = (unsigned char)(bn>>16);
 869	bcb->CDB[2]     = (unsigned char)(bn>>24);
 870
 871	result = ene_send_scsi_cmd(us, FDIR_READ, PageBuf, 0);
 872	if (result != USB_STOR_XFER_GOOD)
 873		return USB_STOR_TRANSPORT_ERROR;
 874
 875
 876	/* Read Extra Data */
 877	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
 878	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
 879	bcb->DataTransferLength = 0x4;
 880	bcb->Flags      = US_BULK_FLAG_IN;
 881	bcb->CDB[0]     = 0xF1;
 882	bcb->CDB[1]     = 0x03;
 883
 884	bcb->CDB[5]     = (unsigned char)(PageNum);
 885	bcb->CDB[4]     = (unsigned char)(PhyBlockAddr);
 886	bcb->CDB[3]     = (unsigned char)(PhyBlockAddr>>8);
 887	bcb->CDB[2]     = (unsigned char)(PhyBlockAddr>>16);
 888	bcb->CDB[6]     = 0x01;
 889
 890	result = ene_send_scsi_cmd(us, FDIR_READ, &ExtBuf, 0);
 891	if (result != USB_STOR_XFER_GOOD)
 892		return USB_STOR_TRANSPORT_ERROR;
 893
 894	ExtraDat->reserved = 0;
 895	ExtraDat->intr     = 0x80;  /* Not yet,fireware support */
 896	ExtraDat->status0  = 0x10;  /* Not yet,fireware support */
 897
 898	ExtraDat->status1  = 0x00;  /* Not yet,fireware support */
 899	ExtraDat->ovrflg   = ExtBuf[0];
 900	ExtraDat->mngflg   = ExtBuf[1];
 901	ExtraDat->logadr   = memstick_logaddr(ExtBuf[2], ExtBuf[3]);
 902
 903	return USB_STOR_TRANSPORT_GOOD;
 904}
 905
 906static int ms_lib_process_bootblock(struct us_data *us, u16 PhyBlock, u8 *PageData)
 907{
 908	struct ms_bootblock_sysent *SysEntry;
 909	struct ms_bootblock_sysinf *SysInfo;
 910	u32 i, result;
 911	u8 PageNumber;
 912	u8 *PageBuffer;
 913	struct ms_lib_type_extdat ExtraData;
 914	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 915
 916	PageBuffer = kmalloc(MS_BYTES_PER_PAGE, GFP_KERNEL);
 917	if (PageBuffer == NULL)
 918		return (u32)-1;
 919
 920	result = (u32)-1;
 921
 922	SysInfo = &(((struct ms_bootblock_page0 *)PageData)->sysinf);
 923
 924	if ((SysInfo->bMsClass != MS_SYSINF_MSCLASS_TYPE_1) ||
 925		(be16_to_cpu(SysInfo->wPageSize) != MS_SYSINF_PAGE_SIZE) ||
 926		((SysInfo->bSecuritySupport & MS_SYSINF_SECURITY) == MS_SYSINF_SECURITY_SUPPORT) ||
 927		(SysInfo->bReserved1 != MS_SYSINF_RESERVED1) ||
 928		(SysInfo->bReserved2 != MS_SYSINF_RESERVED2) ||
 929		(SysInfo->bFormatType != MS_SYSINF_FORMAT_FAT) ||
 930		(SysInfo->bUsage != MS_SYSINF_USAGE_GENERAL))
 931		goto exit;
 932		/* */
 933	switch (info->MS_Lib.cardType = SysInfo->bCardType) {
 934	case MS_SYSINF_CARDTYPE_RDONLY:
 935		ms_lib_ctrl_set(info, MS_LIB_CTRL_RDONLY);
 936		break;
 937	case MS_SYSINF_CARDTYPE_RDWR:
 938		ms_lib_ctrl_reset(info, MS_LIB_CTRL_RDONLY);
 939		break;
 940	case MS_SYSINF_CARDTYPE_HYBRID:
 941	default:
 942		goto exit;
 943	}
 944
 945	info->MS_Lib.blockSize = be16_to_cpu(SysInfo->wBlockSize);
 946	info->MS_Lib.NumberOfPhyBlock = be16_to_cpu(SysInfo->wBlockNumber);
 947	info->MS_Lib.NumberOfLogBlock = be16_to_cpu(SysInfo->wTotalBlockNumber)-2;
 948	info->MS_Lib.PagesPerBlock = info->MS_Lib.blockSize * SIZE_OF_KIRO / MS_BYTES_PER_PAGE;
 949	info->MS_Lib.NumberOfSegment = info->MS_Lib.NumberOfPhyBlock / MS_PHYSICAL_BLOCKS_PER_SEGMENT;
 950	info->MS_Model = be16_to_cpu(SysInfo->wMemorySize);
 951
 952	/*Allocate to all number of logicalblock and physicalblock */
 953	if (ms_lib_alloc_logicalmap(us))
 954		goto exit;
 955
 956	/* Mark the book block */
 957	ms_lib_set_bootblockmark(us, PhyBlock);
 958
 959	SysEntry = &(((struct ms_bootblock_page0 *)PageData)->sysent);
 960
 961	for (i = 0; i < MS_NUMBER_OF_SYSTEM_ENTRY; i++) {
 962		u32  EntryOffset, EntrySize;
 963
 964		EntryOffset = be32_to_cpu(SysEntry->entry[i].dwStart);
 965
 966		if (EntryOffset == 0xffffff)
 967			continue;
 968		EntrySize = be32_to_cpu(SysEntry->entry[i].dwSize);
 969
 970		if (EntrySize == 0)
 971			continue;
 972
 973		if (EntryOffset + MS_BYTES_PER_PAGE + EntrySize > info->MS_Lib.blockSize * (u32)SIZE_OF_KIRO)
 974			continue;
 975
 976		if (i == 0) {
 977			u8 PrevPageNumber = 0;
 978			u16 phyblk;
 979
 980			if (SysEntry->entry[i].bType != MS_SYSENT_TYPE_INVALID_BLOCK)
 981				goto exit;
 982
 983			while (EntrySize > 0) {
 984
 985				PageNumber = (u8)(EntryOffset / MS_BYTES_PER_PAGE + 1);
 986				if (PageNumber != PrevPageNumber) {
 987					switch (ms_read_readpage(us, PhyBlock, PageNumber, (u32 *)PageBuffer, &ExtraData)) {
 988					case MS_STATUS_SUCCESS:
 989						break;
 990					case MS_STATUS_WRITE_PROTECT:
 991					case MS_ERROR_FLASH_READ:
 992					case MS_STATUS_ERROR:
 993					default:
 994						goto exit;
 995					}
 996
 997					PrevPageNumber = PageNumber;
 998				}
 999
1000				phyblk = be16_to_cpu(*(u16 *)(PageBuffer + (EntryOffset % MS_BYTES_PER_PAGE)));
1001				if (phyblk < 0x0fff)
1002					ms_lib_set_initialerrorblock(us, phyblk);
1003
1004				EntryOffset += 2;
1005				EntrySize -= 2;
1006			}
1007		} else if (i == 1) {  /* CIS/IDI */
1008			struct ms_bootblock_idi *idi;
1009
1010			if (SysEntry->entry[i].bType != MS_SYSENT_TYPE_CIS_IDI)
1011				goto exit;
1012
1013			switch (ms_read_readpage(us, PhyBlock, (u8)(EntryOffset / MS_BYTES_PER_PAGE + 1), (u32 *)PageBuffer, &ExtraData)) {
1014			case MS_STATUS_SUCCESS:
1015				break;
1016			case MS_STATUS_WRITE_PROTECT:
1017			case MS_ERROR_FLASH_READ:
1018			case MS_STATUS_ERROR:
1019			default:
1020				goto exit;
1021			}
1022
1023			idi = &((struct ms_bootblock_cis_idi *)(PageBuffer + (EntryOffset % MS_BYTES_PER_PAGE)))->idi.idi;
1024			if (le16_to_cpu(idi->wIDIgeneralConfiguration) != MS_IDI_GENERAL_CONF)
1025				goto exit;
1026
1027			info->MS_Lib.BytesPerSector = le16_to_cpu(idi->wIDIbytesPerSector);
1028			if (info->MS_Lib.BytesPerSector != MS_BYTES_PER_PAGE)
1029				goto exit;
1030		}
1031	} /* End for .. */
1032
1033	result = 0;
1034
1035exit:
1036	if (result)
1037		ms_lib_free_logicalmap(us);
1038
1039	kfree(PageBuffer);
1040
1041	result = 0;
1042	return result;
1043}
1044
1045static void ms_lib_free_writebuf(struct us_data *us)
1046{
1047	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1048	info->MS_Lib.wrtblk = (u16)-1; /* set to -1 */
1049
1050	/* memset((fdoExt)->MS_Lib.pagemap, 0, sizeof((fdoExt)->MS_Lib.pagemap)) */
1051
1052	ms_lib_clear_pagemap(info); /* (pdx)->MS_Lib.pagemap memset 0 in ms.h */
1053
1054	if (info->MS_Lib.blkpag) {
1055		kfree((u8 *)(info->MS_Lib.blkpag));  /* Arnold test ... */
1056		info->MS_Lib.blkpag = NULL;
1057	}
1058
1059	if (info->MS_Lib.blkext) {
1060		kfree((u8 *)(info->MS_Lib.blkext));  /* Arnold test ... */
1061		info->MS_Lib.blkext = NULL;
1062	}
1063}
1064
1065
1066static void ms_lib_free_allocatedarea(struct us_data *us)
1067{
1068	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1069
1070	ms_lib_free_writebuf(us); /* Free MS_Lib.pagemap */
1071	ms_lib_free_logicalmap(us); /* kfree MS_Lib.Phy2LogMap and MS_Lib.Log2PhyMap */
1072
1073	/* set struct us point flag to 0 */
1074	info->MS_Lib.flags = 0;
1075	info->MS_Lib.BytesPerSector = 0;
1076	info->MS_Lib.SectorsPerCylinder = 0;
1077
1078	info->MS_Lib.cardType = 0;
1079	info->MS_Lib.blockSize = 0;
1080	info->MS_Lib.PagesPerBlock = 0;
1081
1082	info->MS_Lib.NumberOfPhyBlock = 0;
1083	info->MS_Lib.NumberOfLogBlock = 0;
1084}
1085
1086
1087static int ms_lib_alloc_writebuf(struct us_data *us)
1088{
1089	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1090
1091	info->MS_Lib.wrtblk = (u16)-1;
1092
1093	info->MS_Lib.blkpag = kmalloc(info->MS_Lib.PagesPerBlock * info->MS_Lib.BytesPerSector, GFP_KERNEL);
1094	info->MS_Lib.blkext = kmalloc(info->MS_Lib.PagesPerBlock * sizeof(struct ms_lib_type_extdat), GFP_KERNEL);
 
 
 
 
1095
1096	if ((info->MS_Lib.blkpag == NULL) || (info->MS_Lib.blkext == NULL)) {
1097		ms_lib_free_writebuf(us);
1098		return (u32)-1;
1099	}
1100
1101	ms_lib_clear_writebuf(us);
1102
1103return 0;
1104}
1105
1106static int ms_lib_force_setlogical_pair(struct us_data *us, u16 logblk, u16 phyblk)
1107{
1108	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1109
1110	if (logblk == MS_LB_NOT_USED)
1111		return 0;
1112
1113	if ((logblk >= info->MS_Lib.NumberOfLogBlock) ||
1114		(phyblk >= info->MS_Lib.NumberOfPhyBlock))
1115		return (u32)-1;
1116
1117	info->MS_Lib.Phy2LogMap[phyblk] = logblk;
1118	info->MS_Lib.Log2PhyMap[logblk] = phyblk;
1119
1120	return 0;
1121}
1122
1123static int ms_read_copyblock(struct us_data *us, u16 oldphy, u16 newphy,
1124			u16 PhyBlockAddr, u8 PageNum, unsigned char *buf, u16 len)
1125{
1126	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1127	int result;
1128
1129	/* printk(KERN_INFO "MS_ReaderCopyBlock --- PhyBlockAddr = %x,
1130		PageNum = %x\n", PhyBlockAddr, PageNum); */
1131	result = ene_load_bincode(us, MS_RW_PATTERN);
1132	if (result != USB_STOR_XFER_GOOD)
1133		return USB_STOR_TRANSPORT_ERROR;
1134
1135	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1136	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1137	bcb->DataTransferLength = 0x200*len;
1138	bcb->Flags = 0x00;
1139	bcb->CDB[0] = 0xF0;
1140	bcb->CDB[1] = 0x08;
1141	bcb->CDB[4] = (unsigned char)(oldphy);
1142	bcb->CDB[3] = (unsigned char)(oldphy>>8);
1143	bcb->CDB[2] = 0; /* (BYTE)(oldphy>>16) */
1144	bcb->CDB[7] = (unsigned char)(newphy);
1145	bcb->CDB[6] = (unsigned char)(newphy>>8);
1146	bcb->CDB[5] = 0; /* (BYTE)(newphy>>16) */
1147	bcb->CDB[9] = (unsigned char)(PhyBlockAddr);
1148	bcb->CDB[8] = (unsigned char)(PhyBlockAddr>>8);
1149	bcb->CDB[10] = PageNum;
1150
1151	result = ene_send_scsi_cmd(us, FDIR_WRITE, buf, 0);
1152	if (result != USB_STOR_XFER_GOOD)
1153		return USB_STOR_TRANSPORT_ERROR;
1154
1155	return USB_STOR_TRANSPORT_GOOD;
1156}
1157
1158static int ms_read_eraseblock(struct us_data *us, u32 PhyBlockAddr)
1159{
1160	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1161	int result;
1162	u32 bn = PhyBlockAddr;
1163
1164	/* printk(KERN_INFO "MS --- ms_read_eraseblock,
1165			PhyBlockAddr = %x\n", PhyBlockAddr); */
1166	result = ene_load_bincode(us, MS_RW_PATTERN);
1167	if (result != USB_STOR_XFER_GOOD)
1168		return USB_STOR_TRANSPORT_ERROR;
1169
1170	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1171	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1172	bcb->DataTransferLength = 0x200;
1173	bcb->Flags = US_BULK_FLAG_IN;
1174	bcb->CDB[0] = 0xF2;
1175	bcb->CDB[1] = 0x06;
1176	bcb->CDB[4] = (unsigned char)(bn);
1177	bcb->CDB[3] = (unsigned char)(bn>>8);
1178	bcb->CDB[2] = (unsigned char)(bn>>16);
1179
1180	result = ene_send_scsi_cmd(us, FDIR_READ, NULL, 0);
1181	if (result != USB_STOR_XFER_GOOD)
1182		return USB_STOR_TRANSPORT_ERROR;
1183
1184	return USB_STOR_TRANSPORT_GOOD;
1185}
1186
1187static int ms_lib_check_disableblock(struct us_data *us, u16 PhyBlock)
1188{
1189	unsigned char *PageBuf = NULL;
1190	u16 result = MS_STATUS_SUCCESS;
1191	u16 blk, index = 0;
1192	struct ms_lib_type_extdat extdat;
1193	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1194
1195	PageBuf = kmalloc(MS_BYTES_PER_PAGE, GFP_KERNEL);
1196	if (PageBuf == NULL) {
1197		result = MS_NO_MEMORY_ERROR;
1198		goto exit;
1199	}
1200
1201	ms_read_readpage(us, PhyBlock, 1, (u32 *)PageBuf, &extdat);
1202	do {
1203		blk = be16_to_cpu(PageBuf[index]);
1204		if (blk == MS_LB_NOT_USED)
1205			break;
1206		if (blk == info->MS_Lib.Log2PhyMap[0]) {
1207			result = MS_ERROR_FLASH_READ;
1208			break;
1209		}
1210		index++;
1211	} while (1);
1212
1213exit:
1214	kfree(PageBuf);
1215	return result;
1216}
1217
1218static int ms_lib_setacquired_errorblock(struct us_data *us, u16 phyblk)
1219{
1220	u16 log;
1221	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1222
1223	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
1224		return (u32)-1;
1225
1226	log = info->MS_Lib.Phy2LogMap[phyblk];
1227
1228	if (log < info->MS_Lib.NumberOfLogBlock)
1229		info->MS_Lib.Log2PhyMap[log] = MS_LB_NOT_USED;
1230
1231	if (info->MS_Lib.Phy2LogMap[phyblk] != MS_LB_INITIAL_ERROR)
1232		info->MS_Lib.Phy2LogMap[phyblk] = MS_LB_ACQUIRED_ERROR;
1233
1234	return 0;
1235}
1236
1237static int ms_lib_overwrite_extra(struct us_data *us, u32 PhyBlockAddr,
1238				u8 PageNum, u8 OverwriteFlag)
1239{
1240	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1241	int result;
1242
1243	/* printk("MS --- MS_LibOverwriteExtra,
1244		PhyBlockAddr = %x, PageNum = %x\n", PhyBlockAddr, PageNum); */
1245	result = ene_load_bincode(us, MS_RW_PATTERN);
1246	if (result != USB_STOR_XFER_GOOD)
1247		return USB_STOR_TRANSPORT_ERROR;
1248
1249	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1250	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1251	bcb->DataTransferLength = 0x4;
1252	bcb->Flags = US_BULK_FLAG_IN;
1253	bcb->CDB[0] = 0xF2;
1254	bcb->CDB[1] = 0x05;
1255	bcb->CDB[5] = (unsigned char)(PageNum);
1256	bcb->CDB[4] = (unsigned char)(PhyBlockAddr);
1257	bcb->CDB[3] = (unsigned char)(PhyBlockAddr>>8);
1258	bcb->CDB[2] = (unsigned char)(PhyBlockAddr>>16);
1259	bcb->CDB[6] = OverwriteFlag;
1260	bcb->CDB[7] = 0xFF;
1261	bcb->CDB[8] = 0xFF;
1262	bcb->CDB[9] = 0xFF;
1263
1264	result = ene_send_scsi_cmd(us, FDIR_READ, NULL, 0);
1265	if (result != USB_STOR_XFER_GOOD)
1266		return USB_STOR_TRANSPORT_ERROR;
1267
1268	return USB_STOR_TRANSPORT_GOOD;
1269}
1270
1271static int ms_lib_error_phyblock(struct us_data *us, u16 phyblk)
1272{
1273	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1274
1275	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
1276		return MS_STATUS_ERROR;
1277
1278	ms_lib_setacquired_errorblock(us, phyblk);
1279
1280	if (ms_lib_iswritable(info))
1281		return ms_lib_overwrite_extra(us, phyblk, 0, (u8)(~MS_REG_OVR_BKST & BYTE_MASK));
1282
1283	return MS_STATUS_SUCCESS;
1284}
1285
1286static int ms_lib_erase_phyblock(struct us_data *us, u16 phyblk)
1287{
1288	u16 log;
1289	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1290
1291	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
1292		return MS_STATUS_ERROR;
1293
1294	log = info->MS_Lib.Phy2LogMap[phyblk];
1295
1296	if (log < info->MS_Lib.NumberOfLogBlock)
1297		info->MS_Lib.Log2PhyMap[log] = MS_LB_NOT_USED;
1298
1299	info->MS_Lib.Phy2LogMap[phyblk] = MS_LB_NOT_USED;
1300
1301	if (ms_lib_iswritable(info)) {
1302		switch (ms_read_eraseblock(us, phyblk)) {
1303		case MS_STATUS_SUCCESS:
1304			info->MS_Lib.Phy2LogMap[phyblk] = MS_LB_NOT_USED_ERASED;
1305			return MS_STATUS_SUCCESS;
1306		case MS_ERROR_FLASH_ERASE:
1307		case MS_STATUS_INT_ERROR:
1308			ms_lib_error_phyblock(us, phyblk);
1309			return MS_ERROR_FLASH_ERASE;
1310		case MS_STATUS_ERROR:
1311		default:
1312			ms_lib_ctrl_set(info, MS_LIB_CTRL_RDONLY); /* MS_LibCtrlSet will used by ENE_MSInit ,need check, and why us to info*/
1313			ms_lib_setacquired_errorblock(us, phyblk);
1314			return MS_STATUS_ERROR;
1315		}
1316	}
1317
1318	ms_lib_setacquired_errorblock(us, phyblk);
1319
1320	return MS_STATUS_SUCCESS;
1321}
1322
1323static int ms_lib_read_extra(struct us_data *us, u32 PhyBlock,
1324				u8 PageNum, struct ms_lib_type_extdat *ExtraDat)
1325{
1326	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
 
 
1327	int result;
1328	u8 ExtBuf[4];
1329
1330	/* printk("MS_LibReadExtra --- PhyBlock = %x, PageNum = %x\n", PhyBlock, PageNum); */
1331	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1332	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1333	bcb->DataTransferLength = 0x4;
1334	bcb->Flags      = US_BULK_FLAG_IN;
1335	bcb->CDB[0]     = 0xF1;
1336	bcb->CDB[1]     = 0x03;
1337	bcb->CDB[5]     = (unsigned char)(PageNum);
1338	bcb->CDB[4]     = (unsigned char)(PhyBlock);
1339	bcb->CDB[3]     = (unsigned char)(PhyBlock>>8);
1340	bcb->CDB[2]     = (unsigned char)(PhyBlock>>16);
1341	bcb->CDB[6]     = 0x01;
1342
1343	result = ene_send_scsi_cmd(us, FDIR_READ, &ExtBuf, 0);
1344	if (result != USB_STOR_XFER_GOOD)
1345		return USB_STOR_TRANSPORT_ERROR;
1346
1347	ExtraDat->reserved = 0;
1348	ExtraDat->intr     = 0x80;  /* Not yet, waiting for fireware support */
1349	ExtraDat->status0  = 0x10;  /* Not yet, waiting for fireware support */
1350	ExtraDat->status1  = 0x00;  /* Not yet, waiting for fireware support */
1351	ExtraDat->ovrflg   = ExtBuf[0];
1352	ExtraDat->mngflg   = ExtBuf[1];
1353	ExtraDat->logadr   = memstick_logaddr(ExtBuf[2], ExtBuf[3]);
1354
1355	return USB_STOR_TRANSPORT_GOOD;
1356}
1357
1358static int ms_libsearch_block_from_physical(struct us_data *us, u16 phyblk)
1359{
1360	u16 Newblk;
1361	u16 blk;
1362	struct ms_lib_type_extdat extdat; /* need check */
1363	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1364
1365
1366	if (phyblk >= info->MS_Lib.NumberOfPhyBlock)
1367		return MS_LB_ERROR;
1368
1369	for (blk = phyblk + 1; blk != phyblk; blk++) {
1370		if ((blk & MS_PHYSICAL_BLOCKS_PER_SEGMENT_MASK) == 0)
1371			blk -= MS_PHYSICAL_BLOCKS_PER_SEGMENT;
1372
1373		Newblk = info->MS_Lib.Phy2LogMap[blk];
1374		if (info->MS_Lib.Phy2LogMap[blk] == MS_LB_NOT_USED_ERASED) {
1375			return blk;
1376		} else if (info->MS_Lib.Phy2LogMap[blk] == MS_LB_NOT_USED) {
1377			switch (ms_lib_read_extra(us, blk, 0, &extdat)) {
1378			case MS_STATUS_SUCCESS:
1379			case MS_STATUS_SUCCESS_WITH_ECC:
1380				break;
1381			case MS_NOCARD_ERROR:
1382				return MS_NOCARD_ERROR;
1383			case MS_STATUS_INT_ERROR:
1384				return MS_LB_ERROR;
1385			case MS_ERROR_FLASH_READ:
1386			default:
1387				ms_lib_setacquired_errorblock(us, blk);
1388				continue;
1389			} /* End switch */
1390
1391			if ((extdat.ovrflg & MS_REG_OVR_BKST) != MS_REG_OVR_BKST_OK) {
1392				ms_lib_setacquired_errorblock(us, blk);
1393				continue;
1394			}
1395
1396			switch (ms_lib_erase_phyblock(us, blk)) {
1397			case MS_STATUS_SUCCESS:
1398				return blk;
1399			case MS_STATUS_ERROR:
1400				return MS_LB_ERROR;
1401			case MS_ERROR_FLASH_ERASE:
1402			default:
1403				ms_lib_error_phyblock(us, blk);
1404				break;
1405			}
1406		}
1407	} /* End for */
1408
1409	return MS_LB_ERROR;
1410}
1411static int ms_libsearch_block_from_logical(struct us_data *us, u16 logblk)
1412{
1413	u16 phyblk;
1414	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1415
1416	phyblk = ms_libconv_to_physical(info, logblk);
1417	if (phyblk >= MS_LB_ERROR) {
1418		if (logblk >= info->MS_Lib.NumberOfLogBlock)
1419			return MS_LB_ERROR;
1420
1421		phyblk = (logblk + MS_NUMBER_OF_BOOT_BLOCK) / MS_LOGICAL_BLOCKS_PER_SEGMENT;
1422		phyblk *= MS_PHYSICAL_BLOCKS_PER_SEGMENT;
1423		phyblk += MS_PHYSICAL_BLOCKS_PER_SEGMENT - 1;
1424	}
1425
1426	return ms_libsearch_block_from_physical(us, phyblk);
1427}
1428
1429static int ms_scsi_test_unit_ready(struct us_data *us, struct scsi_cmnd *srb)
1430{
1431	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
1432
1433	/* pr_info("MS_SCSI_Test_Unit_Ready\n"); */
1434	if (info->MS_Status.Insert && info->MS_Status.Ready) {
1435		return USB_STOR_TRANSPORT_GOOD;
1436	} else {
1437		ene_ms_init(us);
1438		return USB_STOR_TRANSPORT_GOOD;
1439	}
1440
1441	return USB_STOR_TRANSPORT_GOOD;
1442}
1443
1444static int ms_scsi_inquiry(struct us_data *us, struct scsi_cmnd *srb)
1445{
1446	/* pr_info("MS_SCSI_Inquiry\n"); */
1447	unsigned char data_ptr[36] = {
1448		0x00, 0x80, 0x02, 0x00, 0x1F, 0x00, 0x00, 0x00, 0x55,
1449		0x53, 0x42, 0x32, 0x2E, 0x30, 0x20, 0x20, 0x43, 0x61,
1450		0x72, 0x64, 0x52, 0x65, 0x61, 0x64, 0x65, 0x72, 0x20,
1451		0x20, 0x20, 0x20, 0x20, 0x20, 0x30, 0x31, 0x30, 0x30};
1452
1453	usb_stor_set_xfer_buf(data_ptr, 36, srb);
1454	return USB_STOR_TRANSPORT_GOOD;
1455}
1456
1457static int ms_scsi_mode_sense(struct us_data *us, struct scsi_cmnd *srb)
1458{
1459	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1460	unsigned char mediaNoWP[12] = {
1461		0x0b, 0x00, 0x00, 0x08, 0x00, 0x00,
1462		0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
1463	unsigned char mediaWP[12]   = {
1464		0x0b, 0x00, 0x80, 0x08, 0x00, 0x00,
1465		0x71, 0xc0, 0x00, 0x00, 0x02, 0x00 };
1466
1467	if (info->MS_Status.WtP)
1468		usb_stor_set_xfer_buf(mediaWP, 12, srb);
1469	else
1470		usb_stor_set_xfer_buf(mediaNoWP, 12, srb);
1471
1472	return USB_STOR_TRANSPORT_GOOD;
1473}
1474
1475static int ms_scsi_read_capacity(struct us_data *us, struct scsi_cmnd *srb)
1476{
1477	u32   bl_num;
1478	u16    bl_len;
1479	unsigned int offset = 0;
1480	unsigned char    buf[8];
1481	struct scatterlist *sg = NULL;
1482	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1483
1484	US_DEBUGP("ms_scsi_read_capacity\n");
1485	bl_len = 0x200;
1486	if (info->MS_Status.IsMSPro)
1487		bl_num = info->MSP_TotalBlock - 1;
1488	else
1489		bl_num = info->MS_Lib.NumberOfLogBlock * info->MS_Lib.blockSize * 2 - 1;
1490
1491	info->bl_num = bl_num;
1492	US_DEBUGP("bl_len = %x\n", bl_len);
1493	US_DEBUGP("bl_num = %x\n", bl_num);
1494
1495	/*srb->request_bufflen = 8; */
1496	buf[0] = (bl_num >> 24) & 0xff;
1497	buf[1] = (bl_num >> 16) & 0xff;
1498	buf[2] = (bl_num >> 8) & 0xff;
1499	buf[3] = (bl_num >> 0) & 0xff;
1500	buf[4] = (bl_len >> 24) & 0xff;
1501	buf[5] = (bl_len >> 16) & 0xff;
1502	buf[6] = (bl_len >> 8) & 0xff;
1503	buf[7] = (bl_len >> 0) & 0xff;
1504
1505	usb_stor_access_xfer_buf(buf, 8, srb, &sg, &offset, TO_XFER_BUF);
1506
1507	return USB_STOR_TRANSPORT_GOOD;
1508}
1509
1510static void ms_lib_phy_to_log_range(u16 PhyBlock, u16 *LogStart, u16 *LogEnde)
1511{
1512	PhyBlock /= MS_PHYSICAL_BLOCKS_PER_SEGMENT;
1513
1514	if (PhyBlock) {
1515		*LogStart = MS_LOGICAL_BLOCKS_IN_1ST_SEGMENT + (PhyBlock - 1) * MS_LOGICAL_BLOCKS_PER_SEGMENT;/*496*/
1516		*LogEnde = *LogStart + MS_LOGICAL_BLOCKS_PER_SEGMENT;/*496*/
1517	} else {
1518		*LogStart = 0;
1519		*LogEnde = MS_LOGICAL_BLOCKS_IN_1ST_SEGMENT;/*494*/
1520	}
1521}
1522
1523static int ms_lib_read_extrablock(struct us_data *us, u32 PhyBlock,
1524	u8 PageNum, u8 blen, void *buf)
1525{
1526	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1527	int     result;
1528
1529	/* printk("MS_LibReadExtraBlock --- PhyBlock = %x,
1530		PageNum = %x, blen = %x\n", PhyBlock, PageNum, blen); */
1531
1532	/* Read Extra Data */
1533	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1534	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1535	bcb->DataTransferLength = 0x4 * blen;
1536	bcb->Flags      = US_BULK_FLAG_IN;
1537	bcb->CDB[0]     = 0xF1;
1538	bcb->CDB[1]     = 0x03;
1539	bcb->CDB[5]     = (unsigned char)(PageNum);
1540	bcb->CDB[4]     = (unsigned char)(PhyBlock);
1541	bcb->CDB[3]     = (unsigned char)(PhyBlock>>8);
1542	bcb->CDB[2]     = (unsigned char)(PhyBlock>>16);
1543	bcb->CDB[6]     = blen;
1544
1545	result = ene_send_scsi_cmd(us, FDIR_READ, buf, 0);
1546	if (result != USB_STOR_XFER_GOOD)
1547		return USB_STOR_TRANSPORT_ERROR;
1548
1549	return USB_STOR_TRANSPORT_GOOD;
1550}
1551
1552static int ms_lib_scan_logicalblocknumber(struct us_data *us, u16 btBlk1st)
1553{
1554	u16 PhyBlock, newblk, i;
1555	u16 LogStart, LogEnde;
1556	struct ms_lib_type_extdat extdat;
1557	u8 buf[0x200];
1558	u32 count = 0, index = 0;
1559	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 
1560
1561	for (PhyBlock = 0; PhyBlock < info->MS_Lib.NumberOfPhyBlock;) {
1562		ms_lib_phy_to_log_range(PhyBlock, &LogStart, &LogEnde);
1563
1564		for (i = 0; i < MS_PHYSICAL_BLOCKS_PER_SEGMENT; i++, PhyBlock++) {
1565			switch (ms_libconv_to_logical(info, PhyBlock)) {
1566			case MS_STATUS_ERROR:
1567				continue;
1568			default:
1569				break;
1570			}
1571
1572			if (count == PhyBlock) {
1573				ms_lib_read_extrablock(us, PhyBlock, 0, 0x80, &buf);
 
1574				count += 0x80;
1575			}
1576			index = (PhyBlock % 0x80) * 4;
1577
1578			extdat.ovrflg = buf[index];
1579			extdat.mngflg = buf[index+1];
1580			extdat.logadr = memstick_logaddr(buf[index+2], buf[index+3]);
 
1581
1582			if ((extdat.ovrflg & MS_REG_OVR_BKST) != MS_REG_OVR_BKST_OK) {
1583				ms_lib_setacquired_errorblock(us, PhyBlock);
1584				continue;
1585			}
1586
1587			if ((extdat.mngflg & MS_REG_MNG_ATFLG) == MS_REG_MNG_ATFLG_ATTBL) {
1588				ms_lib_erase_phyblock(us, PhyBlock);
1589				continue;
1590			}
1591
1592			if (extdat.logadr != MS_LB_NOT_USED) {
1593				if ((extdat.logadr < LogStart) || (LogEnde <= extdat.logadr)) {
1594					ms_lib_erase_phyblock(us, PhyBlock);
1595					continue;
1596				}
1597
1598				newblk = ms_libconv_to_physical(info, extdat.logadr);
1599
1600				if (newblk != MS_LB_NOT_USED) {
1601					if (extdat.logadr == 0) {
1602						ms_lib_set_logicalpair(us, extdat.logadr, PhyBlock);
1603						if (ms_lib_check_disableblock(us, btBlk1st)) {
1604							ms_lib_set_logicalpair(us, extdat.logadr, newblk);
1605							continue;
1606						}
1607					}
1608
1609					ms_lib_read_extra(us, newblk, 0, &extdat);
1610					if ((extdat.ovrflg & MS_REG_OVR_UDST) == MS_REG_OVR_UDST_UPDATING) {
1611						ms_lib_erase_phyblock(us, PhyBlock);
1612						continue;
1613					} else {
1614						ms_lib_erase_phyblock(us, newblk);
1615					}
1616				}
1617
1618				ms_lib_set_logicalpair(us, extdat.logadr, PhyBlock);
1619			}
1620		}
1621	} /* End for ... */
1622
1623	return MS_STATUS_SUCCESS;
1624}
1625
1626
1627static int ms_scsi_read(struct us_data *us, struct scsi_cmnd *srb)
1628{
1629	int result;
1630	unsigned char *cdb = srb->cmnd;
1631	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1632	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1633
1634	u32 bn = ((cdb[2] << 24) & 0xff000000) | ((cdb[3] << 16) & 0x00ff0000) |
1635		((cdb[4] << 8) & 0x0000ff00) | ((cdb[5] << 0) & 0x000000ff);
1636	u16 blen = ((cdb[7] << 8) & 0xff00) | ((cdb[8] << 0) & 0x00ff);
1637	u32 blenByte = blen * 0x200;
1638
1639	if (bn > info->bl_num)
1640		return USB_STOR_TRANSPORT_ERROR;
1641
1642	if (info->MS_Status.IsMSPro) {
1643		result = ene_load_bincode(us, MSP_RW_PATTERN);
1644		if (result != USB_STOR_XFER_GOOD) {
1645			US_DEBUGP("Load MPS RW pattern Fail !!\n");
1646			return USB_STOR_TRANSPORT_ERROR;
1647		}
1648
1649		/* set up the command wrapper */
1650		memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1651		bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1652		bcb->DataTransferLength = blenByte;
1653		bcb->Flags  = US_BULK_FLAG_IN;
1654		bcb->CDB[0] = 0xF1;
1655		bcb->CDB[1] = 0x02;
1656		bcb->CDB[5] = (unsigned char)(bn);
1657		bcb->CDB[4] = (unsigned char)(bn>>8);
1658		bcb->CDB[3] = (unsigned char)(bn>>16);
1659		bcb->CDB[2] = (unsigned char)(bn>>24);
1660
1661		result = ene_send_scsi_cmd(us, FDIR_READ, scsi_sglist(srb), 1);
1662	} else {
1663		void *buf;
1664		int offset = 0;
1665		u16 phyblk, logblk;
1666		u8 PageNum;
1667		u16 len;
1668		u32 blkno;
1669
1670		buf = kmalloc(blenByte, GFP_KERNEL);
1671		if (buf == NULL)
1672			return USB_STOR_TRANSPORT_ERROR;
1673
1674		result = ene_load_bincode(us, MS_RW_PATTERN);
1675		if (result != USB_STOR_XFER_GOOD) {
1676			pr_info("Load MS RW pattern Fail !!\n");
1677			result = USB_STOR_TRANSPORT_ERROR;
1678			goto exit;
1679		}
1680
1681		logblk  = (u16)(bn / info->MS_Lib.PagesPerBlock);
1682		PageNum = (u8)(bn % info->MS_Lib.PagesPerBlock);
1683
1684		while (1) {
1685			if (blen > (info->MS_Lib.PagesPerBlock-PageNum))
1686				len = info->MS_Lib.PagesPerBlock-PageNum;
1687			else
1688				len = blen;
1689
1690			phyblk = ms_libconv_to_physical(info, logblk);
1691			blkno  = phyblk * 0x20 + PageNum;
1692
1693			/* set up the command wrapper */
1694			memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1695			bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1696			bcb->DataTransferLength = 0x200 * len;
1697			bcb->Flags  = US_BULK_FLAG_IN;
1698			bcb->CDB[0] = 0xF1;
1699			bcb->CDB[1] = 0x02;
1700			bcb->CDB[5] = (unsigned char)(blkno);
1701			bcb->CDB[4] = (unsigned char)(blkno>>8);
1702			bcb->CDB[3] = (unsigned char)(blkno>>16);
1703			bcb->CDB[2] = (unsigned char)(blkno>>24);
1704
1705			result = ene_send_scsi_cmd(us, FDIR_READ, buf+offset, 0);
1706			if (result != USB_STOR_XFER_GOOD) {
1707				pr_info("MS_SCSI_Read --- result = %x\n", result);
1708				result = USB_STOR_TRANSPORT_ERROR;
1709				goto exit;
1710			}
1711
1712			blen -= len;
1713			if (blen <= 0)
1714				break;
1715			logblk++;
1716			PageNum = 0;
1717			offset += MS_BYTES_PER_PAGE*len;
1718		}
1719		usb_stor_set_xfer_buf(buf, blenByte, srb);
1720exit:
1721		kfree(buf);
1722	}
1723	return result;
1724}
1725
1726static int ms_scsi_write(struct us_data *us, struct scsi_cmnd *srb)
1727{
1728	int result;
1729	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1730	unsigned char *cdb = srb->cmnd;
1731	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1732
1733	u32 bn = ((cdb[2] << 24) & 0xff000000) |
1734			((cdb[3] << 16) & 0x00ff0000) |
1735			((cdb[4] << 8) & 0x0000ff00) |
1736			((cdb[5] << 0) & 0x000000ff);
1737	u16 blen = ((cdb[7] << 8) & 0xff00) | ((cdb[8] << 0) & 0x00ff);
1738	u32 blenByte = blen * 0x200;
1739
1740	if (bn > info->bl_num)
1741		return USB_STOR_TRANSPORT_ERROR;
1742
1743	if (info->MS_Status.IsMSPro) {
1744		result = ene_load_bincode(us, MSP_RW_PATTERN);
1745		if (result != USB_STOR_XFER_GOOD) {
1746			pr_info("Load MSP RW pattern Fail !!\n");
1747			return USB_STOR_TRANSPORT_ERROR;
1748		}
1749
1750		/* set up the command wrapper */
1751		memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1752		bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1753		bcb->DataTransferLength = blenByte;
1754		bcb->Flags  = 0x00;
1755		bcb->CDB[0] = 0xF0;
1756		bcb->CDB[1] = 0x04;
1757		bcb->CDB[5] = (unsigned char)(bn);
1758		bcb->CDB[4] = (unsigned char)(bn>>8);
1759		bcb->CDB[3] = (unsigned char)(bn>>16);
1760		bcb->CDB[2] = (unsigned char)(bn>>24);
1761
1762		result = ene_send_scsi_cmd(us, FDIR_WRITE, scsi_sglist(srb), 1);
1763	} else {
1764		void *buf;
1765		int offset = 0;
1766		u16 PhyBlockAddr;
1767		u8 PageNum;
1768		u16 len, oldphy, newphy;
1769
1770		buf = kmalloc(blenByte, GFP_KERNEL);
1771		if (buf == NULL)
1772			return USB_STOR_TRANSPORT_ERROR;
1773		usb_stor_set_xfer_buf(buf, blenByte, srb);
1774
1775		result = ene_load_bincode(us, MS_RW_PATTERN);
1776		if (result != USB_STOR_XFER_GOOD) {
1777			pr_info("Load MS RW pattern Fail !!\n");
1778			result = USB_STOR_TRANSPORT_ERROR;
1779			goto exit;
1780		}
1781
1782		PhyBlockAddr = (u16)(bn / info->MS_Lib.PagesPerBlock);
1783		PageNum      = (u8)(bn % info->MS_Lib.PagesPerBlock);
1784
1785		while (1) {
1786			if (blen > (info->MS_Lib.PagesPerBlock-PageNum))
1787				len = info->MS_Lib.PagesPerBlock-PageNum;
1788			else
1789				len = blen;
1790
1791			oldphy = ms_libconv_to_physical(info, PhyBlockAddr); /* need check us <-> info */
1792			newphy = ms_libsearch_block_from_logical(us, PhyBlockAddr);
1793
1794			result = ms_read_copyblock(us, oldphy, newphy, PhyBlockAddr, PageNum, buf+offset, len);
1795
1796			if (result != USB_STOR_XFER_GOOD) {
1797				pr_info("MS_SCSI_Write --- result = %x\n", result);
1798				result =  USB_STOR_TRANSPORT_ERROR;
1799				goto exit;
1800			}
1801
1802			info->MS_Lib.Phy2LogMap[oldphy] = MS_LB_NOT_USED_ERASED;
1803			ms_lib_force_setlogical_pair(us, PhyBlockAddr, newphy);
1804
1805			blen -= len;
1806			if (blen <= 0)
1807				break;
1808			PhyBlockAddr++;
1809			PageNum = 0;
1810			offset += MS_BYTES_PER_PAGE*len;
1811		}
1812exit:
1813		kfree(buf);
1814	}
1815	return result;
1816}
1817
1818/*
1819 * ENE MS Card
1820 */
1821
1822static int ene_get_card_type(struct us_data *us, u16 index, void *buf)
1823{
1824	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1825	int result;
1826
1827	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1828	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1829	bcb->DataTransferLength	= 0x01;
1830	bcb->Flags			= US_BULK_FLAG_IN;
1831	bcb->CDB[0]			= 0xED;
1832	bcb->CDB[2]			= (unsigned char)(index>>8);
1833	bcb->CDB[3]			= (unsigned char)index;
1834
1835	result = ene_send_scsi_cmd(us, FDIR_READ, buf, 0);
1836	return result;
1837}
1838
1839static int ene_get_card_status(struct us_data *us, u8 *buf)
1840{
1841	u16 tmpreg;
1842	u32 reg4b;
1843	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1844
1845	/*US_DEBUGP("transport --- ENE_ReadSDReg\n");*/
1846	reg4b = *(u32 *)&buf[0x18];
1847	info->SD_READ_BL_LEN = (u8)((reg4b >> 8) & 0x0f);
1848
1849	tmpreg = (u16) reg4b;
1850	reg4b = *(u32 *)(&buf[0x14]);
1851	if (info->SD_Status.HiCapacity && !info->SD_Status.IsMMC)
1852		info->HC_C_SIZE = (reg4b >> 8) & 0x3fffff;
1853
1854	info->SD_C_SIZE = ((tmpreg & 0x03) << 10) | (u16)(reg4b >> 22);
1855	info->SD_C_SIZE_MULT = (u8)(reg4b >> 7)  & 0x07;
1856	if (info->SD_Status.HiCapacity && info->SD_Status.IsMMC)
1857		info->HC_C_SIZE = *(u32 *)(&buf[0x100]);
1858
1859	if (info->SD_READ_BL_LEN > SD_BLOCK_LEN) {
1860		info->SD_Block_Mult = 1 << (info->SD_READ_BL_LEN-SD_BLOCK_LEN);
1861		info->SD_READ_BL_LEN = SD_BLOCK_LEN;
1862	} else {
1863		info->SD_Block_Mult = 1;
1864	}
1865
1866	return USB_STOR_TRANSPORT_GOOD;
1867}
1868
1869static int ene_load_bincode(struct us_data *us, unsigned char flag)
1870{
1871	int err;
1872	char *fw_name = NULL;
1873	unsigned char *buf = NULL;
1874	const struct firmware *sd_fw = NULL;
1875	int result = USB_STOR_TRANSPORT_ERROR;
1876	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
1877	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1878
1879	if (info->BIN_FLAG == flag)
1880		return USB_STOR_TRANSPORT_GOOD;
1881
1882	switch (flag) {
1883	/* For SD */
1884	case SD_INIT1_PATTERN:
1885		US_DEBUGP("SD_INIT1_PATTERN\n");
1886		fw_name = "ene-ub6250/sd_init1.bin";
1887		break;
1888	case SD_INIT2_PATTERN:
1889		US_DEBUGP("SD_INIT2_PATTERN\n");
1890		fw_name = "ene-ub6250/sd_init2.bin";
1891		break;
1892	case SD_RW_PATTERN:
1893		US_DEBUGP("SD_RDWR_PATTERN\n");
1894		fw_name = "ene-ub6250/sd_rdwr.bin";
1895		break;
1896	/* For MS */
1897	case MS_INIT_PATTERN:
1898		US_DEBUGP("MS_INIT_PATTERN\n");
1899		fw_name = "ene-ub6250/ms_init.bin";
1900		break;
1901	case MSP_RW_PATTERN:
1902		US_DEBUGP("MSP_RW_PATTERN\n");
1903		fw_name = "ene-ub6250/msp_rdwr.bin";
1904		break;
1905	case MS_RW_PATTERN:
1906		US_DEBUGP("MS_RW_PATTERN\n");
1907		fw_name = "ene-ub6250/ms_rdwr.bin";
1908		break;
1909	default:
1910		US_DEBUGP("----------- Unknown PATTERN ----------\n");
1911		goto nofw;
1912	}
1913
1914	err = request_firmware(&sd_fw, fw_name, &us->pusb_dev->dev);
1915	if (err) {
1916		US_DEBUGP("load firmware %s failed\n", fw_name);
1917		goto nofw;
1918	}
1919	buf = kmalloc(sd_fw->size, GFP_KERNEL);
1920	if (buf == NULL) {
1921		US_DEBUGP("Malloc memory for fireware failed!\n");
1922		goto nofw;
1923	}
1924	memcpy(buf, sd_fw->data, sd_fw->size);
1925	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
1926	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
1927	bcb->DataTransferLength = sd_fw->size;
1928	bcb->Flags = 0x00;
1929	bcb->CDB[0] = 0xEF;
1930
1931	result = ene_send_scsi_cmd(us, FDIR_WRITE, buf, 0);
 
 
1932	info->BIN_FLAG = flag;
1933	kfree(buf);
1934
1935nofw:
1936	release_firmware(sd_fw);
1937	return result;
1938}
1939
1940static int ms_card_init(struct us_data *us)
1941{
1942	u32 result;
1943	u16 TmpBlock;
1944	unsigned char *PageBuffer0 = NULL, *PageBuffer1 = NULL;
1945	struct ms_lib_type_extdat extdat;
1946	u16 btBlk1st, btBlk2nd;
1947	u32 btBlk1stErred;
1948	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
1949
1950	printk(KERN_INFO "MS_CardInit start\n");
1951
1952	ms_lib_free_allocatedarea(us); /* Clean buffer and set struct us_data flag to 0 */
1953
1954	/* get two PageBuffer */
1955	PageBuffer0 = kmalloc(MS_BYTES_PER_PAGE, GFP_KERNEL);
1956	PageBuffer1 = kmalloc(MS_BYTES_PER_PAGE, GFP_KERNEL);
1957	if ((PageBuffer0 == NULL) || (PageBuffer1 == NULL)) {
1958		result = MS_NO_MEMORY_ERROR;
1959		goto exit;
1960	}
1961
1962	btBlk1st = btBlk2nd = MS_LB_NOT_USED;
1963	btBlk1stErred = 0;
1964
1965	for (TmpBlock = 0; TmpBlock < MS_MAX_INITIAL_ERROR_BLOCKS+2; TmpBlock++) {
1966
1967		switch (ms_read_readpage(us, TmpBlock, 0, (u32 *)PageBuffer0, &extdat)) {
1968		case MS_STATUS_SUCCESS:
1969			break;
1970		case MS_STATUS_INT_ERROR:
1971			break;
1972		case MS_STATUS_ERROR:
1973		default:
1974			continue;
1975		}
1976
1977		if ((extdat.ovrflg & MS_REG_OVR_BKST) == MS_REG_OVR_BKST_NG)
1978			continue;
1979
1980		if (((extdat.mngflg & MS_REG_MNG_SYSFLG) == MS_REG_MNG_SYSFLG_USER) ||
1981			(be16_to_cpu(((struct ms_bootblock_page0 *)PageBuffer0)->header.wBlockID) != MS_BOOT_BLOCK_ID) ||
1982			(be16_to_cpu(((struct ms_bootblock_page0 *)PageBuffer0)->header.wFormatVersion) != MS_BOOT_BLOCK_FORMAT_VERSION) ||
1983			(((struct ms_bootblock_page0 *)PageBuffer0)->header.bNumberOfDataEntry != MS_BOOT_BLOCK_DATA_ENTRIES))
1984				continue;
1985
1986		if (btBlk1st != MS_LB_NOT_USED) {
1987			btBlk2nd = TmpBlock;
1988			break;
1989		}
1990
1991		btBlk1st = TmpBlock;
1992		memcpy(PageBuffer1, PageBuffer0, MS_BYTES_PER_PAGE);
1993		if (extdat.status1 & (MS_REG_ST1_DTER | MS_REG_ST1_EXER | MS_REG_ST1_FGER))
1994			btBlk1stErred = 1;
1995	}
1996
1997	if (btBlk1st == MS_LB_NOT_USED) {
1998		result = MS_STATUS_ERROR;
1999		goto exit;
2000	}
2001
2002	/* write protect */
2003	if ((extdat.status0 & MS_REG_ST0_WP) == MS_REG_ST0_WP_ON)
2004		ms_lib_ctrl_set(info, MS_LIB_CTRL_WRPROTECT);
2005
2006	result = MS_STATUS_ERROR;
2007	/* 1st Boot Block */
2008	if (btBlk1stErred == 0)
2009		result = ms_lib_process_bootblock(us, btBlk1st, PageBuffer1);
2010		/* 1st */
2011	/* 2nd Boot Block */
2012	if (result && (btBlk2nd != MS_LB_NOT_USED))
2013		result = ms_lib_process_bootblock(us, btBlk2nd, PageBuffer0);
2014
2015	if (result) {
2016		result = MS_STATUS_ERROR;
2017		goto exit;
2018	}
2019
2020	for (TmpBlock = 0; TmpBlock < btBlk1st; TmpBlock++)
2021		info->MS_Lib.Phy2LogMap[TmpBlock] = MS_LB_INITIAL_ERROR;
2022
2023	info->MS_Lib.Phy2LogMap[btBlk1st] = MS_LB_BOOT_BLOCK;
2024
2025	if (btBlk2nd != MS_LB_NOT_USED) {
2026		for (TmpBlock = btBlk1st + 1; TmpBlock < btBlk2nd; TmpBlock++)
2027			info->MS_Lib.Phy2LogMap[TmpBlock] = MS_LB_INITIAL_ERROR;
2028
2029		info->MS_Lib.Phy2LogMap[btBlk2nd] = MS_LB_BOOT_BLOCK;
2030	}
2031
2032	result = ms_lib_scan_logicalblocknumber(us, btBlk1st);
2033	if (result)
2034		goto exit;
2035
2036	for (TmpBlock = MS_PHYSICAL_BLOCKS_PER_SEGMENT;
2037		TmpBlock < info->MS_Lib.NumberOfPhyBlock;
2038		TmpBlock += MS_PHYSICAL_BLOCKS_PER_SEGMENT) {
2039		if (ms_count_freeblock(us, TmpBlock) == 0) {
2040			ms_lib_ctrl_set(info, MS_LIB_CTRL_WRPROTECT);
2041			break;
2042		}
2043	}
2044
2045	/* write */
2046	if (ms_lib_alloc_writebuf(us)) {
2047		result = MS_NO_MEMORY_ERROR;
2048		goto exit;
2049	}
2050
2051	result = MS_STATUS_SUCCESS;
2052
2053exit:
2054	kfree(PageBuffer1);
2055	kfree(PageBuffer0);
2056
2057	printk(KERN_INFO "MS_CardInit end\n");
2058	return result;
2059}
2060
2061static int ene_ms_init(struct us_data *us)
2062{
2063	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
2064	int result;
2065	u8 buf[0x200];
2066	u16 MSP_BlockSize, MSP_UserAreaBlocks;
2067	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 
 
2068
2069	printk(KERN_INFO "transport --- ENE_MSInit\n");
2070
2071	/* the same part to test ENE */
2072
2073	result = ene_load_bincode(us, MS_INIT_PATTERN);
2074	if (result != USB_STOR_XFER_GOOD) {
2075		printk(KERN_ERR "Load MS Init Code Fail !!\n");
2076		return USB_STOR_TRANSPORT_ERROR;
2077	}
2078
2079	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
2080	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
2081	bcb->DataTransferLength = 0x200;
2082	bcb->Flags      = US_BULK_FLAG_IN;
2083	bcb->CDB[0]     = 0xF1;
2084	bcb->CDB[1]     = 0x01;
2085
2086	result = ene_send_scsi_cmd(us, FDIR_READ, &buf, 0);
2087	if (result != USB_STOR_XFER_GOOD) {
2088		printk(KERN_ERR "Execution MS Init Code Fail !!\n");
2089		return USB_STOR_TRANSPORT_ERROR;
2090	}
2091	/* the same part to test ENE */
2092	info->MS_Status = *(struct MS_STATUS *)&buf[0];
2093
2094	if (info->MS_Status.Insert && info->MS_Status.Ready) {
2095		printk(KERN_INFO "Insert     = %x\n", info->MS_Status.Insert);
2096		printk(KERN_INFO "Ready      = %x\n", info->MS_Status.Ready);
2097		printk(KERN_INFO "IsMSPro    = %x\n", info->MS_Status.IsMSPro);
2098		printk(KERN_INFO "IsMSPHG    = %x\n", info->MS_Status.IsMSPHG);
2099		printk(KERN_INFO "WtP= %x\n", info->MS_Status.WtP);
2100		if (info->MS_Status.IsMSPro) {
2101			MSP_BlockSize      = (buf[6] << 8) | buf[7];
2102			MSP_UserAreaBlocks = (buf[10] << 8) | buf[11];
 
2103			info->MSP_TotalBlock = MSP_BlockSize * MSP_UserAreaBlocks;
2104		} else {
2105			ms_card_init(us); /* Card is MS (to ms.c)*/
2106		}
2107		US_DEBUGP("MS Init Code OK !!\n");
2108	} else {
2109		US_DEBUGP("MS Card Not Ready --- %x\n", buf[0]);
2110		return USB_STOR_TRANSPORT_ERROR;
2111	}
2112
2113	return USB_STOR_TRANSPORT_GOOD;
2114}
2115
2116static int ene_sd_init(struct us_data *us)
2117{
2118	int result;
2119	u8  buf[0x200];
2120	struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
2121	struct ene_ub6250_info *info = (struct ene_ub6250_info *) us->extra;
 
2122
2123	US_DEBUGP("transport --- ENE_SDInit\n");
2124	/* SD Init Part-1 */
2125	result = ene_load_bincode(us, SD_INIT1_PATTERN);
2126	if (result != USB_STOR_XFER_GOOD) {
2127		US_DEBUGP("Load SD Init Code Part-1 Fail !!\n");
2128		return USB_STOR_TRANSPORT_ERROR;
2129	}
2130
2131	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
2132	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
2133	bcb->Flags = US_BULK_FLAG_IN;
2134	bcb->CDB[0] = 0xF2;
2135
2136	result = ene_send_scsi_cmd(us, FDIR_READ, NULL, 0);
2137	if (result != USB_STOR_XFER_GOOD) {
2138		US_DEBUGP("Execution SD Init Code Fail !!\n");
2139		return USB_STOR_TRANSPORT_ERROR;
2140	}
2141
2142	/* SD Init Part-2 */
2143	result = ene_load_bincode(us, SD_INIT2_PATTERN);
2144	if (result != USB_STOR_XFER_GOOD) {
2145		US_DEBUGP("Load SD Init Code Part-2 Fail !!\n");
2146		return USB_STOR_TRANSPORT_ERROR;
2147	}
2148
2149	memset(bcb, 0, sizeof(struct bulk_cb_wrap));
2150	bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
2151	bcb->DataTransferLength = 0x200;
2152	bcb->Flags              = US_BULK_FLAG_IN;
2153	bcb->CDB[0]             = 0xF1;
2154
2155	result = ene_send_scsi_cmd(us, FDIR_READ, &buf, 0);
2156	if (result != USB_STOR_XFER_GOOD) {
2157		US_DEBUGP("Execution SD Init Code Fail !!\n");
2158		return USB_STOR_TRANSPORT_ERROR;
2159	}
2160
2161	info->SD_Status =  *(struct SD_STATUS *)&buf[0];
2162	if (info->SD_Status.Insert && info->SD_Status.Ready) {
2163		ene_get_card_status(us, (unsigned char *)&buf);
2164		US_DEBUGP("Insert     = %x\n", info->SD_Status.Insert);
2165		US_DEBUGP("Ready      = %x\n", info->SD_Status.Ready);
2166		US_DEBUGP("IsMMC      = %x\n", info->SD_Status.IsMMC);
2167		US_DEBUGP("HiCapacity = %x\n", info->SD_Status.HiCapacity);
2168		US_DEBUGP("HiSpeed    = %x\n", info->SD_Status.HiSpeed);
2169		US_DEBUGP("WtP        = %x\n", info->SD_Status.WtP);
 
 
2170	} else {
2171		US_DEBUGP("SD Card Not Ready --- %x\n", buf[0]);
2172		return USB_STOR_TRANSPORT_ERROR;
2173	}
2174	return USB_STOR_TRANSPORT_GOOD;
2175}
2176
2177
2178static int ene_init(struct us_data *us)
2179{
2180	int result;
2181	u8  misc_reg03 = 0;
2182	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
 
2183
2184	result = ene_get_card_type(us, REG_CARD_STATUS, &misc_reg03);
2185	if (result != USB_STOR_XFER_GOOD)
2186		return USB_STOR_TRANSPORT_ERROR;
2187
 
2188	if (misc_reg03 & 0x01) {
2189		if (!info->SD_Status.Ready) {
2190			result = ene_sd_init(us);
2191			if (result != USB_STOR_XFER_GOOD)
2192				return USB_STOR_TRANSPORT_ERROR;
2193		}
2194	}
2195	if (misc_reg03 & 0x02) {
2196		if (!info->MS_Status.Ready) {
2197			result = ene_ms_init(us);
2198			if (result != USB_STOR_XFER_GOOD)
2199				return USB_STOR_TRANSPORT_ERROR;
2200		}
2201	}
2202	return result;
2203}
2204
2205/*----- sd_scsi_irp() ---------*/
2206static int sd_scsi_irp(struct us_data *us, struct scsi_cmnd *srb)
2207{
2208	int    result;
2209	struct ene_ub6250_info *info = (struct ene_ub6250_info *)us->extra;
2210
2211	info->SrbStatus = SS_SUCCESS;
2212	switch (srb->cmnd[0]) {
2213	case TEST_UNIT_READY:
2214		result = sd_scsi_test_unit_ready(us, srb);
2215		break; /* 0x00 */
 
 
 
2216	case INQUIRY:
2217		result = sd_scsi_inquiry(us, srb);
2218		break; /* 0x12 */
2219	case MODE_SENSE:
2220		result = sd_scsi_mode_sense(us, srb);
2221		break; /* 0x1A */
2222	/*
2223	case START_STOP:
2224		result = SD_SCSI_Start_Stop(us, srb);
2225		break; //0x1B
2226	*/
2227	case READ_CAPACITY:
2228		result = sd_scsi_read_capacity(us, srb);
2229		break; /* 0x25 */
2230	case READ_10:
2231		result = sd_scsi_read(us, srb);
2232		break; /* 0x28 */
2233	case WRITE_10:
2234		result = sd_scsi_write(us, srb);
2235		break; /* 0x2A */
2236	default:
2237		info->SrbStatus = SS_ILLEGAL_REQUEST;
2238		result = USB_STOR_TRANSPORT_FAILED;
2239		break;
2240	}
 
 
2241	return result;
2242}
2243
2244/*
2245 * ms_scsi_irp()
2246 */
2247static int ms_scsi_irp(struct us_data *us, struct scsi_cmnd *srb)
2248{
2249	int result;
2250	struct ene_ub6250_info *info = (struct ene_ub6250_info *)us->extra;
2251	info->SrbStatus = SS_SUCCESS;
2252	switch (srb->cmnd[0]) {
2253	case TEST_UNIT_READY:
2254		result = ms_scsi_test_unit_ready(us, srb);
2255		break; /* 0x00 */
 
 
 
2256	case INQUIRY:
2257		result = ms_scsi_inquiry(us, srb);
2258		break; /* 0x12 */
2259	case MODE_SENSE:
2260		result = ms_scsi_mode_sense(us, srb);
2261		break; /* 0x1A */
2262	case READ_CAPACITY:
2263		result = ms_scsi_read_capacity(us, srb);
2264		break; /* 0x25 */
2265	case READ_10:
2266		result = ms_scsi_read(us, srb);
2267		break; /* 0x28 */
2268	case WRITE_10:
2269		result = ms_scsi_write(us, srb);
2270		break;  /* 0x2A */
2271	default:
2272		info->SrbStatus = SS_ILLEGAL_REQUEST;
2273		result = USB_STOR_TRANSPORT_FAILED;
2274		break;
2275	}
 
 
2276	return result;
2277}
2278
2279static int ene_transport(struct scsi_cmnd *srb, struct us_data *us)
2280{
2281	int result = 0;
2282	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
2283
2284	/*US_DEBUG(usb_stor_show_command(srb)); */
2285	scsi_set_resid(srb, 0);
2286	if (unlikely(!(info->SD_Status.Ready || info->MS_Status.Ready))) {
2287		result = ene_init(us);
2288	} else {
2289		if (info->SD_Status.Ready)
 
2290			result = sd_scsi_irp(us, srb);
2291
2292		if (info->MS_Status.Ready)
2293			result = ms_scsi_irp(us, srb);
2294	}
2295	return 0;
2296}
2297
 
2298
2299static int ene_ub6250_probe(struct usb_interface *intf,
2300			 const struct usb_device_id *id)
2301{
2302	int result;
2303	u8  misc_reg03 = 0;
2304	struct us_data *us;
 
2305
2306	result = usb_stor_probe1(&us, intf, id,
2307		   (id - ene_ub6250_usb_ids) + ene_ub6250_unusual_dev_list);
 
2308	if (result)
2309		return result;
2310
2311	/* FIXME: where should the code alloc extra buf ? */
2312	if (!us->extra) {
2313		us->extra = kzalloc(sizeof(struct ene_ub6250_info), GFP_KERNEL);
2314		if (!us->extra)
2315			return -ENOMEM;
2316		us->extra_destructor = ene_ub6250_info_destructor;
 
 
 
 
 
2317	}
2318
2319	us->transport_name = "ene_ub6250";
2320	us->transport = ene_transport;
2321	us->max_lun = 0;
2322
2323	result = usb_stor_probe2(us);
2324	if (result)
2325		return result;
2326
2327	/* probe card type */
2328	result = ene_get_card_type(us, REG_CARD_STATUS, &misc_reg03);
2329	if (result != USB_STOR_XFER_GOOD) {
2330		usb_stor_disconnect(intf);
2331		return USB_STOR_TRANSPORT_ERROR;
2332	}
2333
 
2334	if (!(misc_reg03 & 0x01)) {
2335		pr_info("ums_eneub6250: The driver only supports SD/MS card. "
2336			"To use SM card, please build driver/staging/keucr\n");
2337	}
2338
2339	return result;
2340}
2341
2342
2343#ifdef CONFIG_PM
2344
2345static int ene_ub6250_resume(struct usb_interface *iface)
2346{
2347	u8 tmp = 0;
2348	struct us_data *us = usb_get_intfdata(iface);
2349	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
2350
2351	mutex_lock(&us->dev_mutex);
2352
2353	US_DEBUGP("%s\n", __func__);
2354	if (us->suspend_resume_hook)
2355		(us->suspend_resume_hook)(us, US_RESUME);
2356
2357	mutex_unlock(&us->dev_mutex);
2358
2359	info->Power_IsResum = true;
2360	/*info->SD_Status.Ready = 0; */
2361	info->SD_Status = *(struct SD_STATUS *)&tmp;
2362	info->MS_Status = *(struct MS_STATUS *)&tmp;
2363	info->SM_Status = *(struct SM_STATUS *)&tmp;
2364
2365	return 0;
2366}
2367
2368static int ene_ub6250_reset_resume(struct usb_interface *iface)
2369{
2370	u8 tmp = 0;
2371	struct us_data *us = usb_get_intfdata(iface);
2372	struct ene_ub6250_info *info = (struct ene_ub6250_info *)(us->extra);
2373	US_DEBUGP("%s\n", __func__);
2374	/* Report the reset to the SCSI core */
2375	usb_stor_reset_resume(iface);
2376
2377	/* FIXME: Notify the subdrivers that they need to reinitialize
2378	 * the device */
 
 
2379	info->Power_IsResum = true;
2380	/*info->SD_Status.Ready = 0; */
2381	info->SD_Status = *(struct SD_STATUS *)&tmp;
2382	info->MS_Status = *(struct MS_STATUS *)&tmp;
2383	info->SM_Status = *(struct SM_STATUS *)&tmp;
2384
2385	return 0;
2386}
2387
2388#else
2389
2390#define ene_ub6250_resume		NULL
2391#define ene_ub6250_reset_resume		NULL
2392
2393#endif
2394
2395static struct usb_driver ene_ub6250_driver = {
2396	.name =		"ums_eneub6250",
2397	.probe =	ene_ub6250_probe,
2398	.disconnect =	usb_stor_disconnect,
2399	.suspend =	usb_stor_suspend,
2400	.resume =	ene_ub6250_resume,
2401	.reset_resume =	ene_ub6250_reset_resume,
2402	.pre_reset =	usb_stor_pre_reset,
2403	.post_reset =	usb_stor_post_reset,
2404	.id_table =	ene_ub6250_usb_ids,
2405	.soft_unbind =	1,
2406	.no_dynamic_id = 1,
2407};
2408
2409module_usb_driver(ene_ub6250_driver);