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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? systffs.c

?? pentium4 pc的vxworks bsp源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
LOCAL void flOutportb     (    unsigned portId,     unsigned char value    )    {    sysOutByte (portId, value);    }/********************************************************************************* get365 - read an 82365SL register** This routine read an 82365SL register** RETURNS: N/A*/LOCAL unsigned char get365    (    FLSocket vol, 		/* pointer identifying drive */    unsigned char reg		/* register index */    )    {    unsigned char value;#if DRIVES > 1    if (vol.serialNo == 1)        reg += 0x40;#endif    flStartCriticalSection (&flPcicMutex);    flOutportb (INDEX_REG,reg);    value = flInportb (DATA_REG);    flEndCriticalSection (&flPcicMutex);    return (value);    }/********************************************************************************* set365 - write an 82365SL register** This routine write an 82365SL register** RETURNS: N/A*/LOCAL void set365    (    FLSocket vol, 		/* pointer identifying drive */    unsigned char reg,		/* register index */    unsigned char value		/* value to set */    )    {#if DRIVES > 1    if (vol.serialNo == 1)        reg += 0x40;#endif    flStartCriticalSection (&flPcicMutex);    flOutportb (INDEX_REG, reg);    flOutportb (DATA_REG, value);    flEndCriticalSection (&flPcicMutex);    }/********************************************************************************* pcCardDetected - detect if a card is present (inserted)** This routine detects if a card is present (inserted).** RETURNS: TRUE, or FALSE if the card is not present.*/LOCAL FLBoolean pcCardDetected    (    FLSocket vol		/* pointer identifying drive */    )    {    return ((~get365 (&vol, INTERFACE) & 	    (CARD_DETECT_1 | CARD_DETECT_2)) == 0);    }/********************************************************************************* pcVccOn - turn on Vcc (3.3/5 Volts)** This routine turns on Vcc (3.3/5 Volts). Vcc must be known to be good * on exit.** RETURNS: N/A*/LOCAL void pcVccOn    (    FLSocket vol		/* pointer identifying drive */    )    {    unsigned char interface;    unsigned long timeout	= flMsecCounter + 2000;    set365 (&vol, POWER, get365 (&vol, POWER) | CARD_POWER_ENABLE);    do {        interface = get365 (&vol, INTERFACE);        } while (pcCardDetected (&vol) && 		 (~interface & (CARD_POWER_ACTIVE | CARD_READY)) &&	         (flMsecCounter < timeout));    }/********************************************************************************* pcVccOff - turn off Vcc (3.3/5 Volts)** This routine turns off Vcc (3.3/5 Volts).** RETURNS: N/A*/LOCAL void pcVccOff    (    FLSocket vol		/* pointer identifying drive */    )    {#if	FALSE    set365 (&vol, POWER, get365 (&vol, POWER) & ~CARD_POWER_ENABLE);#endif    }#ifdef SOCKET_12_VOLTS/********************************************************************************* pcVppOn - turn on Vpp (12 Volts)** This routine turns on Vpp (12 Volts). Vpp must be known to be good on exit.** RETURNS: flOK always*/LOCAL FLStatus pcVppOn    (    FLSocket vol		/* pointer identifying drive */    )    {    set365 (&vol, POWER, 	(get365 (&vol, POWER) & ~(VPP1_CONTROL | VPP2_CONTROL)) | VPP_ON_12V);    flDelayMsecs (VPP_DELAY_MSEC);	/* wait for Vpp to ramp up */    return (flOK);    }/********************************************************************************* pcVppOff - turn off Vpp (12 Volts)** This routine turns off Vpp (12 Volts).** RETURNS: N/A*/LOCAL void pcVppOff    (    FLSocket vol		/* pointer identifying drive */    )    {    set365 (&vol, POWER, 	    (get365(&vol, POWER) & ~(VPP1_CONTROL | VPP2_CONTROL)) | VPP_ON_5V);    }#endif	/* SOCKET_12_VOLTS *//********************************************************************************* pcInitSocket - perform all necessary initializations of the socket** This routine performs all necessary initializations of the socket.** RETURNS: flOK, or flGeneralFailure if it failed to create a mutex semaphore,*                or FALSE if the PCIC is neither STEP_A nor STEP_B.*/LOCAL FLStatus pcInitSocket    (    FLSocket vol		/* pointer identifying drive */    )    {    unsigned char identification;    /* create mutex protecting PCIC registers access */    if ((flPcicMutex == NULL) && (flCreateMutex (&flPcicMutex) != flOK))	{#ifdef DEBUG_PRINT        DEBUG_PRINT ("Debug: failed creating Mutex for PCIC.\n");#endif        return (flGeneralFailure);        }    identification = get365 (&vol, IDENTIFICATION);    if (identification != PCIC_STEP_A && identification != PCIC_STEP_B)        return (FALSE);    set365 (&vol, POWER, DISABLE_RESUME_RESETDRV | ENABLE_OUTPUTS);    set365 (&vol, INTERRUPT, 0);			/* reset */    set365 (&vol, INTERRUPT, PC_CARD_NOT_RESET);	/* enough reset */    set365 (&vol, CARD_STATUS_INTERRUPT, 0);		/* no CSC interrupt */    set365 (&vol, ADDRESS_WINDOW_ENABLE, MEMCS16_DECODE);    return (flOK);    }/********************************************************************************* pcSetWindow - set current window attributes, Base address, size, etc** This routine sets current window hardware attributes: Base address, size,* speed and bus width.  The requested settings are given in the 'vol.window' * structure.  If it is not possible to set the window size requested in* 'vol.window.size', the window size should be set to a larger value, * if possible. In any case, 'vol.window.size' should contain the * actual window size (in 4 KB units) on exit.** RETURNS: N/A*/LOCAL void pcSetWindow    (    FLSocket vol		/* pointer identifying drive */    )    {    set365 (&vol, ADDRESS_WINDOW_ENABLE,	   MEMCS16_DECODE | (MEMORY_WINDOW_0_ENABLE << WINDOW_ID));    set365 (&vol, WINDOW_0_START_LO + WINDOW_ID * 8,	   vol.window.baseAddress);    set365 (&vol, WINDOW_0_START_HI + WINDOW_ID * 8,	   vol.window.busWidth == 16 ? DATA_16_BITS : 0);    set365 (&vol, WINDOW_0_STOP_LO + WINDOW_ID * 8,	   vol.window.baseAddress + (vol.window.size / 0x1000) - 1);    set365 (&vol, WINDOW_0_STOP_HI + WINDOW_ID * 8,0);	/* no wait states */    }/********************************************************************************* pcSetMappingContext - sets the window mapping register to a card address** This routine sets the window mapping register to a card address.* The window should be set to the value of 'vol.window.currentPage',* which is the card address divided by 4 KB. An address over 128MB,* (page over 32K) specifies an attribute-space address.** The page to map is guaranteed to be on a full window-size boundary.** RETURNS: N/A*/LOCAL void pcSetMappingContext    (    FLSocket vol,		/* pointer identifying drive */    unsigned page		/* page to be mapped */    )    {    unsigned mapRegValue = page - vol.window.baseAddress;    mapRegValue &= 0x3fff;    if (page & ATTRIBUTE_SPACE_MAPPED)        mapRegValue |= (REG_ACTIVE << 8);    set365 (&vol, WINDOW_0_ADDRESS_LO + WINDOW_ID * 8, mapRegValue);    set365 (&vol, WINDOW_0_ADDRESS_HI + WINDOW_ID * 8, mapRegValue >> 8);    }/********************************************************************************* pcGetAndClearCardChangeIndicator - return the hardware card-change indicator** This routine returns the hardware card-change indicator and clears it if set.** RETURNS: FALSE, or TRUE if the card has been changed*/LOCAL FLBoolean pcGetAndClearCardChangeIndicator    (    FLSocket vol		/* pointer identifying drive */    )    {    /* Note: On the 365, the indicator is turned off by the act of reading */    return (get365 (&vol, CARD_STATUS_CHANGE) & CARD_DETECT_CHANGE);    }/********************************************************************************* pcWriteProtected - return the write-protect state of the media** This routine returns the write-protect state of the media** RETURNS: FALSE, or TRUE if the card is write-protected*/LOCAL FLBoolean pcWriteProtected    (    FLSocket vol		/* pointer identifying drive */    )    {    return ((~get365 (&vol, INTERFACE) & 	    (MEMORY_WRITE_PROTECT | CARD_DETECT_1 | CARD_DETECT_2)) == 0);    }#endif	/* INCLUDE_PCMCIA */#ifdef EXIT/********************************************************************************* pcFreeSocket - free resources that were allocated for this socket.** This routine free resources that were allocated for this socket.* This function is called when FLite exits.** RETURNS: N/A*/LOCAL void pcFreeSocket    (    FLSocket vol		/* pointer identifying drive */    )    {    flDeleteMutex (&flPcicMutex);    }#endif /* EXIT */#endif	/* defined (INCLUDE_SOCKET_PCIC0) || defined (INCLUDE_SOCKET_PCIC1) *//********************************************************************************* flFitInSocketWindow - check whether the flash array fits in the socket window** This routine checks whether the flash array fits in the socket window.** RETURNS: A chip size guaranteed to fit in the socket window.*/long int flFitInSocketWindow     (    long int chipSize,		/* size of single physical chip in bytes */    int      interleaving,	/* flash chip interleaving (1,2,4 etc) */    long int windowSize		/* socket window size in bytes */    )    {    /* x86 architectures use sliding windows for flash arrays */    /* so this check is irrelevant for them                   */    return (chipSize);    }#if	FALSE/********************************************************************************* sysTffsCpy - copy memory from one location to another** This routine copies <size> characters from the object pointed* to by <source> into the object pointed to by <destination>. If copying* takes place between objects that overlap, the behavior is undefined.** INCLUDE FILES: string.h** RETURNS: A pointer to <destination>.* * NOMANUAL*/void * sysTffsCpy    (    void *       destination,   /* destination of copy */    const void * source,        /* source of copy */    size_t       size           /* size of memory to copy */    )    {    bcopy ((char *) source, (char *) destination, (size_t) size);    return (destination);    }/********************************************************************************* sysTffsSet - set a block of memory** This routine stores <c> converted to an `unsigned char' in each of the* elements of the array of `unsigned char' beginning at <m>, with size <size>.** INCLUDE FILES: string.h** RETURNS: A pointer to <m>.* * NOMANUAL*/void * sysTffsSet    (    void * m,                   /* block of memory */    int    c,                   /* character to store */    size_t size                 /* size of memory */    )    {    bfill ((char *) m, (int) size, c);    return (m);    }#endif	/* FALSE *//********************************************************************************* flDelayMsecs - wait for specified number of milliseconds** This routine waits for specified number of milliseconds.** RETURNS: N/A* * NOMANUAL*/void flDelayMsecs    (    unsigned milliseconds       /* milliseconds to wait */    )    {    UINT32 ix;    UINT32 iy = 1;    UINT32 iz = 2;    /* it doesn't count time consumed in interrupt level */    for (ix = 0; ix < milliseconds; ix++)        for (ix = 0; ix < sysTffsMsecLoopCount; ix++)	    {	    tickGet ();			/* dummy */	    iy = KILL_TIME_FUNC;	/* consume time */	    }    }/********************************************************************************* flDelayLoop - consume the specified time** This routine consumes the specified time.** RETURNS: N/A*/void flDelayLoop     (    int  cycles    )    {    }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费成人av| 欧美一区二区女人| 中文字幕一区av| 国产a精品视频| 中文在线一区二区| 一本色道久久加勒比精品 | 老色鬼精品视频在线观看播放| 欧美日韩国产首页| 久久精品国产免费看久久精品| 久久网这里都是精品| 成人午夜视频在线| 综合久久久久久| 欧美日韩久久久一区| 欧美aⅴ一区二区三区视频| 久久一二三国产| 一本色道综合亚洲| 免费亚洲电影在线| 一区在线播放视频| 777亚洲妇女| 成人性生交大片免费看视频在线| 亚洲午夜影视影院在线观看| 欧美成人猛片aaaaaaa| av在线播放一区二区三区| 天天爽夜夜爽夜夜爽精品视频| 2021国产精品久久精品| 色综合久久久久网| 久久国产成人午夜av影院| 国产精品久久久久aaaa| 欧美一区二区精品在线| 99视频精品在线| 久久99热这里只有精品| 亚洲乱码国产乱码精品精可以看 | 久久伊99综合婷婷久久伊| 波多野结衣在线一区| 手机精品视频在线观看| 欧美韩国日本不卡| 欧美一级生活片| 不卡的av中国片| 国产在线视视频有精品| 亚洲一区二区三区四区在线免费观看 | 奇米精品一区二区三区四区 | 中文字幕永久在线不卡| 欧美一级午夜免费电影| 色av成人天堂桃色av| 处破女av一区二区| 精品一区二区三区在线观看国产 | 精品一区二区三区免费视频| 伊人开心综合网| 亚洲国产精品二十页| 欧美成人a视频| 欧美日本一区二区在线观看| 91麻豆高清视频| 成人美女视频在线观看| 国内精品第一页| 奇米影视一区二区三区小说| 一区二区三区精品| 国产精品乱人伦| 亚洲国产精品成人久久综合一区| 精品入口麻豆88视频| 91精品国产综合久久精品app| 色综合久久中文字幕| 99国产精品久久久久久久久久久| 高清av一区二区| 国产91对白在线观看九色| 激情综合色综合久久| 蜜臀av一区二区在线观看| 日韩成人精品在线观看| 视频一区国产视频| 日韩精品电影在线| 丝袜国产日韩另类美女| 午夜精品aaa| 调教+趴+乳夹+国产+精品| 视频在线观看一区| 日本不卡在线视频| 久草精品在线观看| 狠狠色丁香久久婷婷综合丁香| 久久99精品视频| 韩国理伦片一区二区三区在线播放| 美女一区二区视频| 国产自产视频一区二区三区| 国产综合久久久久影院| 国产成人在线观看免费网站| 成人一区二区三区视频 | 亚洲乱码日产精品bd| 亚洲国产综合91精品麻豆| 亚洲电影一区二区| 丝袜脚交一区二区| 精品一区二区在线免费观看| 国产成人一区在线| 成人午夜短视频| 色综合久久88色综合天天| 欧美性感一区二区三区| 56国语精品自产拍在线观看| 欧美一二三在线| 国产女人aaa级久久久级| 中文字幕日韩av资源站| 亚洲综合丁香婷婷六月香| 五月婷婷久久综合| 精品亚洲aⅴ乱码一区二区三区| 国产精品一卡二卡| 99riav一区二区三区| 欧美久久久久久久久中文字幕| 日韩精品中文字幕在线一区| 久久久精品国产免大香伊| 亚洲日本在线视频观看| 亚洲高清视频的网址| 激情深爱一区二区| 91捆绑美女网站| 日韩免费一区二区| 国产精品免费视频一区| 日韩专区中文字幕一区二区| 国产福利91精品一区| 欧美性xxxxxxxx| 国产女同互慰高潮91漫画| 亚洲第一福利视频在线| 国产精品影音先锋| 欧美性色黄大片| 国产欧美精品国产国产专区| 日韩国产欧美一区二区三区| 99国产精品国产精品毛片| 日韩一区二区三区视频在线| 亚洲欧美日韩国产成人精品影院| 美日韩一区二区| 91传媒视频在线播放| 久久精品综合网| 热久久国产精品| 在线观看免费亚洲| 日本一区二区三区在线观看| 天堂精品中文字幕在线| 91亚洲午夜精品久久久久久| 久久美女艺术照精彩视频福利播放| 亚洲高清不卡在线观看| 成人国产视频在线观看| 精品三级在线看| 日韩二区三区四区| 欧美视频一区二区三区在线观看| 国产精品不卡在线| 国产精品一线二线三线精华| 欧美精品视频www在线观看| 中文字幕在线一区免费| 国产一区二区三区国产| 91精品国产麻豆| 午夜欧美在线一二页| 色屁屁一区二区| 中文字幕一区二区三区四区不卡 | 蜜臀av性久久久久蜜臀aⅴ| 日本高清不卡一区| 国产精品美女久久久久久| 韩国午夜理伦三级不卡影院| 日韩欧美激情一区| 免费在线观看成人| 欧美一区二区三区爱爱| 日韩精品视频网| 欧美高清视频www夜色资源网| 亚洲欧美另类小说| 91一区二区三区在线观看| 日韩美女久久久| 成人动漫在线一区| 中文字幕不卡三区| bt7086福利一区国产| 国产精品美女www爽爽爽| 国产**成人网毛片九色| 国产精品污污网站在线观看| 成人综合在线观看| 亚洲天堂中文字幕| 91亚洲精品久久久蜜桃| 亚洲精品成人少妇| 欧美久久久久久蜜桃| 青青草91视频| 337p日本欧洲亚洲大胆精品| 国产成人超碰人人澡人人澡| 国产三级一区二区| 99精品热视频| 亚洲午夜激情网站| 3d动漫精品啪啪1区2区免费| 久久成人久久爱| 国产亚洲欧洲997久久综合| 国产成人免费9x9x人网站视频| 国产精品嫩草99a| 在线精品视频一区二区| 日本伊人精品一区二区三区观看方式| 日韩一区二区不卡| 国产精品一二三四区| 综合分类小说区另类春色亚洲小说欧美| 97久久精品人人爽人人爽蜜臀| 一区二区三区**美女毛片| 91精选在线观看| 韩国一区二区在线观看| 亚洲欧洲日韩综合一区二区| 欧美无砖专区一中文字| 美腿丝袜亚洲色图| 国产精品国产馆在线真实露脸| 在线视频你懂得一区| 日本网站在线观看一区二区三区| 久久久青草青青国产亚洲免观| 91美女精品福利| 日本最新不卡在线| 国产精品久久久久毛片软件| 欧美日韩一级视频| 国产精品一区二区在线观看不卡|