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

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

?? hub.bak

?? RDC R2886 Ethernet hub功能 源碼,paradigm c++上運行測試
?? BAK
?? 第 1 頁 / 共 2 頁
字號:
      desc_ptr->vndesc_ptr = (desc_ptr + 1);
		desc_ptr->status = 0x8000;
      r_desc_addr += RDC_DESC_SIZE;
      r_buf_addr += BUF_SIZE;
      desc_ptr += 1;
		buf_ptr = (buf_ptr + BUF_SIZE);
   }
   (desc_ptr - 1)->ndesc_ptr = mac_ipr->rxd_raddr;
   (desc_ptr - 1)->vndesc_ptr = mac_ipr->rx_insert_ptr;
}

/* Initilize system
	Disable Watch-dog timer, Enable RCU,
	Re-fresh count, PIO, Register interrupt handler	*/
void init_system(void)
{
   outport(0xffa0, 0xC033);		/* UCS */
   outport(0xffa2, 0x7000);		/* LCS */
   outport(0xffa8, 0x8002);		/* PCS & MCS auxiliary */
   outport(0xffa4, 0x0002);		/* 08/06 Sten */
 	outport(0xfef2, SDRAM_MODE_D);	/* SDRAM mode setting */
 	outport(0xfef4, SDRAM_CTRL_D);	/* SDRAM control register */
 	outport(0xfef6, SDRAM_TIMING_D);	/* SDRAM timing register */
 	outport(0xfffa, SDRAM_DELAYL_D);	/* SDRAM delay line register */
 	outport(0xffe2, REFRESH_COUNT_D)	;/* Clock pre-scaler for re-fresh */
 	outport(0xffe4, 0x8000);		/* Enable RCU Register */
 	outport(0xffe6, 0x3333);		/* Watch-dog Timer write sequence */
 	outport(0xffe6, 0xcccc);		/* Watch-dog Timer write sequence */
 	outport(0xffe6, 0x0000);		/* Disable Watch-dog timer */
   outport(0xffea, 0x0100);

 	/* PIO mode */
 	outport(0xff76, 0x0000);
 	outport(0xff70, 0x0000);
 	/* PIO direction */
 	outport(0xff78, 0x7800);		/* PIO 27,28,29,30 input */
 	outport(0xff72, 0x0000);
   outport(0xff7e, 0x0000);
   outport(0xff6c, 0x0000);

   /* Register Interrupt 4 handler */
   setvect(INT4_TYPE, int4_handler);
   
       /* Register UART0 Interrupt handler */
   setvect(UART0_TYPE, uart0_handler);

   /* Register UART1 Interrupt handler */
   setvect(UART1_TYPE, uart1_handler);
}

   

/* Find PHY chip address
	Search from 0x00 to 0x1F				*/
int find_phy_addr(MAC_STRU * mac_ipr)
{
	uint16 tmpv;

   for (mac_ipr->phy_addr = 0; mac_ipr->phy_addr < 0x2000; mac_ipr->phy_addr += 0x0100) {
   	tmpv = mii_read(mac_ipr, 2);
      if ((tmpv != 0) && (tmpv != 0xffff)) break;
   }

   return mac_ipr->phy_addr >= 0x2000 ? 1:0;
}

/* Write PHY register by MII interface */
int mii_write(MAC_STRU *mac_ipr, int offset, int wdata)
{
	int tmpv;
	int io_base = mac_ipr->io_base;

   outport(io_base + IO_MMWD, wdata);
   outport(io_base + IO_MMDIO, offset + mac_ipr->phy_addr + MIIWR);

   /* Wait command activate */
   while(!(inport(io_base + IO_MMDIO) & MIIWR));

   /* Wait command finish */
   do{
   	tmpv = inport(io_base + IO_MMDIO);
   } while(tmpv & MIIWR);

	return 0;
}

