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

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

?? sysgei82543end.c

?? vxworks嵌入式開(kāi)發(fā)vmware bsp包 其中已包括網(wǎng)卡的驅(qū)動(dòng) 本人試過(guò) 非常好用
?? C
?? 第 1 頁(yè) / 共 4 頁(yè)
字號(hào):
     * actually reflects a system physical memory back to the system memory      * address. The sysBusToLocal here in this driver is NOT used for mapping      * PCI device's memory (e.g. PCI device's control/status registers)      * to the host address space.       */      pBoard->sysLocalToBus = NULL;     /* for 1:1 mapping */     pBoard->sysBusToLocal = NULL;     /* for 1:1 mapping */     /* specify the interrupt connect/disconnect routines to be used */    pBoard->intConnect    = (FUNCPTR) pciIntConnect;    pBoard->intDisConnect = (FUNCPTR) pciIntDisconnect;    /* get the ICW1 and ICW2 stored in EEPROM */    pBoard->eeprom_icw1   = pReso->eeprom_icw1;    pBoard->eeprom_icw2   = pReso->eeprom_icw2;    /* copy Ether address */    memcpy (&pBoard->enetAddr[0], &(pReso->enetAddr[0]),             ETHER_ADDRESS_SIZE);    /* we finish adaptor initialization */    pReso->iniStatus = OK;    /* enable adaptor interrupt */    sysIntEnablePIC (pRsrc->irq);    return (OK);    }/*************************************************************************** sysGei82546DynaTimerSetup - setup device internal timer value dynamically* * This routine will be called every 2 seconds by default if GEI_END_SET_TIMER* flag is set. The available timers to adjust include RDTR(unit of ns), * RADV(unit of us), and ITR(unit of 256ns). Based on CPU's and/or tasks' * usuage on system, user can tune the device's performace dynamically. * This routine would be called in the tNetTask context, and is only * available for 82540/82545/82546 MACs. Any timer value greater than* 0xffff won't be used to change corresponding timer register.** RETURNS: TRUE if timer value should change, or FALSE */LOCAL BOOL sysGei82546DynaTimerSetup     (    ADAPTOR_INFO * pBoard     /* board information for the GEI driver */    )    {    /* user's specific code to decide what value should be used.     * For example, depending on      * 1: CPU usuage on system and/or,     * 2: specific application task's usuage and/or,     * 3: RX/TX packet processing per second, and/or      * 4: RX/TX interrupt counter per second, and/or     * 5: RX packet processing for each calling gei82543RxTxIntHandle(),     * users can choose optimal timer values from a predefined table to      * reduce interrupt rates. The statistic of 3,4,and 5 items above      * may be obtained from pBoard->devDrvStat.      *     * NOTE:     * ITR:  Interrupt throttling register (unit of 256ns)      *       inter-interupt delay between chip's interrupts        *     * RADV: receive interrupt absolute delay timer register (unit of 1.024us)      *       a RX interrupt will absolutely occur at this defined value      *       after the first packet is received.       *     * RDTR: receive delay timer register (unit of 1.024us)     *       a RX interrupt will occur if device has not received a subsequent     *       packet within this defined value.     */        /* value > 0xffff would not be used for corresponding timer registers */    /* pBoard->devTimerUpdate.rdtrVal = 0xffffffff; /@ unit of 1.024ns */    /* pBoard->devTimerUpdate.radvVal = 0xffffffff; /@ unit of 1.024us */    /* pBoard->devTimerUpdate.itrVal  = 0xffffffff; /@ unit of 256 ns */    /* pBoard->devTimerUpdate.watchDogIntVal = 2;   /@ 2 second default */      /* retuen TRUE; */    return FALSE;    }/*************************************************************************** sysGei82546InitTimerSetup - initially setup device internal timer value* * The device's internal timers include RDTR(unit of ns), * RADV(unit of us), and ITR(unit of 256ns). The function is * called before device starts up, and it is only available for * 82540/82545/82546 MACs. Any timer value greater than 0xffff will * be discarded.** RETURNS: TRUE if timer value should change, or FALSE */LOCAL BOOL sysGei82546InitTimerSetup     (    ADAPTOR_INFO * pBoard     /* board information for the GEI driver */    )     {    /* value > 0xffff would not change corresponding timer registers */    /* pBoard->devTimerUpdate.rdtrVal = 0xffffffff; /@ unit of 1.024ns */    /* pBoard->devTimerUpdate.radvVal = 0xffffffff; /@ unit of 1.024us */    /* pBoard->devTimerUpdate.itrVal  = 0xffffffff; /@ unit of 256 ns  */    /* pBoard->devTimerUpdate.watchDogIntVal = 2;   /@ 2 second default */    /* return TRUE; */    return FALSE;    }/*************************************************************************** sys543eepromReadBits - read bits from EEPROM** This routine reads bit data from EEPROM** RETURNS: value in WORD size*/LOCAL UINT16 sys543eepromReadBits    (    int      unit,    int      bitsNum    )    {    int      count;    UINT32   ix;    UINT16   val = 0;    UINT16   reqBit = 0;    PCI_BOARD_RESOURCE * pRsrc;    pRsrc = &geiPciResources[unit];    if (pRsrc->boardType == PRO1000_546_BOARD)        reqBit = EECD_REQ_BIT;            for (ix = 0; ix < bitsNum; ix++)        {        /* raise the clk */         GEI_SYS_WRITE_REG(unit, INTEL_82543GC_EECD,                                 (EECD_CS_BIT | EECD_SK_BIT | reqBit));        /* wait 2000ns */        for (count = 0; count < 3; count++)             sysDelay ();        val = ( val << 1) |           ((GEI_SYS_READ_REG(unit, INTEL_82543GC_EECD) & EECD_DO_BIT)? 1 : 0);        /* lower the clk */        GEI_SYS_WRITE_REG(unit, INTEL_82543GC_EECD, (EECD_CS_BIT | reqBit));        /* wait 2000 ns */        for (count = 0; count < 3; count++)             sysDelay ();           }          return (val);    }/*************************************************************************** sys543eepromWriteBits - write bits out to EEPROM** This routine writes bits out to EEPROM** RETURNS: N/A*/LOCAL void sys543eepromWriteBits    (    int          unit,    UINT16       value,    UINT16       bitNum    )    {    int             count;    volatile UINT16 data;    UINT16          reqBit = 0;    PCI_BOARD_RESOURCE * pRsrc;    pRsrc = &geiPciResources[unit];    if (pRsrc->boardType == PRO1000_546_BOARD)        reqBit = EECD_REQ_BIT;            if (bitNum == 0)        return;    while (bitNum--)        {        data = (value & (0x1 << bitNum )) ? EECD_DI_BIT : 0;        data |=  EECD_CS_BIT;        /* write the data */        GEI_SYS_WRITE_REG(unit, INTEL_82543GC_EECD, (data | reqBit));            /* wait 1000ns */        for (count = 0; count < 2; count++)            sysDelay ();            /* raise the clk */         GEI_SYS_WRITE_REG(unit, INTEL_82543GC_EECD, (data | EECD_SK_BIT | reqBit));        /* wait 1000ns */        for (count = 0; count < 2; count++)            sysDelay ();        /* lower the clk */        GEI_SYS_WRITE_REG(unit, INTEL_82543GC_EECD, (data | reqBit));        /* wait 1000ns */        for (count = 0; count < 2; count++)            sysDelay ();           }    }/*************************************************************************** sys543eepromReadWord - Read a word from EEPROM** RETURNS: value in WORD size*/LOCAL UINT16 sys543eepromReadWord    (    int     unit,    UINT32  index    )    {    int     count;    UINT16  val;    UINT32  tmp;    PCI_BOARD_RESOURCE * pRsrc;    pRsrc = &geiPciResources[unit];       if (pRsrc->boardType == PRO1000_546_BOARD)      {      int  ix = 0;       BOOL accessGet = FALSE;      tmp = GEI_SYS_READ_REG(unit, INTEL_82543GC_EECD);      tmp |= EECD_REQ_BIT;     /* request EEPROM access */      GEI_SYS_WRITE_REG(unit, INTEL_82543GC_EECD, tmp);      do {         /* wait 2us */         for (count = 0; count < 3; count++)              sysDelay ();         if ((tmp = GEI_SYS_READ_REG(unit, INTEL_82543GC_EECD)) & EECD_GNT_BIT)	     {             accessGet = TRUE;             break;             }         } while (ix++ < 500000);      if (!accessGet) 	{	/* timeout in a second */        printf ("ERROR: timeout to grant access to gei unit %d EEPROM\n", unit);        return 0;        }      }    if (index >= geiResources[(unit)].eepromSize)        {        printf ("ERROR: gei unit %d Invalid index %d to EEPROM\n", unit, index);        return 0;        }    tmp = GEI_SYS_READ_REG(unit, INTEL_82543GC_EECD);    GEI_SYS_WRITE_REG(unit, INTEL_82543GC_EECD, EECD_CS_BIT);    /* wait 1000ns */    for (count = 0; count < 2; count++)         sysDelay ();    /* write the opcode out */    sys543eepromWriteBits (unit, EEPROM_READ_OPCODE, EEPROM_CMD_BITS);    /* write the index out */    if (geiResources[(unit)].eepromSize == 64)        sys543eepromWriteBits (unit, index, 6);    else if (geiResources[(unit)].eepromSize == 256)        sys543eepromWriteBits (unit, index, 8);     else /* unsupported, but still try 64 words */        {        sys543eepromWriteBits (unit, index, 6);        printf ("ERROR: gei unit %d unsupported EEPROM size\n", unit);       }    GEI_SYS_READ_REG(unit, INTEL_82543GC_EECD);        /* read the data */    val = sys543eepromReadBits (unit, EEPROM_DATA_BITS);    /* clean up access to EEPROM */          if (pRsrc->boardType == PRO1000_546_BOARD)       tmp &= ~(EECD_DI_BIT | EECD_DO_BIT | EECD_CS_BIT | EECD_REQ_BIT);    else       tmp &= ~(EECD_DI_BIT | EECD_DO_BIT | EECD_CS_BIT);    GEI_SYS_WRITE_REG(unit, INTEL_82543GC_EECD, tmp);    return val;    }/*************************************************************************** sys543EtherAdrGet - Get Ethernet address from EEPROM** This routine get an Ethernet address from EEPROM** RETURNS: OK or ERROR*/LOCAL STATUS sys543EtherAdrGet    (    int    unit    )    {    UINT32 ix;    UINT32 count = 0;    UINT16 val;    UCHAR  adr [ETHER_ADDRESS_SIZE];    GEI_RESOURCE * pReso = (GEI_RESOURCE *)(geiPciResources[unit].pExtended);    for (ix = 0; ix < ETHER_ADDRESS_SIZE / sizeof(UINT16); ix++)         {        /* get word i from EEPROM */        val = sys543eepromReadWord (unit, (UINT16)(EEPROM_IA_ADDRESS + ix));        adr [count++] = (UCHAR)val;        adr [count++] = (UCHAR) (val >> 8);        }    memcpy (&(pReso->enetAddr[0]), adr, ETHER_ADDRESS_SIZE);    /* check IA is UCAST  */

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久黄色| 国产福利91精品一区二区三区| 亚洲欧美视频在线观看| 国产精品福利av| 国产精品久久夜| 中文字幕一区二区三区在线播放 | av在线这里只有精品| 成人永久aaa| 91蜜桃在线免费视频| 91久久精品国产91性色tv| 欧美午夜电影一区| 欧美三级日韩三级| 欧美一级欧美三级| 欧美精品一区二| 国产精品国产馆在线真实露脸 | 久久精品国产一区二区三区免费看 | 午夜精品久久久久久久99水蜜桃| 亚洲bt欧美bt精品| 蜜臀久久久久久久| 九九九久久久精品| 成人免费观看av| 91福利在线看| 欧美一级片免费看| 国产欧美日韩中文久久| 亚洲欧美综合网| 三级久久三级久久久| 精品夜夜嗨av一区二区三区| 国产高清不卡二三区| 色综合久久久久网| 欧美一区二视频| 国产亚洲精品福利| 亚洲一区精品在线| 久久99热99| 欧美日韩午夜影院| 亚洲女厕所小便bbb| 一区二区三区中文在线| 五月婷婷久久综合| 精品一二三四区| 99国产精品久久久久久久久久 | 精品国产人成亚洲区| 中文字幕欧美区| 亚洲国产精品天堂| 国精品**一区二区三区在线蜜桃| aaa国产一区| 欧美一区二区三区啪啪| 国产清纯在线一区二区www| 亚洲自拍另类综合| 国产一区二区三区在线观看免费| 99热99精品| 日韩欧美成人激情| 日韩毛片一二三区| 精品一二三四区| 色999日韩国产欧美一区二区| 日韩一区二区视频在线观看| 综合久久久久综合| 精品亚洲国内自在自线福利| 91蜜桃视频在线| 久久人人爽人人爽| 日韩影院免费视频| 91免费视频网| 国产丝袜在线精品| 免费看欧美美女黄的网站| 91丨九色丨黑人外教| 日韩久久久精品| 亚洲国产欧美日韩另类综合| 国产aⅴ精品一区二区三区色成熟| 欧美麻豆精品久久久久久| 中文字幕亚洲不卡| 美女视频一区二区| 欧美三级在线播放| 亚洲日穴在线视频| 国产成a人无v码亚洲福利| 91超碰这里只有精品国产| 亚洲天堂av一区| 成人一区二区三区| 久久久夜色精品亚洲| 麻豆精品在线播放| 欧美日韩国产小视频在线观看| 国产精品免费视频观看| 国产一区欧美一区| 日韩视频在线一区二区| 视频一区中文字幕| 欧美天天综合网| 一区二区欧美在线观看| 91在线国产观看| 成人欧美一区二区三区1314| 国产美女精品一区二区三区| 日韩视频免费直播| 日本欧美在线观看| 91麻豆精品久久久久蜜臀| 亚洲综合在线观看视频| 一本到不卡精品视频在线观看| 中文字幕精品在线不卡| 极品少妇xxxx精品少妇偷拍| 91精品国产高清一区二区三区| 亚洲一二三四区不卡| 在线日韩av片| 亚洲影视在线播放| 欧美性生活久久| 亚洲va国产天堂va久久en| 日本韩国欧美在线| 亚洲一区二区三区精品在线| 欧美伊人久久久久久久久影院| 亚洲男人的天堂在线观看| 色欧美日韩亚洲| 亚洲小说欧美激情另类| 欧美日韩在线播| 日韩高清欧美激情| 欧美不卡一二三| 国产精品一区二区无线| 国产精品无遮挡| 99re这里都是精品| 尤物在线观看一区| 欧美视频完全免费看| 日韩中文字幕91| 精品成人免费观看| 成人午夜视频在线观看| 成人欧美一区二区三区小说| 色成人在线视频| 亚洲高清不卡在线观看| 91精品久久久久久久久99蜜臂| 日产欧产美韩系列久久99| 久久综合九色综合97婷婷| 成人午夜免费电影| 亚洲制服丝袜一区| 日韩一二三区视频| 夫妻av一区二区| 一区二区三区四区蜜桃| 日韩亚洲欧美在线| 高清成人免费视频| 亚洲香肠在线观看| 欧美精品一区二区三区蜜桃视频| 国产成人在线观看免费网站| 亚洲三级免费观看| 日韩一区二区三区观看| 国产成人午夜片在线观看高清观看| 国产精品国产三级国产有无不卡 | 亚洲精品一区二区在线观看| 国产91精品一区二区麻豆网站| 亚洲美女偷拍久久| 91精品国产综合久久婷婷香蕉| 国产成a人亚洲精品| 亚洲图片一区二区| 国产性天天综合网| 欧美系列一区二区| 国产精品996| 五月婷婷久久丁香| 中文字幕欧美国产| 91精品国产免费| 99精品视频一区二区| 青青草91视频| 一区精品在线播放| 日韩免费视频一区二区| 91啦中文在线观看| 精品一二三四在线| 亚洲午夜av在线| 国产精品丝袜在线| 日韩午夜电影av| 在线观看国产一区二区| 国产一区在线精品| 丝袜亚洲另类欧美综合| 国产精品免费av| 日韩免费一区二区| 欧美日韩亚洲综合在线| 国产91精品精华液一区二区三区| 日韩精品1区2区3区| 亚洲免费成人av| 日本一区二区三区四区| 欧美一区二区三区性视频| 91视频.com| 成人免费视频一区| 国内精品伊人久久久久av影院 | 久久国产麻豆精品| 亚洲国产日产av| 亚洲视频一二区| 国产亚洲精品aa| 欧美成人国产一区二区| 欧美亚洲综合在线| 91丨国产丨九色丨pron| 国产精品一区二区在线播放 | 国产精品羞羞答答xxdd | 欧美日韩另类一区| 成人的网站免费观看| 国产在线一区二区综合免费视频| 午夜精品视频一区| 一区二区三区日韩欧美| 亚洲天天做日日做天天谢日日欢| 久久老女人爱爱| 精品日韩欧美在线| 日韩女优av电影在线观看| 5858s免费视频成人| 欧美精品在线观看播放| 欧美艳星brazzers| 在线视频一区二区免费| 日本高清无吗v一区| 91极品美女在线| 色婷婷综合久久久久中文| 色综合久久久网| 色视频欧美一区二区三区| 93久久精品日日躁夜夜躁欧美|