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

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

?? dp83815.c

?? linux下的DP83815網卡驅動源碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
 * This routine receives the data from Rx queue as long as it gets a valid
 * rx_descriptor and resets the descriptor's CMDSTS field back to the Buffer
 * size, and updates the BUFPTR and SKBPTR fields to the newly allocated SKB.
 */
static int
dp83815_start_receive (struct net_device *dev)
{
    u32         cmdsts;
    int         len;
    bool        do_copy;
    virt_addr   rx_desc;
    struct sk_buff *cur_skb;
    struct sk_buff *new_skb;
    struct sk_buff *rx_skb;
    struct net_device_stats *stats_p;

#if LINK_AGGR
    NsmContext  *pNsm = &((struct dp83815_priv *)(dev->priv))->NsmCtxt;
    AdapterContext *pAdp = &pNsm->AdpCtxt;
    AdapterContext *pAggrCtxt = pAdp->pAggregatorContext;
    NsmContext *pAggrNsmContext = (NsmContext *)(pAggrCtxt->pNsmContext);
#endif
    
    stats_p = &((struct dp83815_priv *)(dev->priv))->stats;
    
    for (rx_desc = dp83815_rx_desc_get(dev);
         (rx_desc != NULL);
         rx_desc = dp83815_rx_desc_get(dev)) {
        
        DP_DEBUG (DP_DEBUG_RX, 
                  (KERN_INFO "%s Rx: rx_desc=0x%x, CMDSTS = 0x%x",
                   dev->name, (u32)rx_desc, DP_DESC_CMDSTS_XLATE_GET(rx_desc)));

        cmdsts = DP_DESC_CMDSTS_XLATE_GET (rx_desc);

        /* Send the packet to the stack if no errors */
        if ((cmdsts & DP_DESC_CMDSTS_RX_ERRORS) == 0) {

            len = (cmdsts & DP_DESC_CMDSTS_SIZE) - ETH_CRC_LEN;

            /*
             * Allocate a new SKB
             * small data packets less than DP_RX_COPY_THRESHOLD are copied
             * into the new SKB, other allocate one to replace the current SKB.
             */
            if (len < DP_RX_COPY_THRESHOLD) {
                do_copy = TRUE;
                new_skb = alloc_skb (len + 2, GFP_ATOMIC);
            } else {
                do_copy = FALSE;
                new_skb = alloc_skb (ETH_MAX_PKT_SIZE, GFP_ATOMIC);
            }
        
            if (new_skb) {
                cur_skb = (struct sk_buff *) DP_DESC_SKBPTR_GET (rx_desc);

                if (do_copy) {
                    /* Copy data from current SKB and send the new SKB up */
                    rx_skb = new_skb;
                    skb_reserve (rx_skb, 2);
                    memcpy (skb_put(rx_skb, len), cur_skb->data, len);
                } else {
                    /* Replace the the current SKB with the new SKB */
                    rx_skb = cur_skb;
                    DP_DESC_BUFPTR_XLATE_SET (rx_desc, new_skb->data);
                    DP_DESC_SKBPTR_SET (rx_desc, (u32) new_skb);
                    (void) skb_put(rx_skb, len);
                }

                /* update the SKB and set it up */
#ifdef LINK_AGGR
                if (pAdp->nFlags & GEC_FLAG)
                    rx_skb->dev = pAggrNsmContext->dev_aggr;
                else
                    rx_skb->dev = pNsm->dev;
#else                
                rx_skb->dev = dev;
#endif                                

                rx_skb->protocol = eth_type_trans (rx_skb, dev);

                netif_rx (rx_skb);

                dev->last_rx = jiffies;
                stats_p->rx_packets++;
                stats_p->rx_bytes += len;
            } else 
                stats_p->rx_dropped++; /* no resources */

            if (cmdsts & DP_DESC_CMDSTS_RX_DEST_MC)
                stats_p->multicast++;
        }
        else {
            stats_p->rx_errors++; /* bad packet */

            /* Update individual counters */
            if (cmdsts & (DP_DESC_CMDSTS_RX_RUNT |
                          DP_DESC_CMDSTS_RX_LONG))
                stats_p->rx_length_errors++;

            if (cmdsts & DP_DESC_CMDSTS_RX_CRCE)
                stats_p->rx_crc_errors++;

            if (cmdsts & DP_DESC_CMDSTS_RX_FAE)
                stats_p->rx_frame_errors++;

            if (cmdsts & DP_DESC_CMDSTS_RX_RXO)
                stats_p->rx_fifo_errors++;
        }

        /* Cleanup the descriptor and make available for reception */
        DP_DESC_CMDSTS_XLATE_SET (rx_desc, ETH_MAX_PKT_SIZE);
    }
    return OK;
}