/* Read PHY register by MII interface */
int mii_read(MAC_STRU *mac_ipr, int offset)
{
	int tmpv;
	int io_base = mac_ipr->io_base;

   outport(io_base + IO_MMDIO, offset + mac_ipr->phy_addr + MIIRD);

   /* Wait command activate */
   while(!(inport(io_base + IO_MMDIO) & MIIRD));

   /* Wait command finish */
   do{
   	tmpv = inport(io_base + IO_MMDIO);
   } while(tmpv & MIIRD);

   return inport(io_base + IO_MMRD);
}

/* Send packet */
int send_pkt(MAC_STRU *mac_ipr, char * buf_ptr, int len)
{
	int	io_base = mac_ipr->io_base;
   RDC_DESCRIPTOR *txd_ptr;

   if (!mac_ipr->TxFreeDesc) return 1;

   disable();		/* Disable interrupt */
   txd_ptr = mac_ipr->tx_insert_ptr;
	txd_ptr->len = len;
   txd_ptr->status = 0x8000;
   mac_ipr->TxFreeDesc--;
   outport(io_base + IO_MTPR, 1);
   mac_ipr->tx_insert_ptr = txd_ptr->vndesc_ptr;
   enable();		/* Enable interrupt */

   return 0;
}

/* Send complete check */
void send_complete(MAC_STRU *mac_ipr)
{
   RDC_DESCRIPTOR *txd_ptr = mac_ipr->tx_remove_ptr;

   while(mac_ipr->TxFreeDesc < DESC_COUNT) {
   	if (txd_ptr->status & 0x8000) break;
      txd_ptr = txd_ptr->vndesc_ptr;
      mac_ipr->TxFreeDesc++;
      mac_ipr->TxSuccCounter++;
	}
   mac_ipr->tx_remove_ptr = txd_ptr;
}

/* Receive packet */
void receive_pkt(MAC_STRU *mac_ipr)
{
   RDC_DESCRIPTOR *rxd_ptr = mac_ipr->rx_remove_ptr;

   while(mac_ipr->RxFreeDesc) {
   	if (rxd_ptr->status & 0x8000) break;
		mac_ipr->RxFreeDesc--;
      mac_ipr->RxSuccCounter++;
      rxd_ptr = rxd_ptr->vndesc_ptr;
   }
   mac_ipr->rx_remove_ptr = rxd_ptr;
}

/* Allocate RX buffer */
void alloc_rx_buf(MAC_STRU *mac_ipr)
{
	int	io_base = mac_ipr->io_base;
   RDC_DESCRIPTOR *rxd_ptr = mac_ipr->rx_insert_ptr;

	while(mac_ipr->RxFreeDesc < DESC_COUNT) {
      outport(io_base + IO_MRDC, 0);
		rxd_ptr->status = 0x8000;
      mac_ipr->RxFreeDesc++;
      rxd_ptr = rxd_ptr->vndesc_ptr;
   }
   mac_ipr->rx_insert_ptr = rxd_ptr;
}

/* MAC1/2 interrupt 4 handler */
void _interrupt int4_handler(__CPPARGS)
{
	int	tmp_int;

   /* Got Host interrupt status */
   tmp_int = inport(INT_STATUS);

   if (tmp_int & MAC1_INT_REQ) mac_handler(&mac1_info);
   if (tmp_int & MAC2_INT_REQ) mac_handler(&mac2_info);

   /* EOI */
   outport(INTC_EOI, INT4_TYPE);
}

/* MAC interrupt handler for TX/RX */
void mac_handler(MAC_STRU *mac_ipr)
{
	int io_base = mac_ipr->io_base;
   unsigned int mac_int_status;

   /* Disable MAC interrupt */
   outport(io_base + IO_MIMR, 0);

   /* Get MAC interrupt status */
   mac_int_status = inport(io_base + IO_MISR);

   /* Handle MAC TX/RX interrupt request */
   if (mac_int_status & INT_TXEE) mac_tx_handler(mac_ipr);
   if (mac_int_status & INT_RXEE) mac_rx_handler(mac_ipr);

  /* Re-enable MAC nterrupt */
  outport(io_base + IO_MIMR, INT_TXEE + INT_RXEE);
}

