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

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

?? cssysend.c

?? VxWorks系統CS網卡END驅動(源碼).zip
?? C
?? 第 1 頁 / 共 2 頁
字號:
*
* sysEnetHWInit - configure the adapter for board-specific IO and media support
*
* This routine uses global variables in the CS_END_DEVICE structure to configure the 
* adapter for the board-specific IO circuitry and media types supported.
*        
* RETURNS: Nothing
*         
*/

LOCAL void sysEnetHWInit( CS_END_DEVICE *pCS )
{
   USHORT BusCtl;
   USHORT SelfCtl;
   IOADDR DataPort;
   IOADDR AddrPort;

   DataPort=pCS->IOAddr + PORT_PKTPG_DATA;
   AddrPort=pCS->IOAddr + PORT_PKTPG_PTR;

   /* If memory mode is enabled */
   if ( pCS->ConfigFlags & CFGFLG_MEM_MODE )
   {
      /* If external logic is present for address decoding */
      if ( csReadPacketPage(pCS,PKTPG_SELF_ST) & SELF_ST_EL_PRES )
      {
         /* Program the external logic to decode address bits SA20-SA23 */
         csWritePacketPage( pCS, PKTPG_EEPROM_CMD,
               ((UINT)(pCS->pPacketPage)>>20) | EEPROM_CMD_ELSEL );
      }

      /* Setup chip for memory mode */
      csWritePacketPage( pCS, PKTPG_MEM_BASE, (UINT)(pCS->pPacketPage)&0xFFFF );
      csWritePacketPage( pCS, PKTPG_MEM_BASE+2, (UINT)(pCS->pPacketPage)>>16 );
      BusCtl = BUS_CTL_MEM_MODE;
      if ( pCS->ConfigFlags & CFGFLG_USE_SA )
         BusCtl |= BUS_CTL_USE_SA;
      csWritePacketPage( pCS, PKTPG_BUS_CTL, BusCtl );

      /* We are in memory mode now! */
      pCS->InMemoryMode = TRUE;
   }

   /* If IOCHRDY is enabled then clear the bit in the BusCtl register */
   BusCtl = csReadPacketPage( pCS, PKTPG_BUS_CTL );
   if ( pCS->ConfigFlags & CFGFLG_IOCHRDY )
      csWritePacketPage( pCS, PKTPG_BUS_CTL, BusCtl & ~BUS_CTL_IOCHRDY );
   else
      csWritePacketPage( pCS, PKTPG_BUS_CTL, BusCtl | BUS_CTL_IOCHRDY );

   /* Set the Line Control register to match the media type */
   if ( pCS->MediaType == MEDIA_10BASET )
      csWritePacketPage( pCS, PKTPG_LINE_CTL, LINE_CTL_10BASET );
   else
      csWritePacketPage( pCS, PKTPG_LINE_CTL, LINE_CTL_AUI_ONLY );

   /* Set the BSTATUS/HC1 pin to be used as HC1 */
   /* HC1 is used to enable the DC/DC converter */
   SelfCtl = SELF_CTL_HC1E;

   /* If the media type is 10Base2 */
   if ( pCS->MediaType == MEDIA_10BASE2 )
   {
      /* Enable the DC/DC converter */
      /* If the DC/DC converter has a low enable */
      if ( (pCS->ConfigFlags & CFGFLG_DCDC_POL) == 0 )
         /* Set the HCB1 bit, which causes the HC1 pin to go low */
         SelfCtl |= SELF_CTL_HCB1;
   }
   else  /* Media type is 10BaseT or AUI */
   {
      /* Disable the DC/DC converter */
      /* If the DC/DC converter has a high enable */
      if ( (pCS->ConfigFlags & CFGFLG_DCDC_POL) != 0 )
         /* Set the HCB1 bit, which causes the HC1 pin to go low */
         SelfCtl |= SELF_CTL_HCB1;
   }
   csWritePacketPage( pCS, PKTPG_SELF_CTL, SelfCtl );

   /* If media type is 10BaseT */
   if ( pCS->MediaType == MEDIA_10BASET )
   {
      /* If full duplex mode then set the FDX bit in TestCtl register */
      if ( pCS->ConfigFlags & CFGFLG_FDX )
         csWritePacketPage( pCS, PKTPG_TEST_CTL, TEST_CTL_FDX );
   }
 
}



