Staging: Remove ENE UB6250 MS card codes from keucr

Remove ENE UB6250 MS card codes from keucr.

Signed-off-by: Cho, Yu-Chen <acho@novell.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
This commit is contained in:
Cho, Yu-Chen 2011-07-07 11:27:14 +08:00 committed by Greg Kroah-Hartman
parent 33842cedfc
commit 20c3d7f71d
11 changed files with 6 additions and 2680 deletions

View file

@ -1,9 +1,9 @@
config USB_ENESTORAGE
tristate "USB ENE SM/MS card reader support"
tristate "USB ENE SM card reader support"
depends on USB && SCSI && m
---help---
Say Y here if you wish to control a ENE SM/MS Card reader.
To use SD card, please build driver/usb/storage/ums-eneub6250.ko
Say Y here if you wish to control a ENE SM Card reader.
To use SD/MS card, please build driver/usb/storage/ums-eneub6250.ko
This option depends on 'SCSI' support being enabled, but you
probably also need 'SCSI device support: SCSI disk support'

View file

@ -7,8 +7,6 @@ keucr-y := \
scsiglue.o \
transport.o \
init.o \
msscsi.o \
ms.o \
smscsi.o \
smilmain.o \
smilsub.o \

View file

@ -31,9 +31,7 @@ int ENE_InitMedia(struct us_data *us)
if (!us->SM_Status.Ready && !us->MS_Status.Ready) {
result = ENE_SMInit(us);
if (result != USB_STOR_XFER_GOOD) {
result = ENE_MSInit(us);
if (result != USB_STOR_XFER_GOOD)
return USB_STOR_TRANSPORT_ERROR;
return USB_STOR_TRANSPORT_ERROR;
}
}
@ -61,60 +59,6 @@ int ENE_Read_BYTE(struct us_data *us, WORD index, void *buf)
return result;
}
/*
* ENE_MSInit():
*/
int ENE_MSInit(struct us_data *us)
{
struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
int result;
BYTE buf[0x200];
WORD MSP_BlockSize, MSP_UserAreaBlocks;
printk(KERN_INFO "transport --- ENE_MSInit\n");
result = ENE_LoadBinCode(us, MS_INIT_PATTERN);
if (result != USB_STOR_XFER_GOOD) {
printk(KERN_ERR "Load MS Init Code Fail !!\n");
return USB_STOR_TRANSPORT_ERROR;
}
memset(bcb, 0, sizeof(struct bulk_cb_wrap));
bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
bcb->DataTransferLength = 0x200;
bcb->Flags = 0x80;
bcb->CDB[0] = 0xF1;
bcb->CDB[1] = 0x01;
result = ENE_SendScsiCmd(us, FDIR_READ, &buf, 0);
if (result != USB_STOR_XFER_GOOD) {
printk(KERN_ERR "Execution MS Init Code Fail !!\n");
return USB_STOR_TRANSPORT_ERROR;
}
us->MS_Status = *(PMS_STATUS)&buf[0];
if (us->MS_Status.Insert && us->MS_Status.Ready) {
printk(KERN_INFO "Insert = %x\n", us->MS_Status.Insert);
printk(KERN_INFO "Ready = %x\n", us->MS_Status.Ready);
printk(KERN_INFO "IsMSPro = %x\n", us->MS_Status.IsMSPro);
printk(KERN_INFO "IsMSPHG = %x\n", us->MS_Status.IsMSPHG);
printk(KERN_INFO "WtP = %x\n", us->MS_Status.WtP);
if (us->MS_Status.IsMSPro) {
MSP_BlockSize = (buf[6] << 8) | buf[7];
MSP_UserAreaBlocks = (buf[10] << 8) | buf[11];
us->MSP_TotalBlock = MSP_BlockSize * MSP_UserAreaBlocks;
} else {
MS_CardInit(us);
}
printk(KERN_INFO "MS Init Code OK !!\n");
} else {
printk(KERN_INFO "MS Card Not Ready --- %x\n", buf[0]);
return USB_STOR_TRANSPORT_ERROR;
}
return USB_STOR_TRANSPORT_GOOD;
}
/*
*ENE_SMInit()
*/
@ -185,19 +129,6 @@ int ENE_LoadBinCode(struct us_data *us, BYTE flag)
if (buf == NULL)
return USB_STOR_TRANSPORT_ERROR;
switch (flag) {
/* For MS */
case MS_INIT_PATTERN:
printk(KERN_INFO "MS_INIT_PATTERN\n");
memcpy(buf, MS_Init, 0x800);
break;
case MSP_RW_PATTERN:
printk(KERN_INFO "MSP_RW_PATTERN\n");
memcpy(buf, MSP_Rdwr, 0x800);
break;
case MS_RW_PATTERN:
printk(KERN_INFO "MS_RW_PATTERN\n");
memcpy(buf, MS_Rdwr, 0x800);
break;
/* For SS */
case SM_INIT_PATTERN:
printk(KERN_INFO "SM_INIT_PATTERN\n");

View file

@ -4,779 +4,6 @@ extern DWORD MediaChange;
extern int Check_D_MediaFmt(struct us_data *);
static BYTE MS_Init[] = {
0x90, 0xF0, 0x15, 0xE0, 0xF5, 0x1C, 0x11, 0x2C,
0x90, 0xFF, 0x09, 0xE0, 0x30, 0xE1, 0x06, 0x90,
0xFF, 0x23, 0x74, 0x80, 0xF0, 0x90, 0xFF, 0x09,
0xE0, 0x30, 0xE5, 0xFC, 0x51, 0x59, 0x75, 0x3F,
0x00, 0x75, 0x3E, 0x00, 0x75, 0x3D, 0x00, 0x75,
0x3C, 0x00, 0xD3, 0x22, 0x90, 0xFF, 0x83, 0xE0,
0xA2, 0xE1, 0x92, 0x25, 0x20, 0x25, 0x06, 0xC2,
0x1F, 0xD2, 0x19, 0xC3, 0x22, 0x7F, 0x02, 0x12,
0x2F, 0xCB, 0x20, 0x19, 0x05, 0x30, 0x1F, 0x02,
0xD3, 0x22, 0x90, 0xEA, 0x44, 0x74, 0x80, 0xF0,
0x7F, 0x10, 0x12, 0x2F, 0xC5, 0x90, 0xFE, 0x47,
0xE0, 0x44, 0x80, 0xF0, 0x78, 0x00, 0xE8, 0xC3,
0x94, 0x04, 0x50, 0x0A, 0x7F, 0x88, 0x7E, 0x13,
0x12, 0xE4, 0xA6, 0x08, 0x80, 0xF0, 0x90, 0xFE,
0x45, 0xE0, 0x54, 0xFB, 0xF0, 0x90, 0xFE, 0x47,
0xE0, 0x54, 0xBF, 0xF0, 0x90, 0xFE, 0x45, 0xE0,
0x54, 0xFE, 0xF0, 0x90, 0xFE, 0x45, 0xE0, 0x54,
0x7F, 0xF0, 0x90, 0xFE, 0x46, 0xE0, 0x44, 0x40,
0xF0, 0x90, 0xFE, 0x45, 0xE0, 0x54, 0xC7, 0x44,
0x18, 0xF0, 0x90, 0xFE, 0x47, 0xE0, 0x44, 0x08,
0xF0, 0x90, 0xFE, 0x45, 0xE0, 0x44, 0x40, 0xF0,
0x7F, 0x32, 0x7E, 0x00, 0x12, 0xE4, 0xA6, 0x90,
0xFE, 0x51, 0xE0, 0x54, 0x33, 0xF0, 0x90, 0xFE,
0x44, 0x74, 0x02, 0xF0, 0x30, 0x25, 0x04, 0xE0,
0x20, 0xE1, 0xF9, 0x90, 0xFE, 0x51, 0xE0, 0x54,
0x0F, 0xF0, 0x90, 0xFE, 0x44, 0x74, 0x02, 0xF0,
0x30, 0x25, 0x04, 0xE0, 0x20, 0xE1, 0xF9, 0x90,
0xFE, 0x44, 0x74, 0x04, 0xF0, 0x30, 0x25, 0x04,
0xE0, 0x20, 0xE2, 0xF9, 0x90, 0xFE, 0x4C, 0xE0,
0xF0, 0x90, 0xFE, 0x4D, 0xE0, 0xF0, 0x90, 0xFE,
0x48, 0x74, 0x7F, 0xF0, 0x90, 0xFE, 0x49, 0x74,
0x9F, 0xF0, 0x90, 0xFE, 0x51, 0xE0, 0x54, 0x3C,
0x44, 0x02, 0xF0, 0x90, 0xFE, 0x44, 0x74, 0x02,
0xF0, 0x30, 0x25, 0x04, 0xE0, 0x20, 0xE1, 0xF9,
0x90, 0xFE, 0x46, 0xE0, 0x44, 0x20, 0xF0, 0x79,
0x02, 0x7A, 0x06, 0x7B, 0x00, 0x7C, 0x00, 0x7D,
0x06, 0x7E, 0xEB, 0x7F, 0xC9, 0x12, 0x2F, 0xA7,
0x40, 0x03, 0x02, 0xE2, 0x37, 0xC2, 0x45, 0xC2,
0x1E, 0x90, 0xEB, 0xCB, 0xE0, 0x64, 0x01, 0x70,
0x65, 0x90, 0xEB, 0xCD, 0xE0, 0x70, 0x5F, 0x90,
0xEB, 0xCE, 0xE0, 0x60, 0x08, 0x54, 0x03, 0x60,
0x55, 0xD2, 0x1E, 0x80, 0x09, 0x90, 0xEB, 0xC9,
0xE0, 0x30, 0xE0, 0x02, 0xD2, 0x1E, 0x90, 0xEA,
0x45, 0x74, 0x01, 0xF0, 0x75, 0x0B, 0x00, 0xE5,
0x0B, 0xC3, 0x94, 0x80, 0x50, 0x31, 0x12, 0x2F,
0xB9, 0x40, 0x03, 0x02, 0xE2, 0x37, 0x90, 0xEB,
0xC8, 0xE0, 0x54, 0x80, 0x70, 0x0B, 0x7F, 0x38,
0x7E, 0x13, 0x12, 0xE4, 0xA6, 0x05, 0x0B, 0x80,
0xDE, 0x12, 0x2F, 0xB9, 0x40, 0x03, 0x02, 0xE2,
0x37, 0x90, 0xEB, 0xC8, 0xE0, 0xF9, 0x54, 0x40,
0x60, 0x0A, 0xE9, 0x54, 0x01, 0x70, 0x03, 0x02,
0xE2, 0x37, 0xD2, 0x1E, 0x80, 0x24, 0x90, 0xEB,
0xCB, 0xE0, 0x64, 0x00, 0x60, 0x03, 0x02, 0xE2,
0x37, 0x90, 0xEA, 0x45, 0x74, 0x00, 0xF0, 0x7F,
0x90, 0x12, 0x2F, 0xC5, 0x12, 0xE2, 0xB0, 0x40,
0x03, 0x02, 0xE2, 0x37, 0xD2, 0x1F, 0xC2, 0x19,
0xD3, 0x22, 0x90, 0xEA, 0x44, 0x74, 0x00, 0xF0,
0x75, 0x17, 0x00, 0x79, 0x00, 0x7A, 0x00, 0x7B,
0x10, 0x7C, 0x02, 0x7D, 0x02, 0x12, 0x2F, 0xA7,
0x40, 0x02, 0x80, 0x5B, 0x7F, 0x80, 0x12, 0x2F,
0xC5, 0x90, 0xFE, 0x45, 0xE0, 0x54, 0xFE, 0xF0,
0x90, 0xFE, 0x45, 0xE0, 0x44, 0x04, 0xF0, 0x90,
0xEB, 0xCC, 0xE0, 0x64, 0x07, 0x70, 0x2D, 0x90,
0xEA, 0x44, 0x74, 0x40, 0xF0, 0x75, 0x17, 0x00,
0x79, 0x00, 0x7A, 0x00, 0x7B, 0x10, 0x7C, 0x02,
0x7D, 0x02, 0x12, 0x2F, 0xA7, 0x40, 0x02, 0x80,
0x26, 0x7F, 0x80, 0x12, 0x2F, 0xC5, 0x90, 0xFE,
0x45, 0xE0, 0x54, 0xFA, 0xF0, 0x90, 0xFE, 0x45,
0xE0, 0x44, 0x01, 0xF0, 0x90, 0xEA, 0x45, 0xE0,
0x60, 0x07, 0x12, 0x2F, 0xCE, 0x40, 0x02, 0x80,
0x06, 0xD2, 0x1F, 0xC2, 0x19, 0xD3, 0x22, 0xE4,
0x90, 0xFE, 0x48, 0xF0, 0x90, 0xFE, 0x49, 0xF0,
0x90, 0xFE, 0x4C, 0xE0, 0xF0, 0x90, 0xFE, 0x4D,
0xE0, 0xF0, 0x90, 0xFE, 0x47, 0xE0, 0x54, 0x7F,
0xF0, 0xC2, 0x25, 0xC2, 0x1F, 0xD2, 0x19, 0xC3,
0x22, 0x90, 0xEA, 0x45, 0xE0, 0x64, 0x01, 0x70,
0x03, 0xD3, 0x80, 0x01, 0xC3, 0xE4, 0x92, 0xE3,
0xC0, 0xE0, 0x90, 0xEB, 0xCC, 0xE0, 0x64, 0x07,
0x70, 0x03, 0xD3, 0x80, 0x01, 0xC3, 0xD0, 0xE0,
0x92, 0xE4, 0xA2, 0x25, 0x92, 0xE0, 0xA2, 0x1F,
0x92, 0xE1, 0xA2, 0x19, 0x92, 0xE2, 0xA2, 0x1E,
0x92, 0xE6, 0x90, 0xF4, 0x00, 0xF0, 0x74, 0xFF,
0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0xF0, 0xA3, 0x7B,
0x40, 0x7C, 0xEB, 0x7D, 0x6F, 0xAE, 0x83, 0xAF,
0x82, 0x12, 0x2F, 0xC8, 0x90, 0xFF, 0x2A, 0x74,
0x02, 0xF0, 0xA3, 0x74, 0x00, 0xF0, 0xD3, 0x22,
0xC2, 0x1E, 0x74, 0xFF, 0x90, 0xEA, 0x49, 0xF0,
0x90, 0xFE, 0x44, 0x74, 0x02, 0xF0, 0x30, 0x25,
0x04, 0xE0, 0x20, 0xE1, 0xF9, 0x90, 0xFF, 0x09,
0x30, 0x25, 0x07, 0xE0, 0x30, 0xE5, 0xF9, 0xD3,
0x80, 0x01, 0xC3, 0x40, 0x01, 0x22, 0xC2, 0x1A,
0xC2, 0x22, 0x75, 0x14, 0x00, 0xE5, 0x14, 0x64,
0x0C, 0x70, 0x03, 0x02, 0xE4, 0x4B, 0x75, 0x17,
0x00, 0x75, 0x18, 0x00, 0x85, 0x14, 0x19, 0x75,
0x1B, 0x00, 0x12, 0x2F, 0x8C, 0x40, 0x03, 0x02,
0xE4, 0x46, 0x30, 0x41, 0x03, 0x02, 0xE4, 0x46,
0x90, 0xEB, 0xDD, 0xE0, 0x20, 0xE7, 0x03, 0x02,
0xE4, 0x46, 0x90, 0xEB, 0xDE, 0xE0, 0x20, 0xE2,
0x02, 0x80, 0x03, 0x02, 0xE4, 0x46, 0x90, 0xF4,
0x00, 0xE0, 0xFE, 0x90, 0xF4, 0x01, 0xE0, 0x64,
0x01, 0x4E, 0x60, 0x03, 0x02, 0xE4, 0x46, 0x90,
0xEA, 0x49, 0xE0, 0x64, 0xFF, 0x60, 0x03, 0x02,
0xE4, 0x4B, 0x90, 0xF5, 0xA0, 0xE0, 0x64, 0x01,
0x60, 0x03, 0x02, 0xE4, 0x46, 0x90, 0xF5, 0xD6,
0xE0, 0x64, 0x01, 0x60, 0x03, 0x02, 0xE4, 0x46,
0x90, 0xF5, 0xD8, 0xE0, 0xFF, 0xC3, 0x74, 0x03,
0x9F, 0x50, 0x03, 0x02, 0xE4, 0x46, 0xEF, 0x60,
0x04, 0xD2, 0x1E, 0x80, 0x0B, 0xC2, 0x1E, 0x90,
0xEB, 0xC9, 0xE0, 0x30, 0xE0, 0x02, 0xD2, 0x1E,
0x90, 0xF5, 0xA2, 0xE0, 0xFE, 0x90, 0xF5, 0xA3,
0xE0, 0xFF, 0x25, 0xE0, 0x90, 0xEA, 0x47, 0xF0,
0xE4, 0x74, 0x10, 0x9F, 0x74, 0x00, 0x9E, 0x50,
0x03, 0x02, 0xE4, 0x46, 0x90, 0xF5, 0xA4, 0xE0,
0xFE, 0x90, 0xF5, 0xA5, 0xE0, 0xFF, 0xC3, 0x74,
0x00, 0x9F, 0x74, 0x20, 0x9E, 0x50, 0x03, 0x02,
0xE4, 0x46, 0xEE, 0x4F, 0x70, 0x03, 0x02, 0xE4,
0x46, 0x90, 0xF5, 0xA6, 0xE0, 0xFE, 0x90, 0xF5,
0xA7, 0xE0, 0xFF, 0xEE, 0x4F, 0x70, 0x03, 0x02,
0xE4, 0x46, 0x90, 0xF5, 0x78, 0xE0, 0x64, 0x01,
0x60, 0x03, 0x02, 0xE4, 0x46, 0x90, 0xF5, 0x74,
0xE0, 0xFC, 0x90, 0xF5, 0x75, 0xE0, 0xFD, 0x90,
0xF5, 0x76, 0xE0, 0x90, 0xEA, 0x5B, 0xF0, 0xFE,
0x90, 0xF5, 0x77, 0xE0, 0x90, 0xEA, 0x5C, 0xF0,
0xFF, 0x4E, 0x4D, 0x4C, 0x70, 0x03, 0x02, 0xE4,
0x46, 0x90, 0xF5, 0x70, 0xE0, 0xFC, 0x90, 0xF5,
0x71, 0xE0, 0xFD, 0x90, 0xF5, 0x72, 0xE0, 0xFE,
0x90, 0xF5, 0x73, 0xE0, 0xFF, 0xEC, 0x90, 0xEA,
0x55, 0xF0, 0xED, 0x90, 0xEA, 0x56, 0xF0, 0xEE,
0x90, 0xEA, 0x57, 0xF0, 0xEF, 0x90, 0xEA, 0x58,
0xF0, 0xEC, 0x64, 0xFF, 0x70, 0x12, 0xED, 0x64,
0xFF, 0x70, 0x0D, 0xEE, 0x64, 0xFF, 0x70, 0x08,
0xEF, 0x64, 0xFF, 0x70, 0x03, 0x02, 0xE4, 0x46,
0xC2, 0x3F, 0x90, 0xF5, 0xD3, 0xE0, 0x64, 0x01,
0x70, 0x02, 0xD2, 0x3F, 0x75, 0x17, 0x00, 0x75,
0x18, 0x00, 0x85, 0x14, 0x19, 0x75, 0x1B, 0x01,
0x12, 0x2F, 0x8C, 0x40, 0x03, 0x02, 0xE4, 0x46,
0x90, 0xEA, 0x49, 0xE5, 0x14, 0xF0, 0x05, 0x14,
0x02, 0xE2, 0xDD, 0xD2, 0x22, 0x90, 0xEA, 0x49,
0xE0, 0x64, 0xFF, 0x70, 0x02, 0x80, 0x02, 0x80,
0x12, 0x90, 0xFE, 0x44, 0x74, 0x02, 0xF0, 0x30,
0x25, 0x04, 0xE0, 0x20, 0xE1, 0xF9, 0x12, 0x2F,
0x9E, 0xC3, 0x22, 0x30, 0x3F, 0x36, 0x74, 0x88,
0x90, 0xEA, 0x44, 0xF0, 0x75, 0x17, 0x00, 0x79,
0x00, 0x7A, 0x00, 0x7B, 0x10, 0x7C, 0x02, 0x7D,
0x02, 0x12, 0x2F, 0xA7, 0x7F, 0x80, 0x12, 0x2F,
0xC5, 0x90, 0xFE, 0x45, 0xE0, 0x54, 0xFE, 0xF0,
0x90, 0xFE, 0x45, 0xE0, 0x44, 0x04, 0xF0, 0x90,
0xFE, 0x44, 0x74, 0x02, 0xF0, 0x30, 0x25, 0x04,
0xE0, 0x20, 0xE1, 0xF9, 0xD3, 0x22, 0x75, 0x8A,
0x00, 0x75, 0x8C, 0xCE, 0xC2, 0x8D, 0x90, 0xEA,
0x65, 0xE4, 0xF0, 0xA3, 0xF0, 0xD2, 0x8C, 0x90,
0xEA, 0x65, 0xE0, 0xFC, 0xA3, 0xE0, 0xFD, 0xEC,
0xC3, 0x9E, 0x40, 0xF3, 0x70, 0x05, 0xED, 0xC3,
0x9F, 0x40, 0xEC, 0xC2, 0x8C, 0x22, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x4D, 0x53, 0x2D, 0x49, 0x6E, 0x69, 0x74, 0x20,
0x20, 0x20, 0x20, 0x31, 0x30, 0x30, 0x30, 0x30 };
static BYTE MSP_Rdwr[] = {
0x90, 0xF0, 0x10, 0xE0, 0x90, 0xEA, 0x46, 0xF0,
0xB4, 0x04, 0x03, 0x02, 0xE1, 0x1E, 0x90, 0xFF,
0x09, 0xE0, 0x30, 0xE1, 0x06, 0x90, 0xFF, 0x23,
0x74, 0x80, 0xF0, 0x90, 0xFF, 0x09, 0xE0, 0x30,
0xE5, 0xFC, 0x90, 0xFF, 0x83, 0xE0, 0xA2, 0xE1,
0x92, 0x25, 0x40, 0x01, 0x22, 0x20, 0x1F, 0x02,
0xC3, 0x22, 0x30, 0x45, 0x02, 0xC3, 0x22, 0xC3,
0xE5, 0x3D, 0x13, 0xF5, 0x08, 0xE5, 0x3E, 0x13,
0xF5, 0x09, 0x78, 0x96, 0x79, 0x20, 0xAA, 0x08,
0xAB, 0x09, 0x12, 0xE2, 0x53, 0x20, 0x1D, 0x10,
0x90, 0xFF, 0x83, 0xE0, 0xA2, 0xE1, 0x92, 0x25,
0x30, 0x25, 0x03, 0x30, 0x24, 0xEF, 0xD2, 0x24,
0x20, 0x23, 0x10, 0x90, 0xFF, 0x83, 0xE0, 0xA2,
0xE1, 0x92, 0x25, 0x30, 0x25, 0x03, 0x30, 0x24,
0xEF, 0xD2, 0x24, 0x30, 0x24, 0x02, 0xC3, 0x22,
0xC2, 0x24, 0xC2, 0x23, 0x90, 0xEA, 0x4B, 0xE0,
0x30, 0xE3, 0x0B, 0xC2, 0x25, 0x90, 0xFF, 0x85,
0xE0, 0x54, 0xFD, 0xF0, 0xC3, 0x22, 0x30, 0xE2,
0x78, 0x90, 0xFF, 0x09, 0x90, 0xFF, 0x83, 0xE0,
0xA2, 0xE1, 0x92, 0x25, 0x30, 0x25, 0x0A, 0x90,
0xFF, 0x09, 0xE0, 0x30, 0xE5, 0xEE, 0xD3, 0x80,
0x01, 0xC3, 0x40, 0x01, 0x22, 0x79, 0x00, 0x90,
0xFE, 0x46, 0xE0, 0x54, 0xF0, 0x49, 0xF0, 0x78,
0x2D, 0x12, 0x2F, 0xAA, 0x7E, 0xF4, 0x7F, 0x00,
0x7D, 0x00, 0x7C, 0x02, 0x12, 0x2F, 0xC2, 0x20,
0x1D, 0x10, 0x90, 0xFF, 0x83, 0xE0, 0xA2, 0xE1,
0x92, 0x25, 0x30, 0x25, 0x03, 0x30, 0x24, 0xEF,
0xD2, 0x24, 0x30, 0x24, 0x13, 0x75, 0x3F, 0x00,
0xC3, 0xE5, 0x09, 0x33, 0xF5, 0x3E, 0xE5, 0x08,
0x33, 0xF5, 0x3D, 0x75, 0x3C, 0x00, 0xC3, 0x22,
0x90, 0xFF, 0x2A, 0x74, 0x02, 0xF0, 0xA3, 0x74,
0x00, 0xF0, 0xE5, 0x09, 0x24, 0xFF, 0xF5, 0x09,
0xE5, 0x08, 0x34, 0xFF, 0xF5, 0x08, 0x02, 0xE0,
0x60, 0x90, 0xEA, 0x4B, 0xE0, 0x20, 0xE0, 0x03,
0x02, 0xE0, 0x60, 0xE4, 0xF5, 0x3F, 0xF5, 0x3E,
0xF5, 0x3D, 0xF5, 0x3C, 0xD3, 0x22, 0x90, 0xFF,
0x09, 0xE0, 0x30, 0xE1, 0x06, 0x90, 0xFF, 0x23,
0x74, 0x80, 0xF0, 0x90, 0xFF, 0x09, 0xE0, 0x30,
0xE5, 0xFC, 0x90, 0xFF, 0x83, 0xE0, 0xA2, 0xE1,
0x92, 0x25, 0x40, 0x01, 0x22, 0x20, 0x1F, 0x02,
0xC3, 0x22, 0x30, 0x1E, 0x02, 0xC3, 0x22, 0xC3,
0xE5, 0x3D, 0x13, 0xF5, 0x08, 0xE5, 0x3E, 0x13,
0xF5, 0x09, 0x78, 0x96, 0x79, 0x21, 0xAA, 0x08,
0xAB, 0x09, 0x12, 0xE2, 0x53, 0x20, 0x1D, 0x10,
0x90, 0xFF, 0x83, 0xE0, 0xA2, 0xE1, 0x92, 0x25,
0x30, 0x25, 0x03, 0x30, 0x24, 0xEF, 0xD2, 0x24,
0x30, 0x2D, 0x05, 0x75, 0x0A, 0x01, 0x80, 0x03,
0x75, 0x0A, 0x08, 0x20, 0x23, 0x10, 0x90, 0xFF,
0x83, 0xE0, 0xA2, 0xE1, 0x92, 0x25, 0x30, 0x25,
0x03, 0x30, 0x24, 0xEF, 0xD2, 0x24, 0x30, 0x24,
0x02, 0xC3, 0x22, 0xC2, 0x24, 0xC2, 0x23, 0x90,
0xEA, 0x4B, 0xE0, 0x30, 0xE1, 0x0B, 0xC2, 0x25,
0x90, 0xFF, 0x85, 0xE0, 0x54, 0xFD, 0xF0, 0xC3,
0x22, 0x20, 0xE2, 0x03, 0x02, 0xE2, 0x3E, 0x79,
0x0F, 0x90, 0xFE, 0x46, 0xE0, 0x54, 0xF0, 0x49,
0xF0, 0x75, 0x0B, 0x00, 0xE5, 0x0B, 0xC3, 0x95,
0x0A, 0x50, 0x43, 0x90, 0xFF, 0x09, 0x30, 0x25,
0x0B, 0xE0, 0x30, 0xE1, 0xF9, 0x90, 0xFF, 0x09,
0xF0, 0xD3, 0x80, 0x01, 0xC3, 0x50, 0x0F, 0xAF,
0x0B, 0x7C, 0xF0, 0x7D, 0x00, 0xAB, 0x4D, 0xAA,
0x4C, 0x12, 0x2F, 0xBF, 0x40, 0x0F, 0x90, 0xFF,
0x09, 0xE0, 0x30, 0xE1, 0x06, 0x90, 0xFF, 0x23,
0x74, 0x80, 0xF0, 0xC3, 0x22, 0x90, 0xFF, 0x09,
0xE0, 0x30, 0xE1, 0x06, 0x90, 0xFF, 0x23, 0x74,
0x80, 0xF0, 0x05, 0x0B, 0x80, 0xB6, 0x20, 0x1D,
0x10, 0x90, 0xFF, 0x83, 0xE0, 0xA2, 0xE1, 0x92,
0x25, 0x30, 0x25, 0x03, 0x30, 0x24, 0xEF, 0xD2,
0x24, 0x30, 0x24, 0x13, 0x75, 0x3F, 0x00, 0xC3,
0xE5, 0x09, 0x33, 0xF5, 0x3E, 0xE5, 0x08, 0x33,
0xF5, 0x3D, 0x75, 0x3C, 0x00, 0xC3, 0x22, 0xE5,
0x09, 0x24, 0xFF, 0xF5, 0x09, 0xE5, 0x08, 0x34,
0xFF, 0xF5, 0x08, 0x02, 0xE1, 0x7B, 0x90, 0xEA,
0x4B, 0xE0, 0x20, 0xE0, 0x03, 0x02, 0xE1, 0x7B,
0xE4, 0xF5, 0x3F, 0xF5, 0x3E, 0xF5, 0x3D, 0xF5,
0x3C, 0xD3, 0x22, 0x90, 0xFE, 0x4C, 0xE0, 0xF0,
0x90, 0xFE, 0x4D, 0xE0, 0xF0, 0xC2, 0x24, 0xC2,
0x23, 0xC2, 0x1D, 0x90, 0xFE, 0x50, 0xE8, 0xF0,
0x90, 0xFE, 0x40, 0xE9, 0xF0, 0x90, 0xFE, 0x40,
0xEA, 0xF0, 0x90, 0xFE, 0x40, 0xEB, 0xF0, 0x90,
0xEB, 0x2A, 0xE0, 0x90, 0xFE, 0x40, 0xF0, 0x90,
0xEB, 0x2B, 0xE0, 0x90, 0xFE, 0x40, 0xF0, 0x90,
0xEB, 0x2C, 0xE0, 0x90, 0xFE, 0x40, 0xF0, 0x90,
0xEB, 0x2D, 0xE0, 0x90, 0xFE, 0x40, 0xF0, 0x90,
0xFE, 0x44, 0x74, 0x01, 0xF0, 0x22, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x4D, 0x53, 0x50, 0x2D, 0x52, 0x57, 0x20, 0x20,
0x20, 0x20, 0x20, 0x31, 0x30, 0x30, 0x30, 0x30 };
static BYTE MS_Rdwr[] = {
0x90, 0xF0, 0x10, 0xE0, 0x90, 0xEA, 0x46, 0xF0,
0xB4, 0x02, 0x02, 0x80, 0x36, 0x90, 0xF0, 0x11,
0xE0, 0xF5, 0x17, 0x90, 0xF0, 0x12, 0xE0, 0xF5,
0x18, 0x90, 0xF0, 0x13, 0xE0, 0xF5, 0x19, 0x90,
0xF0, 0x14, 0xE0, 0xF5, 0x1B, 0x90, 0xF0, 0x15,
0xE0, 0xF5, 0x1C, 0x90, 0xF0, 0x16, 0xE0, 0xF5,
0x1D, 0x90, 0xF0, 0x17, 0xE0, 0xF5, 0x1E, 0x90,
0xF0, 0x18, 0xE0, 0xF5, 0x1F, 0x90, 0xF0, 0x19,
0xE0, 0xF5, 0x10, 0x90, 0xFF, 0x09, 0xE0, 0x30,
0xE1, 0x06, 0x90, 0xFF, 0x23, 0x74, 0x80, 0xF0,
0x90, 0xFF, 0x09, 0xE0, 0x30, 0xE5, 0xFC, 0x90,
0xFF, 0x83, 0xE0, 0xA2, 0xE1, 0x92, 0x25, 0x40,
0x01, 0x22, 0x90, 0xEA, 0x46, 0xE0, 0xB4, 0x02,
0x02, 0x80, 0x2B, 0xB4, 0x03, 0x03, 0x02, 0xE0,
0x96, 0xB4, 0x04, 0x05, 0xD2, 0x21, 0x02, 0xE2,
0xBC, 0xB4, 0x08, 0x0E, 0x85, 0x1C, 0x11, 0x85,
0x1D, 0x12, 0x85, 0x10, 0x1B, 0xC2, 0x21, 0x02,
0xE2, 0xBC, 0xB4, 0x06, 0x03, 0x02, 0xE2, 0x2F,
0xB4, 0x05, 0x03, 0x02, 0xE2, 0x7A, 0x20, 0x1F,
0x02, 0xC3, 0x22, 0x90, 0xEA, 0x46, 0xE0, 0xB4,
0x03, 0x03, 0x02, 0xE1, 0x94, 0xC3, 0xE5, 0x3D,
0x13, 0xF5, 0x14, 0xE5, 0x3E, 0x13, 0xF5, 0x15,
0x90, 0xEB, 0x2A, 0xE0, 0xFC, 0x90, 0xEB, 0x2B,
0xE0, 0xFD, 0x90, 0xEB, 0x2C, 0xE0, 0xFE, 0x90,
0xEB, 0x2D, 0xE0, 0xFF, 0x90, 0xEA, 0x47, 0xE0,
0x14, 0xFB, 0x60, 0x12, 0xC3, 0xEC, 0x13, 0xFC,
0xED, 0x13, 0xFD, 0xEE, 0x13, 0xFE, 0xEF, 0x13,
0xFF, 0xC3, 0xEB, 0x13, 0x80, 0xEB, 0x8E, 0x1E,
0x8F, 0x1F, 0x90, 0xEB, 0x2D, 0xE0, 0xFF, 0x90,
0xEA, 0x47, 0xE0, 0x14, 0x5F, 0xF5, 0x1B, 0xD2,
0x1A, 0x90, 0xEA, 0x47, 0xE0, 0xC3, 0x95, 0x1B,
0xF5, 0x16, 0xE5, 0x14, 0x70, 0x0A, 0xE5, 0x16,
0xD3, 0x95, 0x15, 0x40, 0x03, 0x85, 0x15, 0x16,
0xE5, 0x1E, 0xF5, 0x18, 0xE5, 0x1F, 0xF5, 0x19,
0x75, 0x17, 0x00, 0x90, 0xEA, 0x5C, 0xE0, 0xF8,
0x90, 0xEB, 0x6D, 0xE0, 0x65, 0x18, 0x70, 0x08,
0xA3, 0xE0, 0x65, 0x19, 0x70, 0x03, 0x80, 0x07,
0xA3, 0xA3, 0xD8, 0xEF, 0xC3, 0x80, 0x01, 0xD3,
0x40, 0x4F, 0xE5, 0x16, 0x64, 0x01, 0x70, 0x07,
0x12, 0x2F, 0x8C, 0x50, 0x41, 0x80, 0x07, 0xAB,
0x16, 0x12, 0xE5, 0x60, 0x50, 0x38, 0xC3, 0xE5,
0x15, 0x95, 0x16, 0xF5, 0x15, 0xE5, 0x14, 0x94,
0x00, 0xF5, 0x14, 0xE5, 0x14, 0x45, 0x15, 0x60,
0x17, 0x05, 0x0D, 0xE5, 0x0D, 0x70, 0x02, 0x05,
0x0C, 0x05, 0x1F, 0xE5, 0x1F, 0x70, 0x02, 0x05,
0x1E, 0x74, 0x00, 0xF5, 0x1B, 0x02, 0xE0, 0xF1,
0x75, 0x3F, 0x00, 0x75, 0x3E, 0x00, 0x75, 0x3D,
0x00, 0x75, 0x3C, 0x00, 0xD3, 0x22, 0x12, 0x2F,
0x9E, 0x75, 0x3F, 0x00, 0xC3, 0xE5, 0x15, 0x33,
0xF5, 0x3E, 0xE5, 0x14, 0x33, 0xF5, 0x3D, 0x75,
0x3C, 0x00, 0xC3, 0x22, 0xE5, 0x1C, 0x70, 0x03,
0x75, 0x1C, 0x01, 0xC3, 0x94, 0x80, 0x40, 0x03,
0x75, 0x1C, 0x80, 0xAA, 0x1C, 0xAD, 0x1B, 0x90,
0xF4, 0x00, 0xC0, 0x83, 0xC0, 0x82, 0xEA, 0x60,
0x5F, 0xAE, 0x18, 0xAF, 0x19, 0xE4, 0x90, 0xFE,
0x48, 0xF0, 0x90, 0xFE, 0x49, 0xF0, 0x12, 0x2F,
0x8F, 0x90, 0xFE, 0x48, 0x74, 0x7F, 0xF0, 0x90,
0xFE, 0x49, 0x74, 0x9F, 0xF0, 0x90, 0xEB, 0xDD,
0xE0, 0xD0, 0x82, 0xD0, 0x83, 0xF0, 0xA3, 0xC0,
0x83, 0xC0, 0x82, 0x90, 0xEB, 0xDE, 0xE0, 0xD0,
0x82, 0xD0, 0x83, 0xF0, 0xA3, 0xC0, 0x83, 0xC0,
0x82, 0x90, 0xEB, 0xDF, 0xE0, 0xD0, 0x82, 0xD0,
0x83, 0xF0, 0xA3, 0xC0, 0x83, 0xC0, 0x82, 0x90,
0xEB, 0xE0, 0xE0, 0xD0, 0x82, 0xD0, 0x83, 0xF0,
0xA3, 0xC0, 0x83, 0xC0, 0x82, 0x1A, 0x05, 0x19,
0xE5, 0x19, 0x70, 0x02, 0x05, 0x18, 0x80, 0x9E,
0xD0, 0x82, 0xD0, 0x83, 0xE5, 0x1C, 0x25, 0xE0,
0xFF, 0x74, 0x00, 0x33, 0xFE, 0xEF, 0x25, 0xE0,
0xFF, 0xEE, 0x33, 0xFE, 0x90, 0xFF, 0x2A, 0xEE,
0xF0, 0xA3, 0xEF, 0xF0, 0x02, 0xE1, 0x70, 0x20,
0x1F, 0x02, 0xC3, 0x22, 0x30, 0x1E, 0x02, 0x80,
0xF9, 0xD2, 0x1A, 0x75, 0x17, 0x00, 0x75, 0x3F,
0x00, 0x75, 0x3E, 0x00, 0x75, 0x3D, 0x00, 0x75,
0x3C, 0x00, 0x90, 0xEA, 0x5C, 0xE0, 0xF8, 0x90,
0xEB, 0x6D, 0xE0, 0x65, 0x18, 0x70, 0x08, 0xA3,
0xE0, 0x65, 0x19, 0x70, 0x03, 0x80, 0x07, 0xA3,
0xA3, 0xD8, 0xEF, 0xC3, 0x80, 0x01, 0xD3, 0x40,
0x0E, 0x75, 0x1C, 0xF8, 0x75, 0x1D, 0xFF, 0x12,
0xE7, 0x77, 0x40, 0x05, 0x12, 0x2F, 0x9E, 0xC3,
0x22, 0x22, 0x20, 0x1F, 0x02, 0xC3, 0x22, 0x30,
0x1E, 0x02, 0x80, 0xF9, 0xD2, 0x1A, 0x75, 0x3F,
0x00, 0x75, 0x3E, 0x00, 0x75, 0x3D, 0x00, 0x75,
0x3C, 0x00, 0x90, 0xEA, 0x5C, 0xE0, 0xF8, 0x90,
0xEB, 0x6D, 0xE0, 0x65, 0x18, 0x70, 0x08, 0xA3,
0xE0, 0x65, 0x19, 0x70, 0x03, 0x80, 0x07, 0xA3,
0xA3, 0xD8, 0xEF, 0xC3, 0x80, 0x01, 0xD3, 0x40,
0x08, 0x12, 0xE6, 0x6F, 0x40, 0x05, 0x12, 0x2F,
0x9E, 0xC3, 0x22, 0x22, 0x20, 0x1F, 0x02, 0xC3,
0x22, 0x30, 0x1E, 0x02, 0x80, 0xF9, 0xC3, 0xE5,
0x3D, 0x13, 0xF5, 0x14, 0xE5, 0x3E, 0x13, 0xF5,
0x15, 0x30, 0x21, 0x39, 0x90, 0xEB, 0x2A, 0xE0,
0xFC, 0xA3, 0xE0, 0xFD, 0xA3, 0xE0, 0xFE, 0xA3,
0xE0, 0xFF, 0x90, 0xEA, 0x47, 0xE0, 0x14, 0xFB,
0x60, 0x12, 0xC3, 0xEC, 0x13, 0xFC, 0xED, 0x13,
0xFD, 0xEE, 0x13, 0xFE, 0xEF, 0x13, 0xFF, 0xC3,
0xEB, 0x13, 0x80, 0xEB, 0x8E, 0x18, 0x8F, 0x19,
0x90, 0xEB, 0x2D, 0xE0, 0xFF, 0x90, 0xEA, 0x47,
0xE0, 0x14, 0x5F, 0xF5, 0x1B, 0xD2, 0x1C, 0xC3,
0x90, 0xEA, 0x47, 0xE0, 0x95, 0x1B, 0xF5, 0x16,
0xE5, 0x14, 0x70, 0x0A, 0xD3, 0xE5, 0x16, 0x95,
0x15, 0x40, 0x03, 0x85, 0x15, 0x16, 0x90, 0xEA,
0x5C, 0xE0, 0xF8, 0x90, 0xEB, 0x6D, 0xE0, 0x65,
0x18, 0x70, 0x08, 0xA3, 0xE0, 0x65, 0x19, 0x70,
0x03, 0x80, 0x07, 0xA3, 0xA3, 0xD8, 0xEF, 0xC3,
0x80, 0x01, 0xD3, 0x50, 0x03, 0x02, 0xE4, 0x34,
0x20, 0x21, 0x2F, 0xC2, 0x42, 0x75, 0x10, 0x00,
0xE5, 0x10, 0x65, 0x1B, 0x70, 0x03, 0x02, 0xE3,
0x7A, 0x12, 0x2F, 0x89, 0x40, 0x03, 0x02, 0xE4,
0x31, 0xE5, 0x10, 0x70, 0x11, 0xC0, 0x1C, 0xC0,
0x1B, 0x75, 0x1B, 0x00, 0x75, 0x1C, 0xEF, 0x12,
0x2F, 0x95, 0xD0, 0x1B, 0xD0, 0x1C, 0x05, 0x10,
0x80, 0xD6, 0x75, 0x17, 0x00, 0x30, 0x21, 0x06,
0xC0, 0x18, 0xC0, 0x19, 0x80, 0x10, 0x75, 0x1C,
0xF8, 0x75, 0x1D, 0xFF, 0xC0, 0x18, 0xC0, 0x19,
0x85, 0x11, 0x18, 0x85, 0x12, 0x19, 0xE5, 0x16,
0xB4, 0x01, 0x0C, 0x12, 0xE5, 0x11, 0x40, 0x13,
0xD0, 0x19, 0xD0, 0x18, 0x02, 0xE4, 0x31, 0x12,
0x2F, 0x92, 0x40, 0x07, 0xD0, 0x19, 0xD0, 0x18,
0x02, 0xE4, 0x31, 0xD0, 0x19, 0xD0, 0x18, 0xE5,
0x10, 0x25, 0x16, 0xF5, 0x10, 0x20, 0x21, 0x3A,
0x90, 0xEA, 0x47, 0xE0, 0x65, 0x10, 0x60, 0x0C,
0x12, 0x2F, 0x89, 0x40, 0x03, 0x02, 0xE4, 0x31,
0x05, 0x10, 0x80, 0xEC, 0x20, 0x42, 0x05, 0x12,
0xE7, 0x77, 0x80, 0x09, 0x75, 0x1B, 0x00, 0x75,
0x1C, 0x7F, 0x12, 0x2F, 0x95, 0x75, 0x17, 0x00,
0x85, 0x11, 0x18, 0x85, 0x12, 0x19, 0x75, 0x1B,
0x00, 0x75, 0x1C, 0xF8, 0x75, 0x1D, 0xFF, 0x12,
0xE6, 0x6F, 0xC3, 0xE5, 0x15, 0x95, 0x16, 0xF5,
0x15, 0xE5, 0x14, 0x94, 0x00, 0xF5, 0x14, 0xE5,
0x15, 0x45, 0x14, 0x60, 0x16, 0x05, 0x19, 0xE5,
0x19, 0x70, 0x02, 0x05, 0x18, 0x05, 0x0D, 0xE5,
0x0D, 0x70, 0x02, 0x05, 0x0C, 0x75, 0x1B, 0x00,
0x02, 0xE3, 0x0F, 0x75, 0x3F, 0x00, 0x75, 0x3E,
0x00, 0x75, 0x3D, 0x00, 0x75, 0x3C, 0x00, 0xD3,
0x22, 0x12, 0x2F, 0x9E, 0x90, 0xFF, 0x09, 0xE0,
0x30, 0xE1, 0x06, 0x90, 0xFF, 0x23, 0x74, 0x80,
0xF0, 0x75, 0x3F, 0x00, 0xC3, 0xE5, 0x15, 0x33,
0xF5, 0x3E, 0xE5, 0x14, 0x33, 0xF5, 0x3D, 0x75,
0x3C, 0x00, 0xC3, 0x22, 0x75, 0x1A, 0x20, 0x12,
0x2F, 0xA4, 0x40, 0x03, 0x02, 0xE5, 0x0F, 0x79,
0x0F, 0x90, 0xFE, 0x46, 0xE0, 0x54, 0xF0, 0x49,
0xF0, 0x78, 0xD2, 0x12, 0x2F, 0xAA, 0x30, 0x1C,
0x5A, 0x30, 0x2D, 0x05, 0x75, 0x16, 0x01, 0x80,
0x03, 0x75, 0x16, 0x08, 0x75, 0x08, 0x00, 0xE5,
0x08, 0x65, 0x16, 0x70, 0x02, 0x80, 0x55, 0x90,
0xFF, 0x09, 0x30, 0x25, 0x0B, 0xE0, 0x30, 0xE1,
0xF9, 0x90, 0xFF, 0x09, 0xF0, 0xD3, 0x80, 0x01,
0xC3, 0x50, 0x0F, 0xAF, 0x08, 0x7C, 0xF0, 0x7D,
0x00, 0xAB, 0x4D, 0xAA, 0x4C, 0x12, 0x2F, 0xBF,
0x40, 0x10, 0x90, 0xFF, 0x09, 0xE0, 0x30, 0xE1,
0x06, 0x90, 0xFF, 0x23, 0x74, 0x80, 0xF0, 0x02,
0xE5, 0x0A, 0x90, 0xFF, 0x09, 0xE0, 0x30, 0xE1,
0x06, 0x90, 0xFF, 0x23, 0x74, 0x80, 0xF0, 0x05,
0x08, 0x80, 0xB4, 0x7C, 0xF0, 0x7D, 0x00, 0x7B,
0x00, 0x7A, 0x02, 0x7F, 0x00, 0x12, 0x2F, 0xBF,
0x40, 0x02, 0x80, 0x2E, 0x20, 0x1D, 0x08, 0x30,
0x25, 0x03, 0x30, 0x24, 0xF7, 0xD2, 0x24, 0x30,
0x24, 0x02, 0xC3, 0x22, 0x79, 0x55, 0x7A, 0x01,
0x12, 0x2F, 0xAD, 0x40, 0x02, 0x80, 0x18, 0x12,
0x2F, 0xB0, 0x30, 0x24, 0x02, 0xC3, 0x22, 0xEF,
0x54, 0xC1, 0x64, 0x80, 0x60, 0x02, 0x80, 0x02,
0xD3, 0x22, 0x79, 0xC3, 0x12, 0x2F, 0x9B, 0xC3,
0x22, 0xC0, 0x16, 0x30, 0x1E, 0x03, 0x02, 0xE5,
0x5C, 0x75, 0x09, 0x00, 0x7C, 0x08, 0x30, 0x2D,
0x02, 0x7C, 0x20, 0x20, 0x25, 0x03, 0x02, 0xE5,
0x5C, 0xC0, 0x04, 0x12, 0xE4, 0x54, 0xD0, 0x04,
0x50, 0x04, 0xD0, 0x16, 0xD3, 0x22, 0xA9, 0x09,
0xE9, 0x54, 0x07, 0x60, 0x0C, 0x90, 0xFE, 0x4C,
0xE0, 0xF0, 0x90, 0xFE, 0x4D, 0xE0, 0xF0, 0x80,
0x09, 0x20, 0x25, 0x03, 0x02, 0xE5, 0x5C, 0x12,
0x2F, 0xB3, 0x05, 0x09, 0xE5, 0x09, 0x6C, 0x60,
0x03, 0x02, 0xE5, 0x23, 0xD0, 0x16, 0xC3, 0x22,
0xC0, 0x03, 0x75, 0x1A, 0x00, 0x12, 0x2F, 0xB6,
0x40, 0x04, 0xD0, 0x03, 0xC3, 0x22, 0xC2, 0x41,
0x79, 0xAA, 0x7A, 0x00, 0x12, 0x2F, 0xAD, 0x50,
0xF1, 0xD0, 0x03, 0x1B, 0x8B, 0x08, 0xC2, 0x40,
0x20, 0x20, 0x08, 0x30, 0x25, 0x03, 0x30, 0x24,
0xF7, 0xD2, 0x24, 0x30, 0x24, 0x02, 0xC3, 0x22,
0x12, 0x2F, 0xB0, 0xC2, 0x20, 0xC2, 0x24, 0xEF,
0x54, 0xE1, 0xFF, 0x30, 0xE0, 0x03, 0x02, 0xE6,
0x6D, 0x20, 0xE6, 0x0F, 0x30, 0xE7, 0x02, 0xD2,
0x40, 0x20, 0xE5, 0x19, 0x64, 0x80, 0x70, 0x03,
0x02, 0xE6, 0x4B, 0x12, 0x2F, 0xB9, 0x40, 0x03,
0x02, 0xE6, 0x68, 0x90, 0xEB, 0xCA, 0xE0, 0x54,
0x15, 0x60, 0x02, 0xD2, 0x41, 0xE5, 0x08, 0x70,
0x0E, 0x20, 0x40, 0x0B, 0x79, 0x33, 0x7A, 0x01,
0x12, 0x2F, 0xAD, 0x40, 0x02, 0xC1, 0x6D, 0x12,
0x2F, 0xBC, 0x40, 0x02, 0xC1, 0x6D, 0x90, 0xEB,
0xDE, 0xE0, 0x54, 0x30, 0x64, 0x30, 0x60, 0x02,
0xC1, 0x6D, 0x79, 0x00, 0x90, 0xFE, 0x46, 0xE0,
0x54, 0xF0, 0x49, 0xF0, 0x79, 0x00, 0x78, 0x2D,
0x12, 0x2F, 0xAA, 0x90, 0xFF, 0x09, 0x30, 0x25,
0x07, 0xE0, 0x30, 0xE5, 0xF9, 0xD3, 0x80, 0x01,
0xC3, 0x40, 0x02, 0x80, 0x5B, 0xC0, 0x01, 0x7E,
0xF4, 0x7F, 0x00, 0x7D, 0x00, 0x7C, 0x02, 0x12,
0x2F, 0xC2, 0xD0, 0x01, 0x40, 0x09, 0x09, 0xE9,
0x64, 0x20, 0x70, 0xD2, 0x02, 0xE6, 0x68, 0x90,
0xFF, 0x2A, 0x74, 0x02, 0xF0, 0xA3, 0x74, 0x00,
0xF0, 0x20, 0x1D, 0x08, 0x30, 0x25, 0x03, 0x30,
0x24, 0xF7, 0xD2, 0x24, 0x30, 0x24, 0x02, 0xC3,
0x22, 0x30, 0x40, 0x02, 0x80, 0x05, 0x15, 0x08,
0x02, 0xE5, 0x80, 0x30, 0x41, 0x16, 0x79, 0xCC,
0x12, 0x2F, 0x9B, 0xC2, 0x1A, 0x90, 0xEA, 0x47,
0xE0, 0x65, 0x1B, 0x60, 0x07, 0x12, 0x2F, 0x8C,
0x05, 0x1B, 0x80, 0xF1, 0xD2, 0x1A, 0xD3, 0x22,
0x79, 0xC3, 0x12, 0x2F, 0x9B, 0xC3, 0x22, 0xC0,
0x08, 0x30, 0x1E, 0x02, 0x80, 0x33, 0x75, 0x1A,
0x40, 0x75, 0x1D, 0xFF, 0x75, 0x08, 0x00, 0x20,
0x25, 0x02, 0x80, 0x25, 0x12, 0xE6, 0xAD, 0x50,
0x04, 0xD0, 0x08, 0xD3, 0x22, 0xA9, 0x08, 0xE9,
0x54, 0x07, 0x60, 0x02, 0x80, 0x08, 0x20, 0x25,
0x02, 0x80, 0x0E, 0x12, 0x2F, 0xB3, 0x05, 0x08,
0xE5, 0x08, 0x64, 0x20, 0x60, 0x03, 0x02, 0xE6,
0x7F, 0xD0, 0x08, 0xC3, 0x22, 0x90, 0xFE, 0x4C,
0xE0, 0xF0, 0x90, 0xFE, 0x4D, 0xE0, 0xF0, 0xC2,
0x1D, 0xC2, 0x24, 0x90, 0xFE, 0x50, 0x74, 0x87,
0xF0, 0x90, 0xFE, 0x40, 0x74, 0x00, 0xF0, 0x90,
0xFE, 0x40, 0x74, 0x00, 0xF0, 0x90, 0xFE, 0x40,
0x74, 0x10, 0xF0, 0x90, 0xFE, 0x40, 0x74, 0x0F,
0xF0, 0x90, 0xFE, 0x57, 0x74, 0x0F, 0xF0, 0x90,
0xFE, 0x44, 0x74, 0x01, 0xF0, 0x20, 0x1D, 0x08,
0x30, 0x25, 0x03, 0x30, 0x24, 0xF7, 0xD2, 0x24,
0x30, 0x24, 0x02, 0xC3, 0x22, 0x79, 0x00, 0x90,
0xFE, 0x46, 0xE0, 0x54, 0xF0, 0x49, 0xF0, 0x90,
0xFE, 0x4D, 0x30, 0x25, 0x07, 0xE0, 0x30, 0xE5,
0xF9, 0xD3, 0x80, 0x01, 0xC3, 0x40, 0x01, 0x22,
0x78, 0xB4, 0x12, 0x2F, 0xAA, 0x90, 0xEA, 0x44,
0xE0, 0x90, 0xFE, 0x40, 0xF0, 0x78, 0x17, 0x7D,
0x09, 0xE6, 0x08, 0x90, 0xFE, 0x40, 0xF0, 0xDD,
0xF8, 0x74, 0xFF, 0x90, 0xFE, 0x40, 0xF0, 0xF0,
0xF0, 0xF0, 0xC2, 0x1D, 0xC2, 0x24, 0xF0, 0x20,
0x1D, 0x08, 0x30, 0x25, 0x03, 0x30, 0x24, 0xF7,
0xD2, 0x24, 0x30, 0x24, 0x02, 0xC3, 0x22, 0x90,
0xFE, 0x4E, 0x30, 0x25, 0x07, 0xE0, 0x30, 0xE6,
0xF9, 0xD3, 0x80, 0x01, 0xC3, 0x79, 0x55, 0x7A,
0x01, 0x12, 0x2F, 0xAD, 0x40, 0x02, 0x80, 0x13,
0x12, 0x2F, 0xB0, 0x30, 0x24, 0x02, 0xC3, 0x22,
0xEF, 0x20, 0xE0, 0x07, 0x54, 0xC0, 0xB4, 0x80,
0x02, 0x80, 0x02, 0xC3, 0x22, 0xD3, 0x22, 0x30,
0x1E, 0x02, 0x80, 0x0A, 0x12, 0xE7, 0x88, 0x40,
0x03, 0x02, 0xE7, 0x86, 0xD3, 0x22, 0xC3, 0x22,
0xC0, 0x08, 0x75, 0x08, 0x00, 0x20, 0x25, 0x02,
0x80, 0x25, 0x12, 0x2F, 0xA1, 0x50, 0x03, 0xD0,
0x08, 0x22, 0xA9, 0x08, 0xE9, 0x54, 0x07, 0x60,
0x02, 0x80, 0x09, 0xA2, 0x25, 0x40, 0x02, 0x80,
0x0E, 0x12, 0x2F, 0xB3, 0x05, 0x08, 0xE5, 0x08,
0x64, 0x20, 0x60, 0x03, 0x02, 0xE7, 0x8D, 0xD0,
0x08, 0xC3, 0x22, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
0x4D, 0x53, 0x2D, 0x52, 0x57, 0x20, 0x20, 0x20,
0x20, 0x20, 0x20, 0x31, 0x30, 0x30, 0x30, 0x30 };
static BYTE SM_Init[] = {
0x7B, 0x09, 0x7C, 0xF0, 0x7D, 0x10, 0x7E, 0xE9,

File diff suppressed because it is too large Load diff

View file

@ -1,401 +0,0 @@
#ifndef MS_INCD
#define MS_INCD
#include <linux/blkdev.h>
#include "common.h"
/* MemoryStick Register */
/* Status Register 0 */
#define MS_REG_ST0_MB 0x80 /* media busy */
#define MS_REG_ST0_FB0 0x40 /* flush busy 0 */
#define MS_REG_ST0_BE 0x20 /* buffer empty */
#define MS_REG_ST0_BF 0x10 /* buffer full */
#define MS_REG_ST0_SL 0x02 /* sleep */
#define MS_REG_ST0_WP 0x01 /* write protected */
#define MS_REG_ST0_WP_ON MS_REG_ST0_WP
#define MS_REG_ST0_WP_OFF 0x00
/* Status Register 1 */
#define MS_REG_ST1_MB 0x80 /* media busy */
#define MS_REG_ST1_FB1 0x40 /* flush busy 1 */
#define MS_REG_ST1_DTER 0x20 /* error on data(corrected) */
#define MS_REG_ST1_UCDT 0x10 /* unable to correct data */
#define MS_REG_ST1_EXER 0x08 /* error on extra(corrected) */
#define MS_REG_ST1_UCEX 0x04 /* unable to correct extra */
#define MS_REG_ST1_FGER 0x02 /* error on overwrite flag(corrected) */
#define MS_REG_ST1_UCFG 0x01 /* unable to correct overwrite flag */
#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)
/* System Parameter */
#define MS_REG_SYSPAR_BAMD 0x80 /* block address mode */
#define MS_REG_SYSPAR_BAND_LINEAR MS_REG_SYSPAR_BAMD /* linear mode */
#define MS_REG_SYSPAR_BAND_CHIP 0x00 /* chip mode */
#define MS_REG_SYSPAR_ATEN 0x40 /* attribute ROM enable */
#define MS_REG_SYSPAR_ATEN_ENABLE MS_REG_SYSPAR_ATEN /* enable */
#define MS_REG_SYSPAR_ATEN_DISABLE 0x00 /* disable */
#define MS_REG_SYSPAR_RESERVED 0x2f
/* Command Parameter */
#define MS_REG_CMDPAR_CP2 0x80
#define MS_REG_CMDPAR_CP1 0x40
#define MS_REG_CMDPAR_CP0 0x20
#define MS_REG_CMDPAR_BLOCK_ACCESS 0
#define MS_REG_CMDPAR_PAGE_ACCESS MS_REG_CMDPAR_CP0
#define MS_REG_CMDPAR_EXTRA_DATA MS_REG_CMDPAR_CP1
#define MS_REG_CMDPAR_OVERWRITE MS_REG_CMDPAR_CP2
#define MS_REG_CMDPAR_RESERVED 0x1f
/* Overwrite Area */
#define MS_REG_OVR_BKST 0x80 /* block status */
#define MS_REG_OVR_BKST_OK MS_REG_OVR_BKST /* OK */
#define MS_REG_OVR_BKST_NG 0x00 /* NG */
#define MS_REG_OVR_PGST0 0x40 /* page status */
#define MS_REG_OVR_PGST1 0x20
#define MS_REG_OVR_PGST_MASK (MS_REG_OVR_PGST0 | MS_REG_OVR_PGST1)
#define MS_REG_OVR_PGST_OK (MS_REG_OVR_PGST0 | MS_REG_OVR_PGST1) /* OK */
#define MS_REG_OVR_PGST_NG MS_REG_OVR_PGST1 /* NG */
#define MS_REG_OVR_PGST_DATA_ERROR 0x00 /* data error */
#define MS_REG_OVR_UDST 0x10 /* update status */
#define MS_REG_OVR_UDST_UPDATING 0x00 /* updating */
#define MS_REG_OVR_UDST_NO_UPDATE MS_REG_OVR_UDST
#define MS_REG_OVR_RESERVED 0x08
#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)
/* Management Flag */
#define MS_REG_MNG_SCMS0 0x20 /* serial copy management system */
#define MS_REG_MNG_SCMS1 0x10
#define MS_REG_MNG_SCMS_MASK (MS_REG_MNG_SCMS0 | MS_REG_MNG_SCMS1)
#define MS_REG_MNG_SCMS_COPY_OK (MS_REG_MNG_SCMS0 | MS_REG_MNG_SCMS1)
#define MS_REG_MNG_SCMS_ONE_COPY MS_REG_MNG_SCMS1
#define MS_REG_MNG_SCMS_NO_COPY 0x00
#define MS_REG_MNG_ATFLG 0x08 /* address transfer table flag */
#define MS_REG_MNG_ATFLG_OTHER MS_REG_MNG_ATFLG /* other */
#define MS_REG_MNG_ATFLG_ATTBL 0x00 /* address transfer table */
#define MS_REG_MNG_SYSFLG 0x04 /* system flag */
#define MS_REG_MNG_SYSFLG_USER MS_REG_MNG_SYSFLG /* user block */
#define MS_REG_MNG_SYSFLG_BOOT 0x00 /* system block */
#define MS_REG_MNG_RESERVED 0xc3
#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)
/* Error codes */
#define MS_STATUS_SUCCESS 0x0000
#define MS_ERROR_OUT_OF_SPACE 0x0103
#define MS_STATUS_WRITE_PROTECT 0x0106
#define MS_ERROR_READ_DATA 0x8002
#define MS_ERROR_FLASH_READ 0x8003
#define MS_ERROR_FLASH_WRITE 0x8004
#define MS_ERROR_FLASH_ERASE 0x8005
#define MS_ERROR_FLASH_COPY 0x8006
#define MS_STATUS_ERROR 0xfffe
#define MS_FIFO_ERROR 0xfffd
#define MS_UNDEFINED_ERROR 0xfffc
#define MS_KETIMEOUT_ERROR 0xfffb
#define MS_STATUS_INT_ERROR 0xfffa
#define MS_NO_MEMORY_ERROR 0xfff9
#define MS_NOCARD_ERROR 0xfff8
#define MS_LB_NOT_USED 0xffff
#define MS_LB_ERROR 0xfff0
#define MS_LB_BOOT_BLOCK 0xfff1
#define MS_LB_INITIAL_ERROR 0xfff2
#define MS_STATUS_SUCCESS_WITH_ECC 0xfff3
#define MS_LB_ACQUIRED_ERROR 0xfff4
#define MS_LB_NOT_USED_ERASED 0xfff5
#define MS_LibConv2Physical(pdx, LogBlock) \
(((LogBlock) >= (pdx)->MS_Lib.NumberOfLogBlock) ? \
MS_STATUS_ERROR : (pdx)->MS_Lib.Log2PhyMap[LogBlock])
#define MS_LibConv2Logical(pdx, PhyBlock) \
(((PhyBlock) >= (pdx)->MS_Lib.NumberOfPhyBlock) ? \
MS_STATUS_ERROR : (pdx)->MS_Lib.Phy2LogMap[PhyBlock])
/*dphy->log table */
#define MS_LIB_CTRL_RDONLY 0
#define MS_LIB_CTRL_WRPROTECT 1
#define MS_LibCtrlCheck(pdx, Flag) ((pdx)->MS_Lib.flags & (1 << (Flag)))
#define MS_LibCtrlSet(pdx, Flag) ((pdx)->MS_Lib.flags |= (1 << (Flag)))
#define MS_LibCtrlReset(pdx, Flag) ((pdx)->MS_Lib.flags &= ~(1 << (Flag)))
#define MS_LibIsWritable(pdx) \
((MS_LibCtrlCheck((pdx), MS_LIB_CTRL_RDONLY) == 0) && \
(MS_LibCtrlCheck(pdx, MS_LIB_CTRL_WRPROTECT) == 0))
#define MS_MAX_PAGES_PER_BLOCK 32
#define MS_LIB_BITS_PER_BYTE 8
#define MS_LibPageMapIdx(n) ((n) / MS_LIB_BITS_PER_BYTE)
#define MS_LibPageMapBit(n) (1 << ((n) % MS_LIB_BITS_PER_BYTE))
#define MS_LibCheckPageMapBit(pdx, n) \
((pdx)->MS_Lib.pagemap[MS_LibPageMapIdx(n)] & MS_LibPageMapBit(n))
#define MS_LibSetPageMapBit(pdx, n) \
((pdx)->MS_Lib.pagemap[MS_LibPageMapIdx(n)] |= MS_LibPageMapBit(n))
#define MS_LibResetPageMapBit(pdx, n) \
((pdx)->MS_Lib.pagemap[MS_LibPageMapIdx(n)] &= ~MS_LibPageMapBit(n))
#define MS_LibClearPageMap(pdx) \
memset((pdx)->MS_Lib.pagemap, 0, sizeof((pdx)->MS_Lib.pagemap))
#define MemStickLogAddr(logadr1, logadr0) \
((((WORD)(logadr1)) << 8) | (logadr0))
#define MS_BYTES_PER_PAGE 512
#define MS_MAX_INITIAL_ERROR_BLOCKS 10
#define MS_NUMBER_OF_PAGES_FOR_BOOT_BLOCK 3
#define MS_NUMBER_OF_PAGES_FOR_LPCTBL 2
#define MS_NUMBER_OF_BOOT_BLOCK 2
#define MS_NUMBER_OF_SYSTEM_BLOCK 4
#define MS_LOGICAL_BLOCKS_PER_SEGMENT 496
#define MS_LOGICAL_BLOCKS_IN_1ST_SEGMENT 494
#define MS_PHYSICAL_BLOCKS_PER_SEGMENT 0x200 /* 512 */
#define MS_PHYSICAL_BLOCKS_PER_SEGMENT_MASK 0x1ff
#define MS_SECTOR_SIZE 512
#define MBR_SIGNATURE 0xAA55
#define PBR_SIGNATURE 0xAA55
#define PARTITION_FAT_12 1
#define PARTITION_FAT_16 2
#define MS_BOOT_BLOCK_ID 0x0001
#define MS_BOOT_BLOCK_FORMAT_VERSION 0x0100
#define MS_BOOT_BLOCK_DATA_ENTRIES 2
#define MS_SYSINF_MSCLASS_TYPE_1 1
#define MS_SYSINF_CARDTYPE_RDONLY 1
#define MS_SYSINF_CARDTYPE_RDWR 2
#define MS_SYSINF_CARDTYPE_HYBRID 3
#define MS_SYSINF_SECURITY 0x01
#define MS_SYSINF_SECURITY_NO_SUPPORT MS_SYSINF_SECURITY
#define MS_SYSINF_SECURITY_SUPPORT 0
#define MS_SYSINF_FORMAT_MAT 0 /* ? */
#define MS_SYSINF_FORMAT_FAT 1
#define MS_SYSINF_USAGE_GENERAL 0
#define MS_SYSINF_PAGE_SIZE MS_BYTES_PER_PAGE /* fixed */
#define MS_SYSINF_RESERVED1 1
#define MS_SYSINF_RESERVED2 1
#define MS_SYSENT_TYPE_INVALID_BLOCK 0x01
#define MS_SYSENT_TYPE_CIS_IDI 0x0a /* CIS/IDI */
#define SIZE_OF_KIRO 1024
/* BOOT BLOCK */
#define MS_NUMBER_OF_SYSTEM_ENTRY 4
/*
* MemStickRegisters
*/
/* Status registers (16 bytes) */
typedef struct {
BYTE Reserved0; /* 00 */
BYTE INTRegister; /* 01 */
BYTE StatusRegister0; /* 02 */
BYTE StatusRegister1; /* 03 */
BYTE Reserved1[12]; /* 04-0F */
} MemStickStatusRegisters;
/* Parameter registers (6 bytes) */
typedef struct {
BYTE SystemParameter; /* 10 */
BYTE BlockAddress2; /* 11 */
BYTE BlockAddress1; /* 12 */
BYTE BlockAddress0; /* 13 */
BYTE CMDParameter; /* 14 */
BYTE PageAddress; /* 15 */
} MemStickParameterRegisters;
/* Extra registers (9 bytes) */
typedef struct {
BYTE OverwriteFlag; /* 16 */
BYTE ManagementFlag; /* 17 */
BYTE LogicalAddress1; /* 18 */
BYTE LogicalAddress0; /* 19 */
BYTE ReservedArea[5]; /* 1A-1E */
} MemStickExtraDataRegisters;
/* All registers in Memory Stick (32 bytes, includes 1 byte padding) */
typedef struct {
MemStickStatusRegisters status;
MemStickParameterRegisters param;
MemStickExtraDataRegisters extra;
BYTE padding;
} MemStickRegisters, *PMemStickRegisters;
/*
* MemStickBootBlockPage0
*/
typedef struct {
WORD wBlockID;
WORD wFormatVersion;
BYTE bReserved1[184];
BYTE bNumberOfDataEntry;
BYTE bReserved2[179];
} MemStickBootBlockHeader;
typedef struct {
DWORD dwStart;
DWORD dwSize;
BYTE bType;
BYTE bReserved[3];
} MemStickBootBlockSysEntRec;
typedef struct {
MemStickBootBlockSysEntRec entry[MS_NUMBER_OF_SYSTEM_ENTRY];
} MemStickBootBlockSysEnt;
typedef struct {
BYTE bMsClass; /* must be 1 */
BYTE bCardType; /* see below */
WORD wBlockSize; /* n KB */
WORD wBlockNumber; /* number of physical block */
WORD wTotalBlockNumber; /* number of logical block */
WORD wPageSize; /* must be 0x200 */
BYTE bExtraSize; /* 0x10 */
BYTE bSecuritySupport;
BYTE bAssemblyDate[8];
BYTE bFactoryArea[4];
BYTE bAssemblyMakerCode;
BYTE bAssemblyMachineCode[3];
WORD wMemoryMakerCode;
WORD wMemoryDeviceCode;
WORD wMemorySize;
BYTE bReserved1;
BYTE bReserved2;
BYTE bVCC;
BYTE bVPP;
WORD wControllerChipNumber;
WORD wControllerFunction; /* New MS */
BYTE bReserved3[9]; /* New MS */
BYTE bParallelSupport; /* New MS */
WORD wFormatValue; /* New MS */
BYTE bFormatType;
BYTE bUsage;
BYTE bDeviceType;
BYTE bReserved4[22];
BYTE bFUValue3;
BYTE bFUValue4;
BYTE bReserved5[15];
} MemStickBootBlockSysInf;
typedef struct {
MemStickBootBlockHeader header;
MemStickBootBlockSysEnt sysent;
MemStickBootBlockSysInf sysinf;
} MemStickBootBlockPage0;
/*
* MemStickBootBlockCIS_IDI
*/
typedef struct {
BYTE bCistplDEVICE[6]; /* 0 */
BYTE bCistplDEVICE0C[6]; /* 6 */
BYTE bCistplJEDECC[4]; /* 12 */
BYTE bCistplMANFID[6]; /* 16 */
BYTE bCistplVER1[32]; /* 22 */
BYTE bCistplFUNCID[4]; /* 54 */
BYTE bCistplFUNCE0[4]; /* 58 */
BYTE bCistplFUNCE1[5]; /* 62 */
BYTE bCistplCONF[7]; /* 67 */
BYTE bCistplCFTBLENT0[10]; /* 74 */
BYTE bCistplCFTBLENT1[8]; /* 84 */
BYTE bCistplCFTBLENT2[12]; /* 92 */
BYTE bCistplCFTBLENT3[8]; /* 104 */
BYTE bCistplCFTBLENT4[17]; /* 112 */
BYTE bCistplCFTBLENT5[8]; /* 129 */
BYTE bCistplCFTBLENT6[17]; /* 137 */
BYTE bCistplCFTBLENT7[8]; /* 154 */
BYTE bCistplNOLINK[3]; /* 162 */
} MemStickBootBlockCIS;
typedef struct {
#define MS_IDI_GENERAL_CONF 0x848A
WORD wIDIgeneralConfiguration; /* 0 */
WORD wIDInumberOfCylinder; /* 1 */
WORD wIDIreserved0; /* 2 */
WORD wIDInumberOfHead; /* 3 */
WORD wIDIbytesPerTrack; /* 4 */
WORD wIDIbytesPerSector; /* 5 */
WORD wIDIsectorsPerTrack; /* 6 */
WORD wIDItotalSectors[2]; /* 7-8 high,low */
WORD wIDIreserved1[11]; /* 9-19 */
WORD wIDIbufferType; /* 20 */
WORD wIDIbufferSize; /* 21 */
WORD wIDIlongCmdECC; /* 22 */
WORD wIDIfirmVersion[4]; /* 23-26 */
WORD wIDImodelName[20]; /* 27-46 */
WORD wIDIreserved2; /* 47 */
WORD wIDIlongWordSupported; /* 48 */
WORD wIDIdmaSupported; /* 49 */
WORD wIDIreserved3; /* 50 */
WORD wIDIpioTiming; /* 51 */
WORD wIDIdmaTiming; /* 52 */
WORD wIDItransferParameter; /* 53 */
WORD wIDIformattedCylinder; /* 54 */
WORD wIDIformattedHead; /* 55 */
WORD wIDIformattedSectorsPerTrack; /* 56 */
WORD wIDIformattedTotalSectors[2]; /* 57-58 */
WORD wIDImultiSector; /* 59 */
WORD wIDIlbaSectors[2]; /* 60-61 */
WORD wIDIsingleWordDMA; /* 62 */
WORD wIDImultiWordDMA; /* 63 */
WORD wIDIreserved4[192]; /* 64-255 */
} MemStickBootBlockIDI;
typedef struct {
union {
MemStickBootBlockCIS cis;
BYTE dmy[256];
} cis;
union {
MemStickBootBlockIDI idi;
BYTE dmy[256];
} idi;
} MemStickBootBlockCIS_IDI;
/*
* MS_LibControl
*/
typedef struct {
BYTE reserved;
BYTE intr;
BYTE status0;
BYTE status1;
BYTE ovrflg;
BYTE mngflg;
WORD logadr;
} MS_LibTypeExtdat;
typedef struct {
DWORD flags;
DWORD BytesPerSector;
DWORD NumberOfCylinder;
DWORD SectorsPerCylinder;
WORD cardType; /* R/W, RO, Hybrid */
WORD blockSize;
WORD PagesPerBlock;
WORD NumberOfPhyBlock;
WORD NumberOfLogBlock;
WORD NumberOfSegment;
WORD *Phy2LogMap; /* phy2log table */
WORD *Log2PhyMap; /* log2phy table */
WORD wrtblk;
BYTE pagemap[(MS_MAX_PAGES_PER_BLOCK + (MS_LIB_BITS_PER_BYTE-1)) /
MS_LIB_BITS_PER_BYTE];
BYTE *blkpag;
MS_LibTypeExtdat *blkext;
BYTE copybuf[512];
} MS_LibControl;
#endif

View file

@ -1,344 +0,0 @@
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
#include <linux/sched.h>
#include <linux/errno.h>
#include <linux/slab.h>
#include <scsi/scsi.h>
#include <scsi/scsi_eh.h>
#include <scsi/scsi_device.h>
#include "usb.h"
#include "scsiglue.h"
#include "transport.h"
/*
* MS_SCSI_Test_Unit_Ready()
*/
int MS_SCSI_Test_Unit_Ready(struct us_data *us, struct scsi_cmnd *srb)
{
/* pr_info("MS_SCSI_Test_Unit_Ready\n"); */
if (us->MS_Status.Insert && us->MS_Status.Ready)
return USB_STOR_TRANSPORT_GOOD;
else {
ENE_MSInit(us);
return USB_STOR_TRANSPORT_GOOD;
}
return USB_STOR_TRANSPORT_GOOD;
}
/*
* MS_SCSI_Inquiry()
*/
int MS_SCSI_Inquiry(struct us_data *us, struct scsi_cmnd *srb)
{
/* pr_info("MS_SCSI_Inquiry\n"); */
BYTE data_ptr[36] = {0x00, 0x80, 0x02, 0x00, 0x1F, 0x00,
0x00, 0x00, 0x55, 0x53, 0x42, 0x32,
0x2E, 0x30, 0x20, 0x20, 0x43, 0x61,
0x72, 0x64, 0x52, 0x65, 0x61, 0x64,
0x65, 0x72, 0x20, 0x20, 0x20, 0x20,
0x20, 0x20, 0x30, 0x31, 0x30, 0x30};
usb_stor_set_xfer_buf(us, data_ptr, 36, srb, TO_XFER_BUF);
return USB_STOR_TRANSPORT_GOOD;
}
/*
* MS_SCSI_Mode_Sense()
*/
int MS_SCSI_Mode_Sense(struct us_data *us, struct scsi_cmnd *srb)
{
BYTE mediaNoWP[12] = {0x0b, 0x00, 0x00, 0x08, 0x00, 0x00,
0x71, 0xc0, 0x00, 0x00, 0x02, 0x00};
BYTE mediaWP[12] = {0x0b, 0x00, 0x80, 0x08, 0x00, 0x00,
0x71, 0xc0, 0x00, 0x00, 0x02, 0x00};
if (us->MS_Status.WtP)
usb_stor_set_xfer_buf(us, mediaWP, 12, srb, TO_XFER_BUF);
else
usb_stor_set_xfer_buf(us, mediaNoWP, 12, srb, TO_XFER_BUF);
return USB_STOR_TRANSPORT_GOOD;
}
/*
* MS_SCSI_Read_Capacity()
*/
int MS_SCSI_Read_Capacity(struct us_data *us, struct scsi_cmnd *srb)
{
unsigned int offset = 0;
struct scatterlist *sg = NULL;
DWORD bl_num;
WORD bl_len;
BYTE buf[8];
pr_info("MS_SCSI_Read_Capacity\n");
bl_len = 0x200;
if (us->MS_Status.IsMSPro)
bl_num = us->MSP_TotalBlock - 1;
else
bl_num = us->MS_Lib.NumberOfLogBlock *
us->MS_Lib.blockSize * 2 - 1;
us->bl_num = bl_num;
pr_info("bl_len = %x\n", bl_len);
pr_info("bl_num = %x\n", bl_num);
/* srb->request_bufflen = 8; */
buf[0] = (bl_num >> 24) & 0xff;
buf[1] = (bl_num >> 16) & 0xff;
buf[2] = (bl_num >> 8) & 0xff;
buf[3] = (bl_num >> 0) & 0xff;
buf[4] = (bl_len >> 24) & 0xff;
buf[5] = (bl_len >> 16) & 0xff;
buf[6] = (bl_len >> 8) & 0xff;
buf[7] = (bl_len >> 0) & 0xff;
usb_stor_access_xfer_buf(us, buf, 8, srb, &sg, &offset, TO_XFER_BUF);
/* usb_stor_set_xfer_buf(us, buf, srb->request_bufflen,
srb, TO_XFER_BUF); */
return USB_STOR_TRANSPORT_GOOD;
}
/*
* MS_SCSI_Read()
*/
int MS_SCSI_Read(struct us_data *us, struct scsi_cmnd *srb)
{
struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
int result = 0;
PBYTE Cdb = srb->cmnd;
DWORD bn = ((Cdb[2] << 24) & 0xff000000) |
((Cdb[3] << 16) & 0x00ff0000) |
((Cdb[4] << 8) & 0x0000ff00) |
((Cdb[5] << 0) & 0x000000ff);
WORD blen = ((Cdb[7] << 8) & 0xff00) | ((Cdb[8] << 0) & 0x00ff);
DWORD blenByte = blen * 0x200;
/* pr_info("SCSIOP_READ --- bn = %X, blen = %X, srb->use_sg = %X\n",
bn, blen, srb->use_sg); */
if (bn > us->bl_num)
return USB_STOR_TRANSPORT_ERROR;
if (us->MS_Status.IsMSPro) {
result = ENE_LoadBinCode(us, MSP_RW_PATTERN);
if (result != USB_STOR_XFER_GOOD) {
pr_info("Load MSP RW pattern Fail !!\n");
return USB_STOR_TRANSPORT_ERROR;
}
/* set up the command wrapper */
memset(bcb, 0, sizeof(struct bulk_cb_wrap));
bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
bcb->DataTransferLength = blenByte;
bcb->Flags = 0x80;
bcb->CDB[0] = 0xF1;
bcb->CDB[1] = 0x02;
bcb->CDB[5] = (BYTE)(bn);
bcb->CDB[4] = (BYTE)(bn>>8);
bcb->CDB[3] = (BYTE)(bn>>16);
bcb->CDB[2] = (BYTE)(bn>>24);
result = ENE_SendScsiCmd(us, FDIR_READ, scsi_sglist(srb), 1);
} else {
void *buf;
int offset = 0;
WORD phyblk, logblk;
BYTE PageNum;
WORD len;
DWORD blkno;
buf = kmalloc(blenByte, GFP_KERNEL);
if (buf == NULL)
return USB_STOR_TRANSPORT_ERROR;
result = ENE_LoadBinCode(us, MS_RW_PATTERN);
if (result != USB_STOR_XFER_GOOD) {
pr_info("Load MS RW pattern Fail !!\n");
result = USB_STOR_TRANSPORT_ERROR;
goto exit;
}
logblk = (WORD)(bn / us->MS_Lib.PagesPerBlock);
PageNum = (BYTE)(bn % us->MS_Lib.PagesPerBlock);
while (1) {
if (blen > (us->MS_Lib.PagesPerBlock-PageNum))
len = us->MS_Lib.PagesPerBlock-PageNum;
else
len = blen;
phyblk = MS_LibConv2Physical(us, logblk);
blkno = phyblk * 0x20 + PageNum;
/* set up the command wrapper */
memset(bcb, 0, sizeof(struct bulk_cb_wrap));
bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
bcb->DataTransferLength = 0x200 * len;
bcb->Flags = 0x80;
bcb->CDB[0] = 0xF1;
bcb->CDB[1] = 0x02;
bcb->CDB[5] = (BYTE)(blkno);
bcb->CDB[4] = (BYTE)(blkno>>8);
bcb->CDB[3] = (BYTE)(blkno>>16);
bcb->CDB[2] = (BYTE)(blkno>>24);
result = ENE_SendScsiCmd(us, FDIR_READ, buf+offset, 0);
if (result != USB_STOR_XFER_GOOD) {
pr_info("MS_SCSI_Read --- result = %x\n",
result);
result = USB_STOR_TRANSPORT_ERROR;
goto exit;
}
blen -= len;
if (blen <= 0)
break;
logblk++;
PageNum = 0;
offset += MS_BYTES_PER_PAGE*len;
}
usb_stor_set_xfer_buf(us, buf, blenByte, srb, TO_XFER_BUF);
exit:
kfree(buf);
}
return result;
}
/*
* MS_SCSI_Write()
*/
int MS_SCSI_Write(struct us_data *us, struct scsi_cmnd *srb)
{
struct bulk_cb_wrap *bcb = (struct bulk_cb_wrap *) us->iobuf;
int result = 0;
PBYTE Cdb = srb->cmnd;
DWORD bn = ((Cdb[2] << 24) & 0xff000000) |
((Cdb[3] << 16) & 0x00ff0000) |
((Cdb[4] << 8) & 0x0000ff00) |
((Cdb[5] << 0) & 0x000000ff);
WORD blen = ((Cdb[7] << 8) & 0xff00) | ((Cdb[8] << 0) & 0x00ff);
DWORD blenByte = blen * 0x200;
if (bn > us->bl_num)
return USB_STOR_TRANSPORT_ERROR;
if (us->MS_Status.IsMSPro) {
result = ENE_LoadBinCode(us, MSP_RW_PATTERN);
if (result != USB_STOR_XFER_GOOD) {
pr_info("Load MSP RW pattern Fail !!\n");
return USB_STOR_TRANSPORT_ERROR;
}
/* set up the command wrapper */
memset(bcb, 0, sizeof(struct bulk_cb_wrap));
bcb->Signature = cpu_to_le32(US_BULK_CB_SIGN);
bcb->DataTransferLength = blenByte;
bcb->Flags = 0x00;
bcb->CDB[0] = 0xF0;
bcb->CDB[1] = 0x04;
bcb->CDB[5] = (BYTE)(bn);
bcb->CDB[4] = (BYTE)(bn>>8);
bcb->CDB[3] = (BYTE)(bn>>16);
bcb->CDB[2] = (BYTE)(bn>>24);
result = ENE_SendScsiCmd(us, FDIR_WRITE, scsi_sglist(srb), 1);
} else {
void *buf;
int offset = 0;
WORD PhyBlockAddr;
BYTE PageNum;
DWORD result;
WORD len, oldphy, newphy;
buf = kmalloc(blenByte, GFP_KERNEL);
if (buf == NULL)
return USB_STOR_TRANSPORT_ERROR;
usb_stor_set_xfer_buf(us, buf, blenByte, srb, FROM_XFER_BUF);
result = ENE_LoadBinCode(us, MS_RW_PATTERN);
if (result != USB_STOR_XFER_GOOD) {
pr_info("Load MS RW pattern Fail !!\n");
result = USB_STOR_TRANSPORT_ERROR;
goto exit;
}
PhyBlockAddr = (WORD)(bn / us->MS_Lib.PagesPerBlock);
PageNum = (BYTE)(bn % us->MS_Lib.PagesPerBlock);
while (1) {
if (blen > (us->MS_Lib.PagesPerBlock-PageNum))
len = us->MS_Lib.PagesPerBlock-PageNum;
else
len = blen;
oldphy = MS_LibConv2Physical(us, PhyBlockAddr);
newphy = MS_LibSearchBlockFromLogical(us, PhyBlockAddr);
result = MS_ReaderCopyBlock(us, oldphy, newphy,
PhyBlockAddr, PageNum,
buf+offset, len);
if (result != USB_STOR_XFER_GOOD) {
pr_info("MS_SCSI_Write --- result = %x\n",
result);
result = USB_STOR_TRANSPORT_ERROR;
goto exit;
}
us->MS_Lib.Phy2LogMap[oldphy] = MS_LB_NOT_USED_ERASED;
MS_LibForceSetLogicalPair(us, PhyBlockAddr, newphy);
blen -= len;
if (blen <= 0)
break;
PhyBlockAddr++;
PageNum = 0;
offset += MS_BYTES_PER_PAGE*len;
}
exit:
kfree(buf);
}
return result;
}
/*
* MS_SCSIIrp()
*/
int MS_SCSIIrp(struct us_data *us, struct scsi_cmnd *srb)
{
int result;
us->SrbStatus = SS_SUCCESS;
switch (srb->cmnd[0]) {
case TEST_UNIT_READY:
result = MS_SCSI_Test_Unit_Ready(us, srb);
break; /* 0x00 */
case INQUIRY:
result = MS_SCSI_Inquiry(us, srb);
break; /* 0x12 */
case MODE_SENSE:
result = MS_SCSI_Mode_Sense(us, srb);
break; /* 0x1A */
case READ_CAPACITY:
result = MS_SCSI_Read_Capacity(us, srb);
break; /* 0x25 */
case READ_10:
result = MS_SCSI_Read(us, srb);
break; /* 0x28 */
case WRITE_10:
result = MS_SCSI_Write(us, srb);
break; /* 0x2A */
default:
us->SrbStatus = SS_ILLEGAL_REQUEST;
result = USB_STOR_TRANSPORT_FAILED;
break;
}
return result;
}

View file

@ -432,7 +432,7 @@ void ENE_stor_invoke_transport(struct scsi_cmnd *srb, struct us_data *us)
usb_stor_print_cmd(srb);
/* send the command to the transport layer */
scsi_set_resid(srb, 0);
if (!(us->MS_Status.Ready || us->SM_Status.Ready))
if (!(us->SM_Status.Ready))
result = ENE_InitMedia(us);
if (us->Power_IsResum == true) {
@ -440,8 +440,6 @@ void ENE_stor_invoke_transport(struct scsi_cmnd *srb, struct us_data *us)
us->Power_IsResum = false;
}
if (us->MS_Status.Ready)
result = MS_SCSIIrp(us, srb);
if (us->SM_Status.Ready)
result = SM_SCSIIrp(us, srb);

View file

@ -95,7 +95,6 @@ extern void usb_stor_set_xfer_buf(struct us_data*, unsigned char *buffer,
*/
extern void ENE_stor_invoke_transport(struct scsi_cmnd *, struct us_data *);
extern int ENE_InitMedia(struct us_data *);
extern int ENE_MSInit(struct us_data *);
extern int ENE_SMInit(struct us_data *);
extern int ENE_SendScsiCmd(struct us_data*, BYTE, void*, int);
extern int ENE_LoadBinCode(struct us_data*, BYTE);
@ -107,51 +106,6 @@ extern void BuildSenseBuffer(struct scsi_cmnd *, int);
/*
* ENE scsi function
*/
extern int MS_SCSIIrp(struct us_data *us, struct scsi_cmnd *srb);
extern int SM_SCSIIrp(struct us_data *us, struct scsi_cmnd *srb);
/*
* ENE MS function
*/
extern int MS_CardInit(struct us_data *us);
extern void MS_LibFreeAllocatedArea(struct us_data *us);
extern void MS_LibFreeWriteBuf(struct us_data *us);
extern int MS_LibFreeLogicalMap(struct us_data *us);
extern int MS_LibForceSetLogicalPair(struct us_data *us, WORD logblk,
WORD phyblk);
extern int MS_ReaderReadPage(struct us_data *us, DWORD PhyBlockAddr,
BYTE PageNum, DWORD *PageBuf,
MS_LibTypeExtdat *ExtraDat);
extern int MS_ReaderCopyBlock(struct us_data *us, WORD oldphy,
WORD newphy, WORD PhyBlockAddr,
BYTE PageNum, PBYTE buf, WORD len);
extern int MS_ReaderEraseBlock(struct us_data *us, DWORD PhyBlockAddr);
extern int MS_LibProcessBootBlock(struct us_data *us, WORD PhyBlock,
BYTE *PageData);
extern int MS_LibAllocLogicalMap(struct us_data *us);
extern int MS_LibSetBootBlockMark(struct us_data *us, WORD phyblk);
extern int MS_LibSetLogicalBlockMark(struct us_data *us, WORD phyblk,
WORD mark);
extern int MS_LibSetInitialErrorBlock(struct us_data *us, WORD phyblk);
extern int MS_LibScanLogicalBlockNumber(struct us_data *us, WORD phyblk);
extern int MS_LibAllocWriteBuf(struct us_data *us);
void MS_LibClearWriteBuf(struct us_data *us);
void MS_LibPhy2LogRange(WORD PhyBlock, WORD *LogStart,
WORD *LogEnde);
extern int MS_LibReadExtra(struct us_data *us, DWORD PhyBlock,
BYTE PageNum, MS_LibTypeExtdat *ExtraDat);
extern int MS_LibReadExtraBlock(struct us_data *us, DWORD PhyBlock,
BYTE PageNum, BYTE blen, void *buf);
extern int MS_LibSetAcquiredErrorBlock(struct us_data *us, WORD phyblk);
extern int MS_LibErasePhyBlock(struct us_data *us, WORD phyblk);
extern int MS_LibErrorPhyBlock(struct us_data *us, WORD phyblk);
extern int MS_LibOverwriteExtra(struct us_data *us, DWORD PhyBlockAddr,
BYTE PageNum, BYTE OverwriteFlag);
extern int MS_LibSetLogicalPair(struct us_data *us,
WORD logblk, WORD phyblk);
extern int MS_LibCheckDisableBlock(struct us_data *us, WORD PhyBlock);
extern int MS_CountFreeBlock(struct us_data *us, WORD PhyBlock);
extern int MS_LibSearchBlockFromLogical(struct us_data *us, WORD logblk);
extern int MS_LibSearchBlockFromPhysical(struct us_data *us, WORD phyblk);
#endif

View file

@ -75,7 +75,6 @@ static int eucr_resume(struct usb_interface *iface)
us->Power_IsResum = true;
//
//us->SD_Status.Ready = 0; //??
us->MS_Status = *(PMS_STATUS)&tmp;
us->SM_Status = *(PSM_STATUS)&tmp;
return 0;
@ -98,7 +97,6 @@ static int eucr_reset_resume(struct usb_interface *iface)
us->Power_IsResum = true;
//
//us->SD_Status.Ready = 0; //??
us->MS_Status = *(PMS_STATUS)&tmp;
us->SM_Status = *(PSM_STATUS)&tmp;
return 0;
}

View file

@ -10,7 +10,6 @@
#include <linux/mutex.h>
#include <scsi/scsi_host.h>
#include "common.h"
#include "ms.h"
struct us_data;
struct scsi_cmnd;
@ -201,7 +200,7 @@ struct us_data {
//----- MS Control Data ----------------
BOOLEAN MS_SWWP;
DWORD MSP_TotalBlock;
MS_LibControl MS_Lib;
/* MS_LibControl MS_Lib; */
BOOLEAN MS_IsRWPage;
WORD MS_Model;