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

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

?? short.c

?? linux device driver源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * short.c -- Simple Hardware Operations and Raw Tests * short.c -- also a brief example of interrupt handling ("short int") * * 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: short.c,v 1.22 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/fs.h>     /* everything... */#include <linux/errno.h>  /* error codes */#include <linux/delay.h>  /* udelay */#include <linux/malloc.h>#include <linux/mm.h>#include <linux/ioport.h>#include <linux/interrupt.h>#include <linux/tqueue.h>#include <asm/io.h>#include "sysdep.h"#define SHORT_NR_PORTS 8 /* use 8 ports by default *//* * all of the parameters have no "short_" prefix, to save typing when * specifying them at load time */static int major = 0; /* dynamic by default */MODULE_PARM(major, "i");static int use_mem = 0; /* default is I/O-mapped */MODULE_PARM(use_mem, "i");/* default is the first printer port on PC's. "short_base" is there too   because it's what we want to use in the code */static unsigned long base = 0x378;unsigned long short_base = 0;MODULE_PARM(base, "l");/* Since short_base is vremapped in case use_mem==1, remember the phys addr. */unsigned long short_phys;/* The interrupt line is undefined by default. "short_irq" is as above */static int irq = -1;volatile int short_irq = -1;MODULE_PARM(irq, "i");static int probe = 0; /* select at load time how to probe irq line */MODULE_PARM(probe, "i");static int bh = 0; /* select at load time whether a bottom-half is used */MODULE_PARM(bh, "i");static int tasklet = 0; /* select whether a tasklet is used */MODULE_PARM(tasklet, "i");static int share = 0; /* select at load time whether install a shared irq */MODULE_PARM(share, "i");MODULE_AUTHOR ("Alessandro Rubini");unsigned long short_buffer = 0;unsigned long volatile short_head;volatile unsigned long short_tail;DECLARE_WAIT_QUEUE_HEAD(short_queue);/* Set up our tasklet if we're doing that. */#ifdef HAVE_TASKLETSvoid short_do_tasklet (unsigned long);DECLARE_TASKLET (short_tasklet, short_do_tasklet, 0);#endif/* * Atomicly increment an index into short_buffer */static inline void short_incr_bp(volatile unsigned long *index, int delta){    unsigned long new = *index + delta;    barrier ();  /* Don't optimize these two together */    *index = (new >= (short_buffer + PAGE_SIZE)) ? short_buffer : new;}/* * The devices with low minor numbers write/read burst of data to/from * specific I/O ports (by default the parallel ones). *  * The device with 128 as minor number returns ascii strings telling * when interrupts have been received. Writing to the device toggles * 00/FF on the parallel data lines. If there is a loopback wire, this * generates interrupts.   */int short_open (struct inode *inode, struct file *filp){    extern struct file_operations short_i_fops;    MOD_INC_USE_COUNT;    if (MINOR(inode->i_rdev) & 0x80) {        filp->f_op = &short_i_fops; /* the interrupt-driven node */    }    return 0;}#ifdef LINUX_20void short_release (struct inode *inode, struct file *filp){    MOD_DEC_USE_COUNT;}#elseint short_release (struct inode *inode, struct file *filp){    MOD_DEC_USE_COUNT;    return 0;}#endif/* first, the port-oriented device */enum short_modes {SHORT_DEFAULT=0, SHORT_PAUSE, SHORT_STRING, SHORT_MEMORY};ssize_t do_short_read (struct inode *inode, struct file *filp, char *buf,                size_t count, loff_t *f_pos){    int retval = count;    unsigned long address = short_base + (MINOR(inode->i_rdev)&0x0f);    int mode = (MINOR(inode->i_rdev)&0x70) >> 4;    unsigned char *kbuf=kmalloc(count, GFP_KERNEL), *ptr;        if (!kbuf) return -ENOMEM;    ptr=kbuf;    if (use_mem)	mode = SHORT_MEMORY;	    switch(mode) {      case SHORT_STRING:        insb(address, ptr, count);	rmb();        break;      case SHORT_DEFAULT:        while (count--) {            *(ptr++) = inb(address);	    rmb();	}        break;      case SHORT_MEMORY:        while (count--) {            *(ptr++) = readb(address);	    rmb();	}        break;      case SHORT_PAUSE:        while (count--) {            *(ptr++) = inb_p(address);	    rmb();	}        break;      default: /* no more modes defined by now */        retval = -EINVAL;        break;    }    if ( (retval > 0) && copy_to_user(buf, kbuf, retval))	retval = -EFAULT;    kfree(kbuf);    return retval;}/* * Version-specific methods for the fops structure. */#ifdef LINUX_20int short_read(struct inode *inode, struct file *filp, char *buf, int count){    return do_short_read(inode, filp, buf, count, &filp->f_pos);}#elsessize_t short_read(struct file *filp, char *buf, size_t count, loff_t *f_pos){    return do_short_read(filp->f_dentry->d_inode, filp, buf, count, f_pos);}#endifssize_t do_short_write (struct inode *inode, struct file *filp, const char *buf,                size_t count, loff_t *f_pos){    int retval = count;    unsigned long address = short_base + (MINOR(inode->i_rdev)&0x0f);    int mode = (MINOR(inode->i_rdev)&0x70) >> 4;    unsigned char *kbuf=kmalloc(count, GFP_KERNEL), *ptr;    if (!kbuf) return -ENOMEM;    if (copy_from_user(kbuf, buf, count))	return -EFAULT;    ptr=kbuf;    if (use_mem)	mode = SHORT_MEMORY;    switch(mode) {      case SHORT_PAUSE:        while (count--) {            outb_p(*(ptr++), address);	    wmb();	}        break;      case SHORT_STRING:        outsb(address, ptr, count);	wmb();        break;      case SHORT_DEFAULT:        while (count--) {            outb(*(ptr++), address);	    wmb();	}        break;      case SHORT_MEMORY:        while (count--) {            writeb(*(ptr++), address);	    wmb();	}        break;      default: /* no more modes defined by now */        retval = -EINVAL;        break;    }    kfree(kbuf);    return retval;}#ifdef LINUX_20int short_write(struct inode *inode, struct file *filp, const char *buf,                int count){    return do_short_write(inode, filp, buf, count, &filp->f_pos);}#elsessize_t short_write(struct file *filp, const char *buf, size_t count,                loff_t *f_pos){    return do_short_write(filp->f_dentry->d_inode, filp, buf, count, f_pos);}#endif#ifdef __USE_OLD_SELECT__int short_poll (struct inode *inode, struct file *filp,                  int mode, select_table *table){    return mode==SEL_EX ? 0 : 1; /* readable, writable, not-exceptionable */}#define poll select#else /* Use poll */unsigned int short_poll(struct file *filp, poll_table *wait){    return POLLIN | POLLRDNORM | POLLOUT | POLLWRNORM;}#endif /* __USE_OLD_SELECT__ */struct file_operations short_fops = {    read: short_read,    write: short_write,    poll: short_poll,    open: short_open,    release: short_release,};/* then,  the interrupt-related device */ssize_t short_i_read (struct file *filp, char *buf, size_t count, loff_t *f_pos){    int count0;    while (short_head == short_tail) {        interruptible_sleep_on(&short_queue);        if (signal_pending (current))  /* a signal arrived */          return -ERESTARTSYS; /* tell the fs layer to handle it */        /* else, loop */    }    /* count0 is the number of readable data bytes */    count0 = short_head - short_tail;    if (count0 < 0) /* wrapped */        count0 = short_buffer + PAGE_SIZE - short_tail;    if (count0 < count) count = count0;    if (copy_to_user(buf, (char *)short_tail, count))	return -EFAULT;    short_incr_bp (&short_tail, count);    return count;}ssize_t short_i_write (struct file *filp, const char *buf, size_t count,                loff_t *f_pos){    int written = 0, odd = *f_pos & 1;    unsigned long address = short_base; /* output to the parallel data latch */    if (use_mem) {	while (written < count)	    writeb(0xff * ((++written + odd) & 1), address);    } else {	while (written < count)	    outb(0xff * ((++written + odd) & 1), address);    }    *f_pos += count;    return written;}/* * 2.0 wrappers. */#ifdef LINUX_20int short_i_read_20 (struct inode *inode, struct file *filp, char *buf,                int count){    return short_i_read (filp, buf, count, &filp->f_pos);}int short_i_write_20 (struct inode *inode, struct file *filp, const char *buf,                int count){    return short_i_write (filp, buf, count, &filp->f_pos);}#define short_i_read  short_i_read_20#define short_i_write short_i_write_20#endif /* LINUX_20 */struct file_operations short_i_fops = {    read: short_i_read,    write: short_i_write,    open: short_open,    release: short_release,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久综合狠狠综合久久| 国产欧美精品在线观看| 精品久久久三级丝袜| 亚洲图片欧美色图| 国产在线精品一区二区三区不卡| 色噜噜狠狠色综合欧洲selulu| 日韩你懂的电影在线观看| 亚洲欧美激情插| 国产suv一区二区三区88区| 欧美一区二区三区四区五区| 亚洲欧美一区二区三区孕妇| 国产高清视频一区| 欧美一区三区四区| 亚洲成a人在线观看| 国产乱码精品一区二区三区av | 免费观看在线色综合| 色94色欧美sute亚洲线路二| 国产精品二三区| 欧美一级搡bbbb搡bbbb| 国产精品欧美综合在线| 国模冰冰炮一区二区| 日韩欧美国产综合一区 | 久久精品视频网| 精品亚洲国内自在自线福利| 91精品国产综合久久久久久久久久 | 亚洲免费av高清| 成人高清视频在线| 日韩理论电影院| 99麻豆久久久国产精品免费| 自拍偷在线精品自拍偷无码专区| yourporn久久国产精品| 日韩伦理av电影| 国产99久久久国产精品免费看 | 91年精品国产| 亚洲视频在线一区观看| 成人99免费视频| 亚洲美女视频在线观看| 日本韩国欧美在线| 亚洲一区电影777| 在线成人av影院| 秋霞av亚洲一区二区三| 久久综合久久综合亚洲| 风流少妇一区二区| 成人欧美一区二区三区在线播放| 91视视频在线观看入口直接观看www| 国产精品电影一区二区三区| 91高清视频免费看| 调教+趴+乳夹+国产+精品| 欧美成人aa大片| 国产丶欧美丶日本不卡视频| 国产精品女主播av| 欧美视频精品在线观看| 黑人精品欧美一区二区蜜桃| 中文成人av在线| 欧美三级电影一区| 激情av综合网| 亚洲女同一区二区| 欧美一级片免费看| 北岛玲一区二区三区四区 | 国产精品毛片高清在线完整版| 色综合久久99| 1区2区3区精品视频| 精品精品欲导航| 国产91精品一区二区| 亚洲欧美韩国综合色| 欧美一区二区三区爱爱| 成人在线一区二区三区| 亚洲电影视频在线| 久久久久久久综合日本| 欧美主播一区二区三区| 国产一区二区三区电影在线观看 | 日韩视频免费观看高清完整版在线观看| 在线观看网站黄不卡| 蜜桃av噜噜一区| 亚洲人午夜精品天堂一二香蕉| 日韩一区二区三区电影| 欧美在线视频全部完| 久久精品二区亚洲w码| 日韩毛片视频在线看| 精品国产伦一区二区三区观看体验 | 久久精品亚洲国产奇米99| 91黄色小视频| 成人免费视频网站在线观看| 免费人成网站在线观看欧美高清| 综合色天天鬼久久鬼色| 久久久久国产精品免费免费搜索| 欧美精品乱人伦久久久久久| 成人av片在线观看| 国产最新精品免费| 日韩黄色免费网站| 一区二区三区成人| 中文字幕一区二区三区在线不卡| 精品电影一区二区三区| 欧美精品xxxxbbbb| 精品视频一区 二区 三区| av一区二区三区在线| 成人永久看片免费视频天堂| 精品一区二区免费视频| 17c精品麻豆一区二区免费| 久久国产视频网| 亚洲国产日韩在线一区模特| 欧美国产禁国产网站cc| 精品999久久久| 精品久久99ma| 欧美成人一区二区三区| 欧美一级久久久久久久大片| 欧美色图12p| 欧美日韩中文字幕一区二区| 色诱亚洲精品久久久久久| 99久久99久久综合| 99久久综合99久久综合网站| bt7086福利一区国产| 成人自拍视频在线| 99国产精品视频免费观看| 成人在线一区二区三区| 成人美女视频在线观看| av欧美精品.com| 91一区二区在线观看| 色丁香久综合在线久综合在线观看| av一区二区不卡| 欧美性一二三区| 欧美一三区三区四区免费在线看| 91麻豆精品国产无毒不卡在线观看| 91原创在线视频| 91麻豆精品国产91久久久资源速度 | 欧美精品一区二区三区蜜桃视频| 日韩欧美高清一区| 欧美精品一区二区在线播放| 久久伊人中文字幕| 中文字幕国产一区| 亚洲综合色成人| 日日噜噜夜夜狠狠视频欧美人| 久久精品国产亚洲高清剧情介绍| 91在线视频在线| 欧美在线制服丝袜| 日韩一级大片在线| 国产欧美一区二区在线| 亚洲精品久久久蜜桃| 青青草国产精品亚洲专区无| 国产福利一区二区三区| 91精品国产综合久久蜜臀| 国产亚洲精品超碰| 中文一区二区完整视频在线观看| 综合色中文字幕| 蜜臀久久久久久久| 成人精品鲁一区一区二区| 91啦中文在线观看| 欧美一级欧美一级在线播放| 亚洲国产成人私人影院tom| 一二三四区精品视频| 精品一区免费av| 99精品视频一区二区| 日韩一区二区三区av| 中文字幕免费在线观看视频一区| 午夜国产不卡在线观看视频| 国产成人免费9x9x人网站视频| 欧美日韩在线免费视频| 国产亚洲一二三区| 亚洲超碰97人人做人人爱| 高清不卡在线观看av| 欧美一级午夜免费电影| 亚洲男帅同性gay1069| 久久精品久久综合| 欧美在线一区二区| 国产精品毛片高清在线完整版 | 三级在线观看一区二区| 国产在线不卡一区| 欧美日韩一区中文字幕| 久久免费看少妇高潮| 亚洲国产三级在线| 成人黄色小视频| 久久在线免费观看| 日本欧美一区二区三区乱码 | 99久久精品久久久久久清纯| 日韩精品一区二区三区三区免费| 亚洲国产成人tv| 91在线精品一区二区| 国产女主播视频一区二区| 久久99久久久久| 5858s免费视频成人| 亚洲大片一区二区三区| 色综合天天综合网国产成人综合天 | 色悠悠久久综合| 国产精品久久久久aaaa樱花| 国产精品一区2区| 久久日一线二线三线suv| 毛片av一区二区三区| 亚洲欧美另类综合偷拍| 国产精品一区二区在线看| 日韩美女主播在线视频一区二区三区 | 久久精品国产一区二区三| 欧美一区二区精美| 日本欧美肥老太交大片| 91精品黄色片免费大全| 蜜臀va亚洲va欧美va天堂| 欧美情侣在线播放| 五月婷婷色综合| 欧美日韩国产成人在线91| 亚洲在线一区二区三区| 欧美日韩日本视频|