/* dp83815_get_stats - get current device statistics */
static struct net_device_stats *
dp83815_get_stats (struct net_device *dev)
{
    return &((struct dp83815_priv *)(dev->priv))->stats;
}

/* dp83815_set_multicast_list - sets multicast, & promiscuous mode */
static void
dp83815_set_multicast_list (struct net_device *dev)
{
    u32      rfcr_flags;
#ifndef LINK_AGGR    
    u32      iobase = dev->base_addr;
    u16   hash_table[32];
    int   i;
#endif    
    struct dev_mc_list * mc_list;

#ifdef LINK_AGGR
    MultiList *pMultiList = NULL;
    MultiList *pMulti, *pMultiNext;
    NsmContext *pNsm = &((struct dp83815_priv *)(dev->priv))->NsmCtxt;
    AdapterContext *pAdp = &(pNsm->AdpCtxt);
#endif
    
    /* default RFCR mode */
#ifdef LINK_AGGR
    rfcr_flags = ACCEPT_PERFECT_MATCH_ON | ACCEPT_ALL_BROADCAST_ON;
#else    
    rfcr_flags = DP_RFCR_APM | DP_RFCR_AAB | DP_RFCR_RFEN;
#endif
    
    /* Setup promiscuous mode */
    if (dev->flags & IFF_PROMISC) {
        DP_DEBUG (DP_DEBUG_OPEN,
                  (KERN_INFO "IFF_PROMISC\n"));
#ifdef LINK_AGGR
        rfcr_flags = PROMISCUOUS_ON;
#else                
        rfcr_flags = (DP_RFCR_AAU | DP_RFCR_AAM | DP_RFCR_AAB |
                      DP_RFCR_RFEN);
#endif        
    } else if (dev->flags & IFF_ALLMULTI) {

        /* Receive all multicast packets */
        DP_DEBUG (DP_DEBUG_OPEN,
                  (KERN_INFO "IFF_ALLMULTI\n"));
#ifdef LINK_AGGR
        rfcr_flags |= ACCEPT_ALL_MULTICAST_ON;
#else                
        rfcr_flags |= DP_RFCR_AAM;
#endif        
    } else {
#ifdef LINK_AGGR
        mc_list = dev->mc_list;
        pMultiList = NULL;
        
        /* Get the multicast address list from the mc_list and allocate a
           MultiList structure and put the multicast addresses into the
           MultiList structure  */
        
        while(mc_list)
        {
            pMulti = (MultiList *)kmalloc(sizeof(MultiList), GFP_KERNEL);
            if(pMulti == NULL)
            {
                if(pMultiList)
                {
                    pMulti = pMultiList;
                    while(pMulti)
                    {
                        pMultiNext = pMulti->Next;
                        kfree(pMulti);
                        pMulti = pMultiNext;
                    }
                }
                return;
            }
            memcpy( pMulti->MulticastAddr, mc_list->dmi_addr, 6); 
            pMulti->Next = pMultiList;
            pMultiList = pMulti;
            mc_list = mc_list->next;                    
        }
        
        /* Call the HSM function to add the list of multicast addresses to the
           filter */
        dp83815_multicast_add(pAdp, pMultiList, TRUE);    
        
        /* Free up the list of MultiList structures */
        pMulti = pMultiList;
        while(pMulti)
        {
            pMultiNext = pMulti->Next;
            kfree(pMulti);
            pMulti = pMultiNext;
        }
#else        
        /* Setup to receive programmed multicast packets */
        memset (hash_table, 0, 32);
        for (i=0, mc_list=dev->mc_list; mc_list && i < dev->mc_count;
             i++, mc_list = mc_list->next) {
            DP_DEBUG (DP_DEBUG_OPEN,
                      (KERN_INFO "mc_addr=%p\n", mc_list->dmi_addr));
            set_bit (dp83815_crc((char *)mc_list->dmi_addr) & 0x1ff, hash_table);
        }
        
        /* install the hash table */
        for (i=0; i<32; i++) {
            DP_REG32_WRITE (DP_RFCR, DP_RFCR_RFADDR_FMEM_LO + i*2);
            DP_REG32_WRITE (DP_RFDR, (u32) hash_table[i]);
        }
        
        rfcr_flags |= DP_RFCR_MHEN;
#endif        
    }

#ifdef LINK_AGGR
    dp83815_rxfilter (pAdp, rfcr_flags);
#else    
    DP_REG32_WRITE (DP_RFCR, 0);
    DP_REG32_WRITE (DP_RFCR, rfcr_flags);
#endif
    DP_DEBUG (DP_DEBUG_OPEN,
              (KERN_INFO "%s : MC Setup RFCR flags=0x%x\n",dev->name, rfcr_flags));
    
    return;
}

