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

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

?? snull.c

?? linux device driver源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
     * Ethhdr is 14 bytes, but the kernel arranges for iphdr     * to be aligned (i.e., ethhdr is unaligned)     */    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);    priv = (struct snull_priv *) dest->priv;    priv->status = SNULL_RX_INTR;    priv->rx_packetlen = len;    priv->rx_packetdata = buf;    snull_interrupt(0, dest, NULL);    priv = (struct snull_priv *) dev->priv;    priv->status = SNULL_TX_INTR;    priv->tx_packetlen = len;    priv->tx_packetdata = buf;    if (lockup && ((priv->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) priv->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;    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 0; /* Our simple device can not 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);    return;}/* * 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 int 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;#ifndef LINUX_20                            dev->hard_header_cache = NULL;      /* Disable caching */#endif                                      SET_MODULE_OWNER(dev);    /*     * 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 snull_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 */#ifdef LINUX_24                                                         strcpy(snull_devs[0].name, "eth%d");        strcpy(snull_devs[1].name, "eth%d");#else                                                                   snull_devs[0].name[0] = snull_devs[1].name[0] = ' ';    #endif                                                              }    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 snull_cleanup(void){    int i;       for (i=0; i<2;  i++) {        kfree(snull_devs[i].priv);        unregister_netdev(snull_devs + i);    }    return;}module_init(snull_init_module);module_exit(snull_cleanup);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲第四色夜色| 亚洲女人小视频在线观看| 91啪九色porn原创视频在线观看| 日韩av电影免费观看高清完整版在线观看| 亚洲精品成a人| 1024成人网| 亚洲一区二区三区免费视频| 亚洲青青青在线视频| 亚洲欧美偷拍三级| 亚洲乱码国产乱码精品精小说 | 色悠悠久久综合| 91在线看国产| 91福利在线观看| 欧美色男人天堂| 在线不卡的av| 久久先锋影音av鲁色资源| 久久亚洲捆绑美女| 欧美国产精品一区二区| 国产精品电影院| 亚洲综合久久av| 免费三级欧美电影| 国产精品中文字幕欧美| av毛片久久久久**hd| 一本色道亚洲精品aⅴ| 91精品在线观看入口| 久久久久久久久久美女| 国产精品电影院| 五月婷婷欧美视频| 国产一区高清在线| 成人精品电影在线观看| 欧美三级中文字| 2019国产精品| 亚洲女同一区二区| 精品在线播放午夜| 99精品黄色片免费大全| 91.麻豆视频| 国产精品欧美一级免费| 亚洲大片免费看| 国产一区二区不卡老阿姨| 99免费精品在线| 日韩亚洲欧美成人一区| 国产精品美日韩| 日韩二区三区四区| 91在线观看视频| 日韩欧美久久久| 夜夜嗨av一区二区三区中文字幕| 免费xxxx性欧美18vr| 99riav一区二区三区| 日韩女优毛片在线| 一区二区三区欧美| 成人激情综合网站| 久久综合五月天婷婷伊人| 亚洲动漫第一页| av不卡在线观看| 久久久亚洲精品石原莉奈| 亚洲高清久久久| 91成人国产精品| 亚洲欧美日韩国产中文在线| 国产一区二区三区蝌蚪| 91精品国产综合久久久蜜臀图片| 亚洲精品视频在线看| 国产成人午夜精品5599 | 精品对白一区国产伦| 亚洲高清免费在线| 在线观看一区二区精品视频| 国产女人水真多18毛片18精品视频 | 亚洲人成人一区二区在线观看| 久久99久久精品| 91精品国产色综合久久久蜜香臀| 亚洲欧美自拍偷拍色图| 国产不卡视频一区| 久久久久九九视频| 精品亚洲porn| 欧美精品一区二区三区高清aⅴ | 欧美嫩在线观看| 亚洲国产aⅴ天堂久久| 色香蕉成人二区免费| 欧美国产视频在线| 粉嫩久久99精品久久久久久夜| 精品伦理精品一区| 国产麻豆一精品一av一免费| 欧美成人猛片aaaaaaa| 久久机这里只有精品| 欧美成人官网二区| 国产一区二区三区电影在线观看 | 国产精品久久久久婷婷二区次| 国产麻豆一精品一av一免费| 久久先锋资源网| 粉嫩欧美一区二区三区高清影视| 国产午夜精品久久| 99久久精品久久久久久清纯| 国产精品久久久久久久久免费樱桃| 成人手机在线视频| 亚洲视频网在线直播| 欧美日韩一区久久| 人妖欧美一区二区| 精品福利av导航| 99久久精品情趣| 亚洲18色成人| 日韩女优制服丝袜电影| 国产精品资源网| 亚洲精品欧美激情| 91精品国产欧美一区二区成人| 免费黄网站欧美| 国产精品久久久久天堂| 欧美三级视频在线观看| 激情综合色丁香一区二区| 国产精品日韩成人| 这里只有精品免费| 风间由美一区二区av101| 亚洲一区二区三区四区在线观看 | 中文字幕欧美区| 欧美亚洲精品一区| 狠狠色狠狠色综合系列| 亚洲色图在线视频| 精品欧美一区二区在线观看| 成人a区在线观看| 蜜桃av一区二区| 亚洲欧美另类在线| 精品久久久久久久人人人人传媒 | 午夜精品久久久久久| 国产亚洲精品aa午夜观看| 欧美少妇一区二区| 粉嫩在线一区二区三区视频| 亚洲成人一区二区在线观看| 国产色爱av资源综合区| 欧美性猛交xxxx乱大交退制版 | 亚洲精品亚洲人成人网在线播放| 日韩一级片在线播放| 色94色欧美sute亚洲线路二| 久久www免费人成看片高清| 亚洲一线二线三线视频| 国产人伦精品一区二区| 日韩一级免费一区| 欧美天堂亚洲电影院在线播放| 国产精品99久久久久久有的能看 | 亚洲卡通动漫在线| 国产无人区一区二区三区| 4hu四虎永久在线影院成人| 色系网站成人免费| 国产成人亚洲综合a∨婷婷图片| 青青草视频一区| 天堂久久一区二区三区| 亚洲码国产岛国毛片在线| 中文幕一区二区三区久久蜜桃| 欧美一区二区三区四区在线观看| 91网页版在线| www.亚洲人| 成人丝袜视频网| 国产精品一区二区无线| 久久丁香综合五月国产三级网站| 性久久久久久久久久久久| 一区二区三区在线免费观看| 亚洲天堂免费看| 日韩一区在线播放| 国产精品毛片高清在线完整版| 欧美精品一区二区三区在线播放| 欧美一区二区美女| 91精品蜜臀在线一区尤物| 制服丝袜日韩国产| 欧美精品久久一区| 91麻豆精品91久久久久久清纯 | 亚洲欧美在线高清| 中文字幕日韩一区| 依依成人精品视频| 亚洲黄色小视频| 图片区小说区国产精品视频| 樱桃国产成人精品视频| 亚洲综合色自拍一区| 亚洲成人综合视频| 另类小说一区二区三区| 精品在线一区二区| 成人毛片老司机大片| 成人精品在线视频观看| 91麻豆蜜桃一区二区三区| 欧洲精品视频在线观看| 7777精品伊人久久久大香线蕉经典版下载 | 久久99久久久久久久久久久| 国产在线视视频有精品| 国产黄色成人av| 色综合 综合色| 91精品国产一区二区| 国产色91在线| 亚洲国产三级在线| 蜜臀91精品一区二区三区 | 亚洲美女屁股眼交| 日韩国产欧美在线播放| 国产成人在线网站| 91久久精品日日躁夜夜躁欧美| 在线播放日韩导航| 久久久久久久网| 亚洲一区二区成人在线观看| 久久精品久久综合| 91论坛在线播放| 欧美一区二区三区啪啪| 国产精品午夜在线| 蜜臀av性久久久久蜜臀aⅴ| 99久久亚洲一区二区三区青草| 678五月天丁香亚洲综合网| 国产视频一区在线观看|