亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? oem.h

?? intel xscale pxa270的完整wince4.2 BSP包
?? H
字號:
/*****************************************************************************
*Filename: OEM.H - Defines, structures and prototypes for platform specific
*                     
* SanDisk Host Developer's Toolkit
*
* Copyright (c) 1997-2000 SanDisk Corporation
* All rights reserved.
* This code may not be redistributed in source or linkable object form
* without the consent of its author.
*
* Description: 
*       OEM function implementation.
*
****************************************************************************/

#ifndef __SDOEM__


#ifdef __cplusplus
extern "C" {
#endif


#include "sdtypes.h"
#include "sdconfig.h"


/* Function Prototype implementation for PLATFORM specific. */

/* These routines are system specific and implemented by the developers.
**
** The macros below allow the run-time driver to invoke the system
** specific codes.
**/

/****************************************************************************/
/*************************** DEPENDENT CODE *********************************/
/****************************************************************************/
/* These routines are system specific.  Mostly OEM dependent codes */


/****************************************************************************/
/****************************** I/O Access **********************************/
/****************************************************************************/

#if (USE_MEMMODE)
#else
UINT16 inpbyte(UINT32 addr);
SDVOID outpbyte(UINT32 addr, UINT16 dat);

#if (WORD_ACCESS_ONLY)
UINT16 inpword(UINT32 addr);
SDVOID outpword(UINT32 addr, UINT16 dat);
#endif
#endif /* (USE_MEMMODE) */



/*****************************************************************************
** These routines:
**      platform_critical_handler,
**      platform_report_error
** are in criterr.c and report.c and needed to be ported to the specific platform.
*****************************************************************************/


/**************************** Critical Error ********************************/
/* Critical error handler routine is in criterr.c */
/* Interaction between users and the HDTK. */
INT16 platform_critical_handler(INT16 drv, INT16 errno, ULONG sector);
#define CRITICAL_HANDLER(drv, errno, sector)  (platform_critical_handler(drv, errno, sector))


/***************************** Error Report *********************************/
/* platform_report_error routine is in report.c */
/* Report the error to user */
SDVOID platform_report_error(INT16 err);
#define REPORT_ERROR(err)       (platform_report_error(err))



/*****************************************************************************
/********************************* Timer ************************************/
/*****************************************************************************
** These routines:
**      platform_delayms
**      platform_get_ticks,
**      platform_ticks_per_second,
**      oem_getsysdate
** are in timer.c and needed to be ported for to the specific platform.
*****************************************************************************/
SDVOID platform_delayms(COUNT tdelay);    /* Time to delay in milisecond */
ULONG platform_get_ticks(SDVOID);         /* Get the current tick */
ULONG platform_ticks_p_second(SDVOID);    /* Ticks per second */


/* These macros are to run the system specific code at run-time.
** The macros are used by the FILE SYSTEM and the INTERFACE drivers.
*/
#define OS_WAIT(tdelay)         (platform_delayms(tdelay))
#define OS_GET_TICKS()          (platform_get_ticks())
#define OS_TICKS_P_SECOND()     (platform_ticks_p_second())


#if (USE_FILE_SYSTEM)
#if (RTFS_WRITE)
/* oem_getsysdate() in timer.c */
SDVOID oem_getsysdate(UINT16 *tdate, UINT16 *ttime);
#endif
#endif  /* USE_FILE_SYSTEM */



#if (USE_INTERRUPTS)

/*****************************************************************************
** These routines:
**      platform_controller_init,
**      platform_controller_close,
**      platform_clear_signal,
**      platform_set_signal,
**      platform_wait_for_action
** are in interupt.c and needed to be ported to the specific platform.
** These routines are for the interrupt implementation.
**
** The OS_XX_XX macros are for the FILE SYSTEM and INTERFACE drivers.
*****************************************************************************/


/*********************** IDE & PCMCIA interrupts ***************************/
SDVOID platform_controller_init(INT16 controller_no);
SDVOID platform_controller_close(INT16 controller_no);
SDVOID platform_clear_signal(INT16 controller_no);
SDVOID platform_set_signal(INT16 controller_no);
SDBOOL platform_wait_for_action(INT16 controller_no, COUNT time_out);

#define OS_CONTROLLER_INIT(controller_no)  (platform_controller_init(controller_no))
#define OS_CONTROLLER_CLOSE(controller_no) (platform_controller_close(controller_no))
#define OS_CLEAR_SIGNAL(controller_no)     (platform_clear_signal(controller_no))
#define OS_SET_SIGNAL(controller_no)       (platform_set_signal(controller_no))
#define OS_WAIT_FOR_ACTION(controller_no, time_out)  (platform_wait_for_action(controller_no, time_out))

#else   

#define OS_CONTROLLER_INIT(controller_no)
#define OS_CONTROLLER_CLOSE(controller_no)
#define OS_CLEAR_SIGNAL(controller_no)
#define OS_SET_SIGNAL(controller_no)
#define OS_WAIT_FOR_ACTION(controller_no, time_out) YES

#endif  /* USE_INTERRUPTS */

/*****************************************************************************
**************************** OEM related topics ******************************
******************************************************************************/


/**************************** SPI DRIVER SECTION *****************************/

#if (USE_SPI || USE_SPI_EMULATION)

SDVOID MMCSelectController(INT16 ctrlNo, INT16 cardno);

/* Intialize SPI hardware */
SDVOID spi_hw_init(INT16 controllerno);

/* Enable Chip Select */
SDVOID spi_cs_enable(INT16 driveno);

/* Disable Chip Select */
SDVOID spi_cs_disable(INT16 driveno);

#if (USE_SET_FEATURES)
UINT16 calculateDataCRC16 ( UCHAR *pdata, UINT16 data_length );
UINT16 checkResponseCRC ( UCHAR *response, UINT16 offset, UINT16 response_length );
UINT16 appendCmdCRC ( UCHAR *cmd_bytes, UINT16 cmd_length );
#else

#endif /* (!USE_SET_FEATURES) */

MMC_CC MMCStartTransfer(SDVOID);
MMC_CC MMCStopTransfer(SDVOID);

UINT16 calculateCmdCRC(UINT32 Args, UINT16 cmdIndex);
SDVOID startMMC80Clocks(INT16 ctrlno);
SDVOID mmcSendCommand(UINT32 cmd_arg, UINT16 cmd_index, UINT16 crcCMD);
MMC_CC getMMCResponseInfo(UINT16 *respBuff, UINT16 respType);
MMC_CC MMCPrepareAndSetup(UINT32 Arg, UINT16 Cmd, UINT16 noBlocks, UINT16 Resp);
/* MMC_CC checkCardBusy(INT16 ctrlno); */
SDBOOL checkCardBusy(UINT16 inData);
MMC_CC MMCTransmit(UCHAR *buffer, UINT16 dataLength, UINT16 noBLocks, UINT16 xferMode);
MMC_CC MMCReceive(UCHAR *buffer, UINT16 dataLength, UINT16 noBLocks, UINT16 xferMode);
SDVOID resetMMCController(UINT16 ctrlno);
SDBOOL setMMCClockRate(UINT16 ClockRate);

#if (USE_SPI && !USE_MEMMODE)
extern SDVOID setupMMcHostDataRegister(UINT16 cmdIndex, UINT16 *cmdDatContReg, UINT16 *noBlocks, UINT16 *blkLength);
#endif

#endif  /* (USE_SPI || USE_SPI_EMULATION) */


/**************************** MMC DRIVER SECTION ******************************/

#if (USE_MMC || USE_MMC_EMULATION)

UINT16 calculateDataCRC16 ( UCHAR *pdata, UINT16 data_length );
UINT16 checkResponseCRC ( UCHAR *response, UINT16 offset, UINT16 response_length );
UINT16 appendCmdCRC ( UCHAR *cmd_bytes, UINT16 cmd_length );
UINT16 calculateCmdCRC(UINT32 Args, UINT16 cmdIndex);

SDVOID MMCSelectController(INT16 ctrlNo, INT16 cardno);
SDVOID mmc_hw_init(INT16 ctrlno);
SDVOID startMMC80Clocks(INT16 ctrlno);
MMC_CC MMCPrepareAndSetup(UINT32 Arg, UINT16 Cmd, UINT16 noBlocks, UINT16 Resp);
MMC_CC getMMCResponseInfo(UCHAR *respBuff, UINT16 respLength, UINT16 respType);
MMC_CC MMCTransmit(UCHAR *buffer, UINT16 dataLength, UINT16 noBLocks, UINT16 xferMode);
MMC_CC MMCReceive(UCHAR *buffer, UINT16 dataLength, UINT16 noBLocks, UINT16 xferMode);
UINT16 getMMCStatus(SDVOID);
/* MMC_CC checkCardBusy( INT16 controller_no ); */
SDBOOL checkCardBusy(UINT16 inData);
SDVOID resetMMCController(UINT16 ctrlno);
SDVOID startMMCClock(SDVOID);
SDBOOL stopMMCClock(SDVOID);
SDBOOL setMMCClockRate(UINT16 ClockRate);

#endif /* (USE_MMC || USE_MMC_EMULATION) */

/* Static checking for device present */
SDBOOL is_device_changed (INT16 driveno);
INT16  get_extended_error(INT16 driveno);


/************************* END of DEPENDENT CODE ****************************/


#ifdef __cplusplus
}
#endif


