📄 k_compat.h
字号:
/* * k_compat.h 1.8 1995/12/03 01:26:43 (David Hinds) * 1998/07/12 modified by Pavel Pisa pisa@CMP.felk.cvut.cz */#ifndef _LINUX_K_COMPAT_H#define _LINUX_K_COMPAT_H#define VERSION(v,p,s) (((v)<<16)+(p<<8)+s)#ifndef LINUX_VERSION_CODE #error LINUX_VERSION_CODE not defined#endif#if (LINUX_VERSION_CODE < VERSION(1,3,38))#ifdef MODULE#include <linux/module.h>#if !defined(CONFIG_MODVERSIONS) && !defined(__NO_VERSION__)char kernel_version[] = UTS_RELEASE;#endif#else#define MOD_DEC_USE_COUNT#define MOD_INC_USE_COUNT#endif#else /* 1.3.38 */#if (LINUX_VERSION_CODE <= VERSION(2,5,60))#ifdef CONFIG_MODVERSIONS#define MODVERSIONS 1#if (LINUX_VERSION_CODE >= VERSION(1,3,40)) #include <linux/modversions.h>#endif /* >=1.3.40 */#endif /* CONFIG_MODVERSIONS */#endif /* <=2.5.60 */#include <linux/module.h>#endif /* 1.3.38 */#if (LINUX_VERSION_CODE < VERSION(2,5,50))#define kc_MOD_DEC_USE_COUNT MOD_DEC_USE_COUNT#define kc_MOD_INC_USE_COUNT MOD_INC_USE_COUNT#else /* 2.5.50 */#define kc_MOD_DEC_USE_COUNT#define kc_MOD_INC_USE_COUNT#endif /* 2.5.50 */#if ((LINUX_VERSION_CODE < VERSION(2,2,0)) || (LINUX_VERSION_CODE >= VERSION(2,6,0))) #ifndef EXPORT_NO_SYMBOLS #define EXPORT_NO_SYMBOLS #endif /*EXPORT_NO_SYMBOLS*/#endif /* 2.2.0 *//*** user memory access ***//* I do not know exactly all dates of changes */#if (LINUX_VERSION_CODE < VERSION(2,1,5)) #define kc_copy_from_user(dst,src,len) ({ \ if(!(verify_area(VERIFY_READ, src, len))) \ {memcpy_fromfs(dst,src,len);0;} else len; }) #define kc_copy_to_user(dst,src,len) ({ \ if(!(verify_area(VERIFY_WRITE, dst, len))) \ {memcpy_tofs(dst,src,len);0;} else len; }) #define kc_get_user_long(x,ptr) \ (if(!verify_area(VERIFY_READ, (ptr), sizeof(long))) {(x)=get_fs_long((ptr));0;} else 1; }) #define kc_get_user_word(x,ptr) \ (if(!verify_area(VERIFY_READ, (ptr), sizeof(short))) {(x)=get_fs_word((ptr));0;} else 1; }) #define kc_get_user_byte(x,ptr) \ (if(!verify_area(VERIFY_READ, (ptr), sizeof(char))) {(x)=get_fs_byte((ptr));0;} else 1; }) #define kc_put_user_long(x,ptr) \ (if(!verify_area(VERIFY_WRITE, (ptr), sizeof(long))) {put_fs_long((x),(ptr));0;} else 1; }) #define kc_put_user_word(x,ptr) \ (if(!verify_area(VERIFY_WRITE, (ptr), sizeof(short))){put_fs_word((x),(ptr));0;} else 1; }) #define kc_put_user_byte(x,ptr) \ (if(!verify_area(VERIFY_WRITE, (ptr), sizeof(char))) {put_fs_byte((x),(ptr));0;} else 1; })#elif (LINUX_VERSION_CODE < VERSION(2,1,100)) /* may need correction */ #include <asm/uaccess.h> #define kc_copy_from_user copy_from_user #define kc_copy_to_user copy_to_user #define kc_get_user(x,ptr) \ (__get_user_check((x),(ptr),sizeof(*(ptr)))) #define kc_put_user(x,ptr) \ (__put_user_check((x),(ptr),sizeof(*(ptr))))#else /* >= 2.1.100 */ #include <asm/uaccess.h> #define kc_copy_from_user copy_from_user #define kc_copy_to_user copy_to_user #define kc_get_user(x,ptr) \ (get_user((x),(ptr))) #define kc_put_user(x,ptr) \ (put_user((x),(ptr)))#endif /* < 2.1.100 */#if (LINUX_VERSION_CODE >= VERSION(2,1,5)) #define kc_get_user_long(x,ptr) (kc_get_user((x),(long*)(ptr))) #define kc_get_user_word(x,ptr) (kc_get_user((x),(unsigned short*)(ptr))) #define kc_get_user_byte(x,ptr) (kc_get_user((x),(unsigned char*)(ptr))) #define kc_put_user_long(x,ptr) (kc_put_user((x),(long *)(ptr))) #define kc_put_user_word(x,ptr) (kc_put_user((x),(unsigned short*)(ptr))) #define kc_put_user_byte(x,ptr) (kc_put_user((x),(unsigned char*)(ptr)))#endif /* >= 2.1.5 *//*** resource manipulation changes ***/#if (LINUX_VERSION_CODE >= VERSION(2,4,0)) #define kc_request_region request_region #define kc_release_region release_region#else /* < 2.6.0 */ #define kc_request_region(start,len,name) \ ({ unsigned long kc_t_start=(start), kc_t_len=(len); \ int kc_t_res=!check_region(kc_t_start,kc_t_len); \ if(kc_t_res) request_region(kc_t_start,kc_t_len,name); \ kc_t_res; \ }) #define kc_release_region release_region#endif /* < 2.6.0 *//*** bitops changes ***/#if (LINUX_VERSION_CODE < VERSION(2,1,36)) /* may need correction */ #define test_and_set_bit set_bit#endif/*** interrupt related stuff ***/#if (LINUX_VERSION_CODE < VERSION(2,1,36)) /* may need correction */ #define kc_synchronize_irq(irqnum) do{cli();sti();}while(0)#elif (LINUX_VERSION_CODE < VERSION(2,5,33)) /* may need correction */ #define kc_synchronize_irq(irqnum) synchronize_irq()#else /* >=2.5.33 */ #define kc_synchronize_irq synchronize_irq#endif#if (LINUX_VERSION_CODE <= VERSION(2,5,67)) && !defined(IRQ_RETVAL) typedef void irqreturn_t; #define IRQ_NONE #define IRQ_HANDLED #define IRQ_RETVAL(x)#endif /* <=2.5.67 */#if (LINUX_VERSION_CODE <= VERSION(2,6,18)) #define KC_IRQ_HANDLER_ARGS(intno, dev_id) \ int intno, void *dev_id, struct pt_regs *regs#else /* <=2.6.18 */ #define KC_IRQ_HANDLER_ARGS(intno, dev_id) \ int intno, void *dev_id#endif /* <=2.6.18 *//*** timming related stuff ***/#if (LINUX_VERSION_CODE < VERSION(2,1,100)) /* needs correction */ #define schedule_timeout(timeout_jif) ({ \ current->timeout = jiffies + (timeout_jif); \ schedule(); \ current->timeout = 0; \ }) #ifndef set_current_state #define set_current_state(state_value) do { current->state = state_value; } while (0) #endif#endif#if (LINUX_VERSION_CODE < VERSION(2,1,36)) /* needs correction */ #define mod_timer(timer,expires) ({\ del_timer(timer); \ timer->expires=expires; \ add_timer(timer); \ })#endif/*** file_operations changes ***/#if (LINUX_VERSION_CODE < VERSION(2,1,5)) #define CLOSERET void #define RWRET int #define RWCOUNT_T int #define RWINODE_P struct inode *inode, #define RWPPOS_P #define RWINODE inode #define KC_FOPS_FLUSH(ptr) #define kc_dev2minor MINOR#elif (LINUX_VERSION_CODE < VERSION(2,1,36)) #define CLOSERET void #define RWRET long #define RWCOUNT_T unsigned long #define RWINODE_P struct inode *inode, #define RWPPOS_P #define RWINODE inode #define KC_FOPS_FLUSH(ptr) #define kc_dev2minor MINOR#elif (LINUX_VERSION_CODE < VERSION(2,1,76)) /* may need correction */ #define CLOSERET int #define RWRET long #define RWCOUNT_T unsigned long #define RWINODE_P struct inode *inode, #define RWPPOS_P #define RWINODE inode #define KC_FOPS_FLUSH(ptr) #define kc_dev2minor MINOR#elif (LINUX_VERSION_CODE < VERSION(2,1,117)) /* may need correction */ #define CLOSERET int #define RWRET ssize_t #define RWCOUNT_T size_t #define RWINODE_P #define RWPPOS_P ,loff_t *ppos #define RWINODE file->f_dentry->d_inode #define KC_FOPS_FLUSH(ptr) #define kc_dev2minor MINOR#elif ((LINUX_VERSION_CODE >= VERSION(2,5,7)) && (LINUX_VERSION_CODE < VERSION(2,6,0))) #define CLOSERET int #define RWRET ssize_t #define RWCOUNT_T size_t #define RWINODE_P #define RWPPOS_P ,loff_t *ppos #define RWINODE file->f_dentry->d_inode #define KC_FOPS_FLUSH(ptr) flush:(ptr), #define kc_dev2minor minor#else /* <2.5.7 >=2.6.0 */ /* may need correction */ #define CLOSERET int #define RWRET ssize_t #define RWCOUNT_T size_t #define RWINODE_P #define RWPPOS_P ,loff_t *ppos #define RWINODE file->f_dentry->d_inode #define KC_FOPS_FLUSH(ptr) flush:(ptr), #define kc_dev2minor MINOR#endif /* 2.1.36 */#if (LINUX_VERSION_CODE < VERSION(2,1,50)) /* may need correction */ #define kc_poll_wait(file,address,wait) poll_wait(address,wait)#else /* >= 2.1.50 */ #define kc_poll_wait poll_wait#endif /* 2.1.50 *//* definition of standard parameters for read/write file functions */#define READ_PARAMETERS \ RWINODE_P struct file *file, char *buf, RWCOUNT_T count RWPPOS_P#define WRITE_PARAMETERS \ RWINODE_P struct file *file, const char *buf, RWCOUNT_T count RWPPOS_P#define LSEEK_PARAMETERS \ RWINODE_P struct file *file, loff_t pos, int whence#if (LINUX_VERSION_CODE < VERSION(2,2,0)) /* may need correction */ #define KC_CHRDEV_FOPS_BEG(fops_var) \ static struct file_operations fops_var =\ { #define KC_CHRDEV_FOPS_END \ } #define KC_FOPS_LSEEK(ptr) lseek:(ptr), #define KC_FOPS_RELEASE(ptr) close:(ptr),#elif (LINUX_VERSION_CODE < VERSION(2,4,0)) /* may need correction */ #define KC_CHRDEV_FOPS_BEG(fops_var) \ static struct file_operations fops_var =\ { #define KC_CHRDEV_FOPS_END \ } #define KC_FOPS_LSEEK(ptr) llseek:(ptr), #define KC_FOPS_RELEASE(ptr) release:(ptr),#else /* >= 2.4.0 */ #define KC_CHRDEV_FOPS_BEG(fops_var) \ static struct file_operations fops_var = {\ owner:THIS_MODULE, #define KC_CHRDEV_FOPS_END \ } #define KC_FOPS_LSEEK(ptr) llseek:(ptr), #define KC_FOPS_RELEASE(ptr) release:(ptr),#endif /* 2.4.0 *//*** devices and drivers registration ***/#if (LINUX_VERSION_CODE >= VERSION(2,5,41)) /* may need correction */ #define devfs_register_chrdev register_chrdev #define devfs_unregister_chrdev unregister_chrdev#endif /* 2.5.40 */#if (LINUX_VERSION_CODE >= VERSION(2,5,60)) /* may need correction */ #define kc_devfs_handle_t char * #define kc_devfs_delete(handle) ({ devfs_remove(handle); kfree(handle); }) #define kc_devfs_new_cdev(dir_handle, dev_num, dev_mode, dev_ops, dev_info, dev_name) ({ \ char *kc_t_name; \ const char *kc_t_dev=(dev_name); \ const char *kc_t_dir=(dir_handle); \ const int kc_t_d=kc_t_dir?strlen(kc_t_dir)+1:0; \ int kc_t_n=strlen(kc_t_dev)+1+kc_t_d; \ if ((kc_t_name=kmalloc(kc_t_n,GFP_KERNEL))) { \ if(kc_t_d) {memcpy(kc_t_name,kc_t_dir,kc_t_d-1); kc_t_name[kc_t_d-1]='/';} \ strcpy(kc_t_name+kc_t_d,kc_t_dev); \ if(devfs_mk_cdev((dev_num), (dev_mode), kc_t_name)<0) { \ kfree(kc_t_name); \ kc_t_name = NULL ; \ } \ } \ kc_t_name; \ }) #define kc_devfs_mk_dir devfs_mk_dir#else /* 2.5.60 */ #define kc_devfs_handle_t devfs_handle_t #define kc_devfs_delete devfs_unregister #define kc_devfs_new_cdev(dir_handle, dev_num, dev_mode, dev_ops, dev_info, dev_name) ({ \ devfs_register((dir_handle), (dev_name), DEVFS_FL_DEFAULT, \ MAJOR(dev_num), MINOR(dev_num), (dev_mode), (dev_ops), (dev_info)); \ }) #define kc_devfs_mk_dir(dirname...) ({ \ char kc_buf[64]; int kc_n; \ kc_n = snprintf(buf, 64, ##dirname); \ (kc_n >= 64 || !buf[0])? NULL: devfs_mk_dir(NULL, kc_buf, NULL); \ })#endif /* 2.5.60 */#if (LINUX_VERSION_CODE <= VERSION(2,6,0)) typedef struct {int dummy;} kc_class; #define kc_class_create(...) (NULL) #define kc_class_device_create(...) #define kc_class_device_destroy(...) #define kc_class_destroy(...)#else /* 2.6.0 */ #define KC_WITH #include <linux/device.h> #if LINUX_VERSION_CODE >= VERSION(2,6,15) #define kc_class class #define kc_class_create class_create #define kc_class_device_create class_device_create #define kc_class_device_destroy class_device_destroy #define kc_class_destroy class_destroy #elif LINUX_VERSION_CODE >= VERSION(2,6,13) #define kc_class class #define kc_class_create class_create #define kc_class_device_create(cls, parent, devt, device, fmt...) \ class_device_create(cls, devt, device, ##fmt) #define kc_class_device_destroy class_device_destroy #define kc_class_destroy class_destroy #else /* 2.6.0 ... 2.6.12 */ #define kc_class class_simple #define kc_class_create class_simple_create #define kc_class_device_create(cls, parent, devt, device, fmt...) \ class_simple_device_add(cls, devt, device, ##fmt) #define kc_class_device_destroy(a,b) class_simple_device_remove(b) #define kc_class_destroy class_simple_destroy #endif #define kc_pci_dev_to_dev(pdev) (&(pdev)->dev) #define kc_usb_dev_to_dev(pdev) (&(pdev)->dev)#endif/*** tasklet declaration and processing ***/#if (LINUX_VERSION_CODE < VERSION(2,5,0)) /* may need correction */ #define kc_tasklet_struct tq_struct #define kc_tasklet_data_type void * #define KC_DECLARE_TASKLET(_name, _func, _data) \ struct tq_struct _name = { sync: 0, routine: _func, data: (void*)_data } /* void tasklet_init(struct tasklet_struct *t, void (*func)(unsigned long), unsigned long data); */ #define kc_tasklet_init(_tasklet, _func, _data) \ do{ \ /* (_tasklet)->next=NULL; */ \ /* Above not needed for 2.2.x and buggy for 2.4.x */ \ (_tasklet)->sync=0; \ (_tasklet)->routine=_func; \ (_tasklet)->data=(void*)_data; \ }while(0) /* void tasklet_schedule(struct tasklet_struct *t) */ #define kc_tasklet_schedule(_tasklet) \ do{ \ queue_task(_tasklet,&tq_immediate); \ mark_bh(IMMEDIATE_BH); \ }while(0) /* void tasklet_kill(struct tasklet_struct *t); */ #define kc_tasklet_kill(_tasklet) \ synchronize_irq()#else /* 2.5.40 */ /* struct tasklet_struct */ #define kc_tasklet_struct tasklet_struct /* DECLARE_TASKLET(name, func, data) */ #define kc_tasklet_data_type unsigned long #define KC_DECLARE_TASKLET DECLARE_TASKLET /* void tasklet_init(struct tasklet_struct *t, void (*func)(unsigned long), unsigned long data); */ #define kc_tasklet_init tasklet_init /* void tasklet_schedule(struct tasklet_struct *t) */ #define kc_tasklet_schedule tasklet_schedule /* void tasklet_kill(struct tasklet_struct *t); */ #define kc_tasklet_kill tasklet_kill#endif /* 2.5.40 *//*** scheduler changes ***/#if (LINUX_VERSION_CODE < VERSION(2,3,0)) /* may need correction */ #define kc_yield schedule#else /* 2.3.0 */ #define kc_yield yield#endif /* 2.3.0 *//*** PCI changes ***/#if (LINUX_VERSION_CODE < VERSION(2,6,11)) /* may need correction */ #define kc_pci_name(pdev) (pdev->slot_name)#else /* 2.6.11 */ #define kc_pci_name pci_name#endif /* 2.6.11 *//*** wait queues changes ***//* Next is not sctrictly correct, because of 2.3.0, 2.3.1, 2.3.2 probably need next definitions */#if (LINUX_VERSION_CODE < VERSION(2,2,19)) /* may need correction */ #define wait_queue_head_t struct wait_queue * #define wait_queue_t struct wait_queue #define init_waitqueue_head(queue_head) (*queue_head=NULL) #define init_waitqueue_entry(qentry,qtask) \ (qentry->next=NULL,qentry->task=qtask) #define DECLARE_WAIT_QUEUE_HEAD(name) \ struct wait_queue * name=NULL #define DECLARE_WAITQUEUE(wait, current) \ struct wait_queue wait = { current, NULL } #define init_MUTEX(sem) (*sem=MUTEX) #define DECLARE_MUTEX(name) struct semaphore name=MUTEX#endif /* 2.2.19 */#ifndef MODULE_LICENSE #define MODULE_LICENSE(dummy)#endif /* MODULE_LICENSE */#endif /* _LINUX_K_COMPAT_H */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -