/**************************************************************************** * Copyright (c) 2004 Digital Stream Technologies Inc. All Rights Reserved. * * Module: dstdddev.h * Author: Jun-ku Park, hwatk@dstreamtech.com * Description: DST HAL [Device] Platform/Project Specific Header File * * notes: hwatk20040609 * * TO DO LIST * ***************************************************************************/ #ifndef __DST_DD_DEV_H__ #define __DST_DD_DEV_H__ #include "dsthaldev.h" #if defined(USE_NFLASH_FILE) #define NANDFLASH_FILE "./tmp_nflash" #endif #if defined(USE_SFLASH_FILE) #define SERIALFLASH_FILE "./tmp_sflash" #endif #define NFLASH_WRITE_SIZE_EX (0x200) #define NFLASH_WRITE_ALIGN_EX (0x200-1) #define NFLASH_ERASE_ALIGN_EX (0x20000-1) #define NFLASH_WRITE_SIZE_NORMAL_NOR (0x200) #define NFLASH_WRITE_ALIGN_NORMAL_NOR (0x200-1) #define NFLASH_ERASE_ALIGN_NORMAL_NOR (0x20000-1) #define NFLASH_WRITE_SIZE_NORMAL_NAND (0x1000) #define NFLASH_WRITE_ALIGN_NORMAL_NAND (0x1000-1) #define NFLASH_ERASE_ALIGN_NORMAL_NAND (0x10000-1) #if defined __cplusplus extern "C" { #endif /* E2PROM DST Device Driver API */ /* NAND Flash DST Device Driver API */ DHL_RESULT DD_DEV_NFLASHInit( P_DST_DEV_NFLASH pNFLASH, DS_U32 Size, DS_U32 Start, DS_U32 End ); DHL_RESULT DD_DEV_NFLASHStart( P_DST_DEV_NFLASH pNFLASH ); DHL_RESULT DD_DEV_NFLASHStop( P_DST_DEV_NFLASH pNFLASH ); DHL_RESULT DD_DEV_NFLASHClose(P_DST_DEV_NFLASH pNFLASH ); int DD_DEV_NFLASHRead(P_DST_DEV_NFLASH pNFLASH, DS_U32 Address, DS_U8 *pBuffer, DS_U32 Len ); int DD_DEV_NFLASHWrite(P_DST_DEV_NFLASH pNFLASH, DS_U32 Address, DS_U8 *pBuffer, DS_U32 Len ); DHL_RESULT DD_DEV_NFLASHErase( P_DST_DEV_NFLASH pNFLASH, DS_U32 Address, DS_U32 Len ); DHL_RESULT DD_DEV_NFLASHSetMode( P_DST_DEV_NFLASH pNFLASH, int isSpeedMode ); int DD_DEV_NFLASH_JFFS2Mount(void); DHL_RESULT DD_DEV_NFLASH_JFFS2Format(void); int DD_DEV_NFLASH_IsJFFS2Mounted(void); /* Serial Flash DST Device Driver API */ DHL_RESULT DD_DEV_SFLASHInit( P_DST_DEV_SFLASH pSFLASH, DS_U32 Size, DS_U32 Start, DS_U32 End ); DHL_RESULT DD_DEV_SFLASHStart( P_DST_DEV_SFLASH pSFLASH ); DHL_RESULT DD_DEV_SFLASHStop( P_DST_DEV_SFLASH pSFLASH ); DHL_RESULT DD_DEV_SFLASHClose(P_DST_DEV_SFLASH pSFLASH ); int DD_DEV_SFLASHRead(P_DST_DEV_SFLASH pSFLASH, DS_U32 Address, DS_U8 *pBuffer, DS_U32 Len ); int DD_DEV_SFLASHWrite(P_DST_DEV_SFLASH pSFLASH, DS_U32 Address, DS_U8 *pBuffer, DS_U32 Len ); DHL_RESULT DD_DEV_SFLASHErase( P_DST_DEV_SFLASH pSFLASH, DS_U32 Address, DS_U32 Len ); /* CAS Interface */ DHL_RESULT DD_DEV_InitSmartCard(void); DHL_RESULT DD_DEV_GetCARDStatus(DHL_DEV_CARD_STATUS *Status); DS_S32 DD_DEV_WriteCARDBlock( DS_U8 *data ); DS_S32 DD_DEV_ReadCARDBlock( DS_U8 PCB, DS_U8 *data ); DHL_RESULT DD_CA_InitMULTI2(DS_U8 *SystemKey, DS_U8 *CBC); DHL_RESULT DD_CA_ResetMULTI2(void); DHL_RESULT DD_CA_SetMULTI2Key(DS_U8 Slot, DS_U8 *EvenData, DS_U8 *OddData); DHL_RESULT DD_CA_SetMULTI2Pid(DS_U16 Pid, DS_U32 *slot, DS_BOOL enable); #if defined __cplusplus } #endif #endif /* __DST_HAL_DEV_H__ */