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

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

?? sysdep.h

?? linux device driver源碼
?? H
?? 第 1 頁 / 共 2 頁
字號:
#  define cpu_to_le32p(addr) (cpu_to_le32(*(addr)))#  define cpu_to_be16p(addr) (cpu_to_be16(*(addr)))#  define cpu_to_be32p(addr) (cpu_to_be32(*(addr)))   extern inline void cpu_to_le16s(__u16 *a) {*a = cpu_to_le16(*a);}   extern inline void cpu_to_le32s(__u16 *a) {*a = cpu_to_le32(*a);}   extern inline void cpu_to_be16s(__u16 *a) {*a = cpu_to_be16(*a);}   extern inline void cpu_to_be32s(__u16 *a) {*a = cpu_to_be32(*a);}#  define le16_to_cpup(x) cpu_to_le16p(x)#  define le32_to_cpup(x) cpu_to_le32p(x)#  define be16_to_cpup(x) cpu_to_be16p(x)#  define be32_to_cpup(x) cpu_to_be32p(x)#  define le16_to_cpus(x) cpu_to_le16s(x)#  define le32_to_cpus(x) cpu_to_le32s(x)#  define be16_to_cpus(x) cpu_to_be16s(x)#  define be32_to_cpus(x) cpu_to_be32s(x)#endif#ifdef LINUX_20#  define __USE_OLD_REBUILD_HEADER__#endif/* * 2.0 didn't include sema_init, so we make our own - but only if it * looks like semaphore.h got included. */#ifdef LINUX_20#  ifdef MUTEX_LOCKED   /* Only if semaphore.h included */     extern inline void sema_init (struct semaphore *sem, int val)     {         sem->count = val;         sem->waking = sem->lock = 0;         sem->wait = NULL;     }#  endif#endif /* LINUX_20 *//* * In 2.0, there is no real need for spinlocks, and they weren't really * implemented anyway. * * XXX the _irqsave variant should be defined eventually to do the * right thing. */#ifdef LINUX_20typedef int spinlock_t;#  define spin_lock(lock)#  define spin_unlock(lock)#  define spin_lock_init(lock)#  define spin_lock_irqsave(lock,flags) do { \        save_flags(flags); cli(); } while (0);#  define spin_unlock_irqrestore(lock,flags) restore_flags(flags);#endif/* * 2.1 stuffed the "flush" method into the middle of the file_operations * structure.  The FOP_NO_FLUSH symbol is for drivers that do not implement * flush (most of them), it can be inserted in initializers for all 2.x * kernel versions. */#ifdef LINUX_20#  define FOP_NO_FLUSH   /* nothing */#  define TAG_LLSEEK    lseek#  define TAG_POLL      select#else#  define FOP_NO_FLUSH  NULL,#  define TAG_LLSEEK    llseek#  define TAG_POLL      poll#endif/* * fasync changed in 2.2. */#ifdef LINUX_20/*  typedef struct inode *fasync_file; */#  define fasync_file struct inode *#else  typedef int fasync_file;#endif/* kill_fasync had less arguments, and a different indirection in the first */#ifndef LINUX_24#  define kill_fasync(ptrptr,sig,band)  kill_fasync(*(ptrptr),(sig))#endif/* other things that are virtualized: define the new functions for the old k */#ifdef LINUX_20#  define in_interrupt() (intr_count!=0)#  define mdelay(x) udelay((x)*1000)#  define signal_pending(current)  ((current)->signal & ~(current)->blocked)#endif#ifdef LINUX_PCI_H /* only if PCI stuff is being used */#  ifdef LINUX_20#    include "pci-compat.h" /* a whole set of replacement functions */#  else#    define  pci_release_device(d) /* placeholder, used in 2.0 to free stuff */#  endif#endif/* * Some task state stuff */#ifndef set_current_state#  define set_current_state(s) current->state = (s);#endif#ifdef LINUX_20extern inline void schedule_timeout(int timeout){    current->timeout = jiffies + timeout;    current->state = TASK_INTERRUPTIBLE;    schedule();    current->timeout = 0;}extern inline long sleep_on_timeout(wait_queue_head_t *q, signed long timeout){    signed long early = 0;            current->timeout = jiffies + timeout;    sleep_on (q);    if (current->timeout > 0) {        early = current->timeout - jiffies;        current->timeout = 0;    }    return early;}extern inline long interruptible_sleep_on_timeout(wait_queue_head_t *q,                signed long timeout){    signed long early = 0;            current->timeout = jiffies + timeout;    interruptible_sleep_on (q);    if (current->timeout > 0) {        early = current->timeout - jiffies;        current->timeout = 0;    }    return early;}#endif /* LINUX_20 *//* * Schedule_task was a late 2.4 addition. */#ifndef LINUX_24extern inline int schedule_task(struct tq_struct *task){        queue_task(task, &tq_scheduler);        return 1;}#endif/* * Timing issues */#ifdef LINUX_20#  define get_fast_time do_gettimeofday#endif#ifdef _LINUX_DELAY_H /* only if linux/delay.h is included */#  ifndef mdelay /* linux-2.0 */#    ifndef MAX_UDELAY_MS#      define MAX_UDELAY_MS   5#    endif#    define mdelay(n) (\        (__builtin_constant_p(n) && (n)<=MAX_UDELAY_MS) ? udelay((n)*1000) : \        ({unsigned long msec=(n); while (msec--) udelay(1000);}))#  endif /* mdelay */#endif /* _LINUX_DELAY_H *//* * No del_timer_sync before 2.4 */#ifndef LINUX_24#  define del_timer_sync(timer) del_timer(timer)  /* and hope */#endif/* * mod_timer wasn't present in 2.0 */#ifdef LINUX_20static inline int mod_timer(struct timer_list *timer, unsigned long expires){    int pending = del_timer(timer);    if (pending) {        timer->expires = expires;        add_timer(timer);    }    return pending;}#endif/* * Various changes in mmap and friends. */#ifndef NOPAGE_SIGBUS#  define NOPAGE_SIGBUS  NULL  /* return value of the nopage memory method */#  define NOPAGE_OOM     NULL  /* No real equivalent in older kernels */#endif#ifndef VM_RESERVED            /* Added 2.4.0-test10 */#  define VM_RESERVED 0#endif#ifdef LINUX_24 /* use "vm_pgoff" to get an offset */#define VMA_OFFSET(vma)  ((vma)->vm_pgoff << PAGE_SHIFT)#else /* use "vm_offset" */#define VMA_OFFSET(vma)  ((vma)->vm_offset)#endif#ifdef MAP_NR#define virt_to_page(page) (mem_map + MAP_NR(page))#endif#ifndef get_page#  define get_page(p) atomic_inc(&(p)->count)#endif/* * No DMA lock in 2.0. */#ifdef LINUX_20static inline unsigned long claim_dma_lock(void){    unsigned long flags;    save_flags(flags);    cli();    return flags;}static inline void release_dma_lock(unsigned long flags){    restore_flags(flags);}#endif/* * I/O memory was not managed by ealier kernels, define them as success */#if 0 /* FIXME: what is the right way to do request_mem_region? */#ifndef LINUX_24#  define check_mem_region(start, len)          0#  define request_mem_region(start, len, name)  0#  define release_mem_region(start, len)        0   /*    * Also, request_ and release_ region used to return void. Return 0 instead    */#  define request_region(s, l, n)  ({request_region((s),(l),(n));0;})#  define release_region(s, l)     ({release_region((s),(l));0;})#endif /* not LINUX_24 */#endif/* * Block layer stuff. */#ifndef LINUX_24/* BLK_DEFAULT_QUEUE for use with these macros only!!!! */#define BLK_DEFAULT_QUEUE(major) blk_dev[(major)].request_fn#define blk_init_queue(where,request_fn) where = request_fn;#define blk_cleanup_queue(where) where = NULL;/* No QUEUE_EMPTY in older kernels */#ifndef QUEUE_EMPTY  /* Driver can redefine it too */#  define QUEUE_EMPTY (CURRENT != NULL)#endif#ifdef RO_IOCTLSstatic inline int blk_ioctl(kdev_t dev, unsigned int cmd, unsigned long arg){    int err;    switch (cmd) {      case BLKRAGET: /* return the readahead value */        if (!arg)  return -EINVAL;        err = ! access_ok(VERIFY_WRITE, arg, sizeof(long));        if (err) return -EFAULT;        PUT_USER(read_ahead[MAJOR(dev)],(long *) arg);        return 0;      case BLKRASET: /* set the readahead value */        if (!capable(CAP_SYS_ADMIN)) return -EACCES;        if (arg > 0xff) return -EINVAL; /* limit it */        read_ahead[MAJOR(dev)] = arg;        return 0;      case BLKFLSBUF: /* flush */        if (! capable(CAP_SYS_ADMIN)) return -EACCES; /* only root */        fsync_dev(dev);        invalidate_buffers(dev);        return 0;        RO_IOCTLS(dev, arg);    }    return -ENOTTY;}#endif  /* RO_IOCTLS */#ifdef LINUX_EXTENDED_PARTITION /* defined in genhd.h */static inline void register_disk(struct gendisk *gdev, kdev_t dev,                unsigned minors, struct file_operations *ops, long size){    if (! gdev)        return;    resetup_one_dev(gdev, MINOR(dev) >> gdev->minor_shift);}#endif /* LINUX_EXTENDED_PARTITION */#else  /* it is Linux 2.4 */#define HAVE_BLKPG_H#endif /* LINUX_24 */#ifdef LINUX_20 /* physical and virtual addresses had the same value */#  define __pa(a) (a)#  define __va(a) (a)#endif/* * Network driver compatibility *//* * 2.0 dev_kfree_skb had an extra arg.  The following is a little dangerous * in that it assumes that FREE_WRITE is always wanted.  Very few 2.0 drivers * use FREE_READ, but the number is *not* zero... * * Also: implement the non-checking versions of a couple skb functions - * but they still check in 2.0. */#ifdef LINUX_20#  define dev_kfree_skb(skb) dev_kfree_skb((skb), FREE_WRITE);#  define __skb_push(skb, len) skb_push((skb), (len))#  define __skb_put(skb, len)  skb_put((skb), (len))#endif/* * Softnet changes in 2.4 */#ifndef LINUX_24#  ifdef _LINUX_NETDEVICE_H /* only if netdevice.h was included */#  define netif_start_queue(dev) clear_bit(0, (void *) &(dev)->tbusy);#  define netif_stop_queue(dev)  set_bit(0, (void *) &(dev)->tbusy);static inline void netif_wake_queue(struct device *dev){    clear_bit(0, (void *) &(dev)->tbusy);    mark_bh(NET_BH);}/* struct device became struct net_device */#  define net_device device#  endif /* netdevice.h */#endif /* ! LINUX_24 *//* * Memory barrier stuff, define what's missing from older kernel versions */#ifdef switch_to /* this is always a macro, defined in <asm/sysstem.h> */#  ifndef set_mb#    define set_mb(var, value) do {(var) = (value); mb();}  while 0#  endif#  ifndef set_rmb#    define set_rmb(var, value) do {(var) = (value); rmb();}  while 0#  endif#  ifndef set_wmb#    define set_wmb(var, value) do {(var) = (value); wmb();}  while 0#  endif/* The hw barriers are defined as sw barriers. A correct thing if this   specific kernel/platform is supported but has no specific instruction */#  ifndef mb#    define mb barrier#  endif#  ifndef rmb#    define rmb barrier#  endif#  ifndef wmb#    define wmb barrier#  endif#endif /* switch to (i.e. <asm/system.h>) */#endif /* _SYSDEP_H_ */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品一区二区在线播放 | 午夜精品一区二区三区免费视频 | av一区二区久久| 欧美日韩亚洲综合一区二区三区| 精品电影一区二区三区| 一区二区三区欧美日| 国产黄色成人av| 777奇米四色成人影色区| 日本一区二区三区久久久久久久久不 | 欧美久久婷婷综合色| 国产精品人人做人人爽人人添| 亚洲精品免费视频| 成人一区二区视频| 亚洲精品在线三区| 天天综合日日夜夜精品| 色噜噜久久综合| 综合久久久久久久| 高清不卡在线观看av| 精品奇米国产一区二区三区| 亚洲va国产天堂va久久en| 一本到不卡免费一区二区| 国产精品网站导航| 国产一区二区在线视频| 精品日韩99亚洲| 久久精品国产精品青草| 91精品国产一区二区| 亚洲国产精品一区二区尤物区| 91天堂素人约啪| 日韩理论片一区二区| 91在线码无精品| 中文字幕在线不卡视频| 成人免费福利片| 国产精品福利影院| 99精品国产视频| 亚洲美女在线一区| 在线观看中文字幕不卡| 一区二区三区.www| 欧洲一区在线电影| 午夜天堂影视香蕉久久| 欧美精品三级日韩久久| 蜜桃视频第一区免费观看| 91精品国产综合久久小美女| 日日夜夜精品免费视频| 精品美女在线播放| 成人一区二区在线观看| 亚洲蜜臀av乱码久久精品 | 欧美伦理影视网| 亚洲午夜一区二区三区| 5月丁香婷婷综合| 蓝色福利精品导航| 亚洲国产精品ⅴa在线观看| 成+人+亚洲+综合天堂| 亚洲欧美日韩在线不卡| 欧美午夜精品一区二区蜜桃| 视频一区视频二区在线观看| 精品国产91洋老外米糕| 成人精品小蝌蚪| 亚洲精品国产高清久久伦理二区| 欧美亚日韩国产aⅴ精品中极品| 日韩av在线播放中文字幕| 欧美va天堂va视频va在线| 成人精品亚洲人成在线| 丝袜国产日韩另类美女| 久久先锋影音av| 91丨porny丨国产| 日本v片在线高清不卡在线观看| 久久精品视频一区二区| 91国产免费看| 国产一区在线视频| 亚洲主播在线播放| 久久久久久久久久久久久女国产乱| 波多野结衣中文字幕一区| 婷婷成人激情在线网| 欧美激情在线一区二区| 欧美日韩国产免费一区二区| 国产成人精品亚洲日本在线桃色| 一区二区三区成人在线视频| www欧美成人18+| 欧美日韩中文另类| 成人午夜看片网址| 日韩精品一级中文字幕精品视频免费观看 | 久久奇米777| 精品视频在线免费观看| 东方aⅴ免费观看久久av| 亚洲国产精品久久不卡毛片 | 欧美一卡2卡3卡4卡| 波多野结衣的一区二区三区| 日韩成人午夜精品| 亚洲欧美日本在线| 蜜臀va亚洲va欧美va天堂| 国产在线播精品第三| 欧美日韩一二三| 国产v综合v亚洲欧| 久久综合视频网| 欧美美女一区二区| av网站免费线看精品| 国产在线精品视频| 美女久久久精品| 亚洲高清不卡在线观看| 亚洲黄色小视频| 国产精品久久三| 国产亚洲自拍一区| 26uuu亚洲综合色欧美 | 国产精品高潮久久久久无| 久久久亚洲午夜电影| 日韩美女一区二区三区四区| 欧美人与禽zozo性伦| 欧美视频一区二区| 色婷婷激情综合| 色视频成人在线观看免| 97se亚洲国产综合在线| 成人小视频在线| 成人免费黄色在线| 成人午夜电影久久影院| 丰满白嫩尤物一区二区| 国产69精品久久久久777| 国产综合一区二区| 国内一区二区在线| 韩国v欧美v亚洲v日本v| 激情小说亚洲一区| 国产精品自拍网站| 国产成人精品免费在线| youjizz久久| 在线观看国产91| 911精品国产一区二区在线| 欧美日韩国产综合一区二区| 91精品久久久久久蜜臀| 日韩久久久久久| 久久香蕉国产线看观看99| 欧美国产激情一区二区三区蜜月| 国产精品美女久久久久久| 亚洲精品国产精品乱码不99| 午夜精品久久久久久久久久久 | 国产一区二区不卡在线| 99视频在线观看一区三区| 99视频有精品| 欧美在线制服丝袜| 日韩欧美中文字幕精品| 久久久久久久综合| 亚洲欧美激情一区二区| 日韩国产在线观看一区| 国产美女一区二区| 91麻豆国产福利在线观看| 欧美老人xxxx18| 欧美va亚洲va| 亚洲人精品午夜| 日韩国产欧美在线观看| 国模冰冰炮一区二区| 99在线精品一区二区三区| 欧美精品丝袜久久久中文字幕| 欧美一级国产精品| 国产精品激情偷乱一区二区∴| 一区二区三区四区在线| 久久国产精品区| 97精品国产露脸对白| 欧美日韩国产电影| 国产精品视频在线看| 五月婷婷综合激情| 国产成人精品免费一区二区| 欧洲视频一区二区| 国产日韩欧美电影| 天天色天天爱天天射综合| 懂色av一区二区在线播放| 51精品视频一区二区三区| 国产亚洲精品资源在线26u| 亚洲午夜久久久久中文字幕久| 激情文学综合网| 欧美日韩在线播放三区| 中文字幕av资源一区| 日韩电影在线观看一区| 97se狠狠狠综合亚洲狠狠| 精品成人a区在线观看| 午夜激情久久久| 99久久免费精品高清特色大片| 欧美不卡一区二区三区四区| 亚洲女性喷水在线观看一区| 国产一区视频在线看| 欧美日韩成人在线| 亚洲免费色视频| 国产精品123| 精品国产精品网麻豆系列 | 紧缚捆绑精品一区二区| 欧美性xxxxx极品少妇| 国产精品福利av| 国产一区视频在线看| 日韩欧美区一区二| 日本中文字幕一区二区视频 | 日韩精品影音先锋| 日韩成人一级大片| 欧美日本不卡视频| 五月婷婷另类国产| 日韩精品一区二区三区四区| 亚洲成人动漫在线观看| 欧美体内she精高潮| 亚洲视频免费看| 91女厕偷拍女厕偷拍高清| 国产精品电影一区二区三区| 粉嫩一区二区三区在线看| 国产精品久久久久婷婷二区次| 国产 日韩 欧美大片|