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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? pipe.c

?? LINUX設(shè)備驅(qū)動2源代碼
?? C
字號:
/* * pipe.c -- fifo driver for scull * * Tested with 1.2 on the x86 * Tested with 2.0 on the x86, Sparc */ #ifndef __KERNEL__#  define __KERNEL__#endif#ifndef MODULE#  define MODULE#endif#define __NO_VERSION__#include <linux/module.h> /* get MOD_DEC_USE_COUNT, not the version string */#include <linux/version.h> /* need it for conditionals in scull.h */#include <linux/kernel.h> /* printk() */#include <linux/malloc.h> /* kmalloc() */#include <linux/fs.h>     /* everything... */#include <linux/proc_fs.h>#include <linux/errno.h>  /* error codes */#include <linux/types.h>  /* size_t */#include <linux/fcntl.h>#include <asm/segment.h>  /* memcpy to/from fs */#include "scull.h"        /* local definitions */typedef struct Scull_Pipe {    struct wait_queue *inq, *outq;  /* read and write queues */    char *buffer, *end;             /* begin of buf, end of buf */    int buffersize;                 /* used in pointer arithmetic */    char *rp, *wp;                  /* where to read, where to write */    int nreaders, nwriters;         /* number of openings for r/w */    struct fasync_struct *async_queue; /* asynchronous readers */} Scull_Pipe;/* * I don't use static symbols here, because register_symtab is called */int scull_p_nr_devs =    SCULL_P_NR_DEVS;  /* number of pipe devices */int scull_p_buffer =  SCULL_P_BUFFER; /* buffer size */Scull_Pipe *scull_p_devices;/* * Open and close */int scull_p_open (struct inode *inode, struct file *filp){    Scull_Pipe *dev;    int num = NUM(inode->i_rdev);    if (num >= scull_p_nr_devs) return -ENODEV;    dev = &scull_p_devices[num];    if (!dev->buffer) { /* allocate the buffer */        dev->buffer = kmalloc(scull_p_buffer, GFP_KERNEL);        if (!dev->buffer)            return -ENOMEM;    }    dev->buffersize = scull_p_buffer;    dev->end = dev->buffer + dev->buffersize;    dev->rp = dev->wp = dev->buffer; /* rd and wr from the beginning */    /* use f_mode,not  f_flags: it's cleaner (fs/open.c tells why) */    if (filp->f_mode & FMODE_READ)        dev->nreaders++;    if (filp->f_mode & FMODE_WRITE)        dev->nwriters++;    filp->private_data = dev;    MOD_INC_USE_COUNT;    return 0;}void scull_p_release (struct inode *inode, struct file *filp){    Scull_Pipe *dev = filp->private_data;    int scull_p_fasync (struct inode *inode, struct file *filp, int mode);    /* remove this filp from the asynchronously notified filp's */    scull_p_fasync(inode, filp, 0);    if (filp->f_mode & FMODE_READ)        dev->nreaders--;    if (filp->f_mode & FMODE_WRITE)        dev->nwriters--;    if (dev->nreaders + dev->nwriters == 0) {        kfree(dev->buffer);        dev->buffer = NULL; /* the other fields are not checked on open */    }    MOD_DEC_USE_COUNT;}/* * Data management: read and write */read_write_t scull_p_read (struct inode *inode, struct file *filp,                char *buf, count_t count){    Scull_Pipe *dev = filp->private_data;    while (dev->rp == dev->wp) { /* nothing to read */        if (filp->f_flags & O_NONBLOCK)            return -EAGAIN;        PDEBUG("\"%s\" reading: going to sleep\n",current->comm);        interruptible_sleep_on(&dev->inq);        if (current->signal & ~current->blocked) /* a signal arrived */          return -ERESTARTSYS; /* tell the fs layer to handle it */        /* otherwise loop */    }    /* ok, data is there, return something */    if (dev->wp > dev->rp)        count = min(count, dev->wp - dev->rp);    else /* the write pointer has wrapped, return data up to dev->end */        count = min(count, dev->end - dev->rp);    memcpy_tofs(buf, dev->rp, count);    dev->rp += count;    if (dev->rp == dev->end)        dev->rp = dev->buffer; /* wrapped */    /* finally, awake any writers and return */    wake_up_interruptible(&dev->outq);    PDEBUG("\"%s\" did read %li bytes\n",current->comm, (long)count);    return count;}read_write_t scull_p_write (struct inode *inode, struct file *filp,                const char *buf, count_t count){    Scull_Pipe *dev = filp->private_data;    /* left is the free space in the buffer, but it must be positive */    int left = (dev->rp + dev->buffersize - dev->wp) % dev->buffersize;    PDEBUG("write: left is %i\n",left);    while (left==1) { /* empty */        if (filp->f_flags & O_NONBLOCK)            return -EAGAIN;        PDEBUG("\"%s\" writing: going to sleep\n",current->comm);        interruptible_sleep_on(&dev->outq);        if (current->signal & ~current->blocked) /* a signal arrived */          return -ERESTARTSYS; /* tell the fs layer to handle it */        /* otherwise loop, but recalculate free space */        left = (dev->rp + dev->buffersize - dev->wp) % dev->buffersize;    }    /* ok, space is there, accept something */    if (dev->wp >= dev->rp) {        count = min(count, dev->end - dev->wp); /* up to end-of-buffer */        if (count == left) /* leave a hole, even if at e-o-b */            count--;    }    else /* the write pointer has wrapped, fill up to rp-1 */        count = min(count, dev->rp - dev->wp - 1);    PDEBUG("Going to accept %li bytes to %p from %p\n",           (long)count, dev->wp, buf);    memcpy_fromfs(dev->wp, buf, count);    dev->wp += count;    if (dev->wp == dev->end)        dev ->wp = dev->buffer; /* wrapped */    /* finally, awake any reader */    wake_up_interruptible(&dev->inq);  /* blocked in read() and select() */    if (dev->async_queue)        kill_fasync (dev->async_queue, SIGIO); /* asynchronous readers */    PDEBUG("\"%s\" did write %li bytes\n",current->comm, (long)count);    return count;}int scull_p_select (struct inode *inode, struct file *filp,                  int mode, select_table *table){    Scull_Pipe *dev = filp->private_data;    if (mode == SEL_IN) {        if (dev->rp != dev->wp) return 1; /* readable */        PDEBUG("Waiting to read\n");        select_wait(&dev->inq, table); /* wait for data */        return 0;    }    if (mode == SEL_OUT) {        /*         * the buffer is full if "wp" is right behind "rp",         * and the buffer is circular. "left" can't drop         * to 0, as this would be taken as empty buffer         */        int left = (dev->rp + dev->buffersize - dev->wp) % dev->buffersize;        if (left>1) return 1; /* writable */        PDEBUG("Waiting to write\n");        select_wait(&dev->outq, table); /* wait for free space */        return 0;    }    return 0; /* never exception-able */}#if LINUX_VERSION_CODE > VERSION_CODE(1,3,50)int scull_p_fasync (struct inode *inode, struct file *filp, int mode){    Scull_Pipe *dev = filp->private_data;    return fasync_helper(inode, filp, mode, &dev->async_queue);}#else /* not implemented */int scull_p_fasync (struct inode *inode, struct file *filp, int mode){    return 0;}#endifint scull_p_lseek (struct inode *inode, struct file *filp,                 off_t off, int whence){    return -ESPIPE; /* unseekable */}#ifdef SCULL_USE_PROCint scull_read_p_mem(char *buf, char **start, off_t offset,                   int len, int unused){    int i;    Scull_Pipe *p;    #define LIMIT (PAGE_SIZE-200) /* don't print any more after this size */    len = sprintf(buf, "Default buffersize is %i\n", scull_p_buffer);    for(i = 0; i<scull_p_nr_devs; i++) {        if (len > LIMIT) break;        p = &scull_p_devices[i];        len += sprintf(buf+len, "\nDevice %i: %p\n", i, p);        len += sprintf(buf+len, "   Queues: %p %p\n", p->inq, p->outq);        len += sprintf(buf+len, "   Buffer: %p to %p (%i bytes)\n",                       p->buffer, p->end, p->buffersize);        len += sprintf(buf+len, "   rp %p   wp %p\n", p->rp, p->wp);        len += sprintf(buf+len, "   readers %i   writers %i\n",                       p->nreaders, p->nwriters);    }    return len;}struct proc_dir_entry scull_proc_p_entry = {        0,                 /* low_ino: the inode -- dynamic */        9, "scullpipe",     /* len of name and name */        S_IFREG | S_IRUGO, /* mode */        1, 0, 0,           /* nlinks, owner, group */        0, NULL,           /* size - unused; operations -- use default */        &scull_read_p_mem,   /* function used to read data */        /* nothing more */    };#endif/* * The file operations for the pipe device * (some are overlayed with bare scull) */struct file_operations scull_pipe_fops = {    scull_p_lseek,    scull_p_read,    scull_p_write,    NULL,          /* scull_p_readdir */    scull_p_select,    scull_ioctl,    NULL,          /* scull_p_mmap */    scull_p_open,    scull_p_release,    NULL,          /* scull_p_fsync */    scull_p_fasync,                   /* nothing more, fill with NULLs */};int scull_p_init(void){    scull_p_devices = kmalloc(scull_p_nr_devs * sizeof(Scull_Pipe),                              GFP_KERNEL);    if (scull_p_devices == NULL)        return -ENOMEM;    memset(scull_p_devices, 0, scull_p_nr_devs * sizeof(Scull_Pipe));#ifdef SCULL_USE_PROC    proc_register_dynamic(&proc_root, &scull_proc_p_entry);#endif    return 0;}void scull_p_cleanup(void) /* called by cleanup_module */{    int i;    for (i=0; i < scull_p_nr_devs; i++) {        if (scull_p_devices[i].buffer)            kfree(scull_p_devices[i].buffer);    }    kfree(scull_p_devices);#ifdef SCULL_USE_PROC    proc_unregister(&proc_root, scull_proc_p_entry.low_ino);#endif    return;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国内欧美视频一区二区| 一区二区三区精密机械公司| 人人狠狠综合久久亚洲| 欧美一区二区三区系列电影| 日韩av电影天堂| 欧美一级在线视频| 国产在线视频一区二区三区| 久久久久国产精品人| 不卡av免费在线观看| 国产精品高清亚洲| 欧美三级中文字幕| 激情综合网最新| 国产精品免费网站在线观看| 91看片淫黄大片一级| 午夜亚洲国产au精品一区二区| 777xxx欧美| 大胆亚洲人体视频| 亚洲一二三四区不卡| 欧美一级日韩免费不卡| 国产精品2024| 五月婷婷久久综合| 日本一区二区综合亚洲| 91激情五月电影| 国产精品原创巨作av| 亚洲乱码一区二区三区在线观看| 717成人午夜免费福利电影| 国产精品66部| 亚洲一区二区三区美女| 久久午夜电影网| 91精品福利在线| 国产麻豆成人传媒免费观看| 一级做a爱片久久| 久久无码av三级| 欧美丰满一区二区免费视频| 成人av电影在线| 麻豆91在线观看| 一区二区三区高清| 亚洲国产精品黑人久久久| 欧美久久婷婷综合色| 成人开心网精品视频| 美脚の诱脚舐め脚责91| 亚洲欧美另类小说视频| 久久久久国产精品人| 欧美一区二区三区在线看| 91免费看`日韩一区二区| 奇米色一区二区| 亚洲激情五月婷婷| 国产欧美日韩在线视频| 日韩欧美一二三区| 欧美熟乱第一页| 色婷婷av一区二区三区大白胸| 久久99精品国产麻豆婷婷| 午夜欧美在线一二页| 亚洲精品乱码久久久久久| 国产精品天天摸av网| 亚洲精品一区在线观看| 欧美一级黄色录像| 精品视频资源站| 色呦呦一区二区三区| 成人av中文字幕| 国产99久久久国产精品潘金| 精品亚洲欧美一区| 久久不见久久见免费视频1| 亚洲一二三区不卡| 亚洲免费观看高清完整版在线观看熊| 国产日韩精品视频一区| 欧美电视剧在线观看完整版| 在线成人av影院| 欧美日韩国产色站一区二区三区| 在线观看国产一区二区| 97久久久精品综合88久久| 成人三级伦理片| 国产 欧美在线| 成人深夜福利app| 波多野结衣视频一区| 99久久99久久精品国产片果冻| 国产91清纯白嫩初高中在线观看 | 中文一区二区在线观看| 337p日本欧洲亚洲大胆精品| 亚洲精品一区二区三区四区高清| 精品少妇一区二区三区在线播放| 精品三级在线看| 久久久久久久av麻豆果冻| 久久蜜臀精品av| 国产精品二三区| 亚洲女同ⅹxx女同tv| 亚洲一区二区美女| 日本在线不卡视频| 国产一区二区三区美女| 国产福利一区二区三区视频 | 亚洲一区二区三区四区的| 亚洲444eee在线观看| 日本美女一区二区三区| 国产九九视频一区二区三区| 成人免费视频视频在线观看免费| 99久久久国产精品| 欧美乱妇一区二区三区不卡视频| 欧美丰满一区二区免费视频| 2024国产精品| 亚洲人成影院在线观看| 亚洲aⅴ怡春院| 国产一区二区0| 91在线视频观看| 欧美日韩精品福利| 久久午夜老司机| 一区二区三区在线看| 久久99精品久久久久婷婷| av在线免费不卡| 3d成人h动漫网站入口| 久久先锋影音av鲁色资源网| 亚洲免费观看视频| 九九视频精品免费| 色婷婷综合久久久中文一区二区 | 国产一区二区三区免费在线观看| 成人激情免费视频| 欧美精品aⅴ在线视频| 国产色一区二区| 日韩黄色小视频| 成人精品高清在线| 91精品国产综合久久久久久 | 欧美性猛片xxxx免费看久爱| 日韩美女在线视频| 亚洲免费观看高清完整版在线观看熊 | 亚洲小说春色综合另类电影| 国产一区免费电影| 欧美精品日韩精品| 亚洲人成电影网站色mp4| 日韩不卡一区二区三区| k8久久久一区二区三区 | 国产精品中文有码| 精品视频全国免费看| 国产女人18毛片水真多成人如厕| 午夜精品久久久久久久99樱桃| 成人三级伦理片| 精品国产乱码久久久久久闺蜜| 亚洲乱码国产乱码精品精小说| 国产精品123| 精品理论电影在线观看| 午夜免费欧美电影| 99国产精品视频免费观看| 久久综合九色欧美综合狠狠| 午夜日韩在线电影| 欧美专区日韩专区| 国产精品嫩草影院com| 国产一区二区三区在线观看免费 | 一本久久a久久精品亚洲| 久久男人中文字幕资源站| 美女视频黄频大全不卡视频在线播放| 91欧美一区二区| 成人欧美一区二区三区1314 | 一区二区国产视频| 成人免费福利片| 国产欧美一区二区三区在线老狼| 青青草国产成人99久久| 欧美日韩和欧美的一区二区| 亚洲二区视频在线| 99久久国产综合精品女不卡| 久久精品这里都是精品| 久久国产三级精品| 日韩欧美在线观看一区二区三区| 亚洲国产人成综合网站| 91成人国产精品| 一区二区三区欧美激情| 91色在线porny| 一区二区在线观看不卡| 色成人在线视频| 亚洲日本va在线观看| 91蜜桃婷婷狠狠久久综合9色| 国产精品麻豆视频| 91色九色蝌蚪| 夜夜嗨av一区二区三区四季av| 91久久久免费一区二区| 亚洲狠狠爱一区二区三区| 7777精品伊人久久久大香线蕉经典版下载 | 精品人在线二区三区| 日韩福利视频网| 精品国产伦一区二区三区观看方式| 另类欧美日韩国产在线| 精品福利视频一区二区三区| 韩国一区二区视频| 国产日韩亚洲欧美综合| 成人手机在线视频| 一区二区在线观看视频在线观看| 欧美日韩在线观看一区二区| 日韩成人一区二区三区在线观看| 欧美一级二级三级乱码| 麻豆精品在线看| 国产三级欧美三级| av资源网一区| 午夜亚洲国产au精品一区二区 | 亚洲精品一区二区三区蜜桃下载| 国产成人在线免费观看| 国产精品系列在线| 在线观看欧美日本| 韩国理伦片一区二区三区在线播放| 国产日韩欧美不卡| 精品视频一区三区九区| 久久69国产一区二区蜜臀| 亚洲国产精品成人久久综合一区| 91国内精品野花午夜精品|