summaryrefslogblamecommitdiffstats
path: root/drivers/staging/keucr/smil.h
blob: 4226813ba588f46fb5086d7baadbb2852e1080f4 (plain) (tree)
1
                                                                        





































































































































































                                                                                                     





                          



                          





                          



               



                                                             
  
 

                        




                                                             


               

                                                             




















































































                                                                                                                                    
/*----- < smil.h> ----------------------------------------------------*/
#ifndef SMIL_INCD
#define SMIL_INCD

/***************************************************************************
Define Definition
***************************************************************************/
#define K_BYTE              1024   /* Kilo Byte */
#define SECTSIZE            512    /* Sector buffer size */
#define REDTSIZE            16     /* Redundant buffer size */

/***************************************************************************/
#define DUMMY_DATA          0xFF   /* No Assign Sector Read Data */

/***************************************************************************
Max Zone/Block/Sectors Data Definition
***************************************************************************/
#define MAX_ZONENUM         128    /* Max Zone Numbers in a SmartMedia    */
#define MAX_BLOCKNUM        0x0400 /* Max Block Numbers in a Zone         */
#define MAX_SECTNUM         0x20   /* Max Sector Numbers in a Block       */
#define MAX_LOGBLOCK        1000   /* Max Logical Block Numbers in a Zone */

/***************************************************************************/
#define CIS_SEARCH_SECT     0x08   /* Max CIS Search Sector Number */

/***************************************************************************
Logical to Physical Block Table Data Definition
***************************************************************************/
#define NO_ASSIGN           0xFFFF /* No Assign Logical Block Address */

/***************************************************************************
'SectCopyMode' Data
***************************************************************************/
#define COMPLETED           0      /* Sector Copy Completed */
#define REQ_ERASE           1      /* Request Read Block Erase */
#define REQ_FAIL            2      /* Request Read Block Failed */

/***************************************************************************
Retry Counter Definition
***************************************************************************/
#define RDERR_REASSIGN      1      /* Reassign with Read Error */
#define L2P_ERR_ERASE       1      /* BlockErase for Contradicted L2P Table */

/***************************************************************************
Hardware ECC Definition
***************************************************************************/
#define HW_ECC_SUPPORTED    1      /* Hardware ECC Supported */  /* No difinition for Software ECC */

/***************************************************************************
SmartMedia Command & Status Definition
***************************************************************************/
/* SmartMedia Command */
#define WRDATA        0x80
//#define READ          0x00
#define READ_REDT     0x50
//#define WRITE         0x10
#define RDSTATUS      0x70

#define READ1         0x00 //NO
#define READ2         0x01 //NO
#define READ3         0x50 //NO
#define RST_CHIP      0xFF
#define ERASE1        0x60
#define ERASE2        0xD0
#define READ_ID_1     0x90
#define READ_ID_2     0x91
#define READ_ID_3     0x9A

/* 712 SmartMedia Command */
#define SM_CMD_RESET                0x00    // 0xFF
#define SM_CMD_READ_ID_1            0x10    // 0x90
#define SM_CMD_READ_ID_2            0x20    // 0x91
#define SM_CMD_READ_STAT            0x30    // 0x70
#define SM_CMD_RDMULTPL_STAT        0x40    // 0x71
#define SM_CMD_READ_1               0x50    // 0x00
#define SM_CMD_READ_2               0x60    // 0x01
#define SM_CMD_READ_3               0x70    // 0x50
#define SM_CMD_PAGPRGM_TRUE         0x80    // {0x80, 0x10}
#define SM_CMD_PAGPRGM_DUMY         0x90    // {0x80, 0x11}
#define SM_CMD_PAGPRGM_MBLK         0xA0    // {0x80, 0x15}
#define SM_CMD_BLKERASE             0xB0    // {0x60, 0xD0}
#define SM_CMD_BLKERASE_MULTPL      0xC0    // {0x60-0x60, 0xD0}

#define SM_CRADDTCT_DEBNCETIMER_EN  0x02
#define SM_CMD_START_BIT            0x01

#define SM_WaitCmdDone { while (!SM_CmdDone); }
#define SM_WaitDmaDone { while (!SM_DmaDone); }

// SmartMedia Status
#define WR_FAIL       0x01      // 0:Pass, 1:Fail
#define SUSPENDED     0x20      // 0:Not Suspended, 1:Suspended
#define READY         0x40      // 0:Busy, 1:Ready
#define WR_PRTCT      0x80      // 0:Protect, 1:Not Protect