/******************************************************************************
*
* sysEnetIntEnable - enable CS8900 interrupts at the system level
*
* This routine enables the interrupt used by the CS8900 at the system level.  
* For the i386/i486 BSPs, this is done by making the system call 
* sysIntEnablePIC to enable the CS8900's interrupt at the 8259 PIC.
*
* RETURNS: OK or ERROR
*/

LOCAL STATUS sysEnetIntEnable( CS_END_DEVICE *pCS )
{
#if CPU_FAMILY == ARM
	/* For ARM user:
	   Please make sure how to enable your ARM interrupt for CS8900. */
   /* Enable interrupt at the Interrupt Controller */
   int_enable(INT_GPIO68); /* turn on the GPIO IRQ bit*/
#else
   /* Enable interrupt at the 8259 PIC */
   if ( sysIntEnablePIC(pCS->IntLevel) == ERROR )
   {
      return ERROR;
   }
#endif

   return OK;
}


/******************************************************************************
*
* sysEnetIntDisable - disable CS8900 interrupts at the system level
*
* This routine disables the interrupt used by the CS8900 at the system level.  
* For the i386/i486 BSPs, this is done by making the system call 
* sysIntDisablePIC to disable the CS8900's interrupt at the 8259 PIC.
*
* NOTE: This routine is not currently required by the CS8900 driver.
*
* RETURNS: OK or ERROR
*/

LOCAL STATUS sysEnetIntDisable( CS_END_DEVICE *pCS )
{
   
#if CPU_FAMILY == ARM
	/* For ARM user:
	   Please make sure how to disable your ARM interrupt for CS8900.*/
   /* disable interrupt at the Interrupt Controller */
   int_disable(INT_GPIO68); /* turn off the GPIO IRQ bit*/
#else
   if ( sysIntDisablePIC(pCS->IntLevel) == ERROR )
   {
      return ERROR;
   }
#endif

   return OK;
}

void   INT_UNLOCK(int lockKey)
{
#if CPU_FAMILY ==  ARM
/* For ARM User:
   Please modify these two functions to fit your board.*/
   int_enable(INT_GPIO68); /*turn on the GPIO IRQ bit*/
#else
     intUnlock(lockKey);
#endif
}


int    INT_LOCK(void)
{
#if CPU_FAMILY ==  ARM
/* For ARM User:
   Please modify these two functions to fit your board.*/
   int_disable(INT_GPIO68); /* turn off the GPIO IRQ bit*/
    return 0;
#else
   return intLock();
#endif
}


/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ *
 * Support routines for the above board-specific routines                      *
 * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */


/*******************************************************************************
*
* csGetUnspecifiedParms
*
*
*/

LOCAL STATUS csGetUnspecifiedParms( CS_END_DEVICE *pCS )
{
   USHORT SelfStatus;
   USHORT ISAConfig;
   USHORT MemBase;
   USHORT AdapterConfig;
   USHORT XmitCtl;

   /* If all of these parameters were specified */
   if ( pCS->ConfigFlags!=0 && pCS->pPacketPage!=NULL && pCS->IntLevel!=0 &&
         pCS->MediaType!=0 )
      return OK;  /* Don't need to get anything from the EEPROM */

   /* Verify that the EEPROM is present and OK */
   SelfStatus = csReadPacketPage( pCS, PKTPG_SELF_ST );
   if ( !((SelfStatus & SELF_ST_EEP_PRES) && (SelfStatus & SELF_ST_EEP_OK)) )
   {
      LOGMSG("\ncs0 - EEPROM is missing or bad\n",0,0,0,0,0,0);
      return ERROR;
   }

   /* Get ISA configuration from the EEPROM */
   if ( csReadEEPROM(pCS,EEPROM_ISA_CFG,&ISAConfig) == ERROR )
      return ERROR;

   /* Get adapter configuration from the EEPROM */
   if ( csReadEEPROM(pCS,EEPROM_ADPTR_CFG,&AdapterConfig) == ERROR )
      return ERROR;

   /* Get transmission control from the EEPROM */
   if ( csReadEEPROM(pCS,EEPROM_XMIT_CTL,&XmitCtl) == ERROR )
      return ERROR;

   /* If the configuration flags were not specified */
   if ( pCS->ConfigFlags == 0 )
   {
      /* Copy the memory mode flag */
      if ( ISAConfig & ISA_CFG_MEM_MODE )
         pCS->ConfigFlags |= CFGFLG_MEM_MODE;

      /* Copy the USE_SA flag */
      if ( ISAConfig & ISA_CFG_USE_SA )
         pCS->ConfigFlags |= CFGFLG_USE_SA;

      /* Copy the IO Channel Ready flag */
      if ( ISAConfig & ISA_CFG_IOCHRDY )
         pCS->ConfigFlags |= CFGFLG_IOCHRDY;

      /* Copy the DC/DC Polarity flag */
      if ( AdapterConfig & ADPTR_CFG_DCDC_POL )
         pCS->ConfigFlags |= CFGFLG_DCDC_POL;

      /* Copy the Full Duplex flag */
      if ( XmitCtl & XMIT_CTL_FDX )
         pCS->ConfigFlags |= CFGFLG_FDX;
   }

   /* If the PacketPage pointer was not specified */
   if ( pCS->pPacketPage == NULL )
   {
      /* If memory mode is enabled */
      if ( pCS->ConfigFlags & CFGFLG_MEM_MODE )
      {
         /* Get the memory base address from EEPROM */
         if ( csReadEEPROM(pCS,EEPROM_MEM_BASE,&MemBase) == ERROR )
            return ERROR;

         MemBase &= MEM_BASE_MASK;  /* Clear unused bits */

         /* Setup the PacketPage pointer */
         pCS->pPacketPage = (unsigned short *)(((ULONG)MemBase)<<8);
      }
   }

   /* If the interrupt level was not specified */
   if ( pCS->IntLevel == 0 )
   {
      /* Get the interrupt level from the ISA config */
      pCS->IntLevel = ISAConfig & ISA_CFG_IRQ_MASK;
      if ( pCS->IntLevel == 3 )
         pCS->IntLevel = 5;
      else
         pCS->IntLevel += 10;
   }

   /* If the media type was not specified */
   if ( pCS->MediaType == 0 )
   {
      switch( AdapterConfig & ADPTR_CFG_MEDIA )
      {
         case ADPTR_CFG_AUI:
            pCS->MediaType = MEDIA_AUI;
            break;
         case ADPTR_CFG_10BASE2:
            pCS->MediaType = MEDIA_10BASE2;
            break;
         case ADPTR_CFG_10BASET:
         default:
            pCS->MediaType = MEDIA_10BASET;
            break;
      }
   }

   return OK;
}


/*******************************************************************************
*
* csValidateParms
*
* This routine verifies that the memory address, interrupt level and media
* type are valid.  If any of these parameters are invalid, then and error
* message is printed and ERROR is returned.
*
*/

LOCAL STATUS csValidateParms( CS_END_DEVICE *pCS )
{
   int MemAddr;

   MemAddr = (int)(pCS->pPacketPage);

   if ( (MemAddr & 0x000FFF) != 0 )
   {
      LOGMSG("\ncs0 - Memory address (0x%X) must start on a 4K boundry\n",
            MemAddr,0,0,0,0,0);
      return ERROR;
   }

#if CPU_FAMILY != ARM
   if ( MemAddr > 0xFFF000 )
   {
      LOGMSG("\ncs0 - Memory address (0x%X) is too large\n", MemAddr,0,0,0,0,0 );
      return ERROR;
   }

   if ( !(pCS->IntLevel==5 || pCS->IntLevel==10 || pCS->IntLevel==11 ||
         pCS->IntLevel==12) )
   {
      LOGMSG("\ncs0 - Interrupt level (%d) is invalid\n", pCS->IntLevel,0,0,0,0,0 );
      return ERROR;
   }
#endif

   if ( !(pCS->MediaType==MEDIA_AUI || pCS->MediaType==MEDIA_10BASE2 ||
         pCS->MediaType==MEDIA_10BASET) )
   {
      LOGMSG("\ncs0 - Media type (%d) is invalid\n", pCS->MediaType,0,0,0,0,0);
      return ERROR;
   }

   return OK;
}




