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

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

?? snull.c.orig

?? ldd1的源代碼
?? ORIG
?? 第 1 頁 / 共 2 頁
字號:
/* * snull.c --  the Simple Network Utility * * $Id: snull.c,v 1.7 2000/11/29 14:08:27 rubini Exp $ */#ifndef __KERNEL__#  define __KERNEL__#endif#ifndef MODULE#  define MODULE#endif#include <linux/config.h>#include <linux/module.h>#include <linux/version.h>#include <linux/sched.h>#include <linux/kernel.h> /* printk() */#include <linux/malloc.h> /* kmalloc() */#include <linux/errno.h>  /* error codes */#include <linux/types.h>  /* size_t */#include <linux/interrupt.h> /* mark_bh */#include <linux/in.h>#include <linux/netdevice.h>   /* struct device, and other headers */#include <linux/etherdevice.h> /* eth_type_trans */#include <linux/ip.h>          /* struct iphdr */#include <linux/tcp.h>         /* struct tcphdr */#include <linux/skbuff.h>#include "snull.h"#ifdef LINUX_20#  include <linux/if_ether.h>#  define net_device_stats enet_statistics#else#  include <linux/in6.h>#endif#include <asm/checksum.h>MODULE_AUTHOR("Alessandro Rubini");/* This is a load-time options */static int eth = 0; /* Call yourself "ethX". Default is "sn0"/"sn1" */MODULE_PARM(eth, "i");/* * Transmitter lockup simulation, normally disabled. */static int lockup = 0;MODULE_PARM(lockup, "i");#ifdef HAVE_TX_TIMEOUTstatic int timeout = SNULL_TIMEOUT;MODULE_PARM(timeout, "i");#endifint snull_eth;/* * This structure is private to each device. It is used to pass * packets in and out, so there is place for a packet */struct snull_priv {    struct net_device_stats stats;    int status;    int rx_packetlen;    u8 *rx_packetdata;    int tx_packetlen;    u8 *tx_packetdata;    struct sk_buff *skb;    spinlock_t lock;};extern struct net_device snull_devs[];void snull_tx_timeout (struct net_device *dev);        /* * Open and close */int snull_open(struct net_device *dev){    MOD_INC_USE_COUNT;        /* request_region(), request_irq(), ....  (like fops->open) */#if 0 && defined(LINUX_20)    /*     * We have no irq line, otherwise this assignment can be used to     * grab a non-shared interrupt. To share interrupt lines use     * the dev_id argument of request_irq. See snull_interrupt below.     */    irq2dev_map[dev->irq] = dev;#endif    /*      * Assign the hardware address of the board: use "\0SNULx", where     * x is 0 or 1. The first byte is '\0' to avoid being a multicast     * address (the first byte of multicast addrs is odd).     */    memcpy(dev->dev_addr, "\0SNUL0", ETH_ALEN);    dev->dev_addr[ETH_ALEN-1] += (dev - snull_devs); /* the number */    netif_start_queue(dev);    return 0;}int snull_release(struct net_device *dev){    /* release ports, irq and such -- like fops->close */    netif_stop_queue(dev); /* can't transmit any more */    MOD_DEC_USE_COUNT;    return 0;}/* * Configuration changes (passed on by ifconfig) */int snull_config(struct net_device *dev, struct ifmap *map){    if (dev->flags & IFF_UP) /* can't act on a running interface */        return -EBUSY;    /* Don't allow changing the I/O address */    if (map->base_addr != dev->base_addr) {        printk(KERN_WARNING "snull: Can't change I/O address\n");        return -EOPNOTSUPP;    }    /* Allow changing the IRQ */    if (map->irq != dev->irq) {        dev->irq = map->irq;        /* request_irq() is delayed to open-time */    }    /* ignore other fields */    return 0;}/* * Receive a packet: retrieve, encapsulate and pass over to upper levels */void snull_rx(struct net_device *dev, int len, unsigned char *buf){    struct sk_buff *skb;    struct snull_priv *privp = (struct snull_priv *)dev->priv;    /*     * The packet has been retrieved from the transmission     * medium. Build an skb around it, so upper layers can handle it     */    skb = dev_alloc_skb(len+2);    if (!skb) {        printk("snull rx: low on mem - packet dropped\n");        privp->stats.rx_dropped++;        return;    }    skb_reserve(skb, 2); /* align IP on 16B boundary */      memcpy(skb_put(skb, len), buf, len);    /* Write metadata, and then pass to the receive level */    skb->dev = dev; /* FIXME: "dev" or "tx_dev" ??? */    skb->protocol = eth_type_trans(skb, dev);    skb->ip_summed = CHECKSUM_UNNECESSARY; /* don't check it */    privp->stats.rx_packets++;    privp->stats.rx_bytes += len;    netif_rx(skb);    return;}            /* * The typical interrupt entry point */#ifdef LINUX_24void snull_interrupt(int irq, void *dev_id, struct pt_regs *regs){    int statusword;    struct snull_priv *privptr;    /*     * As usual, check the "device" pointer for shared handlers.     * Then assign "struct device *dev"     */    struct net_device *dev = (struct net_device *)dev_id;    /* ... and check with hw if it's really ours */    if (!dev /*paranoid*/ ) return;    /* Lock the device */    privptr = (struct snull_priv *)(dev->priv);    spin_lock(&privptr->lock);    /* retrieve statusword: real netdevices use I/O instructions */    statusword = privptr->status;    if (statusword & SNULL_RX_INTR) {        /* send it to snull_rx for handling */        snull_rx(dev, privptr->rx_packetlen, privptr->rx_packetdata);    }    if (statusword & SNULL_TX_INTR) {        /* a transmission is over: free the skb */        privptr->stats.tx_packets++;        privptr->stats.tx_bytes += privptr->tx_packetlen;        dev_kfree_skb(privptr->skb);    }    /* Unlock the device and we are done */    spin_unlock(&privptr->lock);    return;}#else /* LINUX_22 or earlier */void snull_interrupt(int irq, void *dev_id, struct pt_regs *regs){    int statusword;    struct snull_priv *privptr;    /*     * As usual, check the "device" pointer for shared handlers.     * Then assign "struct device *dev"     */#if 0 && defined(LINUX_20)    /* This is the way to do things for non-shared handlers */    struct device *dev = (struct device *)(irq2dev_map[irq]);#else    /* Otherwise use this SA_SHIRQ-safe approach */    struct net_device *dev = (struct net_device *)dev_id;    /* ... and check with hw if it's really ours */#endif    if (!dev /*paranoid*/ ) return;    /* Lock the device */    privptr = (struct snull_priv *)(dev->priv);    spin_lock(&privptr->lock);    dev->interrupt = 1;    /* retrieve statusword: real netdevices use inb() or inw() */    statusword = privptr->status;    if (statusword & SNULL_RX_INTR) {        /* send it to snull_rx for handling */        snull_rx(dev, privptr->rx_packetlen, privptr->rx_packetdata);    }    if (statusword & SNULL_TX_INTR) {        /* a transmission is over: tell we are no more busy */        privptr->stats.tx_packets++;#ifndef LINUX_20        privptr->stats.tx_bytes += privptr->tx_packetlen;#endif        dev_kfree_skb(privptr->skb);    }    spin_unlock(&privptr->lock);    dev->interrupt = 0;    return;}#endif /* LINUX_22 or earlier *//* * Transmit a packet (low level interface) */void snull_hw_tx(char *buf, int len, struct net_device *dev){    /*     * This function deals with hw details. This interface loops     * back the packet to the other snull interface (if any).     * In other words, this function implements the snull behaviour,     * while all other procedures are rather device-independent     */    struct iphdr *ih;    struct net_device *dest;    struct snull_priv *privp;    u32 *saddr, *daddr;    /* I am paranoid. Ain't I? */    if (len < sizeof(struct ethhdr) + sizeof(struct iphdr)) {        printk("snull: Hmm... packet too short (%i octets)\n",               len);        return;    }    if (0) { /* enable this conditional to look at the data */        int i;        PDEBUG("len is %i\n" KERN_DEBUG "data:",len);        for (i=14 ; i<len; i++)            printk(" %02x",buf[i]&0xff);        printk("\n");    }    /*     * Ethhdr is 14 bytes, but the kernel arranges for iphdr     * to be aligned (i.e., ethhdr is unaligned)     */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区在线| 亚洲免费在线看| 麻豆一区二区三| 久久综合九色综合欧美就去吻| 国产综合久久久久久久久久久久| 久久综合av免费| 99re6这里只有精品视频在线观看| 一区精品在线播放| 欧美日韩一卡二卡| 美女视频网站久久| 久久久久久一级片| 91亚洲国产成人精品一区二三| 伊人婷婷欧美激情| 3d动漫精品啪啪一区二区竹菊 | 成人久久视频在线观看| 国产精品成人免费精品自在线观看| 日本精品视频一区二区| 日韩电影在线免费观看| 久久久高清一区二区三区| 99久免费精品视频在线观看| 午夜欧美2019年伦理| 精品国产凹凸成av人网站| 92精品国产成人观看免费| 性做久久久久久久久| 国产亚洲女人久久久久毛片| 99久久久久久| 国产综合色在线| 亚洲第四色夜色| 国产欧美精品一区二区色综合朱莉| 欧美亚洲丝袜传媒另类| 国产一区二区三区最好精华液| 亚洲欧洲av一区二区三区久久| 欧美一区永久视频免费观看| 成人av电影观看| 免费成人在线网站| 一区二区三区四区蜜桃| 久久免费午夜影院| 欧美日韩第一区日日骚| 顶级嫩模精品视频在线看| 亚洲国产另类av| 久久久.com| 欧美一区二区三区影视| 97久久超碰国产精品| 国产一区二区在线视频| 午夜激情一区二区| 亚洲视频一二三区| 国产三级一区二区| 欧美成人r级一区二区三区| 一本大道av一区二区在线播放| 国精产品一区一区三区mba视频 | 欧美一区日本一区韩国一区| 不卡电影免费在线播放一区| 美日韩一区二区三区| 亚洲自拍偷拍av| 国产精品毛片a∨一区二区三区| 欧美精品一区二区三| 欧美日韩一级二级| 色综合久久久久久久久| 丁香亚洲综合激情啪啪综合| 激情亚洲综合在线| 免费av成人在线| 亚洲va韩国va欧美va| 一区二区免费看| ...xxx性欧美| 亚洲欧洲日韩在线| 国产精品嫩草影院av蜜臀| 337p粉嫩大胆噜噜噜噜噜91av | 7777精品伊人久久久大香线蕉完整版| 一本久久精品一区二区| 成人久久18免费网站麻豆 | 狠狠色2019综合网| 蜜桃精品视频在线观看| 日本亚洲一区二区| 天堂精品中文字幕在线| 婷婷成人激情在线网| 偷拍日韩校园综合在线| 日产精品久久久久久久性色| 日韩高清不卡一区二区三区| 日本欧美久久久久免费播放网| 欧美aⅴ一区二区三区视频| 日日嗨av一区二区三区四区| 爽爽淫人综合网网站| 天堂在线亚洲视频| 免费在线成人网| 久久精品国产成人一区二区三区 | 久久精品99国产精品| 美腿丝袜亚洲三区| 国产毛片精品国产一区二区三区| 国产精品一区二区在线看| 国产一区二区三区免费播放 | 99久久精品免费看国产免费软件| 99精品视频一区| 欧美伊人久久久久久久久影院 | 免费高清视频精品| 国产自产视频一区二区三区| 国产69精品久久久久毛片| heyzo一本久久综合| 欧美亚男人的天堂| 欧美电影一区二区| 久久久久久夜精品精品免费| 国产精品美女久久久久久 | 视频一区二区国产| 精品一区中文字幕| 99久久精品国产麻豆演员表| 欧美性大战久久久久久久蜜臀| 91精品国产一区二区人妖| 久久精品视频免费观看| 亚洲色图欧美激情| 秋霞午夜鲁丝一区二区老狼| 国产ts人妖一区二区| 欧美色图片你懂的| 国产亚洲一区二区三区在线观看| 亚洲欧美日韩小说| 日本美女一区二区| 99这里只有精品| 91精品国产色综合久久不卡蜜臀 | 日韩一区二区三区免费观看| 国产日韩精品一区二区浪潮av| 夜夜揉揉日日人人青青一国产精品 | 亚洲一区二区三区四区在线观看| 国模冰冰炮一区二区| 91福利国产精品| 欧美激情在线观看视频免费| 香蕉久久一区二区不卡无毒影院| 国产精品综合在线视频| 欧美高清dvd| 国产精品成人免费精品自在线观看| 日韩电影在线免费| 色婷婷久久久亚洲一区二区三区| 久久午夜免费电影| 亚洲成人精品一区二区| 99精品国产91久久久久久| 日韩女优制服丝袜电影| 亚洲丝袜制服诱惑| 国产传媒一区在线| 日韩手机在线导航| 亚洲成人久久影院| 色一情一伦一子一伦一区| 久久精品欧美日韩精品 | 九九精品视频在线看| 色8久久精品久久久久久蜜| 国产午夜精品一区二区 | 国产调教视频一区| 久久电影网电视剧免费观看| 在线观看精品一区| 中文字幕在线不卡国产视频| 国内国产精品久久| 日韩亚洲欧美一区二区三区| 亚洲国产精品视频| 色综合久久久久综合| 国产精品美女一区二区在线观看| 精品一区二区影视| 欧美一级久久久| 天堂成人国产精品一区| 欧美丝袜丝交足nylons| 亚洲欧美日韩在线播放| 91在线观看一区二区| 国产精品国产自产拍高清av王其 | 色哟哟国产精品| 日韩美女啊v在线免费观看| 国产精品99久久久久久有的能看 | 激情综合网av| 日韩亚洲欧美中文三级| 免费在线成人网| 日韩免费高清电影| 韩国三级中文字幕hd久久精品| 欧美成人三级在线| 麻豆国产91在线播放| 精品国产一二三| 精品一区二区三区在线观看国产| 日韩午夜三级在线| 精品中文字幕一区二区小辣椒| 欧美大片国产精品| 久久精品国产99国产精品| 欧美大度的电影原声| 激情久久久久久久久久久久久久久久| 欧美电影免费观看完整版| 国产一区欧美日韩| 国产精品视频一区二区三区不卡| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 亚洲天堂成人网| 在线视频国内自拍亚洲视频| 午夜精品123| 欧美精品一区二区三| 成人动漫视频在线| 亚洲在线观看免费视频| 欧美精三区欧美精三区| 久久精品久久99精品久久| 久久久亚洲精品一区二区三区| 不卡的av网站| 亚洲午夜电影网| 久久综合精品国产一区二区三区 | 欧美经典三级视频一区二区三区| 成+人+亚洲+综合天堂| 亚洲在线观看免费视频| 日韩欧美国产一区二区三区 | 成人免费不卡视频| 亚洲成人动漫在线免费观看| 欧美tickling网站挠脚心| 不卡电影一区二区三区|