Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 268278
b: refs/heads/master
c: 0900bea
h: refs/heads/master
v: v3
  • Loading branch information
Jerome Marchand authored and Greg Kroah-Hartman committed Sep 6, 2011
1 parent 168e8ff commit 4a72534
Show file tree
Hide file tree
Showing 4 changed files with 45 additions and 27 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: a1c821ae6c63d9ac648374f4953295e350572d3c
refs/heads/master: 0900beae178a84e653d9088979cf3014babc097e
46 changes: 29 additions & 17 deletions trunk/drivers/staging/zram/zram_drv.c
Original file line number Diff line number Diff line change
Expand Up @@ -560,27 +560,34 @@ static int zram_make_request(struct request_queue *queue, struct bio *bio)
{
struct zram *zram = queue->queuedata;

if (unlikely(!zram->init_done) && zram_init_device(zram))
goto error;

down_read(&zram->init_lock);
if (unlikely(!zram->init_done))
goto error_unlock;

if (!valid_io_request(zram, bio)) {
zram_stat64_inc(zram, &zram->stats.invalid_io);
bio_io_error(bio);
return 0;
}

if (unlikely(!zram->init_done) && zram_init_device(zram)) {
bio_io_error(bio);
return 0;
goto error_unlock;
}

__zram_make_request(zram, bio, bio_data_dir(bio));
up_read(&zram->init_lock);

return 0;

error_unlock:
up_read(&zram->init_lock);
error:
bio_io_error(bio);
return 0;
}

void zram_reset_device(struct zram *zram)
void __zram_reset_device(struct zram *zram)
{
size_t index;

mutex_lock(&zram->init_lock);
zram->init_done = 0;

/* Free various per-device buffers */
Expand Down Expand Up @@ -617,18 +624,24 @@ void zram_reset_device(struct zram *zram)
memset(&zram->stats, 0, sizeof(zram->stats));

zram->disksize = 0;
mutex_unlock(&zram->init_lock);
}

void zram_reset_device(struct zram *zram)
{
down_write(&zram->init_lock);
__zram_reset_device(zram);
up_write(&zram->init_lock);
}

int zram_init_device(struct zram *zram)
{
int ret;
size_t num_pages;

mutex_lock(&zram->init_lock);
down_write(&zram->init_lock);

if (zram->init_done) {
mutex_unlock(&zram->init_lock);
up_write(&zram->init_lock);
return 0;
}

Expand Down Expand Up @@ -671,15 +684,14 @@ int zram_init_device(struct zram *zram)
}

zram->init_done = 1;
mutex_unlock(&zram->init_lock);
up_write(&zram->init_lock);

pr_debug("Initialization done!\n");
return 0;

fail:
mutex_unlock(&zram->init_lock);
zram_reset_device(zram);

__zram_reset_device(zram);
up_write(&zram->init_lock);
pr_err("Initialization failed: err=%d\n", ret);
return ret;
}
Expand All @@ -703,7 +715,7 @@ static int create_device(struct zram *zram, int device_id)
int ret = 0;

init_rwsem(&zram->lock);
mutex_init(&zram->init_lock);
init_rwsem(&zram->init_lock);
spin_lock_init(&zram->stat64_lock);

zram->queue = blk_alloc_queue(GFP_KERNEL);
Expand Down
6 changes: 3 additions & 3 deletions trunk/drivers/staging/zram/zram_drv.h
Original file line number Diff line number Diff line change
Expand Up @@ -112,8 +112,8 @@ struct zram {
struct request_queue *queue;
struct gendisk *disk;
int init_done;
/* Prevent concurrent execution of device init and reset */
struct mutex init_lock;
/* Prevent concurrent execution of device init, reset and R/W request */
struct rw_semaphore init_lock;
/*
* This is the limit on amount of *uncompressed* worth of data
* we can store in a disk.
Expand All @@ -130,6 +130,6 @@ extern struct attribute_group zram_disk_attr_group;
#endif

extern int zram_init_device(struct zram *zram);
extern void zram_reset_device(struct zram *zram);
extern void __zram_reset_device(struct zram *zram);

#endif
18 changes: 12 additions & 6 deletions trunk/drivers/staging/zram/zram_sysfs.c
Original file line number Diff line number Diff line change
Expand Up @@ -55,19 +55,23 @@ static ssize_t disksize_store(struct device *dev,
struct device_attribute *attr, const char *buf, size_t len)
{
int ret;
u64 disksize;
struct zram *zram = dev_to_zram(dev);

ret = strict_strtoull(buf, 10, &disksize);
if (ret)
return ret;

down_write(&zram->init_lock);
if (zram->init_done) {
up_write(&zram->init_lock);
pr_info("Cannot change disksize for initialized device\n");
return -EBUSY;
}

ret = strict_strtoull(buf, 10, &zram->disksize);
if (ret)
return ret;

zram->disksize = PAGE_ALIGN(zram->disksize);
zram->disksize = PAGE_ALIGN(disksize);
set_capacity(zram->disk, zram->disksize >> SECTOR_SHIFT);
up_write(&zram->init_lock);

return len;
}
Expand Down Expand Up @@ -106,8 +110,10 @@ static ssize_t reset_store(struct device *dev,
if (bdev)
fsync_bdev(bdev);

down_write(&zram->init_lock);
if (zram->init_done)
zram_reset_device(zram);
__zram_reset_device(zram);
up_write(&zram->init_lock);

return len;
}
Expand Down

0 comments on commit 4a72534

Please sign in to comment.