#include <linux/types.h>
#include <linux/device.h>
-#include <linux/spinlock.h>
struct arqb {
u64 data;
u64 size;
unsigned int nr_max_block;
struct device dev;
- spinlock_t lock;
struct {
unsigned int persistence:4;
unsigned int oper_state:4;
#define pr_fmt(fmt) KMSG_COMPONENT ": " fmt
#include <linux/module.h>
-#include <linux/spinlock.h>
#include <linux/slab.h>
#include <asm/eadm.h>
#include "scm_blk.h"
if (!bdev)
return -ENOMEM;
- spin_lock_irq(&scmdev->lock);
dev_set_drvdata(&scmdev->dev, bdev);
- spin_unlock_irq(&scmdev->lock);
-
ret = scm_blk_dev_setup(bdev, scmdev);
if (ret) {
- spin_lock_irq(&scmdev->lock);
dev_set_drvdata(&scmdev->dev, NULL);
- spin_unlock_irq(&scmdev->lock);
kfree(bdev);
goto out;
}
static int scm_remove(struct scm_device *scmdev)
{
- struct scm_blk_dev *bdev;
+ struct scm_blk_dev *bdev = dev_get_drvdata(&scmdev->dev);
- spin_lock_irq(&scmdev->lock);
- bdev = dev_get_drvdata(&scmdev->dev);
dev_set_drvdata(&scmdev->dev, NULL);
- spin_unlock_irq(&scmdev->lock);
scm_blk_dev_cleanup(bdev);
kfree(bdev);
* Author(s): Sebastian Ott <sebott@linux.vnet.ibm.com>
*/
-#include <linux/spinlock.h>
#include <linux/device.h>
#include <linux/module.h>
#include <linux/mutex.h>
struct scm_device *scmdev = to_scm_dev(dev); \
int ret; \
\
- spin_lock(&scmdev->lock); \
+ device_lock(dev); \
ret = sprintf(buf, "%u\n", scmdev->attrs.name); \
- spin_unlock(&scmdev->lock); \
+ device_unlock(dev); \
\
return ret; \
} \
scmdev->dev.bus = &scm_bus_type;
scmdev->dev.release = scmdev_release;
scmdev->dev.groups = scmdev_attr_groups;
- spin_lock_init(&scmdev->lock);
}
/*