Commit d22f76e7 authored by Alex Elder's avatar Alex Elder Committed by Sage Weil
Browse files

rbd: dynamically allocate pool name



There is no need to impose a small limit the length of the pool name
recorded for an rbd image in a struct rbd_device.  Remove the
limitation by allocating space for the pool name ynamically.

Signed-off-by: default avatarAlex Elder <elder@inktank.com>
Reviewed-by: default avatarJosh Durgin <josh.durgin@inktank.com>
parent 9bb2f334
Loading
Loading
Loading
Loading
+19 −8
Original line number Original line Diff line number Diff line
@@ -56,7 +56,6 @@
#define RBD_MINORS_PER_MAJOR	256		/* max minors per blkdev */
#define RBD_MINORS_PER_MAJOR	256		/* max minors per blkdev */


#define RBD_MAX_MD_NAME_LEN	(RBD_MAX_OBJ_NAME_LEN + sizeof(RBD_SUFFIX))
#define RBD_MAX_MD_NAME_LEN	(RBD_MAX_OBJ_NAME_LEN + sizeof(RBD_SUFFIX))
#define RBD_MAX_POOL_NAME_LEN	64
#define RBD_MAX_SNAP_NAME_LEN	32
#define RBD_MAX_SNAP_NAME_LEN	32
#define RBD_MAX_OPT_LEN		1024
#define RBD_MAX_OPT_LEN		1024


@@ -166,7 +165,7 @@ struct rbd_device {
	char			obj[RBD_MAX_OBJ_NAME_LEN]; /* rbd image name */
	char			obj[RBD_MAX_OBJ_NAME_LEN]; /* rbd image name */
	int			obj_len;
	int			obj_len;
	char			obj_md_name[RBD_MAX_MD_NAME_LEN]; /* hdr nm. */
	char			obj_md_name[RBD_MAX_MD_NAME_LEN]; /* hdr nm. */
	char			pool_name[RBD_MAX_POOL_NAME_LEN];
	char			*pool_name;
	int			pool_id;
	int			pool_id;


	struct ceph_osd_event   *watch_event;
	struct ceph_osd_event   *watch_event;
@@ -2331,6 +2330,8 @@ static inline char *dup_token(const char **buf, size_t *lenp)
 * rbd_dev, rbd_md_name, and name fields of the given rbd_dev, based
 * rbd_dev, rbd_md_name, and name fields of the given rbd_dev, based
 * on the list of monitor addresses and other options provided via
 * on the list of monitor addresses and other options provided via
 * /sys/bus/rbd/add.
 * /sys/bus/rbd/add.
 *
 * Note: rbd_dev is assumed to have been initially zero-filled.
 */
 */
static int rbd_add_parse_args(struct rbd_device *rbd_dev,
static int rbd_add_parse_args(struct rbd_device *rbd_dev,
			      const char *buf,
			      const char *buf,
@@ -2340,6 +2341,7 @@ static int rbd_add_parse_args(struct rbd_device *rbd_dev,
			      size_t options_size)
			      size_t options_size)
{
{
	size_t len;
	size_t len;
	int ret;


	/* The first four tokens are required */
	/* The first four tokens are required */


@@ -2355,13 +2357,14 @@ static int rbd_add_parse_args(struct rbd_device *rbd_dev,
	if (!len || len >= options_size)
	if (!len || len >= options_size)
		return -EINVAL;
		return -EINVAL;


	len = copy_token(&buf, rbd_dev->pool_name, sizeof (rbd_dev->pool_name));
	rbd_dev->pool_name = dup_token(&buf, NULL);
	if (!len || len >= sizeof (rbd_dev->pool_name))
	if (!rbd_dev->pool_name)
		return -EINVAL;
		return -ENOMEM;


	ret = -EINVAL;
	len = copy_token(&buf, rbd_dev->obj, sizeof (rbd_dev->obj));
	len = copy_token(&buf, rbd_dev->obj, sizeof (rbd_dev->obj));
	if (!len || len >= sizeof (rbd_dev->obj))
	if (!len || len >= sizeof (rbd_dev->obj))
		return -EINVAL;
		goto out_err;


	/* We have the object length in hand, save it. */
	/* We have the object length in hand, save it. */


@@ -2380,9 +2383,15 @@ static int rbd_add_parse_args(struct rbd_device *rbd_dev,
		memcpy(rbd_dev->snap_name, RBD_SNAP_HEAD_NAME,
		memcpy(rbd_dev->snap_name, RBD_SNAP_HEAD_NAME,
			sizeof (RBD_SNAP_HEAD_NAME));
			sizeof (RBD_SNAP_HEAD_NAME));
	else if (len >= sizeof (rbd_dev->snap_name))
	else if (len >= sizeof (rbd_dev->snap_name))
		return -EINVAL;
		goto out_err;


	return 0;
	return 0;

out_err:
	kfree(rbd_dev->pool_name);
	rbd_dev->pool_name = NULL;

	return ret;
}
}


static ssize_t rbd_add(struct bus_type *bus,
static ssize_t rbd_add(struct bus_type *bus,
@@ -2480,6 +2489,7 @@ static ssize_t rbd_add(struct bus_type *bus,
err_out_client:
err_out_client:
	rbd_put_client(rbd_dev);
	rbd_put_client(rbd_dev);
err_put_id:
err_put_id:
	kfree(rbd_dev->pool_name);
	rbd_id_put(rbd_dev);
	rbd_id_put(rbd_dev);
err_nomem:
err_nomem:
	kfree(options);
	kfree(options);
@@ -2528,6 +2538,7 @@ static void rbd_dev_release(struct device *dev)
	unregister_blkdev(rbd_dev->major, rbd_dev->name);
	unregister_blkdev(rbd_dev->major, rbd_dev->name);


	/* done with the id, and with the rbd_dev */
	/* done with the id, and with the rbd_dev */
	kfree(rbd_dev->pool_name);
	rbd_id_put(rbd_dev);
	rbd_id_put(rbd_dev);
	kfree(rbd_dev);
	kfree(rbd_dev);