/* MAC TX interrupt handler */
void mac_tx_handler(MAC_STRU *mac_ipr)
{
	MAC_STRU *next_mac = mac_ipr->next_mac;
   int io_base = next_mac->io_base;
   RDC_DESCRIPTOR *txd_ptr = mac_ipr->tx_remove_ptr;
   RDC_DESCRIPTOR *rxd_ptr = next_mac->rx_insert_ptr;

   while(mac_ipr->TxFreeDesc < DESC_COUNT) {
   	if (txd_ptr->status & 0x8000) break;
      txd_ptr = txd_ptr->vndesc_ptr;
      mac_ipr->TxFreeDesc++;
      mac_ipr->TxSuccCounter++;

      /* Re-use RX desciptor */
		rxd_ptr->status = 0x8000;
      outport(io_base + IO_MRDC, 0);	/* Trigger MAC increase RX descriptor count */
      next_mac->RxFreeDesc++;
      rxd_ptr = rxd_ptr->vndesc_ptr;
	}
   mac_ipr->tx_remove_ptr = txd_ptr;
   next_mac->rx_insert_ptr = rxd_ptr;
}

/* MAC RX interrupt handler */
void mac_rx_handler(MAC_STRU *mac_ipr)
{
	MAC_STRU *next_mac = mac_ipr->next_mac;
	int io_base = next_mac->io_base;
   RDC_DESCRIPTOR *rxd_ptr = mac_ipr->rx_remove_ptr;
   RDC_DESCRIPTOR *txd_ptr = next_mac->tx_insert_ptr;

   while(mac_ipr->RxFreeDesc) {
   	if (rxd_ptr->status & 0x8000) break;
		mac_ipr->RxFreeDesc--;
      mac_ipr->RxSuccCounter++;

      /* Another MAC send */
      txd_ptr->len = rxd_ptr->len - 4;		/* Skip 4 byte CRC */
      txd_ptr->status = 0x8000;
      outport(io_base + IO_MTPR, 1);
      next_mac->TxFreeDesc--;

      /* Next descriptor */
      rxd_ptr = rxd_ptr->vndesc_ptr;
      txd_ptr = txd_ptr->vndesc_ptr;
   }
   mac_ipr->rx_remove_ptr = rxd_ptr;
   next_mac->tx_insert_ptr = txd_ptr;
}



void delaye(void)
{
     int i;
     for (i=0;i<8000;i++)
     {
       Loops();
     }
}

void Loops(void)
{
     int i;
     for (i=0;i<80;i++)
     {
       asm nop;
       asm nop;
       asm nop;
       asm nop;
     }
}
void FlashLed(void)
{
    int StartLed=1;
    	
    int i;

    for (i=0; i<8; i++)
    {
        outport(0x80, StartLed);
        StartLed <<=1;
        delaye();
    }

}
/* UART0 interrupt handler */
void _interrupt uart0_handler(__CPPARGS)
{
	unsigned char tmpv;

   /* Clear UART0 interrupt status */
   tmpv = inport(0xff84);	/* IIR to prevent TX Empty interrupt */

   /* Check UART0 status*/
  	tmpv = inport(0xff8a);	/* UART0 status */
   if (tmpv & 0x01) {
     	tmpv = inport(0xff80);	/* Received data */
      switch (tmpv)
      {
       case 0x55:
       outport(0xff7a, 0x0800);
		 delaye();
       outport(0xff7a, 0x1800);
		 delaye();
       outport(0xff7a, 0x3800);
		 delaye();
       outport(0xff7a, 0x7800);
       break;
       case 0xaa:
       outport(0xff7a, 0x7000);
		 delaye();
       outport(0xff7a, 0x3000);
		 delaye();
       outport(0xff7a, 0x1000);
		 delaye();
       outport(0xff7a, 0x0000);
       break;
       case 0x80:
       outport(0xffe6, 0x3333);		/* Watch-dog Timer write sequence */
 	    outport(0xffe6, 0xcccc);		/* Watch-dog Timer write sequence */
 	    outport(0xffe6, 0x9080);		/* Enable Watch-dog timer for 1.342s*/
       break;
       default:
       break;
      }

      outport(0xff80, tmpv);	/* Send Data */
      PutStr(0,"<<==Response Code\r\n");
	}

   /* EOI */
   outport(INTC_EOI, 0x8000);
}