/*******************************************************************************
*
* csReadEEPROM
*
* This routine reads a word from the EEPROM at the specified offset.
*
*/

LOCAL STATUS csReadEEPROM( CS_END_DEVICE *pCS, USHORT Offset, USHORT *pValue )
{
   int x;

   /* Ensure that the EEPROM is not busy */
   for ( x=0; x < MAXLOOP; x++ )
      if ( !(csReadPacketPage(pCS,PKTPG_SELF_ST)&SELF_ST_SI_BUSY) )
         break;
   if ( x == MAXLOOP )
   {
      LOGMSG("\ncs0 - Can not read from EEPROM\n",0,0,0,0,0,0);
      return ERROR;
   }

   /* Issue the command to read the offset within the EEPROM */
   csWritePacketPage( pCS, PKTPG_EEPROM_CMD, Offset | EEPROM_CMD_READ );

   /* Wait until the command is completed */
   for ( x=0; x<MAXLOOP; x++ )
      if ( !(csReadPacketPage(pCS,PKTPG_SELF_ST)&SELF_ST_SI_BUSY) )
         break;
   if ( x == MAXLOOP )
   {
      LOGMSG("\ncs0 - Can not read from EEPROM\n",0,0,0,0,0,0);
      return ERROR;
   }

   /* Get the EEPROM data from the EEPROM Data register */
   *pValue = csReadPacketPage( pCS, PKTPG_EEPROM_DATA );

   return OK;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区在线视频| 91免费观看视频| 亚洲成av人片www| 亚洲午夜国产一区99re久久| 亚洲免费观看高清完整版在线| 亚洲国产电影在线观看| 国产午夜精品理论片a级大结局| 亚洲精品一线二线三线| 精品久久久久av影院| 久久伊人中文字幕| 国产精品午夜在线| 亚洲人123区| 日韩影视精彩在线| 久久精品国产精品亚洲红杏 | 亚洲欧美一区二区三区孕妇| 国产精品久久久久7777按摩 | 亚洲午夜久久久久久久久电影院| 夜夜爽夜夜爽精品视频| 亚洲成在线观看| 极品销魂美女一区二区三区| 国产成人综合视频| 在线一区二区三区四区五区| 欧美午夜精品久久久久久孕妇 | 欧美电影免费观看高清完整版在| 久久久久久99精品| 亚洲视频中文字幕| 日本伊人午夜精品| 成人污视频在线观看| 欧美午夜免费电影| 国产亚洲人成网站| 亚洲国产aⅴ天堂久久| 久久国产精品第一页| 成人自拍视频在线| 欧美片在线播放| 国产精品久久久久影视| 美腿丝袜亚洲综合| 99精品国产热久久91蜜凸| 91精品国产一区二区| 中文字幕日本不卡| 精品综合久久久久久8888| 一本到不卡精品视频在线观看| 日韩视频在线你懂得| 亚洲视频免费在线观看| 日本vs亚洲vs韩国一区三区二区 | 91丨porny丨户外露出| 51午夜精品国产| 综合久久久久久久| 狠狠色丁香久久婷婷综合丁香| 一本大道久久a久久综合| 欧美大片一区二区| 午夜视频在线观看一区二区| 不卡的看片网站| 久久久美女毛片| 久久99蜜桃精品| 欧美日韩国产乱码电影| 国产精品美女久久久久久2018 | 中文字幕欧美日韩一区| 首页国产欧美久久| 欧美中文字幕久久| 亚洲人精品午夜| www.日韩大片| 中国av一区二区三区| 国产一区二区看久久| 欧美一级欧美三级| 久久精品国产99久久6| 欧美欧美欧美欧美| 日韩一区欧美二区| 欧美疯狂性受xxxxx喷水图片| 亚洲精品第1页| 色哟哟亚洲精品| 一区二区三区欧美日韩| 日本久久电影网| 亚洲精品免费在线| 日本高清成人免费播放| 亚洲欧美国产毛片在线| 91小视频免费观看| 一级女性全黄久久生活片免费| 色综合天天综合| 亚洲午夜国产一区99re久久| 欧美日韩视频不卡| 日韩—二三区免费观看av| 911精品产国品一二三产区| 秋霞午夜鲁丝一区二区老狼| 91精品国产一区二区三区香蕉| 久久国产婷婷国产香蕉| 久久女同性恋中文字幕| 成人性视频免费网站| 国产精品视频免费| 色狠狠色狠狠综合| 日日摸夜夜添夜夜添精品视频 | 亚洲国产日韩a在线播放性色| 91欧美激情一区二区三区成人| 亚洲乱码中文字幕| 8x8x8国产精品| 国产精品一二三在| 亚洲色图在线视频| 欧美视频在线一区| 老汉av免费一区二区三区| 国产嫩草影院久久久久| 欧美中文字幕不卡| 久久精品999| 日韩理论电影院| 欧美一区二区精品在线| 成人性生交大合| 亚洲国产精品一区二区www在线| 欧美一区二区三区视频在线| 国产成人精品免费在线| 一区二区成人在线视频| 久久综合久久综合久久综合| 91老师片黄在线观看| 久久精品国产网站| 一区二区三区免费看视频| 日韩欧美国产综合| 色综合久久88色综合天天免费| 秋霞午夜av一区二区三区| 国产精品毛片大码女人| 欧美美女一区二区| thepron国产精品| 久久精品999| 午夜激情综合网| 国产精品九色蝌蚪自拍| 欧美成人福利视频| 欧美系列一区二区| 99久久婷婷国产精品综合| 麻豆精品一区二区三区| 亚洲欧美一区二区三区孕妇| 久久丝袜美腿综合| 欧美一级xxx| 在线综合亚洲欧美在线视频| 99久久国产免费看| 国产精品一级在线| 美国十次了思思久久精品导航| 亚洲男人天堂一区| 国产精品国产成人国产三级| 精品欧美一区二区久久| 欧美精品精品一区| 欧美影视一区在线| 91日韩精品一区| 成人黄色免费短视频| 国产精品一区二区在线观看网站 | www久久久久| 7777女厕盗摄久久久| 欧美吞精做爰啪啪高潮| 一本一本大道香蕉久在线精品| 国产99久久久久久免费看农村| 极品少妇xxxx精品少妇偷拍| 男女性色大片免费观看一区二区| 亚洲v中文字幕| 天天色综合天天| 性感美女久久精品| 天堂一区二区在线| 日本在线播放一区二区三区| 热久久国产精品| 久久激情五月激情| 国产麻豆精品视频| 成人性生交大片免费看中文网站| 国产精选一区二区三区| 国产成人精品免费| a亚洲天堂av| 色婷婷激情久久| 欧美日韩精品一区二区三区四区| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 色婷婷综合中文久久一本| 色老汉一区二区三区| 欧美性生活一区| 91麻豆精品91久久久久同性| 日韩欧美综合在线| 国产人伦精品一区二区| 国产精品久久久一本精品| 亚洲一二三四区| 秋霞午夜av一区二区三区| 国产成人在线电影| 色天使久久综合网天天| 制服丝袜激情欧洲亚洲| 欧美精品一区二区三区久久久| 国产欧美精品日韩区二区麻豆天美 | 国产99久久久国产精品潘金| 成人免费视频一区| 欧美亚洲动漫精品| 欧美成人性福生活免费看| 国产精品美日韩| 日韩成人av影视| av在线播放不卡| 欧美一区二区视频免费观看| 国产午夜精品一区二区| 一区二区三区视频在线看| 国产在线视频一区二区三区| 不卡一区二区中文字幕| 欧美人成免费网站| 亚洲丝袜美腿综合| 精品一区二区三区免费播放 | 在线不卡中文字幕播放| 国产亚洲人成网站| 五月天国产精品| 欧美电影免费观看高清完整版 | 国产乱码精品1区2区3区| 国产成人在线免费观看| 欧美亚洲丝袜传媒另类| 亚洲精品一区二区三区在线观看| 国产精品乱人伦中文|