// SmartMedia Busy Time (1bit:0.1ms)
#define BUSY_PROG     200       // tPROG   : 20ms  ----- Program Time          old : 200
#define BUSY_ERASE    4000      // tBERASE : 400ms ----- Block Erase Time      old : 4000
//for 712 Test
//#define BUSY_READ     1         // tR      : 100us ----- Data transfer Time   old : 1
//#define BUSY_READ     10         // tR      : 100us ----- Data transfer Time   old : 1
#define BUSY_READ     200       // tR      : 20ms   ----- Data transfer Time   old : 1
//#define BUSY_RESET    60        // tRST    : 6ms   ----- Device Resetting Time old : 60
#define BUSY_RESET    600        // tRST    : 60ms   ----- Device Resetting Time old : 60

// Hardware Timer (1bit:0.1ms)
#define TIME_PON      3000      // 300ms ------ Power On Wait Time
#define TIME_CDCHK    200       // 20ms  ------ Card Check Interval Timer
#define TIME_WPCHK    50        // 5ms   ------ WP Check Interval Timer
#define TIME_5VCHK    10        // 1ms   ------ 5V Check Interval Timer

/***************************************************************************
Redundant Data
***************************************************************************/
#define REDT_DATA     0x04
#define REDT_BLOCK    0x05
#define REDT_ADDR1H   0x06
#define REDT_ADDR1L   0x07
#define REDT_ADDR2H   0x0B
#define REDT_ADDR2L   0x0C
#define REDT_ECC10    0x0D
#define REDT_ECC11    0x0E
#define REDT_ECC12    0x0F
#define REDT_ECC20    0x08
#define REDT_ECC21    0x09
#define REDT_ECC22    0x0A

/***************************************************************************
SmartMedia Model & Attribute
***************************************************************************/
/* SmartMedia Attribute */
#define NOWP          0x00 // 0... .... No Write Protect
#define WP            0x80 // 1... .... Write Protected
#define MASK          0x00 // .00. .... NAND MASK ROM Model
#define FLASH         0x20 // .01. .... NAND Flash ROM Model
#define AD3CYC        0x00 // ...0 .... Address 3-cycle
#define AD4CYC        0x10 // ...1 .... Address 4-cycle
#define BS16          0x00 // .... 00.. 16page/block
#define BS32          0x04 // .... 01.. 32page/block
#define PS256         0x00 // .... ..00 256byte/page
#define PS512         0x01 // .... ..01 512byte/page
#define MWP           0x80 // WriteProtect mask
#define MFLASH        0x60 // Flash Rom mask
#define MADC          0x10 // Address Cycle
#define MBS           0x0C // BlockSize mask
#define MPS           0x03 // PageSize mask

/* SmartMedia Model */
#define NOSSFDC       0x00 // NO   SmartMedia
#define SSFDC1MB      0x01 // 1MB  SmartMedia
#define SSFDC2MB      0x02 // 2MB  SmartMedia
#define SSFDC4MB      0x03 // 4MB  SmartMedia
#define SSFDC8MB      0x04 // 8MB  SmartMedia
#define SSFDC16MB     0x05 // 16MB SmartMedia
#define SSFDC32MB     0x06 // 32MB SmartMedia
#define SSFDC64MB     0x07 // 64MB SmartMedia
#define SSFDC128MB    0x08 //128MB SmartMedia
#define SSFDC256MB    0x09
#define SSFDC512MB    0x0A
#define SSFDC1GB      0x0B
#define SSFDC2GB      0x0C

/***************************************************************************
Struct Definition
***************************************************************************/
struct SSFDCTYPE
{
	BYTE Model;
	BYTE Attribute;
	BYTE MaxZones;
	BYTE MaxSectors;
	WORD MaxBlocks;
	WORD MaxLogBlocks;
};

typedef struct SSFDCTYPE_T
{
	BYTE Model;
	BYTE Attribute;
	BYTE MaxZones;
	BYTE MaxSectors;
	WORD MaxBlocks;
	WORD MaxLogBlocks;
} *SSFDCTYPE_T;

struct ADDRESS
{
	BYTE Zone;	/* Zone Number */
	BYTE Sector;	/* Sector(512byte) Number on Block */
	WORD PhyBlock;	/* Physical Block Number on Zone */
	WORD LogBlock;	/* Logical Block Number of Zone */
};

typedef struct ADDRESS_T
{
	BYTE Zone;	/* Zone Number */
	BYTE Sector;	/* Sector(512byte) Number on Block */
	WORD PhyBlock;	/* Physical Block Number on Zone */
	WORD LogBlock;	/* Logical Block Number of Zone */
} *ADDRESS_T;

struct CIS_AREA
{
	BYTE Sector;	/* Sector(512byte) Number on Block */
	WORD PhyBlock;	/* Physical Block Number on Zone 0 */
};


