Files
m68k-bdm/m683xx/bdm-driver/k_compat.h
Bernd Mueller adfd70813f initial push
2026-06-17 13:44:30 +02:00

437 lines
14 KiB
C

/*
* 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 */