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

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

?? snull.c

?? linux設備驅動第二版例子程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * snull.c --  the Simple Network Utility * * Copyright (C) 2001 Alessandro Rubini and Jonathan Corbet * Copyright (C) 2001 O'Reilly & Associates * * The source code in this file can be freely used, adapted, * and redistributed in source or binary form, so long as an * acknowledgment appears in derived source files.  The citation * should list that the code comes from the book "Linux Device * Drivers" by Alessandro Rubini and Jonathan Corbet, published * by O'Reilly & Associates.   No warranty is attached; * we cannot take responsibility for errors or fitness for use. * * $Id: snull.c,v 1.17 2001/07/18 22:28:18 rubini Exp $ */#ifndef __KERNEL__#  define __KERNEL__#endif#ifndef MODULE#  define MODULE#endif#include <linux/config.h>#include <linux/module.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 */#ifndef LINUX_24                    dev->start = 1;             #endif                              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 */#ifndef LINUX_24                    dev->start = 0;             #endif                              MOD_DEC_USE_COUNT;    /* if irq2dev_map was used (2.0 kernel), zero the entry here */    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 *priv = (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");        priv->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;    skb->protocol = eth_type_trans(skb, dev);    skb->ip_summed = CHECKSUM_UNNECESSARY; /* don't check it */    priv->stats.rx_packets++;#ifndef LINUX_20                            priv->stats.rx_bytes += len;#endif                                      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 *priv;    /*     * 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 */    priv = (struct snull_priv *) dev->priv;    spin_lock(&priv->lock);    /* retrieve statusword: real netdevices use I/O instructions */    statusword = priv->status;    if (statusword & SNULL_RX_INTR) {        /* send it to snull_rx for handling */        snull_rx(dev, priv->rx_packetlen, priv->rx_packetdata);    }    if (statusword & SNULL_TX_INTR) {        /* a transmission is over: free the skb */        priv->stats.tx_packets++;        priv->stats.tx_bytes += priv->tx_packetlen;        dev_kfree_skb(priv->skb);    }    /* Unlock the device and we are done */    spin_unlock(&priv->lock);    return;}#else /* LINUX_22 or earlier */void snull_interrupt(int irq, void *dev_id, struct pt_regs *regs){    int statusword;    struct snull_priv *priv;    /*     * 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 */    priv = (struct snull_priv *) dev->priv;    spin_lock(&priv->lock);    dev->interrupt = 1;    /* retrieve statusword: real netdevices use inb() or inw() */    statusword = priv->status;    if (statusword & SNULL_RX_INTR) {        /* send it to snull_rx for handling */        snull_rx(dev, priv->rx_packetlen, priv->rx_packetdata);    }    if (statusword & SNULL_TX_INTR) {        /* a transmission is over: tell we are no more busy */        priv->stats.tx_packets++;#ifndef LINUX_20        priv->stats.tx_bytes += priv->tx_packetlen;#endif        dev_kfree_skb(priv->skb);    }    spin_unlock(&priv->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 *priv;    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");    }    /*

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丝袜美腿亚洲色图| 欧美综合天天夜夜久久| 99精品久久只有精品| 欧美精品乱人伦久久久久久| 国产亚洲人成网站| 日韩主播视频在线| 一本色道久久加勒比精品| 国产视频在线观看一区二区三区| 亚洲第一电影网| 色综合久久久久网| 久久久久久久久久久久久久久99 | 波多野结衣精品在线| 91精品一区二区三区在线观看| 国产精品美女久久久久久久久| 久久精品噜噜噜成人av农村| 欧美性猛交xxxxxxxx| 亚洲精选一二三| av福利精品导航| 中文字幕欧美日本乱码一线二线 | 国产v综合v亚洲欧| 日韩精品在线看片z| 日韩vs国产vs欧美| 欧美一区二区精美| 日本不卡123| 欧美一区永久视频免费观看| 亚洲国产精品一区二区www | 成人av综合在线| 欧美韩国日本不卡| 粉嫩一区二区三区性色av| 久久先锋资源网| 国产麻豆视频一区| 久久久精品综合| 国产成人激情av| 国产精品欧美综合在线| voyeur盗摄精品| 亚洲视频一区二区免费在线观看| aa级大片欧美| 一区二区在线电影| 欧美日韩美女一区二区| 日韩精品一级中文字幕精品视频免费观看| 欧洲另类一二三四区| 亚洲国产综合人成综合网站| 欧美色图片你懂的| 日本不卡视频一二三区| 久久中文字幕电影| 成人国产电影网| 一区二区欧美精品| 日韩一级完整毛片| 国产盗摄视频一区二区三区| 中文字幕一区二区三区在线观看 | 欧美精品xxxxbbbb| 理论片日本一区| 国产精品网站在线观看| 色8久久精品久久久久久蜜| 偷拍与自拍一区| 久久综合久久99| 一本到高清视频免费精品| 亚洲二区视频在线| www成人在线观看| 色婷婷av一区二区三区gif| 视频一区视频二区中文| 国产亚洲一本大道中文在线| 91丨porny丨国产入口| 日韩精品成人一区二区在线| 国产亚洲自拍一区| 欧美日韩视频一区二区| 国产a精品视频| 婷婷国产在线综合| 国产精品久久久久久久蜜臀| 欧美日高清视频| 国产69精品久久777的优势| 亚洲国产精品欧美一二99| 欧美大片在线观看一区二区| 91色婷婷久久久久合中文| 老色鬼精品视频在线观看播放| 国产精品久久久久久亚洲毛片| 欧美久久久久久久久久| 成人免费看黄yyy456| 蜜乳av一区二区| 亚洲一区二区在线免费观看视频| 2021久久国产精品不只是精品| 色猫猫国产区一区二在线视频| 韩国v欧美v日本v亚洲v| 亚洲国产精品久久艾草纯爱| 国产日韩亚洲欧美综合| 欧美一级日韩免费不卡| 色综合久久天天综合网| 成人网在线免费视频| 免费看日韩a级影片| 亚洲一区二区黄色| 成人免费一区二区三区视频 | 国产成人啪免费观看软件| 亚洲大型综合色站| 亚洲欧洲av色图| 国产欧美一区二区三区在线看蜜臀| 欧美日韩国产首页| 在线精品亚洲一区二区不卡| 成人av网址在线观看| 国产美女av一区二区三区| 久久不见久久见免费视频1| 婷婷久久综合九色国产成人| 亚洲图片一区二区| 亚洲国产日韩一级| 亚洲综合无码一区二区| 亚洲欧美福利一区二区| 中文字幕一区二区三区在线播放| 久久精品欧美一区二区三区不卡| 久久只精品国产| 国产亚洲美州欧州综合国| 国产三级三级三级精品8ⅰ区| 精品国产亚洲在线| 337p日本欧洲亚洲大胆色噜噜| 日韩欧美高清在线| 日韩午夜小视频| 精品国产污网站| 国产亚洲综合色| 国产精品久久久久永久免费观看 | 欧美大片在线观看| 欧美肥妇毛茸茸| 欧美亚洲国产怡红院影院| 色8久久精品久久久久久蜜| 在线观看欧美日本| 欧美精品乱码久久久久久| 777欧美精品| 精品免费视频一区二区| 精品福利一二区| 国产偷国产偷精品高清尤物| 国产日本亚洲高清| 国产精品第四页| 一区二区三区av电影| 日本欧美在线看| 国产自产v一区二区三区c| 成人自拍视频在线| 色一区在线观看| 91精品国产综合久久福利软件| 欧美videossexotv100| 欧美国产一区在线| 亚洲午夜一区二区三区| 麻豆91在线观看| 成人午夜视频网站| 欧美在线观看视频一区二区三区| 欧美人狂配大交3d怪物一区| 日韩美女视频在线| 亚洲国产精品t66y| 亚洲一区二区三区视频在线播放 | 久久精品亚洲精品国产欧美kt∨| 国产精品女主播av| 肉肉av福利一精品导航| 国产一区二区按摩在线观看| 99国产一区二区三精品乱码| 欧美日韩一区二区三区在线| 精品人伦一区二区色婷婷| 国产精品卡一卡二卡三| 日韩国产在线观看一区| 成人在线综合网站| 欧美一区二区三区日韩视频| 国产精品人成在线观看免费| 亚洲电影一区二区三区| 国产激情一区二区三区| 欧美日韩一区三区| 国产丝袜在线精品| 肉色丝袜一区二区| 91视频国产观看| 久久久久久久综合狠狠综合| 偷窥国产亚洲免费视频| 成人免费视频caoporn| 欧美一区二区三区婷婷月色 | caoporm超碰国产精品| 欧美精品乱人伦久久久久久| 椎名由奈av一区二区三区| 久久机这里只有精品| 色呦呦国产精品| 欧美极品xxx| 黑人巨大精品欧美一区| 欧美精品色综合| 亚洲精品国产精品乱码不99| 国产99久久久国产精品潘金| 欧美一区二区三级| 亚洲午夜久久久| 色婷婷国产精品| 亚洲视频一二区| 高清国产一区二区三区| 欧美精品一区在线观看| 精品系列免费在线观看| 69久久夜色精品国产69蝌蚪网| 亚洲欧美另类久久久精品2019| 成人综合在线视频| 久久久另类综合| 国产在线精品免费av| 日韩三级av在线播放| 三级影片在线观看欧美日韩一区二区| 99久久久国产精品| 亚洲人成亚洲人成在线观看图片| 成人在线一区二区三区| 中日韩av电影| 成人免费看的视频| 中文字幕一区二区5566日韩| 成人网在线播放| 中文字幕一区av| 色天天综合色天天久久|