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

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

?? cssysend.c

?? CS8900的Vxworks驅動源代碼 1.0
?? C
?? 第 1 頁 / 共 2 頁
字號:
*
* 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
   /* For generic processor */
   /*  intEnable(pCS->IntLevel); */

   /* 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
   /* For generic processor */
   /*  intDisable(pCS->IntLevel); */

   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)) )
   {
#ifdef CS_DEBUG_ENABLE
      logMsg("\ncs0 - EEPROM is missing or bad\n",0,0,0,0,0,0);
#endif
      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 CPU_FAMILY == I80X86
   /* 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;
   }
#endif

   /* 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 )
   {
#ifdef CS_DEBUG_ENABLE
      logMsg("\ncs0 - Memory address (0x%X) must start on a 4K boundry\n",
            MemAddr,0,0,0,0,0);
#endif
      return ERROR;
   }

#if CPU_FAMILY == I80X86
   if ( MemAddr > 0xFFF000 )
   {
#ifdef CS_DEBUG_ENABLE
      logMsg("\ncs0 - Memory address (0x%X) is too large\n", MemAddr,0,0,0,0,0 );
#endif
      return ERROR;
   }

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

   if ( !(pCS->MediaType==MEDIA_AUI || pCS->MediaType==MEDIA_10BASE2 ||
         pCS->MediaType==MEDIA_10BASET) )
   {
#ifdef CS_DEBUG_ENABLE
      logMsg("\ncs0 - Media type (%d) is invalid\n", pCS->MediaType,0,0,0,0,0);
#endif
      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 )
   {
#ifdef CS_DEBUG_ENABLE
      logMsg("\ncs0 - Can not read from EEPROM\n",0,0,0,0,0,0);
#endif
      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 )
   {
#ifdef CS_DEBUG_ENABLE
      logMsg("\ncs0 - Can not read from EEPROM\n",0,0,0,0,0,0);
#endif
      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影院在线免费观看| 日韩电影免费在线| 洋洋成人永久网站入口| 国产亚洲一区二区三区在线观看| 4438x成人网最大色成网站| 在线亚洲一区二区| 色哟哟国产精品免费观看| 不卡一区二区三区四区| 成人午夜伦理影院| 福利电影一区二区三区| 成人午夜私人影院| aaa亚洲精品| 色综合天天综合色综合av| 99国产一区二区三精品乱码| 成人99免费视频| 色综合色狠狠综合色| 在线亚洲免费视频| 制服.丝袜.亚洲.中文.综合| 91精品国产入口| 日韩片之四级片| 26uuu亚洲| 国产精品每日更新在线播放网址| 综合婷婷亚洲小说| 亚洲欧美激情在线| 夜夜揉揉日日人人青青一国产精品| 亚洲精品视频在线| 亚洲成人你懂的| 蜜桃久久久久久| 国内外精品视频| 99久久精品一区二区| 在线观看国产91| 欧美一级黄色大片| 国产日韩综合av| 亚洲精品成人在线| 看片网站欧美日韩| 波多野洁衣一区| 欧美日韩不卡在线| 久久精品视频一区二区三区| 亚洲色图一区二区| 午夜精品123| 寂寞少妇一区二区三区| 97成人超碰视| 欧美伦理视频网站| 国产视频视频一区| 依依成人精品视频| 国模娜娜一区二区三区| 91网址在线看| 日韩欧美卡一卡二| 国产精品大尺度| 日精品一区二区三区| 国产福利精品导航| 欧美精品aⅴ在线视频| 国产日韩欧美在线一区| 亚洲宅男天堂在线观看无病毒| 免费av成人在线| 97久久超碰精品国产| 日韩一区二区在线观看视频| 国产精品国产a| 男男视频亚洲欧美| 色综合久久中文综合久久97| 精品成人在线观看| 亚洲国产精品久久久男人的天堂| 国产一区二区三区最好精华液| 91蝌蚪porny| 久久久久久亚洲综合影院红桃| 亚洲午夜精品17c| 粉嫩一区二区三区性色av| 91精品久久久久久久99蜜桃 | 精品电影一区二区| 亚洲欧美色图小说| 国产主播一区二区| 91精品国产麻豆| 亚洲手机成人高清视频| 国产剧情一区二区三区| 欧美—级在线免费片| 天堂av在线一区| 色婷婷激情综合| 国产三级三级三级精品8ⅰ区| 婷婷综合久久一区二区三区| av亚洲精华国产精华| 欧美成人a∨高清免费观看| 亚洲已满18点击进入久久| 波多野结衣中文字幕一区| 精品福利一二区| 老司机一区二区| 欧美日本一区二区| 亚洲一卡二卡三卡四卡无卡久久| 成人a级免费电影| 久久精品一区二区三区av| 蜜臀av性久久久久av蜜臀妖精| 欧美天堂亚洲电影院在线播放| 中文字幕日韩一区| 成人免费看的视频| 欧美国产精品v| 国产成人综合亚洲91猫咪| 亚洲精品一区二区三区蜜桃下载| 视频一区在线视频| 欧美日韩免费不卡视频一区二区三区| 亚洲欧美另类图片小说| 播五月开心婷婷综合| 中文字幕欧美国产| 不卡av免费在线观看| 国产精品高潮呻吟| 91麻豆福利精品推荐| 亚洲人成网站色在线观看| 色一情一伦一子一伦一区| 亚洲靠逼com| 欧美在线|欧美| 亚洲一区二区三区四区的| 欧美日韩国产欧美日美国产精品| 亚洲国产裸拍裸体视频在线观看乱了 | 国产亚洲欧美激情| 国产一区二区三区不卡在线观看 | 亚洲视频狠狠干| 欧洲av一区二区嗯嗯嗯啊| 亚洲最大色网站| 欧美日韩视频第一区| 丝袜亚洲精品中文字幕一区| 337p亚洲精品色噜噜| 免费精品视频在线| 久久久精品黄色| 99久久久久久| 午夜电影一区二区| 日韩精品自拍偷拍| 国产精品一区专区| 国产精品国产三级国产普通话蜜臀 | 在线观看欧美黄色| 男人的天堂久久精品| 久久久国产精品麻豆| 91网站最新地址| 亚洲成a人片在线不卡一二三区| 91麻豆精品91久久久久久清纯| 日本欧美一区二区在线观看| 精品1区2区在线观看| 成人avav影音| 视频一区中文字幕| 久久伊人中文字幕| 97国产精品videossex| 午夜精品一区在线观看| 精品久久一区二区三区| av在线不卡网| 天天做天天摸天天爽国产一区| 精品少妇一区二区三区日产乱码 | 久久久精品免费免费| 色狠狠综合天天综合综合| 人人超碰91尤物精品国产| 中文字幕乱码日本亚洲一区二区| 色吊一区二区三区| 久久99精品久久久久| 麻豆精品国产传媒mv男同| 欧美韩国日本不卡| 精品视频1区2区| 国产成人亚洲综合a∨猫咪| 亚洲综合无码一区二区| 久久久青草青青国产亚洲免观| 色婷婷狠狠综合| 狠狠色丁香久久婷婷综合_中| 综合精品久久久| 精品欧美久久久| 91福利在线免费观看| 国产一区视频在线看| 性做久久久久久免费观看欧美| 久久精品这里都是精品| 精品视频123区在线观看| 国产精品123区| 日本中文字幕一区二区有限公司| 中文字幕va一区二区三区| 日韩欧美成人一区二区| 99国产精品久久久久| 精品一区二区三区视频| 亚洲国产sm捆绑调教视频| 欧美激情自拍偷拍| 精品国产一区二区三区不卡| 欧美吻胸吃奶大尺度电影 | 欧美精品少妇一区二区三区| 国产v综合v亚洲欧| 久久se精品一区精品二区| 亚洲一区二区视频在线观看| 日本一区二区三区dvd视频在线| 欧美日高清视频| 日本精品裸体写真集在线观看| 国产麻豆视频一区二区| 亚洲成av人片在www色猫咪| 国产欧美精品一区二区色综合 | 成人黄色av电影| 视频一区二区不卡| 亚洲欧美综合另类在线卡通| 精品美女被调教视频大全网站| 在线看国产日韩| 粉嫩在线一区二区三区视频| 首页综合国产亚洲丝袜| 亚洲一区在线观看免费 | 国产亚洲欧美中文| 日韩一区二区精品葵司在线| 日本久久一区二区三区| 国产丶欧美丶日本不卡视频| 寂寞少妇一区二区三区| 视频一区二区中文字幕| 一区二区三区中文字幕|