Add class / device portability code. Two autoconf tests
were added to cover the 3 possible APIs from 2.6.9 to 2.6.26. We attempt to use the newest interfaces and if not available fallback to the oldest. This a rework of some changes proposed by Ricardo for RHEL4. git-svn-id: https://outreach.scidac.gov/svn/spl/trunk@150 7e1ea52c-4ff2-0310-8f11-9dd32ca42a1c
This commit is contained in:
parent
877a32e91e
commit
46c685d0c4
|
@ -457,3 +457,31 @@ AC_DEFUN([SPL_AC_FLS64],
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
])
|
])
|
||||||
])
|
])
|
||||||
|
|
||||||
|
dnl #
|
||||||
|
dnl # 2.6.18 API change, check whether device_create() is available.
|
||||||
|
dnl # Device_create() was introduced in 2.6.18 and depricated
|
||||||
|
dnl # class_device_create() which was fully removed in 2.6.26.
|
||||||
|
dnl #
|
||||||
|
AC_DEFUN([SPL_AC_DEVICE_CREATE], [
|
||||||
|
SPL_CHECK_SYMBOL_EXPORT(
|
||||||
|
[device_create],
|
||||||
|
[drivers/base/core.c],
|
||||||
|
[AC_DEFINE(HAVE_DEVICE_CREATE, 1,
|
||||||
|
[device_create() is available])],
|
||||||
|
[])
|
||||||
|
])
|
||||||
|
|
||||||
|
dnl #
|
||||||
|
dnl # 2.6.13 API change, check whether class_device_create() is available.
|
||||||
|
dnl # Class_device_create() was introduced in 2.6.13 and depricated
|
||||||
|
dnl # class_simple_device_add() which was fully removed in 2.6.13.
|
||||||
|
dnl #
|
||||||
|
AC_DEFUN([SPL_AC_CLASS_DEVICE_CREATE], [
|
||||||
|
SPL_CHECK_SYMBOL_EXPORT(
|
||||||
|
[class_device_create],
|
||||||
|
[drivers/base/class.c],
|
||||||
|
[AC_DEFINE(HAVE_CLASS_DEVICE_CREATE, 1,
|
||||||
|
[class_device_create() is available])],
|
||||||
|
[])
|
||||||
|
])
|
||||||
|
|
|
@ -52,6 +52,8 @@ SPL_AC_PATH_IN_NAMEIDATA
|
||||||
SPL_AC_TASK_CURR
|
SPL_AC_TASK_CURR
|
||||||
SPL_AC_CTL_UNNUMBERED
|
SPL_AC_CTL_UNNUMBERED
|
||||||
SPL_AC_FLS64
|
SPL_AC_FLS64
|
||||||
|
SPL_AC_DEVICE_CREATE
|
||||||
|
SPL_AC_CLASS_DEVICE_CREATE
|
||||||
|
|
||||||
TOPDIR=`/bin/pwd`
|
TOPDIR=`/bin/pwd`
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,53 @@
|
||||||
|
#ifndef _SPL_DEVICE_H
|
||||||
|
#define _SPL_DEVICE_H
|
||||||
|
|
||||||
|
#include <linux/device.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Preferred API from 2.6.18 to 2.6.26+
|
||||||
|
*/
|
||||||
|
#ifdef HAVE_DEVICE_CREATE
|
||||||
|
|
||||||
|
typedef struct class spl_class;
|
||||||
|
|
||||||
|
#define spl_class_create(mod, name) class_create(mod, name)
|
||||||
|
#define spl_class_destroy(cls) class_destroy(cls)
|
||||||
|
#define spl_device_create(cls, parent, devt, device, fmt, args...) \
|
||||||
|
device_create(cls, parent, devt, fmt, ## args)
|
||||||
|
#define spl_device_destroy(cls, devt) device_destroy(cls, devt)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Preferred API from 2.6.13 to 2.6.17
|
||||||
|
* Depricated in 2.6.18
|
||||||
|
* Removed in 2.6.26
|
||||||
|
*/
|
||||||
|
#else
|
||||||
|
#ifdef HAVE_CLASS_DEVICE_CREATE
|
||||||
|
|
||||||
|
typedef struct class spl_class;
|
||||||
|
|
||||||
|
#define spl_class_create(mod, name) class_create(mod, name)
|
||||||
|
#define spl_class_destroy(cls) class_destroy(cls)
|
||||||
|
#define spl_device_create(cls, parent, devt, device, fmt, args...) \
|
||||||
|
class_device_create(cls, parent, devt, device, fmt, ## args)
|
||||||
|
#define spl_device_destroy(cls, devt) class_device_destroy(cls, devt)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Prefered API from 2.6.0 to 2.6.12
|
||||||
|
* Depricated in 2.6.13
|
||||||
|
* Removed in 2.6.13
|
||||||
|
*/
|
||||||
|
#else /* Legacy API */
|
||||||
|
|
||||||
|
typedef struct class_simple spl_class;
|
||||||
|
|
||||||
|
#define spl_class_create(mod, name) class_simple_create(mod, name)
|
||||||
|
#define spl_class_destroy(cls) class_simple_destroy(cls)
|
||||||
|
#define spl_device_create(cls, parent, devt, device, fmt, args...) \
|
||||||
|
class_simple_device_add(cls, devt, device, fmt, ## args)
|
||||||
|
#define spl_device_destroy(cls, devt) class_simple_device_remove(devt)
|
||||||
|
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _SPL_DEVICE_H */
|
|
@ -33,6 +33,7 @@
|
||||||
|
|
||||||
#define SPLAT_MAJOR 229 /* XXX - Arbitrary */
|
#define SPLAT_MAJOR 229 /* XXX - Arbitrary */
|
||||||
#define SPLAT_MINORS 1
|
#define SPLAT_MINORS 1
|
||||||
|
#define SPLAT_NAME "splatctl"
|
||||||
#define SPLAT_DEV "/dev/splatctl"
|
#define SPLAT_DEV "/dev/splatctl"
|
||||||
|
|
||||||
#define SPLAT_NAME_SIZE 12
|
#define SPLAT_NAME_SIZE 12
|
||||||
|
|
|
@ -35,7 +35,7 @@
|
||||||
#include <linux/fs.h>
|
#include <linux/fs.h>
|
||||||
#include <linux/cdev.h>
|
#include <linux/cdev.h>
|
||||||
#include <linux/list.h>
|
#include <linux/list.h>
|
||||||
#include <linux/device.h>
|
#include <spl-device.h>
|
||||||
|
|
||||||
typedef int ddi_devid_t;
|
typedef int ddi_devid_t;
|
||||||
|
|
||||||
|
@ -81,7 +81,7 @@ typedef struct dev_info {
|
||||||
kmutex_t di_lock;
|
kmutex_t di_lock;
|
||||||
struct dev_ops *di_ops;
|
struct dev_ops *di_ops;
|
||||||
struct cdev *di_cdev;
|
struct cdev *di_cdev;
|
||||||
struct class *di_class;
|
spl_class *di_class;
|
||||||
major_t di_major;
|
major_t di_major;
|
||||||
minor_t di_minor;
|
minor_t di_minor;
|
||||||
dev_t di_dev;
|
dev_t di_dev;
|
||||||
|
|
|
@ -153,7 +153,7 @@ __ddi_create_minor_node(dev_info_t *di, char *name, int spec_type,
|
||||||
RETURN(DDI_FAILURE);
|
RETURN(DDI_FAILURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
di->di_class = class_create(THIS_MODULE, name);
|
di->di_class = spl_class_create(THIS_MODULE, name);
|
||||||
if (IS_ERR(di->di_class)) {
|
if (IS_ERR(di->di_class)) {
|
||||||
rc = PTR_ERR(di->di_class);
|
rc = PTR_ERR(di->di_class);
|
||||||
CERROR("Error creating %s class, %d\n", name, rc);
|
CERROR("Error creating %s class, %d\n", name, rc);
|
||||||
|
@ -165,11 +165,11 @@ __ddi_create_minor_node(dev_info_t *di, char *name, int spec_type,
|
||||||
|
|
||||||
/* Do not append a 0 to devices with minor nums of 0 */
|
/* Do not append a 0 to devices with minor nums of 0 */
|
||||||
if (di->di_minor == 0) {
|
if (di->di_minor == 0) {
|
||||||
class_device_create(di->di_class, NULL, di->di_dev,
|
spl_device_create(di->di_class, NULL, di->di_dev,
|
||||||
NULL, "%s", name);
|
NULL, "%s", name);
|
||||||
} else {
|
} else {
|
||||||
class_device_create(di->di_class, NULL, di->di_dev,
|
spl_device_create(di->di_class, NULL, di->di_dev,
|
||||||
NULL, "%s%d", name, di->di_minor);
|
NULL, "%s%d", name, di->di_minor);
|
||||||
}
|
}
|
||||||
|
|
||||||
di->di_cdev = cdev;
|
di->di_cdev = cdev;
|
||||||
|
@ -188,8 +188,8 @@ static void
|
||||||
__ddi_remove_minor_node_locked(dev_info_t *di, char *name)
|
__ddi_remove_minor_node_locked(dev_info_t *di, char *name)
|
||||||
{
|
{
|
||||||
if (di->di_class) {
|
if (di->di_class) {
|
||||||
class_device_destroy(di->di_class, di->di_dev);
|
spl_device_destroy(di->di_class, di->di_dev);
|
||||||
class_destroy(di->di_class);
|
spl_class_destroy(di->di_class);
|
||||||
|
|
||||||
di->di_class = NULL;
|
di->di_class = NULL;
|
||||||
di->di_dev = 0;
|
di->di_dev = 0;
|
||||||
|
|
|
@ -42,18 +42,7 @@
|
||||||
|
|
||||||
#include "splat-internal.h"
|
#include "splat-internal.h"
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18)
|
static spl_class *splat_class;
|
||||||
#include <linux/devfs_fs_kernel.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <linux/cdev.h>
|
|
||||||
|
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18)
|
|
||||||
static struct class_simple *splat_class;
|
|
||||||
#else
|
|
||||||
static struct class *splat_class;
|
|
||||||
#endif
|
|
||||||
static struct list_head splat_module_list;
|
static struct list_head splat_module_list;
|
||||||
static spinlock_t splat_module_lock;
|
static spinlock_t splat_module_lock;
|
||||||
|
|
||||||
|
@ -594,7 +583,7 @@ static struct file_operations splat_fops = {
|
||||||
|
|
||||||
static struct cdev splat_cdev = {
|
static struct cdev splat_cdev = {
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.kobj = { .name = "splatctl", },
|
.kobj = { .name = SPLAT_NAME, },
|
||||||
};
|
};
|
||||||
|
|
||||||
static int __init
|
static int __init
|
||||||
|
@ -619,7 +608,7 @@ splat_init(void)
|
||||||
SPLAT_SUBSYSTEM_INIT(atomic);
|
SPLAT_SUBSYSTEM_INIT(atomic);
|
||||||
|
|
||||||
dev = MKDEV(SPLAT_MAJOR, 0);
|
dev = MKDEV(SPLAT_MAJOR, 0);
|
||||||
if ((rc = register_chrdev_region(dev, SPLAT_MINORS, "splatctl")))
|
if ((rc = register_chrdev_region(dev, SPLAT_MINORS, SPLAT_NAME)))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
/* Support for registering a character driver */
|
/* Support for registering a character driver */
|
||||||
|
@ -632,11 +621,7 @@ splat_init(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Support for udev make driver info available in sysfs */
|
/* Support for udev make driver info available in sysfs */
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18)
|
splat_class = spl_class_create(THIS_MODULE, "splat");
|
||||||
splat_class = class_simple_create(THIS_MODULE, "splat");
|
|
||||||
#else
|
|
||||||
splat_class = class_create(THIS_MODULE, "splat");
|
|
||||||
#endif
|
|
||||||
if (IS_ERR(splat_class)) {
|
if (IS_ERR(splat_class)) {
|
||||||
rc = PTR_ERR(splat_class);
|
rc = PTR_ERR(splat_class);
|
||||||
printk(KERN_ERR "splat: Error creating splat class, %d\n", rc);
|
printk(KERN_ERR "splat: Error creating splat class, %d\n", rc);
|
||||||
|
@ -645,13 +630,8 @@ splat_init(void)
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18)
|
spl_device_create(splat_class, NULL, MKDEV(SPLAT_MAJOR, 0),
|
||||||
class_simple_device_add(splat_class, MKDEV(SPLAT_MAJOR, 0),
|
NULL, SPLAT_NAME);
|
||||||
NULL, "splatctl");
|
|
||||||
#else
|
|
||||||
class_device_create(splat_class, NULL, MKDEV(SPLAT_MAJOR, 0),
|
|
||||||
NULL, "splatctl");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
printk(KERN_INFO "splat: Loaded Solaris Porting LAyer "
|
printk(KERN_INFO "splat: Loaded Solaris Porting LAyer "
|
||||||
"Tests v%s\n", VERSION);
|
"Tests v%s\n", VERSION);
|
||||||
|
@ -666,15 +646,8 @@ splat_fini(void)
|
||||||
{
|
{
|
||||||
dev_t dev = MKDEV(SPLAT_MAJOR, 0);
|
dev_t dev = MKDEV(SPLAT_MAJOR, 0);
|
||||||
|
|
||||||
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,18)
|
spl_device_destroy(splat_class, dev);
|
||||||
class_simple_device_remove(dev);
|
spl_class_destroy(splat_class);
|
||||||
class_simple_destroy(splat_class);
|
|
||||||
devfs_remove("splat/splatctl");
|
|
||||||
devfs_remove("splat");
|
|
||||||
#else
|
|
||||||
class_device_destroy(splat_class, dev);
|
|
||||||
class_destroy(splat_class);
|
|
||||||
#endif
|
|
||||||
cdev_del(&splat_cdev);
|
cdev_del(&splat_cdev);
|
||||||
unregister_chrdev_region(dev, SPLAT_MINORS);
|
unregister_chrdev_region(dev, SPLAT_MINORS);
|
||||||
|
|
||||||
|
|
|
@ -60,7 +60,9 @@
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/kobj.h>
|
#include <sys/kobj.h>
|
||||||
#include <sys/atomic.h>
|
#include <sys/atomic.h>
|
||||||
|
#include <linux/cdev.h>
|
||||||
|
|
||||||
|
#include "spl-device.h"
|
||||||
#include "splat-ctl.h"
|
#include "splat-ctl.h"
|
||||||
|
|
||||||
#define SPLAT_SUBSYSTEM_INIT(type) \
|
#define SPLAT_SUBSYSTEM_INIT(type) \
|
||||||
|
|
Loading…
Reference in New Issue