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

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

?? snull.c.orig

?? ldd1的源代碼
?? ORIG
?? 第 1 頁 / 共 2 頁
字號:
    ih = (struct iphdr *)(buf+sizeof(struct ethhdr));    saddr = &ih->saddr;    daddr = &ih->daddr;    ((u8 *)saddr)[2] ^= 1; /* change the third octet (class C) */    ((u8 *)daddr)[2] ^= 1;    ih->check = 0;         /* and rebuild the checksum (ip needs it) */    ih->check = ip_fast_csum((unsigned char *)ih,ih->ihl);    if (dev == snull_devs)        PDEBUGG("%08x:%05i --> %08x:%05i\n",               ntohl(ih->saddr),ntohs(((struct tcphdr *)(ih+1))->source),               ntohl(ih->daddr),ntohs(((struct tcphdr *)(ih+1))->dest));    else        PDEBUGG("%08x:%05i <-- %08x:%05i\n",               ntohl(ih->daddr),ntohs(((struct tcphdr *)(ih+1))->dest),               ntohl(ih->saddr),ntohs(((struct tcphdr *)(ih+1))->source));    /*     * Ok, now the packet is ready for transmission: first simulate a     * receive interrupt on the twin device, then  a     * transmission-done on the transmitting device     */    dest = snull_devs + (dev==snull_devs ? 1 : 0);    privp = (struct snull_priv *)dest->priv;    privp->status = SNULL_RX_INTR;    privp->rx_packetlen = len;    privp->rx_packetdata = buf;    snull_interrupt(0, dest, NULL);    privp = (struct snull_priv *)dev->priv;    privp->status = SNULL_TX_INTR;    privp->tx_packetlen = len;    privp->tx_packetdata = buf;    if (lockup && ((privp->stats.tx_packets + 1) % lockup) == 0) {        /* Simulate a dropped transmit interrupt */        netif_stop_queue(dev);        PDEBUG("Simulate lockup at %ld, txp %ld\n", jiffies,                        (unsigned long) privp->stats.tx_packets);    }    else        snull_interrupt(0, dev, NULL);}/* * Transmit a packet (called by the kernel) */int snull_tx(struct sk_buff *skb, struct net_device *dev){    int len, retval=0;    char *data;    struct snull_priv *priv = (struct snull_priv *)dev->priv;#ifndef LINUX_24    if (dev->tbusy || skb == NULL) {        PDEBUG("tint for %p, tbusy %ld, skb %p\n", dev, dev->tbusy, skb);        snull_tx_timeout (dev);        if (skb == NULL)            return 0;    }#endif    len = skb->len < ETH_ZLEN ? ETH_ZLEN : skb->len;    data = skb->data;    dev->trans_start = jiffies; /* save the timestamp */    /* Remember the skb, so we can free it at interrupt time */    priv->skb = skb;    /* actual deliver of data is device-specific, and not shown here */    snull_hw_tx(data, len, dev);    return retval; /* zero == done; nonzero == fail */}/* * Deal with a transmit timeout. */void snull_tx_timeout (struct net_device *dev){    struct snull_priv *priv = (struct snull_priv *)dev->priv;    PDEBUG("Transmit timeout at %ld, latency %ld\n", jiffies,                    jiffies - dev->trans_start);    priv->status = SNULL_TX_INTR;    snull_interrupt(0, dev, NULL);    priv->stats.tx_errors++;    netif_wake_queue(dev);}/* * Ioctl commands  */int snull_ioctl(struct net_device *dev, struct ifreq *rq, int cmd){     PDEBUG("ioctl\n");    return 0;}/* * Return statistics to the caller */struct net_device_stats *snull_stats(struct net_device *dev){    struct snull_priv *priv = (struct snull_priv *)dev->priv;    return &priv->stats;}/* * This function is called to fill up an eth header, since arp is not * available on the interface */#ifndef LINUX_20int snull_rebuild_header(struct sk_buff *skb){    struct ethhdr *eth = (struct ethhdr *) skb->data;    struct net_device *dev = skb->dev;        memcpy(eth->h_source, dev->dev_addr, dev->addr_len);    memcpy(eth->h_dest, dev->dev_addr, dev->addr_len);    eth->h_dest[ETH_ALEN-1]   ^= 0x01;   /* dest is us xor 1 */    return 0;}#else /* LINUX_20 */int snull_rebuild_header(void *buff, struct net_device *dev, unsigned long dst,                    struct sk_buff *skb){    struct ethhdr *eth = (struct ethhdr *)buff;    memcpy(eth->h_source, dev->dev_addr, dev->addr_len);    memcpy(eth->h_dest, dev->dev_addr, dev->addr_len);    eth->h_dest[ETH_ALEN-1]   ^= 0x01;   /* dest is us xor 1 */    return 0;}#endif /* LINUX_20 */int snull_header(struct sk_buff *skb, struct net_device *dev,                unsigned short type, void *daddr, void *saddr, unsigned len){    struct ethhdr *eth = (struct ethhdr *)skb_push(skb,ETH_HLEN);    eth->h_proto = htons(type);    memcpy(eth->h_source, saddr ? saddr : dev->dev_addr, dev->addr_len);    memcpy(eth->h_dest,   daddr ? daddr : dev->dev_addr, dev->addr_len);    eth->h_dest[ETH_ALEN-1]   ^= 0x01;   /* dest is us xor 1 */    return (dev->hard_header_len);}/* * The "change_mtu" method is usually not needed. * If you need it, it must be like this. */int snull_change_mtu(struct net_device *dev, int new_mtu){    unsigned long flags;    spinlock_t *lock = &((struct snull_priv *) dev->priv)->lock;        /* check ranges */    if ((new_mtu < 68) || (new_mtu > 1500))        return -EINVAL;    /*     * Do anything you need, and the accept the value     */    spin_lock_irqsave(lock, flags);    dev->mtu = new_mtu;    spin_unlock_irqrestore(lock, flags);    return 0; /* success */}/* * The init function (sometimes called probe). * It is invoked by register_netdev() */int snull_init(struct net_device *dev){#if 0    /*     * Make the usual checks: check_region(), probe irq, ...  -ENODEV     * should be returned if no device found.  No resource should be     * grabbed: this is done on open().      */#endif    /*      * Then, assign other fields in dev, using ether_setup() and some     * hand assignments     */    ether_setup(dev); /* assign some of the fields */    dev->open            = snull_open;    dev->stop            = snull_release;    dev->set_config      = snull_config;    dev->hard_start_xmit = snull_tx;    dev->do_ioctl        = snull_ioctl;    dev->get_stats       = snull_stats;    dev->change_mtu      = snull_change_mtu;      dev->rebuild_header  = snull_rebuild_header;    dev->hard_header     = snull_header;#ifdef HAVE_TX_TIMEOUT    dev->tx_timeout     = snull_tx_timeout;    dev->watchdog_timeo = timeout;#endif    /* keep the default flags, just add NOARP */    dev->flags           |= IFF_NOARP;    dev->hard_header_cache = NULL;      /* Disable caching */    /*     * Then, allocate the priv field. This encloses the statistics     * and a few private fields.     */    dev->priv = kmalloc(sizeof(struct snull_priv), GFP_KERNEL);    if (dev->priv == NULL)        return -ENOMEM;    memset(dev->priv, 0, sizeof(struct snull_priv));    spin_lock_init (& ((struct snull_priv *) dev->priv)->lock);    return 0;}/* * The devices */#ifdef LINUX_24struct net_device snull_devs[2] = {    { init: snull_init, },  /* init, nothing more */    { init: snull_init, }};#else /* pre-2.4 */char snull_names[16];struct net_device snull_devs[2] = {    {        name: snull_names,        init: snull_init,  /* init function */    },    {        name: snull_names+8,        init: snull_init,            /* init function */    }};#endif /* LINUX_24 *//* * Finally, the module stuff */int init_module(void){    int result, i, device_present = 0;    snull_eth = eth; /* copy the cfg datum in the non-static place */    if (!snull_eth) { /* call them "sn0" and "sn1" */        strcpy(snull_devs[0].name, "sn0");        strcpy(snull_devs[1].name, "sn1");    } else { /* use automatic assignment */        strcpy(snull_devs[0].name, "eth%d");        strcpy(snull_devs[1].name, "eth%d");    }    for (i=0; i<2;  i++)        if ( (result = register_netdev(snull_devs + i)) )            printk("snull: error %i registering device \"%s\"\n",                   result, snull_devs[i].name);        else device_present++;#ifndef SNULL_DEBUG    EXPORT_NO_SYMBOLS;#endif    return device_present ? 0 : -ENODEV;}void cleanup_module(void){    int i;       for (i=0; i<2;  i++) {        kfree(snull_devs[i].priv);        unregister_netdev(snull_devs + i);    }    return;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
制服视频三区第一页精品| 欧美系列在线观看| 亚洲影视资源网| 欧美一区二区视频在线观看2022 | 亚洲va欧美va人人爽午夜| 日韩欧美一级二级| 色综合久久久久综合体桃花网| 美日韩黄色大片| 一区二区三区在线影院| 久久久亚洲高清| 欧美一级二级三级乱码| 在线一区二区三区四区| 高潮精品一区videoshd| 捆绑调教一区二区三区| 亚洲成av人影院在线观看网| 国产精品久久久久毛片软件| 欧美电影免费观看高清完整版在线| 在线日韩国产精品| 99精品欧美一区二区三区小说 | 91福利视频网站| 成人午夜视频免费看| 国产在线精品一区二区三区不卡| 天天综合日日夜夜精品| 亚洲欧美日韩久久| 国产精品人妖ts系列视频| 精品国产乱子伦一区| 欧美一区二区三区人| 欧美久久久久久蜜桃| 欧美日韩一区二区三区四区| 在线影视一区二区三区| 色偷偷88欧美精品久久久| 不卡av免费在线观看| 成人性生交大片免费看中文| 国产一区二区在线观看免费| 久久99久久99| 麻豆传媒一区二区三区| 蜜桃久久久久久| 激情六月婷婷久久| 国产一区视频在线看| 国内成人自拍视频| 国产精品亚洲一区二区三区妖精| 韩国欧美国产一区| 国产精品1区二区.| 国产成人免费9x9x人网站视频| 国产精品538一区二区在线| 国产一区二区三区免费看| 国产精品亚洲第一区在线暖暖韩国 | 亚洲国产精品99久久久久久久久| 国产欧美日韩中文久久| 国产女同性恋一区二区| 欧美韩国日本一区| 亚洲欧美在线视频| 亚洲卡通动漫在线| 亚洲国产成人高清精品| 男女男精品视频网| 国产一区二区三区久久悠悠色av| 国产成人精品一区二区三区四区| 成人性视频网站| 91黄色激情网站| 欧美一区二区三区系列电影| 久久伊人蜜桃av一区二区| 国产欧美一区视频| 亚洲乱码中文字幕| 日韩精彩视频在线观看| 国产乱人伦偷精品视频不卡| jlzzjlzz亚洲女人18| 精品视频色一区| 日韩欧美一区二区久久婷婷| 久久久不卡网国产精品一区| 亚洲天堂av老司机| 丝袜a∨在线一区二区三区不卡| 韩日欧美一区二区三区| 成人av片在线观看| 欧美性大战久久| 精品盗摄一区二区三区| 亚洲视频一二三| 琪琪久久久久日韩精品| a级高清视频欧美日韩| 欧美日韩国产a| 久久久久久久综合日本| 一区二区三区在线视频免费观看| 麻豆成人免费电影| 99九九99九九九视频精品| 欧美一区二区视频在线观看2022 | 成人免费视频一区二区| 91国偷自产一区二区使用方法| 欧美电影免费观看高清完整版在| 中文字幕在线不卡国产视频| 日韩av电影天堂| av电影在线观看一区| 日韩免费看的电影| 亚洲一区二区精品视频| 国产黑丝在线一区二区三区| 欧美吻胸吃奶大尺度电影| 国产色91在线| 天天影视涩香欲综合网| 白白色 亚洲乱淫| 欧美成人r级一区二区三区| 亚洲老妇xxxxxx| 懂色av中文一区二区三区| 91精品国产综合久久蜜臀| 亚洲欧美综合另类在线卡通| 国产一区 二区| 91精品国产一区二区| 亚洲美女精品一区| 国产成人鲁色资源国产91色综 | 色婷婷精品久久二区二区蜜臂av| 精品久久五月天| 亚洲第一精品在线| 91色乱码一区二区三区| 国产无一区二区| 黄色日韩网站视频| 91麻豆精品国产91| 亚洲一区二三区| 99v久久综合狠狠综合久久| 久久久久久久久久美女| 久久国产精品一区二区| 这里只有精品免费| 亚洲国产成人tv| 欧美怡红院视频| 亚洲一二三专区| 91久久人澡人人添人人爽欧美| 国产精品丝袜一区| 国产福利视频一区二区三区| 精品国产免费一区二区三区香蕉 | 99re6这里只有精品视频在线观看| 国产亚洲成aⅴ人片在线观看| 黄页视频在线91| 久久色在线视频| 国产一区不卡视频| 国产夜色精品一区二区av| 国产久卡久卡久卡久卡视频精品| 精品日产卡一卡二卡麻豆| 麻豆精品国产91久久久久久| 欧美不卡一区二区| 久久精品国产亚洲高清剧情介绍| 91精品久久久久久蜜臀| 青青草原综合久久大伊人精品| 91精品国产综合久久香蕉麻豆| 视频在线观看91| 在线电影欧美成精品| 免费在线看成人av| 精品国内片67194| 国产一区二区伦理片| 国产欧美一区二区精品性| 成人深夜在线观看| 亚洲男人电影天堂| 欧美日韩国产免费一区二区| 日本午夜一本久久久综合| 日韩视频在线永久播放| 精品亚洲国产成人av制服丝袜| 久久精品欧美日韩| 92精品国产成人观看免费| 亚洲激情六月丁香| 欧美美女一区二区| 久久精品国产久精国产| 久久久99精品免费观看| 99re视频精品| 日一区二区三区| 久久亚洲捆绑美女| 白白色亚洲国产精品| 亚洲国产综合人成综合网站| 日韩午夜中文字幕| 国产99精品视频| 亚洲国产日韩综合久久精品| 日韩精品专区在线影院重磅| 国产一区二区按摩在线观看| 亚洲欧美日韩国产综合| 制服.丝袜.亚洲.另类.中文 | 欧美一区二区三区免费观看视频 | 99久久国产综合色|国产精品| 一区二区三区欧美| 日韩欧美在线影院| 成人中文字幕在线| 亚洲成a人v欧美综合天堂下载| www成人在线观看| 91麻豆自制传媒国产之光| 日韩激情在线观看| 国产精品福利电影一区二区三区四区| 欧美色电影在线| 国产精品资源在线看| 一区二区三区在线看| 精品国产91九色蝌蚪| 色综合天天综合色综合av| 精品一区二区三区欧美| 亚洲精选免费视频| 精品国产成人系列| 欧美综合一区二区三区| 国产一区二区视频在线播放| 亚洲大尺度视频在线观看| 久久免费看少妇高潮| 精品1区2区3区| 大白屁股一区二区视频| 男女男精品网站| 亚洲午夜在线视频| 国产精品免费观看视频| 日韩欧美国产三级电影视频| 91福利资源站| 9i在线看片成人免费| 国模一区二区三区白浆|