| /*----- < 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 |