#define __SDOEM__

#endif /* __SDOEM__ */



?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
极品少妇一区二区三区精品视频| 一区二区三国产精华液| 国产一区二区在线观看免费| 欧美大片免费久久精品三p | 亚洲免费av高清| 欧美亚洲一区三区| 麻豆精品久久久| 国产精品美女一区二区| 一本色道综合亚洲| 日韩av中文字幕一区二区三区| 日韩色视频在线观看| 国产精品香蕉一区二区三区| 中文字幕一区在线观看视频| 欧美午夜精品一区| 精品一区二区三区在线观看国产| 国产精品少妇自拍| 欧美日韩在线播放三区四区| 国产原创一区二区三区| 亚洲欧美一区二区三区久本道91| 欧美另类高清zo欧美| 国产麻豆视频精品| 亚洲自拍偷拍av| 久久久国产精品午夜一区ai换脸| 色狠狠桃花综合| 国产综合久久久久久久久久久久| 亚洲欧美一区二区三区国产精品| 欧美电视剧在线观看完整版| 不卡一区二区中文字幕| 免费看欧美女人艹b| 国产精品乱人伦中文| 6080国产精品一区二区| www.亚洲精品| 日韩av电影天堂| 亚洲伦理在线免费看| 国产亚洲综合在线| 欧美日韩黄色一区二区| 国产91丝袜在线播放| 三级不卡在线观看| 亚洲精品乱码久久久久| 久久精品欧美一区二区三区不卡| 欧美日精品一区视频| 99国产欧美另类久久久精品 | 26uuu精品一区二区在线观看| 色先锋资源久久综合| 国产成人一级电影| 青草国产精品久久久久久| 亚洲视频网在线直播| 久久先锋影音av鲁色资源网| 欧美日韩国产综合一区二区三区| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 在线免费亚洲电影| 国产成人免费网站| 国精品**一区二区三区在线蜜桃| 亚洲国产成人av好男人在线观看| 综合婷婷亚洲小说| 国产日本一区二区| 欧美成人三级电影在线| 欧美日韩一卡二卡| 色综合欧美在线| 99精品久久久久久| eeuss鲁片一区二区三区在线看| 国产一区二区h| 韩国成人在线视频| 国内精品久久久久影院色| 久久精品国产秦先生| 日本不卡在线视频| 午夜av一区二区三区| 一区二区三区中文字幕精品精品| 国产精品久久久久久久久晋中| 久久免费的精品国产v∧| 欧美xxxxx牲另类人与| 精品嫩草影院久久| 久久免费精品国产久精品久久久久| 日韩欧美色综合网站| 精品久久久久久久久久久久久久久| 欧美夫妻性生活| 欧美一区二区在线不卡| 日韩精品专区在线| 精品久久久久99| 国产欧美精品国产国产专区| 国产精品久久久一本精品| 国产精品久久久一本精品| 亚洲视频在线观看三级| 亚洲一区视频在线| 日韩中文字幕亚洲一区二区va在线| 午夜精品免费在线观看| 青青草国产成人99久久| 国产麻豆精品久久一二三| 成人综合在线观看| 91福利资源站| 欧美一区二区三区免费观看视频 | 精品成人a区在线观看| 2024国产精品视频| 国产精品初高中害羞小美女文| 亚洲日本在线视频观看| 亚洲1区2区3区4区| 久草在线在线精品观看| 国产成人午夜视频| 91理论电影在线观看| 欧美日韩视频一区二区| 精品噜噜噜噜久久久久久久久试看| 久久久精品人体av艺术| 亚洲欧美一区二区三区极速播放 | 亚洲最新在线观看| 毛片基地黄久久久久久天堂| 国产成人av电影在线播放| 99久久精品国产观看| 在线播放欧美女士性生活| 国产性色一区二区| 亚洲国产精品一区二区久久 | 制服视频三区第一页精品| 久久久久久久久久久久久女国产乱| 日韩一区中文字幕| 日韩成人一区二区| 9l国产精品久久久久麻豆| 欧美人体做爰大胆视频| 日本一区二区三区视频视频| 亚洲国产日产av| 国产suv精品一区二区6| 欧美日本国产视频| 中文在线一区二区| 青青草原综合久久大伊人精品优势 | 欧美日韩电影一区| 久久蜜桃一区二区| 水野朝阳av一区二区三区| 成人免费福利片| 精品国产伦一区二区三区观看体验| 综合久久给合久久狠狠狠97色| 免费在线一区观看| 91久久精品一区二区| 久久婷婷国产综合精品青草 | 亚洲同性gay激情无套| 韩国av一区二区三区在线观看| 在线观看国产精品网站| 亚洲欧洲性图库| 国产激情一区二区三区| 69久久99精品久久久久婷婷| 亚洲激情校园春色| 国产69精品久久久久777| 这里是久久伊人| 亚洲国产一区在线观看| 99久久精品免费看| 国产亚洲成年网址在线观看| 免费看欧美女人艹b| 欧美三级资源在线| 亚洲欧美区自拍先锋| 成人禁用看黄a在线| 久久精品夜夜夜夜久久| 久久精品国产亚洲一区二区三区| 欧美日韩在线播放三区| 亚洲综合在线第一页| 99久久99久久精品国产片果冻| 国产日韩精品一区二区三区| 激情文学综合丁香| 337p日本欧洲亚洲大胆精品| 美女脱光内衣内裤视频久久网站| 777久久久精品| 视频在线观看国产精品| 欧美日韩高清一区二区不卡 | 精品久久久久香蕉网| 免费不卡在线观看| 日韩欧美aaaaaa| 青青草国产成人99久久| 日韩精品在线网站| 国产在线视频不卡二| 亚洲精品一线二线三线| 精品一区二区在线播放| www久久精品| 成人永久aaa| 亚洲欧美日韩国产中文在线| 日本丶国产丶欧美色综合| 亚洲一区av在线| 在线播放视频一区| 蜜桃一区二区三区在线观看| 精品少妇一区二区| 国产精品一二一区| 国产精品毛片无遮挡高清| 色婷婷av一区二区三区软件| 亚洲一区二区三区四区五区中文| 欧美性色aⅴ视频一区日韩精品| 午夜精品久久久久久不卡8050| 欧美精品丝袜中出| 麻豆成人在线观看| 国产网红主播福利一区二区| av一区二区三区在线| 夜夜嗨av一区二区三区中文字幕| 欧美人牲a欧美精品| 精品一区二区三区视频| 国产精品理论片| 欧美日韩国产片| 国产一区在线观看视频| 亚洲私人影院在线观看| 7777精品伊人久久久大香线蕉 | 另类小说色综合网站| 中文字幕精品综合| 欧美日韩精品一区二区三区蜜桃| 蜜臀av性久久久久蜜臀av麻豆| 中文在线一区二区| 欧美日韩小视频| 成人性生交大片免费|