From: Jerome Marchand <jmarchan@redhat.com>
To: Sergey Senozhatsky <sergey.senozhatsky@gmail.com>
Cc: Minchan Kim <minchan@kernel.org>, Nitin Gupta <ngupta@vflare.org>,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH 1/3] zram: drop `init_done' struct zram member
Date: Tue, 14 Jan 2014 12:03:36 +0100 [thread overview]
Message-ID: <52D51988.3050708@redhat.com> (raw)
In-Reply-To: <1389692260-4421-2-git-send-email-sergey.senozhatsky@gmail.com>
On 01/14/2014 10:37 AM, Sergey Senozhatsky wrote:
> Introduce init_done() helper function which allows us to drop
> `init_done' struct zram member. init_done() uses the fact that
> ->init_done == 1 equals to ->meta != NULL.
>
> Signed-off-by: Sergey Senozhatsky <sergey.senozhatsky@gmail.com>
Acked-by: Jerome Marchand <jmarchan@redhat.com>
> ---
> drivers/block/zram/zram_drv.c | 21 +++++++++++----------
> drivers/block/zram/zram_drv.h | 1 -
> 2 files changed, 11 insertions(+), 11 deletions(-)
>
> diff --git a/drivers/block/zram/zram_drv.c b/drivers/block/zram/zram_drv.c
> index 011e55d..c323e05 100644
> --- a/drivers/block/zram/zram_drv.c
> +++ b/drivers/block/zram/zram_drv.c
> @@ -42,6 +42,11 @@ static struct zram *zram_devices;
> /* Module params (documentation at end) */
> static unsigned int num_devices = 1;
>
> +static inline int init_done(struct zram *zram)
> +{
> + return zram->meta != NULL;
> +}
> +
> static inline struct zram *dev_to_zram(struct device *dev)
> {
> return (struct zram *)dev_to_disk(dev)->private_data;
> @@ -60,7 +65,7 @@ static ssize_t initstate_show(struct device *dev,
> {
> struct zram *zram = dev_to_zram(dev);
>
> - return sprintf(buf, "%u\n", zram->init_done);
> + return sprintf(buf, "%u\n", init_done(zram));
> }
>
> static ssize_t num_reads_show(struct device *dev,
> @@ -133,7 +138,7 @@ static ssize_t mem_used_total_show(struct device *dev,
> struct zram_meta *meta = zram->meta;
>
> down_read(&zram->init_lock);
> - if (zram->init_done)
> + if (init_done(zram))
> val = zs_get_total_size_bytes(meta->mem_pool);
> up_read(&zram->init_lock);
>
> @@ -546,14 +551,12 @@ static void zram_reset_device(struct zram *zram, bool reset_capacity)
> struct zram_meta *meta;
>
> down_write(&zram->init_lock);
> - if (!zram->init_done) {
> + if (!init_done(zram)) {
> up_write(&zram->init_lock);
> return;
> }
>
> meta = zram->meta;
> - zram->init_done = 0;
> -
> /* Free all pages that are still in this zram device */
> for (index = 0; index < zram->disksize >> PAGE_SHIFT; index++) {
> unsigned long handle = meta->table[index].handle;
> @@ -594,8 +597,6 @@ static void zram_init_device(struct zram *zram, struct zram_meta *meta)
> queue_flag_set_unlocked(QUEUE_FLAG_NONROT, zram->disk->queue);
>
> zram->meta = meta;
> - zram->init_done = 1;
> -
> pr_debug("Initialization done!\n");
> }
>
> @@ -613,7 +614,7 @@ static ssize_t disksize_store(struct device *dev,
> disksize = PAGE_ALIGN(disksize);
> meta = zram_meta_alloc(disksize);
> down_write(&zram->init_lock);
> - if (zram->init_done) {
> + if (init_done(zram)) {
> up_write(&zram->init_lock);
> zram_meta_free(meta);
> pr_info("Cannot change disksize for initialized device\n");
> @@ -734,7 +735,7 @@ static void zram_make_request(struct request_queue *queue, struct bio *bio)
> struct zram *zram = queue->queuedata;
>
> down_read(&zram->init_lock);
> - if (unlikely(!zram->init_done))
> + if (unlikely(!init_done(zram)))
> goto error;
>
> if (!valid_io_request(zram, bio)) {
> @@ -857,7 +858,7 @@ static int create_device(struct zram *zram, int device_id)
> goto out_free_disk;
> }
>
> - zram->init_done = 0;
> + zram->meta = NULL;
> return 0;
>
> out_free_disk:
> diff --git a/drivers/block/zram/zram_drv.h b/drivers/block/zram/zram_drv.h
> index ad8aa35..e81e9cd 100644
> --- a/drivers/block/zram/zram_drv.h
> +++ b/drivers/block/zram/zram_drv.h
> @@ -95,7 +95,6 @@ struct zram {
> struct zram_meta *meta;
> struct request_queue *queue;
> struct gendisk *disk;
> - int init_done;
> /* Prevent concurrent execution of device init, reset and R/W request */
> struct rw_semaphore init_lock;
> /*
>
next prev parent reply other threads:[~2014-01-14 11:04 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-01-14 9:37 [PATCH 0/3] zram stats rework and code cleanup Sergey Senozhatsky
2014-01-14 9:37 ` [PATCH 1/3] zram: drop `init_done' struct zram member Sergey Senozhatsky
2014-01-14 11:03 ` Jerome Marchand [this message]
2014-01-15 1:52 ` Minchan Kim
2014-01-14 9:37 ` [PATCH 2/3] zram: do not pass rw argument to __zram_make_request() Sergey Senozhatsky
2014-01-14 11:02 ` Jerome Marchand
2014-01-14 11:13 ` Sergey Senozhatsky
2014-01-14 12:27 ` Jerome Marchand
2014-01-14 11:27 ` [PATCHv2 " Sergey Senozhatsky
2014-01-15 2:10 ` Minchan Kim
2014-01-14 9:37 ` [PATCH 3/3] zram: rework reported to end-user zram statistics Sergey Senozhatsky
2014-01-14 10:38 ` Jerome Marchand
2014-01-14 10:57 ` Sergey Senozhatsky
2014-01-14 12:15 ` Jerome Marchand
2014-01-14 12:30 ` Sergey Senozhatsky
2014-01-14 11:10 ` Sergey Senozhatsky
2014-01-14 13:43 ` Jerome Marchand
2014-01-14 13:53 ` Sergey Senozhatsky
2014-01-14 14:02 ` Jerome Marchand
2014-01-14 14:09 ` Sergey Senozhatsky
2014-01-14 14:20 ` Jerome Marchand
2014-01-15 4:24 ` Minchan Kim
2014-01-15 9:10 ` Sergey Senozhatsky
2014-01-14 9:42 ` [PATCH 0/3] zram stats rework and code cleanup Sergey Senozhatsky
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=52D51988.3050708@redhat.com \
--to=jmarchan@redhat.com \
--cc=linux-kernel@vger.kernel.org \
--cc=minchan@kernel.org \
--cc=ngupta@vflare.org \
--cc=sergey.senozhatsky@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.