/* dp83815_crc - computer CRC for hash table entries */
static int
dp83815_crc (char * mc_addr)
{
    u32    crc;
    u8    cur_byte;
    u8    msb;
    u8    byte, bit;

    crc = ~0;
    for (byte=0; byte<6; byte++) {
        cur_byte = *mc_addr++;
        for (bit=0; bit<8; bit++) {
            msb = crc >> 31;
            crc <<= 1;
            if (msb ^ (cur_byte & 1)) {
                crc ^= DP_POLYNOMIAL;
                crc |= 1;
            }
            cur_byte >>= 1;
        }
    }
    crc >>= 23;

    return (crc);
}

/* dp83815_interrupt - handle driver specific ioctls */
static int
dp83815_ioctl (struct net_device *dev, struct ifreq *rq, int cmd)
{
#if LINK_AGGR
    void *data = &(rq->ifr_data);
    NsmContext *pNsm = &((struct dp83815_priv *)(dev->priv))->NsmCtxt;
    AdapterContext *pAdp = &(pNsm->AdpCtxt);

    switch (cmd)
    {
    case SIOCSIFADDR:
        memcpy ((void *)dev->dev_addr, data, 6);
        memcpy ((void *)pAdp->CurrMacAddr, data, 6);
        dp83815_mac_address_set (pAdp, pAdp->CurrMacAddr);
        break;
    case SIOCDEVPRIVATE:
        break;
    default:
        return -EOPNOTSUPP;
    }
    return OK;
#else
    return -EOPNOTSUPP;
#endif    
}

static void
dp83815_interrupt (int irq, void *dev_id, struct pt_regs *regs)
{
    struct net_device * dev = dev_id;
    u16  iobase = dev->base_addr;
    u32  reg_isr;
    u32  CurrentLinkStatus;
	u16  tmpVal;
	u32  version;
	struct dp83815_priv *dev_priv = (struct dp83815_priv *)dev->priv;

#ifdef TEST_RX
    static int rx_cnt = 0;
    u16 phy_status;    
#endif    
#ifdef LINK_AGGR
    u16 phy_status;
    NsmContext     *pNsm = &((struct dp83815_priv *)(dev->priv))->NsmCtxt;
    AdapterContext *pAdp =  &pNsm->AdpCtxt;
#endif
    
    CurrentLinkStatus= DP_REG32_READ(DP_PHYSTS);
    if(dev_priv->PrevLinkSts!=(CurrentLinkStatus&DP_PHYSTS_LNK_VALID)){	//Link Changed
	    if( CurrentLinkStatus&DP_PHYSTS_LNK_VALID){
		    if( ~(CurrentLinkStatus&DP_PHYSTS_SPEED_10)){
			    if( (dev_priv->autoneg !=1) || (dev_priv->speed100 !=2) || (dev_priv->fullduplex!=2))
				    dp83815_phy_setup(dev);
			    else
				    dp83815_PhyCoefAdjust(dev);
		    }
	    }
	   else{
		   dp83815_ResetPhy(dev);
		    dp83815_PhyAdjust(dev);
	    }
	   dev_priv->PrevLinkSts = (CurrentLinkStatus&DP_PHYSTS_LNK_VALID);
    }
    
    reg_isr = DP_REG32_READ (DP_ISR);
    
    DP_DEBUG (DP_DEBUG_IOCTL,
              (KERN_INFO "%s: intr_status=0x%x\n", dev->name,
               reg_isr));
    if (reg_isr & DP_ISR_RXOK)
        dp83815_start_receive (dev);    

    
    if (reg_isr & (DP_ISR_TXOK | DP_ISR_TXERR | DP_ISR_TXURN | DP_ISR_TXIDLE |
                   DP_ISR_TXDESC))
        dp83815_tx_skb_reclaim_irq (dev, NULL);


    if (reg_isr & DP_ISR_PHY)
    {
#ifdef LINK_AGGR
        phy_status = DP_REG16_READ (DP_PHYSTS);
        
        if ((phy_status & DP_PHYSTS_LNK_VALID) &&
            !(pAdp->AdapterStatus & LINK_UP))
        {
            DP_DEBUG (DP_DEBUG_IOCTL,
                      (KERN_INFO " %s: is up \n", dev->name));
            pAdp->AdapterStatus |= LINK_UP;
        }
        if (!(phy_status & DP_PHYSTS_LNK_VALID) &&
            (pAdp->AdapterStatus & LINK_UP))
        {
            DP_DEBUG (DP_DEBUG_IOCTL,
                      (KERN_INFO "%s: is down \n", dev->name));
            pAdp->AdapterStatus &= ~LINK_UP;            
        }

        if (pAdp->nFlags)
            LacpAdapterStatusCheck(pAdp);
#else    
        DP_DEBUG (DP_DEBUG_IOCTL,
                   (KERN_INFO " %s: Link status changed \n", dev->name));
#endif        
    }
}