//----- SMILMain.c ---------------------------------------------------
/******************************************/
int         Init_D_SmartMedia           (void);
int         Pwoff_D_SmartMedia          (void);
int         Check_D_SmartMedia          (void);
int         Check_D_Parameter           (struct us_data *,WORD *,BYTE *,BYTE *);
int         Media_D_ReadSector          (struct us_data *,DWORD,WORD,BYTE *);
int         Media_D_WriteSector         (struct us_data *,DWORD,WORD,BYTE *);
int         Media_D_CopySector          (struct us_data *,DWORD,WORD,BYTE *);
int         Media_D_EraseBlock          (struct us_data *,DWORD,WORD);
int         Media_D_EraseAll            (struct us_data *);
/******************************************/
int         Media_D_OneSectWriteStart   (struct us_data *,DWORD,BYTE *);
int         Media_D_OneSectWriteNext    (struct us_data *,BYTE *);
int         Media_D_OneSectWriteFlush   (struct us_data *);

/******************************************/
void        SM_EnableLED                (struct us_data *,BOOLEAN);
void        Led_D_TernOn                (void);
void        Led_D_TernOff               (void);

int         Media_D_EraseAllRedtData    (DWORD Index, BOOLEAN CheckBlock);
//DWORD       Media_D_GetMediaInfo        (struct us_data * fdoExt, PIOCTL_MEDIA_INFO_IN pParamIn, PIOCTL_MEDIA_INFO_OUT pParamOut);

//----- SMILSub.c ----------------------------------------------------
/******************************************/
int  Check_D_DataBlank            (BYTE *);
int  Check_D_FailBlock            (BYTE *);
int  Check_D_DataStatus           (BYTE *);
int  Load_D_LogBlockAddr          (BYTE *);
void Clr_D_RedundantData          (BYTE *);
void Set_D_LogBlockAddr           (BYTE *);
void Set_D_FailBlock              (BYTE *);
void Set_D_DataStaus              (BYTE *);

/******************************************/
void Ssfdc_D_Reset                (struct us_data *);
int  Ssfdc_D_ReadCisSect          (struct us_data *, BYTE *,BYTE *);
void Ssfdc_D_WriteRedtMode        (void);
void Ssfdc_D_ReadID               (BYTE *, BYTE);
int  Ssfdc_D_ReadSect             (struct us_data *, BYTE *,BYTE *);
int  Ssfdc_D_ReadBlock            (struct us_data *, WORD, BYTE *,BYTE *);
int  Ssfdc_D_WriteSect            (struct us_data *, BYTE *,BYTE *);
int  Ssfdc_D_WriteBlock           (struct us_data *, WORD, BYTE *,BYTE *);
int  Ssfdc_D_CopyBlock            (struct us_data *, WORD, BYTE *,BYTE *);
int  Ssfdc_D_WriteSectForCopy     (struct us_data *, BYTE *,BYTE *);
int  Ssfdc_D_EraseBlock           (struct us_data *);
int  Ssfdc_D_ReadRedtData         (struct us_data *, BYTE *);
int  Ssfdc_D_WriteRedtData        (struct us_data *, BYTE *);
int  Ssfdc_D_CheckStatus          (void);
int  Set_D_SsfdcModel             (BYTE);
void Cnt_D_Reset                  (void);
int  Cnt_D_PowerOn                (void);
void Cnt_D_PowerOff               (void);
void Cnt_D_LedOn                  (void);
void Cnt_D_LedOff                 (void);
int  Check_D_CntPower             (void);
int  Check_D_CardExist            (void);
int  Check_D_CardStsChg           (void);
int  Check_D_SsfdcWP              (void);
int  SM_ReadBlock                 (struct us_data *, BYTE *,BYTE *);

int  Ssfdc_D_ReadSect_DMA         (struct us_data *, BYTE *,BYTE *);
int  Ssfdc_D_ReadSect_PIO         (struct us_data *, BYTE *,BYTE *);
int  Ssfdc_D_WriteSect_DMA        (struct us_data *, BYTE *,BYTE *);
int  Ssfdc_D_WriteSect_PIO        (struct us_data *, BYTE *,BYTE *);

/******************************************/
int  Check_D_ReadError            (BYTE *);
int  Check_D_Correct              (BYTE *,BYTE *);
int  Check_D_CISdata              (BYTE *,BYTE *);
void Set_D_RightECC               (BYTE *);

//----- SMILECC.c ----------------------------------------------------
void calculate_ecc                (BYTE *, BYTE *, BYTE *, BYTE *, BYTE *);
BYTE correct_data                 (BYTE *, BYTE *, BYTE,   BYTE,   BYTE);
int  _Correct_D_SwECC             (BYTE *,BYTE *,BYTE *);
void _Calculate_D_SwECC           (BYTE *,BYTE *);

void SM_Init        (void);

#endif // already included