void _interrupt uart1_handler(__CPPARGS)
{
	unsigned char tmpv1;
	
	 /* Clear UART1 interrupt status */
   tmpv1 = inport(0xff14);	/* IIR to prevent TX Empty interrupt */

   /* Check UART1 status*/
  	tmpv1 = inport(0xff1a);	/* UART0 status */
   if (tmpv1 & 0x01) {
   	
     	tmpv1 = inport(0xff10);	/* Received data */
      outport(0xff10, tmpv1);	/* Send Data */
      PutStr(1,"<<==Response Code\r\n");
	}

   /* EOI */
   outport(INTC_EOI, 0x8000);
}

void PutStr(int p,char *pstr)
{
	while(*pstr!='\0')
    {
    	PutCh(p,*pstr++);
    }
}

void PutCh(int p,char ch)
{
	unsigned char	tmp;
    unsigned int	base;

    base=(p==0)?UARTBASE0:UARTBASE1;

    while(1)
    {
    	tmp=inportb(base+10);
        if(tmp&0x20)
        {
        	outportb(base,ch);
        	return;
        }
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合久久久久| 亚洲国产一区二区三区| 国产亚洲va综合人人澡精品| 亚洲精品写真福利| 国产一区亚洲一区| 日韩免费观看2025年上映的电影| 久久久蜜桃精品| 午夜一区二区三区在线观看| 成人视屏免费看| 日韩你懂的在线播放| 一区二区高清在线| 91在线国产观看| 国产三级欧美三级| 精品午夜久久福利影院 | 午夜不卡av在线| 99久久亚洲一区二区三区青草| 日韩欧美成人午夜| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲国产精品影院| 久久精品国产一区二区三| 色菇凉天天综合网| 亚洲欧洲成人精品av97| 福利一区二区在线| 精品国产乱码久久久久久图片 | 久久久久久久免费视频了| 免费在线视频一区| 欧美日韩和欧美的一区二区| 国产精品久久免费看| 国产iv一区二区三区| 国产欧美1区2区3区| 国产精品夜夜爽| 日本一区二区免费在线观看视频| 国内精品不卡在线| 久久精品免视看| 丁香激情综合国产| 亚洲欧洲av色图| 91精品办公室少妇高潮对白| 亚洲自拍欧美精品| 欧美日韩精品一区视频| 三级不卡在线观看| 日韩欧美国产一区二区三区| 国产最新精品免费| 国产精品人妖ts系列视频| 成人av网站大全| 一区二区三区日本| 717成人午夜免费福利电影| 蜜臀av性久久久久蜜臀av麻豆| 欧美sm极限捆绑bd| 国产成人a级片| 亚洲精品免费视频| 欧美日韩成人一区二区| 九九九精品视频| 国产精品久久久久久久久快鸭| 91福利在线看| 蜜臀久久久久久久| 欧美激情综合网| 欧美亚一区二区| 久久99国产精品成人| 中文字幕高清不卡| 欧美日韩一区二区在线观看| 国内国产精品久久| 中文字幕日韩一区二区| 欧美喷水一区二区| 国产福利精品导航| 亚洲永久精品国产| 久久久久久电影| 欧美亚洲愉拍一区二区| 国产一区免费电影| 亚洲午夜久久久久久久久久久 | 欧美色综合网站| 精品中文字幕一区二区| 中文字幕亚洲一区二区av在线| 欧美日韩亚洲国产综合| 国产成人免费视频网站| 亚洲大片免费看| 国产精品家庭影院| 日韩视频国产视频| 欧美中文字幕亚洲一区二区va在线 | 欧美老肥妇做.爰bbww视频| 韩国三级中文字幕hd久久精品| 一本色道**综合亚洲精品蜜桃冫| 盗摄精品av一区二区三区| 玉米视频成人免费看| 日韩欧美黄色影院| 欧美三级电影网| 懂色av一区二区在线播放| 免费人成网站在线观看欧美高清| 欧美激情一区二区三区全黄| 日韩午夜av一区| 欧美性受xxxx| 97久久精品人人做人人爽| 国模一区二区三区白浆| 日韩在线观看一区二区| 亚洲精品成人悠悠色影视| 国产人成亚洲第一网站在线播放| 欧美一区中文字幕| 欧美日韩国产成人在线91| 色综合久久久久| 99精品偷自拍| 丁香婷婷综合五月| 国产精品18久久久久| 久久综合综合久久综合| 日韩精品久久理论片| 亚洲高清视频在线| 欧美人动与zoxxxx乱| 亚洲国产视频一区| 国产欧美日韩视频在线观看| 91.com视频| 欧美日韩国产片| 欧美午夜视频网站| 精品视频1区2区| 在线这里只有精品| 91福利精品视频| 色哟哟一区二区| 日本道在线观看一区二区| 91色视频在线| 91久久精品日日躁夜夜躁欧美| 99久久综合精品| 色综合视频一区二区三区高清| 99精品在线观看视频| av电影在线观看不卡 | 国产精品国产三级国产aⅴ中文 | 国产精品18久久久久久久网站| 3d成人动漫网站| 91九色最新地址| 在线观看www91| 色老汉一区二区三区| 日本道精品一区二区三区| 在线观看日韩国产| 欧美色国产精品| 欧美一级日韩一级| 久久久亚洲精华液精华液精华液| 久久免费偷拍视频| 自拍av一区二区三区| 一区二区三区资源| 乱一区二区av| 成人深夜在线观看| 欧美日韩一区二区三区在线看| 日韩视频一区二区三区| 久久精品这里都是精品| 亚洲欧美另类久久久精品2019| 亚洲一区二区三区四区五区黄| 日日骚欧美日韩| 国产91高潮流白浆在线麻豆| 色综合中文字幕国产| 欧美成人精品二区三区99精品| 成人99免费视频| 在线观看91精品国产入口| 欧美猛男男办公室激情| 精品国产123| 亚洲欧美激情小说另类| 午夜私人影院久久久久| 国产伦精品一区二区三区在线观看| 丁香婷婷综合色啪| 91麻豆精品91久久久久同性| 国产亚洲精品超碰| 图片区日韩欧美亚洲| 粉嫩高潮美女一区二区三区 | 成人午夜精品一区二区三区| 91成人网在线| 国产亚洲美州欧州综合国| 亚洲精品亚洲人成人网 | 色综合一个色综合亚洲| 日韩欧美一区二区三区在线| 专区另类欧美日韩| 激情亚洲综合在线| 欧美视频在线播放| 中文一区二区完整视频在线观看| 日韩成人dvd| 91碰在线视频| 国产欧美一区二区三区沐欲| 午夜精品视频在线观看| 色综合天天在线| 日本一区二区电影| 久久99这里只有精品| 欧美日韩国产综合一区二区| 亚洲色图都市小说| 国产成人精品三级| 精品国产一区二区三区不卡 | 亚洲欧洲综合另类在线| 国产在线不卡一区| 91精品国产综合久久久蜜臀粉嫩 | 亚洲资源中文字幕| 波多野结衣亚洲一区| 久久久亚洲欧洲日产国码αv| 日韩中文字幕不卡| 欧美剧情电影在线观看完整版免费励志电影| 国产午夜亚洲精品午夜鲁丝片 | 日韩免费观看2025年上映的电影| 亚洲国产欧美一区二区三区丁香婷| 成人高清视频在线| 国产亚洲欧美一区在线观看| 精品中文av资源站在线观看| 欧美一区二区观看视频| 日韩精品一级二级| 欧美精品一级二级| 视频一区二区中文字幕| 欧美日韩国产片| 日韩av中文字幕一区二区 | 色综合久久久久综合|