/* dp83815_mac_address_set - set the ethernet address */
static void
#ifdef LINK_AGGR    
dp83815_mac_address_set (AdapterContext *pAdp, char* mac_addr)
#else    

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费观看日韩电影| 88在线观看91蜜桃国自产| 风间由美中文字幕在线看视频国产欧美| 国产又粗又猛又爽又黄91精品| 国产福利一区二区| 欧美精品一级二级| 中文字幕第一区第二区| 亚洲成人av资源| 国产精品 日产精品 欧美精品| 国产女人18毛片水真多成人如厕 | 欧美美女直播网站| 久久久午夜精品| 亚洲最新视频在线播放| 国产高清不卡二三区| 国产精品免费人成网站| 日韩福利视频导航| 在线视频综合导航| 国产婷婷色一区二区三区| 麻豆专区一区二区三区四区五区| 日本伦理一区二区| 国产精品理论片在线观看| 极品少妇xxxx精品少妇偷拍| 在线视频国内自拍亚洲视频| 三级欧美韩日大片在线看| 欧美色爱综合网| 亚洲成av人片在线观看无码| 欧美精品一区二区三区在线播放 | 成人综合在线视频| 国产网红主播福利一区二区| 欧美优质美女网站| 国产女人18毛片水真多成人如厕 | 亚洲人成在线播放网站岛国| 韩国精品一区二区| 精品成a人在线观看| 91在线看国产| 亚洲精品国产精华液| 在线观看欧美日本| 国产91精品一区二区麻豆亚洲| 亚洲综合免费观看高清完整版| 欧美日本一区二区三区四区| 丰满白嫩尤物一区二区| 日韩高清在线电影| 一区二区免费在线| 国产精品无码永久免费888| 欧美成人精品3d动漫h| 久久精品二区亚洲w码| 国产亚洲一本大道中文在线| 欧美日韩美少妇| 色婷婷精品久久二区二区蜜臂av| 一区二区三区在线免费观看| 国产日产欧美精品一区二区三区| 欧美一区二区视频在线观看2022 | 久久精品国产99国产精品| 亚洲精品国产一区二区精华液 | 午夜不卡av免费| 日韩一区二区精品| 国产 日韩 欧美大片| 青草国产精品久久久久久| 亚洲一级二级三级| 亚洲精品成人少妇| 一区二区中文视频| 制服丝袜av成人在线看| 在线视频综合导航| 一本到高清视频免费精品| 成人在线视频一区二区| 韩日欧美一区二区三区| 激情五月婷婷综合网| 久久国产人妖系列| 精品一区二区三区免费观看| 蜜桃av一区二区| 精品一区免费av| 精品一区二区三区在线观看 | 国产午夜精品在线观看| 久久精品欧美日韩精品| 久久人人爽爽爽人久久久| 久久久91精品国产一区二区精品 | 91精品国产色综合久久不卡蜜臀| 欧美色视频一区| 欧美一区中文字幕| 日韩欧美国产麻豆| 欧美亚洲国产一卡| 欧美色图天堂网| 88在线观看91蜜桃国自产| 日韩一区二区三免费高清| 久久综合av免费| 91精品在线免费| 日韩视频免费观看高清完整版在线观看| 欧美一区二区免费| 精品国产免费人成电影在线观看四季| 久久综合精品国产一区二区三区| 日本一区二区免费在线观看视频 | 成人一区二区在线观看| 成人av中文字幕| 国产一区二区三区四区五区入口| 国产精品自在在线| 六月丁香综合在线视频| 国产精品一区一区三区| 成人av在线电影| 在线视频你懂得一区| 制服丝袜成人动漫| 久久精品欧美日韩| 亚洲少妇30p| 国产精品系列在线| 一区二区三区中文字幕精品精品 | 91精品在线观看入口| 国产午夜精品美女毛片视频| 亚洲日本在线a| 日韩福利电影在线观看| 国产成人综合网站| 欧美性猛交xxxx黑人交| 精品国产乱码久久久久久夜甘婷婷 | 蜜臀av一区二区三区| 国产成人免费在线观看| 欧美中文字幕亚洲一区二区va在线 | 国产乱码精品一区二区三区五月婷| 成人免费精品视频| 91精品国产福利在线观看| 亚洲国产精品t66y| 日本亚洲电影天堂| 99国产欧美另类久久久精品| 欧美一区二区三区在线视频| 国产精品天干天干在观线| 日韩中文字幕不卡| 成人app在线| 精品国产91乱码一区二区三区| 亚洲乱码日产精品bd| 国产在线一区观看| 欧美美女激情18p| 亚洲欧洲另类国产综合| 精品在线播放免费| 欧美精品在线视频| 中文字幕一区二区三区色视频| 青青青伊人色综合久久| 欧美在线视频日韩| 中文字幕亚洲不卡| 国产乱码精品一区二区三 | 欧美人伦禁忌dvd放荡欲情| 日本一区二区综合亚洲| 精品系列免费在线观看| 欧美丰满一区二区免费视频| 亚洲欧洲性图库| 国产suv精品一区二区883| 精品99久久久久久| 日本成人在线视频网站| 欧美蜜桃一区二区三区| 亚洲午夜久久久久久久久电影院 | 丝袜美腿亚洲色图| 色综合视频一区二区三区高清| 精品黑人一区二区三区久久 | 日韩欧美国产精品| 日韩av网站免费在线| 欧美久久一二三四区| 亚洲国产视频在线| 91久久精品一区二区三区| 亚洲视频一区二区在线观看| 成人免费毛片嘿嘿连载视频| 亚洲国产精品国自产拍av| 国产福利精品一区| 亚洲国产精品v| 99久久综合狠狠综合久久| 欧美日韩久久久| 亚洲福中文字幕伊人影院| 欧美亚洲图片小说| 亚洲国产精品综合小说图片区| 色婷婷精品久久二区二区蜜臀av | 91在线porny国产在线看| 欧美日韩在线不卡| 亚洲国产日日夜夜| 欧美日韩国产综合视频在线观看 | 久久九九久久九九| 国产成a人无v码亚洲福利| 欧美韩国日本一区| 97精品电影院| 亚洲午夜视频在线观看| 欧美日韩国产片| 免费xxxx性欧美18vr| 精品国产露脸精彩对白| 懂色av一区二区三区免费观看| 国产精品久久久久久久裸模| 91福利在线免费观看| 香蕉成人啪国产精品视频综合网| 欧美一区三区二区| 国产高清久久久| 亚洲免费在线播放| 欧美日韩不卡在线| 激情综合色综合久久综合| 中文字幕国产精品一区二区| 色域天天综合网| 日本不卡123| 亚洲国产精品成人久久综合一区| 日本大香伊一区二区三区| 日韩不卡手机在线v区| 久久先锋影音av| 91在线码无精品| 日本成人在线不卡视频| 欧美国产亚洲另类动漫| 欧美伊人久久大香线蕉综合69| 蜜臀av性久久久久蜜臀aⅴ| 国产精品久久久久影视| 欧美日产国产精品|