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

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

?? spull.c

?? LINUX設(shè)備驅(qū)動(dòng)2源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/* * Block-driver specific functions *//* * Find the device for this request. */static Spull_Dev *spull_locate_device(const struct request *req){    int devno;    Spull_Dev *device;    /* Check if the minor number is in range */    devno = DEVICE_NR(req->rq_dev);    if (devno >= spull_devs) {        static int count = 0;        if (count++ < 5) /* print the message at most five times */            printk(KERN_WARNING "spull: request for unknown device\n");        return NULL;    }    device = spull_devices + devno;    return device;}/* * Perform an actual transfer. */static int spull_transfer(Spull_Dev *device, const struct request *req){    int size, minor = MINOR(req->rq_dev);    u8 *ptr;        ptr = device->data +            (spull_partitions[minor].start_sect + req->sector)*SPULL_HARDSECT;    size = req->current_nr_sectors*SPULL_HARDSECT;    /*     * Make sure that the transfer fits within the device.     */    if (req->sector + req->current_nr_sectors >                    spull_partitions[minor].nr_sects) {        static int count = 0;        if (count++ < 5)            printk(KERN_WARNING "spull: request past end of partition\n");        return 0;    }    /*     * Looks good, do the transfer.     */    switch(req->cmd) {        case READ:            memcpy(req->buffer, ptr, size); /* from spull to buffer */            return 1;        case WRITE:            memcpy(ptr, req->buffer, size); /* from buffer to spull */            return 1;        default:            /* can't happen */            return 0;        }}#ifdef LINUX_24void spull_request(request_queue_t *q)#else           void spull_request()#endif  {    Spull_Dev *device;    int status;    long flags;    while(1) {        INIT_REQUEST;  /* returns when queue is empty */        /* Which "device" are we using?  (Is returned locked) */        device = spull_locate_device (CURRENT);        if (device == NULL) {            end_request(0);            continue;        }	spin_lock_irqsave(&device->lock, flags);        /* Perform the transfer and clean up. */        status = spull_transfer(device, CURRENT);        spin_unlock_irqrestore(&device->lock, flags);        end_request(status); /* success */    }}/* * The fake interrupt-driven request */struct timer_list spull_timer; /* the engine for async invocation */#ifdef LINUX_24void spull_irqdriven_request(request_queue_t *q)#else                                           void spull_irqdriven_request()                  #endif                                          {    Spull_Dev *device;    int status;    long flags;    /* If we are already processing requests, don't do any more now. */    if (spull_busy)            return;    while(1) {        INIT_REQUEST;  /* returns when queue is empty */        /* Which "device" are we using? */        device = spull_locate_device (CURRENT);        if (device == NULL) {            end_request(0);            continue;        }	spin_lock_irqsave(&device->lock, flags);	        /* Perform the transfer and clean up. */        status = spull_transfer(device, CURRENT);        spin_unlock_irqrestore(&device->lock, flags);        /* ... and wait for the timer to expire -- no end_request(1) */        spull_timer.expires = jiffies + spull_irq;        add_timer(&spull_timer);        spull_busy = 1;        return;    }}/* this is invoked when the timer expires */void spull_interrupt(unsigned long unused){    unsigned long flags;    spin_lock_irqsave(&io_request_lock, flags);    end_request(1);    /* This request is done - we always succeed */    spull_busy = 0;  /* We have io_request_lock, no conflict with request */    if (! QUEUE_EMPTY) /* more of them? */#ifdef LINUX_24                                 spull_irqdriven_request(NULL);  /* Start the next transfer */#else                                           spull_irqdriven_request();      #endif                                      spin_unlock_irqrestore(&io_request_lock, flags);}/* * Finally, the module stuff */int spull_init(void){    int result, i;    /*     * Copy the (static) cfg variables to public prefixed ones to allow     * snoozing with a debugger.     */    spull_major    = major;    spull_devs     = devs;    spull_rahead   = rahead;    spull_size     = size;    spull_blksize  = blksize;    /*     * Register your major, and accept a dynamic number     */    result = register_blkdev(spull_major, "spull", &spull_bdops);    if (result < 0) {        printk(KERN_WARNING "spull: can't get major %d\n",spull_major);        return result;    }    if (spull_major == 0) spull_major = result; /* dynamic */    major = spull_major; /* Use `major' later on to save typing */    spull_gendisk.major = major; /* was unknown at load time */    /*      * allocate the devices -- we can't have them static, as the number     * can be specified at load time     */    spull_devices = kmalloc(spull_devs * sizeof (Spull_Dev), GFP_KERNEL);    if (!spull_devices)        goto fail_malloc;    memset(spull_devices, 0, spull_devs * sizeof (Spull_Dev));    for (i=0; i < spull_devs; i++) {        /* data and usage remain zeroed */        spull_devices[i].size = blksize * spull_size;        init_timer(&(spull_devices[i].timer));        spull_devices[i].timer.data = (unsigned long)(spull_devices+i);        spull_devices[i].timer.function = spull_expires;        spin_lock_init(&spull_devices[i].lock);    }    /*     * Assign the other needed values: request, rahead, size, blksize,     * hardsect. All the minor devices feature the same value.     * Note that `spull' defines all of them to allow testing non-default     * values. A real device could well avoid setting values in global     * arrays if it uses the default values.     */    read_ahead[major] = spull_rahead;    result = -ENOMEM; /* for the possible errors */    spull_sizes = kmalloc( (spull_devs << SPULL_SHIFT) * sizeof(int),                          GFP_KERNEL);    if (!spull_sizes)        goto fail_malloc;    /* Start with zero-sized partitions, and correctly sized units */    memset(spull_sizes, 0, (spull_devs << SPULL_SHIFT) * sizeof(int));    for (i=0; i< spull_devs; i++)        spull_sizes[i<<SPULL_SHIFT] = spull_size;    blk_size[MAJOR_NR] = spull_gendisk.sizes = spull_sizes;    /* Allocate the partitions array. */    spull_partitions = kmalloc( (spull_devs << SPULL_SHIFT) *                               sizeof(struct hd_struct), GFP_KERNEL);    if (!spull_partitions)        goto fail_malloc;    memset(spull_partitions, 0, (spull_devs << SPULL_SHIFT) *           sizeof(struct hd_struct));    /* fill in whole-disk entries */    for (i=0; i < spull_devs; i++)         spull_partitions[i << SPULL_SHIFT].nr_sects =		spull_size*(blksize/SPULL_HARDSECT);    spull_gendisk.part = spull_partitions;    spull_gendisk.nr_real = spull_devs;#ifndef LINUX_24    spull_gendisk.max_nr = spull_devs;#endif    /*     * Put our gendisk structure on the list.     */    spull_gendisk.next = gendisk_head;    gendisk_head = &spull_gendisk;     /* dump the partition table to see it */    for (i=0; i < spull_devs << SPULL_SHIFT; i++)        PDEBUGG("part %i: beg %lx, size %lx\n", i,               spull_partitions[i].start_sect,               spull_partitions[i].nr_sects);    /*     * Allow interrupt-driven operation, if "irq=" has been specified     */    spull_irq = irq; /* copy the static variable to the visible one */    if (spull_irq) {        PDEBUG("setting timer\n");        spull_timer.function = spull_interrupt;        blk_init_queue(BLK_DEFAULT_QUEUE(major), spull_irqdriven_request);    }    else        blk_init_queue(BLK_DEFAULT_QUEUE(major), spull_request);#ifdef NOTNOW    for (i = 0; i < spull_devs; i++)            register_disk(NULL, MKDEV(major, i), 1, &spull_bdops,                            spull_size << 1);#endif#ifndef SPULL_DEBUG    EXPORT_NO_SYMBOLS; /* otherwise, leave global symbols visible */#endif    printk ("<1>spull: init complete, %d devs, size %d blks %d\n",                    spull_devs, spull_size, spull_blksize);    return 0; /* succeed */  fail_malloc:    read_ahead[major] = 0;    if (spull_sizes) kfree(spull_sizes);    if (spull_partitions) kfree(spull_partitions);    blk_size[major] = NULL;    if (spull_devices) kfree(spull_devices);    unregister_blkdev(major, "spull");    return result;}void spull_cleanup(void){    int i;    struct gendisk **gdp;/* * Before anything else, get rid of the timer functions.  Set the "usage" * flag on each device as well, under lock, so that if the timer fires up * just before we delete it, it will either complete or abort.  Otherwise * we have nasty race conditions to worry about. */    for (i = 0; i < spull_devs; i++) {        Spull_Dev *dev = spull_devices + i;        del_timer(&dev->timer);        spin_lock(&dev->lock);        dev->usage++;        spin_unlock(&dev->lock);    }    /* flush it all and reset all the data structures *//* * Unregister the device now to avoid further operations during cleanup. */    unregister_blkdev(major, "spull");    for (i = 0; i < (spull_devs << SPULL_SHIFT); i++)        fsync_dev(MKDEV(spull_major, i)); /* flush the devices */    blk_cleanup_queue(BLK_DEFAULT_QUEUE(major));    read_ahead[major] = 0;    kfree(blk_size[major]); /* which is gendisk->sizes as well */    blk_size[major] = NULL;    kfree(spull_gendisk.part);    kfree(blksize_size[major]);    blksize_size[major] = NULL;    /*     * Get our gendisk structure off the list.     */    for (gdp = &gendisk_head; *gdp; gdp = &((*gdp)->next))        if (*gdp == &spull_gendisk) {            *gdp = (*gdp)->next;            break;        }    /* finally, the usual cleanup */    for (i=0; i < spull_devs; i++) {        if (spull_devices[i].data)            vfree(spull_devices[i].data);    }    kfree(spull_devices);}module_init(spull_init);module_exit(spull_cleanup);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合中文字幕国产 | 欧美在线视频日韩| 成人午夜视频福利| 国产凹凸在线观看一区二区| 国产乱码字幕精品高清av| 久国产精品韩国三级视频| 美女免费视频一区| 精品一区二区免费视频| 久久99国产精品免费| 激情丁香综合五月| 国产成人在线视频网站| 成人午夜精品一区二区三区| 成人精品视频.| 91丨porny丨最新| 欧美在线999| 在线不卡中文字幕播放| 欧美一区二区播放| 精品国产乱码久久久久久老虎| 精品久久久久久久久久久久久久久| 精品国产一二三| 国产日韩三级在线| 1000精品久久久久久久久| 亚洲一区二区三区四区在线免费观看| 一二三四区精品视频| 奇米色一区二区| 国产精品88av| 91精品1区2区| 日韩亚洲欧美成人一区| 欧美国产亚洲另类动漫| 亚洲美女免费在线| 五月天一区二区| 国产乱人伦偷精品视频免下载| 成人av电影在线网| 精品视频在线免费观看| 久久人人97超碰com| 亚洲欧洲日本在线| 日日摸夜夜添夜夜添亚洲女人| 国产精品中文字幕日韩精品| 91丨porny丨在线| 欧美一区二区视频在线观看| 久久久99精品免费观看不卡| 亚洲精品国产a| 国产曰批免费观看久久久| 成人国产在线观看| 91精品福利在线一区二区三区| 国产亚洲精品aa| 亚洲成av人片一区二区梦乃| 久久成人免费电影| 91九色02白丝porn| 久久精品亚洲精品国产欧美| 亚洲一区二区中文在线| 国产精品一卡二卡在线观看| 欧美日韩一区二区三区四区 | 日韩中文字幕麻豆| 国产宾馆实践打屁股91| 欧美精品一二三四| 国产精品久久看| 人人狠狠综合久久亚洲| eeuss国产一区二区三区| 欧美一级黄色大片| 亚洲激情图片一区| 不卡的av在线| 欧美不卡视频一区| 亚洲一区二区视频在线观看| 国产激情91久久精品导航| 欧美日韩在线一区二区| 中文字幕日本乱码精品影院| 久久精品久久精品| 欧美日韩在线综合| 亚洲欧美精品午睡沙发| 国产99久久久国产精品免费看| 51精品秘密在线观看| 亚洲精品日日夜夜| aaa国产一区| 国产欧美日韩三区| 国内外成人在线| 91麻豆精品国产91久久久| 亚洲免费成人av| 成人黄色av网站在线| 国产午夜亚洲精品羞羞网站| 麻豆精品国产91久久久久久| 在线观看日韩电影| 一区二区三区欧美激情| 成人av网站在线观看| 中文字幕国产一区二区| 国产一区二区剧情av在线| 日韩美女一区二区三区四区| 亚洲动漫第一页| 欧美三级日本三级少妇99| 一区二区三区日本| 在线亚洲一区观看| 亚洲黄色免费电影| 色婷婷亚洲综合| 亚洲蜜桃精久久久久久久| 成人黄色av电影| 中文字幕一区日韩精品欧美| 国产91清纯白嫩初高中在线观看| 久久久久久久久久久久久女国产乱 | 国产精品国产三级国产专播品爱网| 狠狠色丁香久久婷婷综合_中| 欧美精品久久一区二区三区| 午夜av一区二区三区| 欧美群妇大交群中文字幕| 亚洲成人精品一区| 欧美日韩一区二区三区在线看| 亚洲国产精品久久艾草纯爱| 欧洲精品在线观看| 亚洲一区二区偷拍精品| 884aa四虎影成人精品一区| 午夜精品福利一区二区三区av | 色丁香久综合在线久综合在线观看| 中文字幕亚洲一区二区av在线| 不卡的av网站| 亚洲免费视频成人| 精品视频在线免费看| 免费人成精品欧美精品| 欧美成人性战久久| 国产伦理精品不卡| 国产精品伦理在线| 欧美中文字幕一二三区视频| 日韩av中文字幕一区二区三区| 日韩无一区二区| 狠狠色2019综合网| 国产精品对白交换视频| 在线观看国产日韩| 麻豆精品一二三| 26uuu成人网一区二区三区| 粗大黑人巨茎大战欧美成人| 日韩毛片在线免费观看| 欧美久久久久免费| 蓝色福利精品导航| 亚洲欧洲一区二区三区| 欧美三级日韩三级| 国产一区二区剧情av在线| 成人免费在线视频观看| 欧美视频完全免费看| 奇米影视一区二区三区小说| 欧美经典一区二区| 欧美最猛性xxxxx直播| 久久精品国产久精国产爱| 国产嫩草影院久久久久| 欧美体内she精高潮| 久久精品国产99久久6| 国产精品欧美久久久久无广告| 欧美亚洲尤物久久| 久久99精品久久久久久动态图| 综合激情网...| 欧美一区二区大片| 91色视频在线| 久久97超碰国产精品超碰| 亚洲欧美日韩国产手机在线| 欧美一卡二卡在线| 色婷婷久久久亚洲一区二区三区| 免费xxxx性欧美18vr| 一区视频在线播放| 日韩精品在线网站| 欧美伊人精品成人久久综合97| 国产精品亚洲一区二区三区在线 | 蜜臀a∨国产成人精品| 国产精品不卡一区二区三区| 51精品秘密在线观看| 99精品欧美一区二区三区小说| 蜜臀av性久久久久蜜臀av麻豆 | 成人av午夜影院| 久久疯狂做爰流白浆xx| 亚洲永久免费视频| 国产精品午夜免费| 精品久久人人做人人爱| 欧美日韩一区三区四区| av电影在线不卡| 久久99精品久久久久久| 午夜av一区二区| 一级女性全黄久久生活片免费| 中文字幕不卡在线观看| 精品国产乱码久久久久久影片| 欧美三级午夜理伦三级中视频| 成人激情黄色小说| 国产一区二区三区| 免费在线观看一区| 五月天亚洲精品| 亚洲一区二区三区自拍| 亚洲美女视频一区| 最好看的中文字幕久久| 国产精品色在线| 国产亚洲成aⅴ人片在线观看| 日韩一区二区不卡| 欧美日韩不卡在线| 欧洲国产伦久久久久久久| a级高清视频欧美日韩| 国产精品一二三区在线| 国产一区二区中文字幕| 日本aⅴ亚洲精品中文乱码| 丝袜亚洲另类欧美| 午夜亚洲福利老司机| 亚洲国产成人av网| 亚洲成人激情自拍| 视频一区视频二区在线观看| 亚洲一区二区偷拍精品| 亚洲国产另类av| 亚洲午夜激情av|