]> git.neil.brown.name Git - history.git/commitdiff
[PATCH] dm: remove dynamic table resizing
authorAndrew Morton <akpm@osdl.org>
Mon, 29 Dec 2003 13:55:40 +0000 (05:55 -0800)
committerLinus Torvalds <torvalds@home.osdl.org>
Mon, 29 Dec 2003 13:55:40 +0000 (05:55 -0800)
From: Joe Thornber <thornber@sistina.com>

The dm table size is always known in advance, so we can specify it in
dm_table_create(), rather than relying on dynamic resizing.

drivers/md/dm-ioctl-v1.c
drivers/md/dm-ioctl-v4.c
drivers/md/dm-table.c
drivers/md/dm.h

index fed010cafc1d93a77e4f0c0a33d610016ec1a207..ad78def0281ead658fe396e424e65ef614ea6153 100644 (file)
@@ -566,7 +566,7 @@ static int create(struct dm_ioctl *param, struct dm_ioctl *user)
        if (r)
                return r;
 
-       r = dm_table_create(&t, get_mode(param));
+       r = dm_table_create(&t, get_mode(param), param->target_count);
        if (r)
                return r;
 
@@ -894,7 +894,7 @@ static int reload(struct dm_ioctl *param, struct dm_ioctl *user)
        struct mapped_device *md;
        struct dm_table *t;
 
-       r = dm_table_create(&t, get_mode(param));
+       r = dm_table_create(&t, get_mode(param), param->target_count);
        if (r)
                return r;
 
index 64c7598e80f2fd8efd9bce7fcb2b5167bdc79eab..63658f25a9c602f3415247b3583430d8c4e6e334 100644 (file)
@@ -872,7 +872,7 @@ static int table_load(struct dm_ioctl *param, size_t param_size)
        struct hash_cell *hc;
        struct dm_table *t;
 
-       r = dm_table_create(&t, get_mode(param));
+       r = dm_table_create(&t, get_mode(param), param->target_count);
        if (r)
                return r;
 
index 46eaee908b40451ebc6e1b1d7841703d1bdb3bf0..39f101b707e81137206abc4b4366fa88375284ad 100644 (file)
@@ -202,7 +202,7 @@ static int alloc_targets(struct dm_table *t, unsigned int num)
        return 0;
 }
 
-int dm_table_create(struct dm_table **result, int mode)
+int dm_table_create(struct dm_table **result, int mode, unsigned num_targets)
 {
        struct dm_table *t = kmalloc(sizeof(*t), GFP_NOIO);
 
@@ -213,8 +213,12 @@ int dm_table_create(struct dm_table **result, int mode)
        INIT_LIST_HEAD(&t->devices);
        atomic_set(&t->holders, 1);
 
-       /* allocate a single nodes worth of targets to begin with */
-       if (alloc_targets(t, KEYS_PER_NODE)) {
+       if (!num_targets)
+               num_targets = KEYS_PER_NODE;
+
+       num_targets = dm_round_up(num_targets, KEYS_PER_NODE);
+
+       if (alloc_targets(t, num_targets)) {
                kfree(t);
                t = NULL;
                return -ENOMEM;
index d5deaf13fd80a502c5d512d2886699e1a11922b3..7619155211674641b575c804e21772285f65c263 100644 (file)
@@ -95,7 +95,7 @@ int dm_suspended(struct mapped_device *md);
  * Functions for manipulating a table.  Tables are also reference
  * counted.
  *---------------------------------------------------------------*/
-int dm_table_create(struct dm_table **result, int mode);
+int dm_table_create(struct dm_table **result, int mode, unsigned num_targets);
 
 void dm_table_get(struct dm_table *t);
 void dm_table_put(struct dm_table *t);