nbd.c 28.9 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5 6
/*
 * Network block device - make block devices work over TCP
 *
 * Note that you can not swap over this thing, yet. Seems to work but
 * deadlocks sometimes - you can not swap over TCP in general.
 * 
P
Pavel Machek 已提交
7
 * Copyright 1997-2000, 2008 Pavel Machek <pavel@ucw.cz>
L
Linus Torvalds 已提交
8 9
 * Parts copyright 2001 Steven Whitehouse <steve@chygwyn.com>
 *
10
 * This file is released under GPLv2 or later.
L
Linus Torvalds 已提交
11
 *
12
 * (part of code stolen from loop.c)
L
Linus Torvalds 已提交
13 14 15 16 17 18 19 20 21 22 23 24 25 26
 */

#include <linux/major.h>

#include <linux/blkdev.h>
#include <linux/module.h>
#include <linux/init.h>
#include <linux/sched.h>
#include <linux/fs.h>
#include <linux/bio.h>
#include <linux/stat.h>
#include <linux/errno.h>
#include <linux/file.h>
#include <linux/ioctl.h>
27
#include <linux/mutex.h>
28 29 30
#include <linux/compiler.h>
#include <linux/err.h>
#include <linux/kernel.h>
31
#include <linux/slab.h>
L
Linus Torvalds 已提交
32
#include <net/sock.h>
33
#include <linux/net.h>
34
#include <linux/kthread.h>
M
Markus Pargmann 已提交
35
#include <linux/types.h>
M
Markus Pargmann 已提交
36
#include <linux/debugfs.h>
J
Josef Bacik 已提交
37
#include <linux/blk-mq.h>
L
Linus Torvalds 已提交
38

39
#include <linux/uaccess.h>
L
Linus Torvalds 已提交
40 41 42 43
#include <asm/types.h>

#include <linux/nbd.h>

44 45 46
static DEFINE_IDR(nbd_index_idr);
static DEFINE_MUTEX(nbd_index_mutex);

J
Josef Bacik 已提交
47 48 49
struct nbd_sock {
	struct socket *sock;
	struct mutex tx_lock;
J
Josef Bacik 已提交
50 51
	struct request *pending;
	int sent;
J
Josef Bacik 已提交
52 53
};

J
Josef Bacik 已提交
54 55
#define NBD_TIMEDOUT			0
#define NBD_DISCONNECT_REQUESTED	1
J
Josef Bacik 已提交
56 57
#define NBD_DISCONNECTED		2
#define NBD_RUNNING			3
J
Josef Bacik 已提交
58

59
struct nbd_device {
M
Markus Pargmann 已提交
60
	u32 flags;
J
Josef Bacik 已提交
61
	unsigned long runtime_flags;
J
Josef Bacik 已提交
62
	struct nbd_sock **socks;
63 64
	int magic;

J
Josef Bacik 已提交
65
	struct blk_mq_tag_set tag_set;
66

J
Josef Bacik 已提交
67
	struct mutex config_lock;
68
	struct gendisk *disk;
J
Josef Bacik 已提交
69 70 71
	int num_connections;
	atomic_t recv_threads;
	wait_queue_head_t recv_wq;
72
	loff_t blksize;
M
Markus Pargmann 已提交
73
	loff_t bytesize;
M
Markus Pargmann 已提交
74 75

	struct task_struct *task_recv;
J
Josef Bacik 已提交
76
	struct task_struct *task_setup;
M
Markus Pargmann 已提交
77 78 79 80

#if IS_ENABLED(CONFIG_DEBUG_FS)
	struct dentry *dbg_dir;
#endif
81 82
};

J
Josef Bacik 已提交
83 84
struct nbd_cmd {
	struct nbd_device *nbd;
J
Josef Bacik 已提交
85
	struct completion send_complete;
J
Josef Bacik 已提交
86 87
};

M
Markus Pargmann 已提交
88 89 90 91 92 93
#if IS_ENABLED(CONFIG_DEBUG_FS)
static struct dentry *nbd_dbg_dir;
#endif

#define nbd_name(nbd) ((nbd)->disk->disk_name)

94
#define NBD_MAGIC 0x68797548
L
Linus Torvalds 已提交
95

96
static unsigned int nbds_max = 16;
L
Laurent Vivier 已提交
97
static int max_part;
98
static struct workqueue_struct *recv_workqueue;
99
static int part_shift;
L
Linus Torvalds 已提交
100

J
Josef Bacik 已提交
101 102 103 104
static int nbd_dev_dbg_init(struct nbd_device *nbd);
static void nbd_dev_dbg_close(struct nbd_device *nbd);


105
static inline struct device *nbd_to_dev(struct nbd_device *nbd)
L
Linus Torvalds 已提交
106
{
107
	return disk_to_dev(nbd->disk);
L
Linus Torvalds 已提交
108 109
}

110 111 112 113 114
static bool nbd_is_connected(struct nbd_device *nbd)
{
	return !!nbd->task_recv;
}

L
Linus Torvalds 已提交
115 116 117 118 119 120
static const char *nbdcmd_to_ascii(int cmd)
{
	switch (cmd) {
	case  NBD_CMD_READ: return "read";
	case NBD_CMD_WRITE: return "write";
	case  NBD_CMD_DISC: return "disconnect";
A
Alex Bligh 已提交
121
	case NBD_CMD_FLUSH: return "flush";
P
Paul Clements 已提交
122
	case  NBD_CMD_TRIM: return "trim/discard";
L
Linus Torvalds 已提交
123 124 125 126
	}
	return "invalid";
}

127 128
static int nbd_size_clear(struct nbd_device *nbd, struct block_device *bdev)
{
129 130
	if (bdev->bd_openers <= 1)
		bd_set_size(bdev, 0);
131 132 133 134 135 136 137 138
	set_capacity(nbd->disk, 0);
	kobject_uevent(&nbd_to_dev(nbd)->kobj, KOBJ_CHANGE);

	return 0;
}

static void nbd_size_update(struct nbd_device *nbd, struct block_device *bdev)
{
139 140 141
	blk_queue_logical_block_size(nbd->disk->queue, nbd->blksize);
	blk_queue_physical_block_size(nbd->disk->queue, nbd->blksize);
	bd_set_size(bdev, nbd->bytesize);
142 143 144 145
	set_capacity(nbd->disk, nbd->bytesize >> 9);
	kobject_uevent(&nbd_to_dev(nbd)->kobj, KOBJ_CHANGE);
}

146
static void nbd_size_set(struct nbd_device *nbd, struct block_device *bdev,
147
			loff_t blocksize, loff_t nr_blocks)
148 149
{
	nbd->blksize = blocksize;
150
	nbd->bytesize = blocksize * nr_blocks;
151 152
	if (nbd_is_connected(nbd))
		nbd_size_update(nbd, bdev);
153 154
}

J
Josef Bacik 已提交
155
static void nbd_end_request(struct nbd_cmd *cmd)
L
Linus Torvalds 已提交
156
{
J
Josef Bacik 已提交
157 158
	struct nbd_device *nbd = cmd->nbd;
	struct request *req = blk_mq_rq_from_pdu(cmd);
159
	int error = req->errors ? -EIO : 0;
L
Linus Torvalds 已提交
160

J
Josef Bacik 已提交
161
	dev_dbg(nbd_to_dev(nbd), "request %p: %s\n", cmd,
162
		error ? "failed" : "done");
L
Linus Torvalds 已提交
163

J
Josef Bacik 已提交
164
	blk_mq_complete_request(req, error);
L
Linus Torvalds 已提交
165 166
}

167 168 169
/*
 * Forcibly shutdown the socket causing all listeners to error
 */
170
static void sock_shutdown(struct nbd_device *nbd)
171
{
J
Josef Bacik 已提交
172
	int i;
M
Markus Pargmann 已提交
173

J
Josef Bacik 已提交
174 175 176
	if (nbd->num_connections == 0)
		return;
	if (test_and_set_bit(NBD_DISCONNECTED, &nbd->runtime_flags))
M
Markus Pargmann 已提交
177
		return;
M
Markus Pargmann 已提交
178

J
Josef Bacik 已提交
179 180 181 182 183 184 185
	for (i = 0; i < nbd->num_connections; i++) {
		struct nbd_sock *nsock = nbd->socks[i];
		mutex_lock(&nsock->tx_lock);
		kernel_sock_shutdown(nsock->sock, SHUT_RDWR);
		mutex_unlock(&nsock->tx_lock);
	}
	dev_warn(disk_to_dev(nbd->disk), "shutting down sockets\n");
186 187
}

188 189
static enum blk_eh_timer_return nbd_xmit_timeout(struct request *req,
						 bool reserved)
190
{
191 192
	struct nbd_cmd *cmd = blk_mq_rq_to_pdu(req);
	struct nbd_device *nbd = cmd->nbd;
M
Markus Pargmann 已提交
193

J
Josef Bacik 已提交
194
	dev_err(nbd_to_dev(nbd), "Connection timed out, shutting down connection\n");
J
Josef Bacik 已提交
195
	set_bit(NBD_TIMEDOUT, &nbd->runtime_flags);
196
	req->errors = -EIO;
J
Josef Bacik 已提交
197 198 199 200

	mutex_lock(&nbd->config_lock);
	sock_shutdown(nbd);
	mutex_unlock(&nbd->config_lock);
201
	return BLK_EH_HANDLED;
202 203
}

L
Linus Torvalds 已提交
204 205 206
/*
 *  Send or receive packet.
 */
A
Al Viro 已提交
207
static int sock_xmit(struct nbd_device *nbd, int index, int send,
J
Josef Bacik 已提交
208
		     struct iov_iter *iter, int msg_flags, int *sent)
L
Linus Torvalds 已提交
209
{
J
Josef Bacik 已提交
210
	struct socket *sock = nbd->socks[index]->sock;
L
Linus Torvalds 已提交
211 212
	int result;
	struct msghdr msg;
213
	unsigned long pflags = current->flags;
L
Linus Torvalds 已提交
214

215
	if (unlikely(!sock)) {
216
		dev_err_ratelimited(disk_to_dev(nbd->disk),
217 218
			"Attempted %s on closed socket in sock_xmit\n",
			(send ? "send" : "recv"));
219 220 221
		return -EINVAL;
	}

A
Al Viro 已提交
222
	msg.msg_iter = *iter;
223

224
	current->flags |= PF_MEMALLOC;
L
Linus Torvalds 已提交
225
	do {
226
		sock->sk->sk_allocation = GFP_NOIO | __GFP_MEMALLOC;
L
Linus Torvalds 已提交
227 228 229 230 231 232
		msg.msg_name = NULL;
		msg.msg_namelen = 0;
		msg.msg_control = NULL;
		msg.msg_controllen = 0;
		msg.msg_flags = msg_flags | MSG_NOSIGNAL;

M
Markus Pargmann 已提交
233
		if (send)
234
			result = sock_sendmsg(sock, &msg);
M
Markus Pargmann 已提交
235
		else
236
			result = sock_recvmsg(sock, &msg, msg.msg_flags);
L
Linus Torvalds 已提交
237 238 239 240 241 242

		if (result <= 0) {
			if (result == 0)
				result = -EPIPE; /* short read */
			break;
		}
J
Josef Bacik 已提交
243 244
		if (sent)
			*sent += result;
245
	} while (msg_data_left(&msg));
L
Linus Torvalds 已提交
246

247
	tsk_restore_flags(current, pflags, PF_MEMALLOC);
L
Linus Torvalds 已提交
248 249 250 251

	return result;
}

252
/* always call with the tx_lock held */
J
Josef Bacik 已提交
253
static int nbd_send_cmd(struct nbd_device *nbd, struct nbd_cmd *cmd, int index)
L
Linus Torvalds 已提交
254
{
J
Josef Bacik 已提交
255
	struct request *req = blk_mq_rq_from_pdu(cmd);
J
Josef Bacik 已提交
256
	struct nbd_sock *nsock = nbd->socks[index];
257
	int result;
A
Al Viro 已提交
258 259 260
	struct nbd_request request = {.magic = htonl(NBD_REQUEST_MAGIC)};
	struct kvec iov = {.iov_base = &request, .iov_len = sizeof(request)};
	struct iov_iter from;
261
	unsigned long size = blk_rq_bytes(req);
262
	struct bio *bio;
C
Christoph Hellwig 已提交
263
	u32 type;
J
Josef Bacik 已提交
264
	u32 tag = blk_mq_unique_tag(req);
J
Josef Bacik 已提交
265
	int sent = nsock->sent, skip = 0;
C
Christoph Hellwig 已提交
266

A
Al Viro 已提交
267 268
	iov_iter_kvec(&from, WRITE | ITER_KVEC, &iov, 1, sizeof(request));

269 270
	switch (req_op(req)) {
	case REQ_OP_DISCARD:
C
Christoph Hellwig 已提交
271
		type = NBD_CMD_TRIM;
272 273
		break;
	case REQ_OP_FLUSH:
C
Christoph Hellwig 已提交
274
		type = NBD_CMD_FLUSH;
275 276
		break;
	case REQ_OP_WRITE:
C
Christoph Hellwig 已提交
277
		type = NBD_CMD_WRITE;
278 279
		break;
	case REQ_OP_READ:
C
Christoph Hellwig 已提交
280
		type = NBD_CMD_READ;
281 282 283 284
		break;
	default:
		return -EIO;
	}
L
Linus Torvalds 已提交
285

286 287 288 289 290 291 292
	if (rq_data_dir(req) == WRITE &&
	    (nbd->flags & NBD_FLAG_READ_ONLY)) {
		dev_err_ratelimited(disk_to_dev(nbd->disk),
				    "Write on read-only\n");
		return -EIO;
	}

J
Josef Bacik 已提交
293 294 295 296 297 298 299 300 301 302 303
	/* We did a partial send previously, and we at least sent the whole
	 * request struct, so just go and send the rest of the pages in the
	 * request.
	 */
	if (sent) {
		if (sent >= sizeof(request)) {
			skip = sent - sizeof(request);
			goto send_pages;
		}
		iov_iter_advance(&from, sent);
	}
C
Christoph Hellwig 已提交
304
	request.type = htonl(type);
J
Josef Bacik 已提交
305
	if (type != NBD_CMD_FLUSH) {
A
Alex Bligh 已提交
306 307 308
		request.from = cpu_to_be64((u64)blk_rq_pos(req) << 9);
		request.len = htonl(size);
	}
J
Josef Bacik 已提交
309
	memcpy(request.handle, &tag, sizeof(tag));
L
Linus Torvalds 已提交
310

311
	dev_dbg(nbd_to_dev(nbd), "request %p: sending control (%s@%llu,%uB)\n",
J
Josef Bacik 已提交
312
		cmd, nbdcmd_to_ascii(type),
313
		(unsigned long long)blk_rq_pos(req) << 9, blk_rq_bytes(req));
A
Al Viro 已提交
314
	result = sock_xmit(nbd, index, 1, &from,
J
Josef Bacik 已提交
315
			(type == NBD_CMD_WRITE) ? MSG_MORE : 0, &sent);
L
Linus Torvalds 已提交
316
	if (result <= 0) {
J
Josef Bacik 已提交
317 318 319 320 321 322 323 324 325 326 327 328
		if (result == -ERESTARTSYS) {
			/* If we havne't sent anything we can just return BUSY,
			 * however if we have sent something we need to make
			 * sure we only allow this req to be sent until we are
			 * completely done.
			 */
			if (sent) {
				nsock->pending = req;
				nsock->sent = sent;
			}
			return BLK_MQ_RQ_QUEUE_BUSY;
		}
329
		dev_err_ratelimited(disk_to_dev(nbd->disk),
330
			"Send control failed (result %d)\n", result);
331
		return -EIO;
L
Linus Torvalds 已提交
332
	}
J
Josef Bacik 已提交
333
send_pages:
334
	if (type != NBD_CMD_WRITE)
J
Josef Bacik 已提交
335
		goto out;
336 337 338 339 340

	bio = req->bio;
	while (bio) {
		struct bio *next = bio->bi_next;
		struct bvec_iter iter;
341
		struct bio_vec bvec;
342 343 344

		bio_for_each_segment(bvec, bio, iter) {
			bool is_last = !next && bio_iter_last(bvec, iter);
345
			int flags = is_last ? 0 : MSG_MORE;
346

347
			dev_dbg(nbd_to_dev(nbd), "request %p: sending %d bytes data\n",
J
Josef Bacik 已提交
348
				cmd, bvec.bv_len);
A
Al Viro 已提交
349 350
			iov_iter_bvec(&from, ITER_BVEC | WRITE,
				      &bvec, 1, bvec.bv_len);
J
Josef Bacik 已提交
351 352 353 354 355 356 357 358 359
			if (skip) {
				if (skip >= iov_iter_count(&from)) {
					skip -= iov_iter_count(&from);
					continue;
				}
				iov_iter_advance(&from, skip);
				skip = 0;
			}
			result = sock_xmit(nbd, index, 1, &from, flags, &sent);
360
			if (result <= 0) {
J
Josef Bacik 已提交
361 362 363 364 365 366 367 368 369
				if (result == -ERESTARTSYS) {
					/* We've already sent the header, we
					 * have no choice but to set pending and
					 * return BUSY.
					 */
					nsock->pending = req;
					nsock->sent = sent;
					return BLK_MQ_RQ_QUEUE_BUSY;
				}
370
				dev_err(disk_to_dev(nbd->disk),
371 372
					"Send data failed (result %d)\n",
					result);
373
				return -EIO;
374
			}
375 376 377 378 379 380 381 382
			/*
			 * The completion might already have come in,
			 * so break for the last one instead of letting
			 * the iterator do it. This prevents use-after-free
			 * of the bio.
			 */
			if (is_last)
				break;
L
Linus Torvalds 已提交
383
		}
384
		bio = next;
L
Linus Torvalds 已提交
385
	}
J
Josef Bacik 已提交
386 387 388
out:
	nsock->pending = NULL;
	nsock->sent = 0;
L
Linus Torvalds 已提交
389 390 391 392
	return 0;
}

/* NULL returned = something went wrong, inform userspace */
J
Josef Bacik 已提交
393
static struct nbd_cmd *nbd_read_stat(struct nbd_device *nbd, int index)
L
Linus Torvalds 已提交
394 395 396
{
	int result;
	struct nbd_reply reply;
J
Josef Bacik 已提交
397 398 399
	struct nbd_cmd *cmd;
	struct request *req = NULL;
	u16 hwq;
J
Josef Bacik 已提交
400
	u32 tag;
A
Al Viro 已提交
401 402
	struct kvec iov = {.iov_base = &reply, .iov_len = sizeof(reply)};
	struct iov_iter to;
L
Linus Torvalds 已提交
403 404

	reply.magic = 0;
A
Al Viro 已提交
405
	iov_iter_kvec(&to, READ | ITER_KVEC, &iov, 1, sizeof(reply));
J
Josef Bacik 已提交
406
	result = sock_xmit(nbd, index, 0, &to, MSG_WAITALL, NULL);
L
Linus Torvalds 已提交
407
	if (result <= 0) {
J
Josef Bacik 已提交
408 409 410 411
		if (!test_bit(NBD_DISCONNECTED, &nbd->runtime_flags) &&
		    !test_bit(NBD_DISCONNECT_REQUESTED, &nbd->runtime_flags))
			dev_err(disk_to_dev(nbd->disk),
				"Receive control failed (result %d)\n", result);
412
		return ERR_PTR(result);
L
Linus Torvalds 已提交
413
	}
414 415

	if (ntohl(reply.magic) != NBD_REPLY_MAGIC) {
416
		dev_err(disk_to_dev(nbd->disk), "Wrong magic (0x%lx)\n",
417
				(unsigned long)ntohl(reply.magic));
418
		return ERR_PTR(-EPROTO);
419 420
	}

J
Josef Bacik 已提交
421
	memcpy(&tag, reply.handle, sizeof(u32));
422

J
Josef Bacik 已提交
423 424 425 426 427 428 429 430
	hwq = blk_mq_unique_tag_to_hwq(tag);
	if (hwq < nbd->tag_set.nr_hw_queues)
		req = blk_mq_tag_to_rq(nbd->tag_set.tags[hwq],
				       blk_mq_unique_tag_to_tag(tag));
	if (!req || !blk_mq_request_started(req)) {
		dev_err(disk_to_dev(nbd->disk), "Unexpected reply (%d) %p\n",
			tag, req);
		return ERR_PTR(-ENOENT);
L
Linus Torvalds 已提交
431
	}
J
Josef Bacik 已提交
432
	cmd = blk_mq_rq_to_pdu(req);
L
Linus Torvalds 已提交
433
	if (ntohl(reply.error)) {
434
		dev_err(disk_to_dev(nbd->disk), "Other side returned error (%d)\n",
435
			ntohl(reply.error));
436
		req->errors = -EIO;
J
Josef Bacik 已提交
437
		return cmd;
L
Linus Torvalds 已提交
438 439
	}

J
Josef Bacik 已提交
440
	dev_dbg(nbd_to_dev(nbd), "request %p: got reply\n", cmd);
C
Christoph Hellwig 已提交
441
	if (rq_data_dir(req) != WRITE) {
442
		struct req_iterator iter;
443
		struct bio_vec bvec;
444 445

		rq_for_each_segment(bvec, req, iter) {
A
Al Viro 已提交
446 447
			iov_iter_bvec(&to, ITER_BVEC | READ,
				      &bvec, 1, bvec.bv_len);
J
Josef Bacik 已提交
448
			result = sock_xmit(nbd, index, 0, &to, MSG_WAITALL, NULL);
449
			if (result <= 0) {
450
				dev_err(disk_to_dev(nbd->disk), "Receive data failed (result %d)\n",
451
					result);
452
				req->errors = -EIO;
J
Josef Bacik 已提交
453
				return cmd;
454
			}
455
			dev_dbg(nbd_to_dev(nbd), "request %p: got %d bytes data\n",
J
Josef Bacik 已提交
456
				cmd, bvec.bv_len);
L
Linus Torvalds 已提交
457
		}
J
Josef Bacik 已提交
458 459 460
	} else {
		/* See the comment in nbd_queue_rq. */
		wait_for_completion(&cmd->send_complete);
L
Linus Torvalds 已提交
461
	}
J
Josef Bacik 已提交
462
	return cmd;
L
Linus Torvalds 已提交
463 464
}

465 466
static ssize_t pid_show(struct device *dev,
			struct device_attribute *attr, char *buf)
467
{
468
	struct gendisk *disk = dev_to_disk(dev);
M
Markus Pargmann 已提交
469
	struct nbd_device *nbd = (struct nbd_device *)disk->private_data;
470

M
Markus Pargmann 已提交
471
	return sprintf(buf, "%d\n", task_pid_nr(nbd->task_recv));
472 473
}

474
static struct device_attribute pid_attr = {
475
	.attr = { .name = "pid", .mode = S_IRUGO},
476 477 478
	.show = pid_show,
};

J
Josef Bacik 已提交
479 480 481 482 483 484 485
struct recv_thread_args {
	struct work_struct work;
	struct nbd_device *nbd;
	int index;
};

static void recv_work(struct work_struct *work)
L
Linus Torvalds 已提交
486
{
J
Josef Bacik 已提交
487 488 489 490
	struct recv_thread_args *args = container_of(work,
						     struct recv_thread_args,
						     work);
	struct nbd_device *nbd = args->nbd;
J
Josef Bacik 已提交
491
	struct nbd_cmd *cmd;
J
Josef Bacik 已提交
492
	int ret = 0;
L
Linus Torvalds 已提交
493

494
	BUG_ON(nbd->magic != NBD_MAGIC);
495
	while (1) {
J
Josef Bacik 已提交
496
		cmd = nbd_read_stat(nbd, args->index);
J
Josef Bacik 已提交
497 498
		if (IS_ERR(cmd)) {
			ret = PTR_ERR(cmd);
499 500 501
			break;
		}

J
Josef Bacik 已提交
502
		nbd_end_request(cmd);
503
	}
504

J
Josef Bacik 已提交
505 506 507 508 509 510 511 512
	/*
	 * We got an error, shut everybody down if this wasn't the result of a
	 * disconnect request.
	 */
	if (ret && !test_bit(NBD_DISCONNECT_REQUESTED, &nbd->runtime_flags))
		sock_shutdown(nbd);
	atomic_dec(&nbd->recv_threads);
	wake_up(&nbd->recv_wq);
L
Linus Torvalds 已提交
513 514
}

J
Josef Bacik 已提交
515
static void nbd_clear_req(struct request *req, void *data, bool reserved)
L
Linus Torvalds 已提交
516
{
J
Josef Bacik 已提交
517
	struct nbd_cmd *cmd;
L
Linus Torvalds 已提交
518

J
Josef Bacik 已提交
519 520 521
	if (!blk_mq_request_started(req))
		return;
	cmd = blk_mq_rq_to_pdu(req);
522
	req->errors = -EIO;
J
Josef Bacik 已提交
523 524 525 526 527
	nbd_end_request(cmd);
}

static void nbd_clear_que(struct nbd_device *nbd)
{
528
	BUG_ON(nbd->magic != NBD_MAGIC);
L
Linus Torvalds 已提交
529

J
Josef Bacik 已提交
530
	blk_mq_tagset_busy_iter(&nbd->tag_set, nbd_clear_req, NULL);
531
	dev_dbg(disk_to_dev(nbd->disk), "queue cleared\n");
L
Linus Torvalds 已提交
532 533
}

534

J
Josef Bacik 已提交
535
static int nbd_handle_cmd(struct nbd_cmd *cmd, int index)
536
{
J
Josef Bacik 已提交
537 538
	struct request *req = blk_mq_rq_from_pdu(cmd);
	struct nbd_device *nbd = cmd->nbd;
J
Josef Bacik 已提交
539
	struct nbd_sock *nsock;
J
Josef Bacik 已提交
540
	int ret;
J
Josef Bacik 已提交
541

J
Josef Bacik 已提交
542
	if (index >= nbd->num_connections) {
543 544
		dev_err_ratelimited(disk_to_dev(nbd->disk),
				    "Attempted send on invalid socket\n");
J
Josef Bacik 已提交
545
		return -EINVAL;
J
Josef Bacik 已提交
546
	}
547

J
Josef Bacik 已提交
548
	if (test_bit(NBD_DISCONNECTED, &nbd->runtime_flags)) {
549 550
		dev_err_ratelimited(disk_to_dev(nbd->disk),
				    "Attempted send on closed socket\n");
J
Josef Bacik 已提交
551
		return -EINVAL;
J
Josef Bacik 已提交
552 553
	}

554 555
	req->errors = 0;

J
Josef Bacik 已提交
556 557 558 559
	nsock = nbd->socks[index];
	mutex_lock(&nsock->tx_lock);
	if (unlikely(!nsock->sock)) {
		mutex_unlock(&nsock->tx_lock);
560 561
		dev_err_ratelimited(disk_to_dev(nbd->disk),
				    "Attempted send on closed socket\n");
J
Josef Bacik 已提交
562
		return -EINVAL;
563 564
	}

J
Josef Bacik 已提交
565 566 567 568 569 570 571 572 573
	/* Handle the case that we have a pending request that was partially
	 * transmitted that _has_ to be serviced first.  We need to call requeue
	 * here so that it gets put _after_ the request that is already on the
	 * dispatch list.
	 */
	if (unlikely(nsock->pending && nsock->pending != req)) {
		blk_mq_requeue_request(req, true);
		ret = 0;
		goto out;
574
	}
J
Josef Bacik 已提交
575 576
	ret = nbd_send_cmd(nbd, cmd, index);
out:
J
Josef Bacik 已提交
577
	mutex_unlock(&nsock->tx_lock);
J
Josef Bacik 已提交
578
	return ret;
579 580
}

J
Josef Bacik 已提交
581 582
static int nbd_queue_rq(struct blk_mq_hw_ctx *hctx,
			const struct blk_mq_queue_data *bd)
L
Linus Torvalds 已提交
583
{
J
Josef Bacik 已提交
584
	struct nbd_cmd *cmd = blk_mq_rq_to_pdu(bd->rq);
J
Josef Bacik 已提交
585
	int ret;
L
Linus Torvalds 已提交
586

J
Josef Bacik 已提交
587 588 589 590 591 592 593 594 595 596
	/*
	 * Since we look at the bio's to send the request over the network we
	 * need to make sure the completion work doesn't mark this request done
	 * before we are done doing our send.  This keeps us from dereferencing
	 * freed data if we have particularly fast completions (ie we get the
	 * completion before we exit sock_xmit on the last bvec) or in the case
	 * that the server is misbehaving (or there was an error) before we're
	 * done sending everything over the wire.
	 */
	init_completion(&cmd->send_complete);
J
Josef Bacik 已提交
597
	blk_mq_start_request(bd->rq);
J
Josef Bacik 已提交
598 599 600 601 602 603 604 605 606 607 608

	/* We can be called directly from the user space process, which means we
	 * could possibly have signals pending so our sendmsg will fail.  In
	 * this case we need to return that we are busy, otherwise error out as
	 * appropriate.
	 */
	ret = nbd_handle_cmd(cmd, hctx->queue_num);
	if (ret < 0)
		ret = BLK_MQ_RQ_QUEUE_ERROR;
	if (!ret)
		ret = BLK_MQ_RQ_QUEUE_OK;
J
Josef Bacik 已提交
609 610
	complete(&cmd->send_complete);

J
Josef Bacik 已提交
611
	return ret;
L
Linus Torvalds 已提交
612 613
}

J
Josef Bacik 已提交
614 615
static int nbd_add_socket(struct nbd_device *nbd, struct block_device *bdev,
			  unsigned long arg)
M
Markus Pargmann 已提交
616
{
J
Josef Bacik 已提交
617
	struct socket *sock;
J
Josef Bacik 已提交
618 619
	struct nbd_sock **socks;
	struct nbd_sock *nsock;
J
Josef Bacik 已提交
620 621 622 623 624
	int err;

	sock = sockfd_lookup(arg, &err);
	if (!sock)
		return err;
M
Markus Pargmann 已提交
625

J
Josef Bacik 已提交
626 627 628 629 630
	if (!nbd->task_setup)
		nbd->task_setup = current;
	if (nbd->task_setup != current) {
		dev_err(disk_to_dev(nbd->disk),
			"Device being setup by another task");
J
Josef Bacik 已提交
631
		sockfd_put(sock);
J
Josef Bacik 已提交
632
		return -EINVAL;
M
Markus Pargmann 已提交
633 634
	}

J
Josef Bacik 已提交
635 636
	socks = krealloc(nbd->socks, (nbd->num_connections + 1) *
			 sizeof(struct nbd_sock *), GFP_KERNEL);
J
Josef Bacik 已提交
637 638
	if (!socks) {
		sockfd_put(sock);
J
Josef Bacik 已提交
639
		return -ENOMEM;
J
Josef Bacik 已提交
640
	}
J
Josef Bacik 已提交
641
	nsock = kzalloc(sizeof(struct nbd_sock), GFP_KERNEL);
J
Josef Bacik 已提交
642 643
	if (!nsock) {
		sockfd_put(sock);
J
Josef Bacik 已提交
644
		return -ENOMEM;
J
Josef Bacik 已提交
645
	}
J
Josef Bacik 已提交
646 647

	nbd->socks = socks;
M
Markus Pargmann 已提交
648

J
Josef Bacik 已提交
649 650
	mutex_init(&nsock->tx_lock);
	nsock->sock = sock;
J
Josef Bacik 已提交
651 652
	nsock->pending = NULL;
	nsock->sent = 0;
J
Josef Bacik 已提交
653
	socks[nbd->num_connections++] = nsock;
M
Markus Pargmann 已提交
654

J
Josef Bacik 已提交
655 656
	if (max_part)
		bdev->bd_invalidated = 1;
J
Josef Bacik 已提交
657
	return 0;
M
Markus Pargmann 已提交
658 659
}

660 661 662
/* Reset all properties of an NBD device */
static void nbd_reset(struct nbd_device *nbd)
{
J
Josef Bacik 已提交
663
	nbd->runtime_flags = 0;
664 665 666 667
	nbd->blksize = 1024;
	nbd->bytesize = 0;
	set_capacity(nbd->disk, 0);
	nbd->flags = 0;
668
	nbd->tag_set.timeout = 0;
669 670 671 672 673
	queue_flag_clear_unlocked(QUEUE_FLAG_DISCARD, nbd->disk->queue);
}

static void nbd_bdev_reset(struct block_device *bdev)
{
674 675
	if (bdev->bd_openers > 1)
		return;
676 677 678 679 680 681 682 683
	set_device_ro(bdev, false);
	bdev->bd_inode->i_size = 0;
	if (max_part > 0) {
		blkdev_reread_part(bdev);
		bdev->bd_invalidated = 1;
	}
}

684 685 686 687 688 689 690
static void nbd_parse_flags(struct nbd_device *nbd, struct block_device *bdev)
{
	if (nbd->flags & NBD_FLAG_READ_ONLY)
		set_device_ro(bdev, true);
	if (nbd->flags & NBD_FLAG_SEND_TRIM)
		queue_flag_set_unlocked(QUEUE_FLAG_DISCARD, nbd->disk->queue);
	if (nbd->flags & NBD_FLAG_SEND_FLUSH)
691
		blk_queue_write_cache(nbd->disk->queue, true, false);
692
	else
693
		blk_queue_write_cache(nbd->disk->queue, false, false);
694 695
}

J
Josef Bacik 已提交
696 697
static void send_disconnects(struct nbd_device *nbd)
{
A
Al Viro 已提交
698 699 700 701 702 703
	struct nbd_request request = {
		.magic = htonl(NBD_REQUEST_MAGIC),
		.type = htonl(NBD_CMD_DISC),
	};
	struct kvec iov = {.iov_base = &request, .iov_len = sizeof(request)};
	struct iov_iter from;
J
Josef Bacik 已提交
704 705 706
	int i, ret;

	for (i = 0; i < nbd->num_connections; i++) {
A
Al Viro 已提交
707
		iov_iter_kvec(&from, WRITE | ITER_KVEC, &iov, 1, sizeof(request));
J
Josef Bacik 已提交
708
		ret = sock_xmit(nbd, i, 1, &from, 0, NULL);
J
Josef Bacik 已提交
709 710 711 712 713 714
		if (ret <= 0)
			dev_err(disk_to_dev(nbd->disk),
				"Send disconnect failed %d\n", ret);
	}
}

J
Josef Bacik 已提交
715 716 717 718 719
static int nbd_disconnect(struct nbd_device *nbd, struct block_device *bdev)
{
	dev_info(disk_to_dev(nbd->disk), "NBD_DISCONNECT\n");
	if (!nbd->socks)
		return -EINVAL;
M
Markus Pargmann 已提交
720

J
Josef Bacik 已提交
721 722 723 724 725 726 727 728 729 730 731 732 733 734 735
	mutex_unlock(&nbd->config_lock);
	fsync_bdev(bdev);
	mutex_lock(&nbd->config_lock);

	/* Check again after getting mutex back.  */
	if (!nbd->socks)
		return -EINVAL;

	if (!test_and_set_bit(NBD_DISCONNECT_REQUESTED,
			      &nbd->runtime_flags))
		send_disconnects(nbd);
	return 0;
}

static int nbd_clear_sock(struct nbd_device *nbd, struct block_device *bdev)
P
Pavel Machek 已提交
736
{
J
Josef Bacik 已提交
737 738
	sock_shutdown(nbd);
	nbd_clear_que(nbd);
739 740

	__invalidate_device(bdev, true);
J
Josef Bacik 已提交
741 742 743 744 745 746 747 748 749
	nbd_bdev_reset(bdev);
	/*
	 * We want to give the run thread a chance to wait for everybody
	 * to clean up and then do it's own cleanup.
	 */
	if (!test_bit(NBD_RUNNING, &nbd->runtime_flags) &&
	    nbd->num_connections) {
		int i;

J
Josef Bacik 已提交
750 751
		for (i = 0; i < nbd->num_connections; i++) {
			sockfd_put(nbd->socks[i]->sock);
J
Josef Bacik 已提交
752
			kfree(nbd->socks[i]);
J
Josef Bacik 已提交
753
		}
J
Josef Bacik 已提交
754 755 756
		kfree(nbd->socks);
		nbd->socks = NULL;
		nbd->num_connections = 0;
P
Pavel Machek 已提交
757
	}
J
Josef Bacik 已提交
758
	nbd->task_setup = NULL;
J
Josef Bacik 已提交
759

J
Josef Bacik 已提交
760 761 762 763 764 765 766 767
	return 0;
}

static int nbd_start_device(struct nbd_device *nbd, struct block_device *bdev)
{
	struct recv_thread_args *args;
	int num_connections = nbd->num_connections;
	int error = 0, i;
P
Pavel Machek 已提交
768

J
Josef Bacik 已提交
769 770 771 772 773 774 775 776 777 778
	if (nbd->task_recv)
		return -EBUSY;
	if (!nbd->socks)
		return -EINVAL;
	if (num_connections > 1 &&
	    !(nbd->flags & NBD_FLAG_CAN_MULTI_CONN)) {
		dev_err(disk_to_dev(nbd->disk), "server does not support multiple connections per device.\n");
		error = -EINVAL;
		goto out_err;
	}
M
Markus Pargmann 已提交
779

J
Josef Bacik 已提交
780 781 782 783 784 785 786 787 788
	set_bit(NBD_RUNNING, &nbd->runtime_flags);
	blk_mq_update_nr_hw_queues(&nbd->tag_set, nbd->num_connections);
	args = kcalloc(num_connections, sizeof(*args), GFP_KERNEL);
	if (!args) {
		error = -ENOMEM;
		goto out_err;
	}
	nbd->task_recv = current;
	mutex_unlock(&nbd->config_lock);
M
Markus Pargmann 已提交
789

J
Josef Bacik 已提交
790
	nbd_parse_flags(nbd, bdev);
M
Markus Pargmann 已提交
791

J
Josef Bacik 已提交
792 793 794 795
	error = device_create_file(disk_to_dev(nbd->disk), &pid_attr);
	if (error) {
		dev_err(disk_to_dev(nbd->disk), "device_create_file failed!\n");
		goto out_recv;
P
Pavel Machek 已提交
796 797
	}

J
Josef Bacik 已提交
798
	nbd_size_update(nbd, bdev);
799

J
Josef Bacik 已提交
800 801 802 803 804 805 806 807
	nbd_dev_dbg_init(nbd);
	for (i = 0; i < num_connections; i++) {
		sk_set_memalloc(nbd->socks[i]->sock->sk);
		atomic_inc(&nbd->recv_threads);
		INIT_WORK(&args[i].work, recv_work);
		args[i].nbd = nbd;
		args[i].index = i;
		queue_work(recv_workqueue, &args[i].work);
808
	}
J
Josef Bacik 已提交
809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827
	wait_event_interruptible(nbd->recv_wq,
				 atomic_read(&nbd->recv_threads) == 0);
	for (i = 0; i < num_connections; i++)
		flush_work(&args[i].work);
	nbd_dev_dbg_close(nbd);
	nbd_size_clear(nbd, bdev);
	device_remove_file(disk_to_dev(nbd->disk), &pid_attr);
out_recv:
	mutex_lock(&nbd->config_lock);
	nbd->task_recv = NULL;
out_err:
	clear_bit(NBD_RUNNING, &nbd->runtime_flags);
	nbd_clear_sock(nbd, bdev);

	/* user requested, ignore socket errors */
	if (test_bit(NBD_DISCONNECT_REQUESTED, &nbd->runtime_flags))
		error = 0;
	if (test_bit(NBD_TIMEDOUT, &nbd->runtime_flags))
		error = -ETIMEDOUT;
P
Pavel Machek 已提交
828

J
Josef Bacik 已提交
829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844
	nbd_reset(nbd);
	return error;
}

/* Must be called with config_lock held */
static int __nbd_ioctl(struct block_device *bdev, struct nbd_device *nbd,
		       unsigned int cmd, unsigned long arg)
{
	switch (cmd) {
	case NBD_DISCONNECT:
		return nbd_disconnect(nbd, bdev);
	case NBD_CLEAR_SOCK:
		return nbd_clear_sock(nbd, bdev);
	case NBD_SET_SOCK:
		return nbd_add_socket(nbd, bdev, arg);
	case NBD_SET_BLKSIZE:
845 846 847
		nbd_size_set(nbd, bdev, arg,
			     div_s64(nbd->bytesize, arg));
		return 0;
L
Linus Torvalds 已提交
848
	case NBD_SET_SIZE:
849 850 851
		nbd_size_set(nbd, bdev, nbd->blksize,
			     div_s64(arg, nbd->blksize));
		return 0;
852
	case NBD_SET_SIZE_BLOCKS:
853 854
		nbd_size_set(nbd, bdev, nbd->blksize, arg);
		return 0;
855
	case NBD_SET_TIMEOUT:
J
Josef Bacik 已提交
856 857 858 859
		if (arg) {
			nbd->tag_set.timeout = arg * HZ;
			blk_queue_rq_timeout(nbd->disk->queue, arg * HZ);
		}
860
		return 0;
P
Pavel Machek 已提交
861

P
Paul Clements 已提交
862 863 864
	case NBD_SET_FLAGS:
		nbd->flags = arg;
		return 0;
J
Josef Bacik 已提交
865 866
	case NBD_DO_IT:
		return nbd_start_device(nbd, bdev);
L
Linus Torvalds 已提交
867
	case NBD_CLEAR_QUE:
868 869 870 871
		/*
		 * This is for compatibility only.  The queue is always cleared
		 * by NBD_DO_IT or NBD_CLEAR_SOCK.
		 */
L
Linus Torvalds 已提交
872 873
		return 0;
	case NBD_PRINT_DEBUG:
J
Josef Bacik 已提交
874 875 876 877
		/*
		 * For compatibility only, we no longer keep a list of
		 * outstanding requests.
		 */
L
Linus Torvalds 已提交
878 879
		return 0;
	}
P
Pavel Machek 已提交
880 881 882 883 884 885
	return -ENOTTY;
}

static int nbd_ioctl(struct block_device *bdev, fmode_t mode,
		     unsigned int cmd, unsigned long arg)
{
886
	struct nbd_device *nbd = bdev->bd_disk->private_data;
P
Pavel Machek 已提交
887 888 889 890 891
	int error;

	if (!capable(CAP_SYS_ADMIN))
		return -EPERM;

892
	BUG_ON(nbd->magic != NBD_MAGIC);
P
Pavel Machek 已提交
893

J
Josef Bacik 已提交
894
	mutex_lock(&nbd->config_lock);
895
	error = __nbd_ioctl(bdev, nbd, cmd, arg);
J
Josef Bacik 已提交
896
	mutex_unlock(&nbd->config_lock);
P
Pavel Machek 已提交
897 898

	return error;
L
Linus Torvalds 已提交
899 900
}

901
static const struct block_device_operations nbd_fops =
L
Linus Torvalds 已提交
902 903
{
	.owner =	THIS_MODULE,
904
	.ioctl =	nbd_ioctl,
A
Al Viro 已提交
905
	.compat_ioctl =	nbd_ioctl,
L
Linus Torvalds 已提交
906 907
};

M
Markus Pargmann 已提交
908 909 910 911 912 913 914 915 916 917 918 919 920 921 922 923 924 925 926 927 928 929 930 931 932 933 934 935 936 937 938 939 940 941 942 943 944 945 946 947 948 949 950 951 952 953 954 955 956 957 958 959 960 961 962 963 964 965 966 967
#if IS_ENABLED(CONFIG_DEBUG_FS)

static int nbd_dbg_tasks_show(struct seq_file *s, void *unused)
{
	struct nbd_device *nbd = s->private;

	if (nbd->task_recv)
		seq_printf(s, "recv: %d\n", task_pid_nr(nbd->task_recv));

	return 0;
}

static int nbd_dbg_tasks_open(struct inode *inode, struct file *file)
{
	return single_open(file, nbd_dbg_tasks_show, inode->i_private);
}

static const struct file_operations nbd_dbg_tasks_ops = {
	.open = nbd_dbg_tasks_open,
	.read = seq_read,
	.llseek = seq_lseek,
	.release = single_release,
};

static int nbd_dbg_flags_show(struct seq_file *s, void *unused)
{
	struct nbd_device *nbd = s->private;
	u32 flags = nbd->flags;

	seq_printf(s, "Hex: 0x%08x\n\n", flags);

	seq_puts(s, "Known flags:\n");

	if (flags & NBD_FLAG_HAS_FLAGS)
		seq_puts(s, "NBD_FLAG_HAS_FLAGS\n");
	if (flags & NBD_FLAG_READ_ONLY)
		seq_puts(s, "NBD_FLAG_READ_ONLY\n");
	if (flags & NBD_FLAG_SEND_FLUSH)
		seq_puts(s, "NBD_FLAG_SEND_FLUSH\n");
	if (flags & NBD_FLAG_SEND_TRIM)
		seq_puts(s, "NBD_FLAG_SEND_TRIM\n");

	return 0;
}

static int nbd_dbg_flags_open(struct inode *inode, struct file *file)
{
	return single_open(file, nbd_dbg_flags_show, inode->i_private);
}

static const struct file_operations nbd_dbg_flags_ops = {
	.open = nbd_dbg_flags_open,
	.read = seq_read,
	.llseek = seq_lseek,
	.release = single_release,
};

static int nbd_dev_dbg_init(struct nbd_device *nbd)
{
	struct dentry *dir;
968 969 970

	if (!nbd_dbg_dir)
		return -EIO;
M
Markus Pargmann 已提交
971 972

	dir = debugfs_create_dir(nbd_name(nbd), nbd_dbg_dir);
973 974 975 976
	if (!dir) {
		dev_err(nbd_to_dev(nbd), "Failed to create debugfs dir for '%s'\n",
			nbd_name(nbd));
		return -EIO;
M
Markus Pargmann 已提交
977 978 979
	}
	nbd->dbg_dir = dir;

980 981
	debugfs_create_file("tasks", 0444, dir, nbd, &nbd_dbg_tasks_ops);
	debugfs_create_u64("size_bytes", 0444, dir, &nbd->bytesize);
982
	debugfs_create_u32("timeout", 0444, dir, &nbd->tag_set.timeout);
983
	debugfs_create_u64("blocksize", 0444, dir, &nbd->blksize);
984
	debugfs_create_file("flags", 0444, dir, nbd, &nbd_dbg_flags_ops);
M
Markus Pargmann 已提交
985 986 987 988 989 990 991 992 993 994 995 996 997 998

	return 0;
}

static void nbd_dev_dbg_close(struct nbd_device *nbd)
{
	debugfs_remove_recursive(nbd->dbg_dir);
}

static int nbd_dbg_init(void)
{
	struct dentry *dbg_dir;

	dbg_dir = debugfs_create_dir("nbd", NULL);
999 1000
	if (!dbg_dir)
		return -EIO;
M
Markus Pargmann 已提交
1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033

	nbd_dbg_dir = dbg_dir;

	return 0;
}

static void nbd_dbg_close(void)
{
	debugfs_remove_recursive(nbd_dbg_dir);
}

#else  /* IS_ENABLED(CONFIG_DEBUG_FS) */

static int nbd_dev_dbg_init(struct nbd_device *nbd)
{
	return 0;
}

static void nbd_dev_dbg_close(struct nbd_device *nbd)
{
}

static int nbd_dbg_init(void)
{
	return 0;
}

static void nbd_dbg_close(void)
{
}

#endif

J
Josef Bacik 已提交
1034 1035 1036 1037 1038 1039 1040 1041 1042
static int nbd_init_request(void *data, struct request *rq,
			    unsigned int hctx_idx, unsigned int request_idx,
			    unsigned int numa_node)
{
	struct nbd_cmd *cmd = blk_mq_rq_to_pdu(rq);
	cmd->nbd = data;
	return 0;
}

1043
static const struct blk_mq_ops nbd_mq_ops = {
J
Josef Bacik 已提交
1044 1045
	.queue_rq	= nbd_queue_rq,
	.init_request	= nbd_init_request,
1046
	.timeout	= nbd_xmit_timeout,
J
Josef Bacik 已提交
1047 1048
};

1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111 1112 1113 1114 1115 1116 1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129 1130 1131 1132 1133 1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144
static void nbd_dev_remove(struct nbd_device *nbd)
{
	struct gendisk *disk = nbd->disk;
	nbd->magic = 0;
	if (disk) {
		del_gendisk(disk);
		blk_cleanup_queue(disk->queue);
		blk_mq_free_tag_set(&nbd->tag_set);
		put_disk(disk);
	}
	kfree(nbd);
}

static int nbd_dev_add(int index)
{
	struct nbd_device *nbd;
	struct gendisk *disk;
	struct request_queue *q;
	int err = -ENOMEM;

	nbd = kzalloc(sizeof(struct nbd_device), GFP_KERNEL);
	if (!nbd)
		goto out;

	disk = alloc_disk(1 << part_shift);
	if (!disk)
		goto out_free_nbd;

	if (index >= 0) {
		err = idr_alloc(&nbd_index_idr, nbd, index, index + 1,
				GFP_KERNEL);
		if (err == -ENOSPC)
			err = -EEXIST;
	} else {
		err = idr_alloc(&nbd_index_idr, nbd, 0, 0, GFP_KERNEL);
		if (err >= 0)
			index = err;
	}
	if (err < 0)
		goto out_free_disk;

	nbd->disk = disk;
	nbd->tag_set.ops = &nbd_mq_ops;
	nbd->tag_set.nr_hw_queues = 1;
	nbd->tag_set.queue_depth = 128;
	nbd->tag_set.numa_node = NUMA_NO_NODE;
	nbd->tag_set.cmd_size = sizeof(struct nbd_cmd);
	nbd->tag_set.flags = BLK_MQ_F_SHOULD_MERGE |
		BLK_MQ_F_SG_MERGE | BLK_MQ_F_BLOCKING;
	nbd->tag_set.driver_data = nbd;

	err = blk_mq_alloc_tag_set(&nbd->tag_set);
	if (err)
		goto out_free_idr;

	q = blk_mq_init_queue(&nbd->tag_set);
	if (IS_ERR(q)) {
		err = PTR_ERR(q);
		goto out_free_tags;
	}
	disk->queue = q;

	/*
	 * Tell the block layer that we are not a rotational device
	 */
	queue_flag_set_unlocked(QUEUE_FLAG_NONROT, disk->queue);
	queue_flag_clear_unlocked(QUEUE_FLAG_ADD_RANDOM, disk->queue);
	disk->queue->limits.discard_granularity = 512;
	blk_queue_max_discard_sectors(disk->queue, UINT_MAX);
	blk_queue_max_hw_sectors(disk->queue, 65536);
	disk->queue->limits.max_sectors = 256;

	nbd->magic = NBD_MAGIC;
	mutex_init(&nbd->config_lock);
	disk->major = NBD_MAJOR;
	disk->first_minor = index << part_shift;
	disk->fops = &nbd_fops;
	disk->private_data = nbd;
	sprintf(disk->disk_name, "nbd%d", index);
	init_waitqueue_head(&nbd->recv_wq);
	nbd_reset(nbd);
	add_disk(disk);
	return index;

out_free_tags:
	blk_mq_free_tag_set(&nbd->tag_set);
out_free_idr:
	idr_remove(&nbd_index_idr, index);
out_free_disk:
	put_disk(disk);
out_free_nbd:
	kfree(nbd);
out:
	return err;
}

L
Linus Torvalds 已提交
1145 1146 1147 1148 1149 1150 1151 1152 1153
/*
 * And here should be modules and kernel interface 
 *  (Just smiley confuses emacs :-)
 */

static int __init nbd_init(void)
{
	int i;

1154
	BUILD_BUG_ON(sizeof(struct nbd_request) != 28);
L
Linus Torvalds 已提交
1155

L
Laurent Vivier 已提交
1156
	if (max_part < 0) {
1157
		printk(KERN_ERR "nbd: max_part must be >= 0\n");
L
Laurent Vivier 已提交
1158 1159 1160 1161
		return -EINVAL;
	}

	part_shift = 0;
1162
	if (max_part > 0) {
L
Laurent Vivier 已提交
1163 1164
		part_shift = fls(max_part);

1165 1166 1167 1168 1169 1170 1171 1172 1173 1174 1175
		/*
		 * Adjust max_part according to part_shift as it is exported
		 * to user space so that user can know the max number of
		 * partition kernel should be able to manage.
		 *
		 * Note that -1 is required because partition 0 is reserved
		 * for the whole disk.
		 */
		max_part = (1UL << part_shift) - 1;
	}

1176 1177 1178 1179 1180
	if ((1UL << part_shift) > DISK_MAX_PARTS)
		return -EINVAL;

	if (nbds_max > 1UL << (MINORBITS - part_shift))
		return -EINVAL;
1181 1182 1183 1184
	recv_workqueue = alloc_workqueue("knbd-recv",
					 WQ_MEM_RECLAIM | WQ_HIGHPRI, 0);
	if (!recv_workqueue)
		return -ENOMEM;
1185

1186 1187
	if (register_blkdev(NBD_MAJOR, "nbd")) {
		destroy_workqueue(recv_workqueue);
1188
		return -EIO;
1189
	}
L
Linus Torvalds 已提交
1190

M
Markus Pargmann 已提交
1191 1192
	nbd_dbg_init();

1193 1194 1195 1196 1197 1198
	mutex_lock(&nbd_index_mutex);
	for (i = 0; i < nbds_max; i++)
		nbd_dev_add(i);
	mutex_unlock(&nbd_index_mutex);
	return 0;
}
L
Linus Torvalds 已提交
1199

1200 1201 1202 1203
static int nbd_exit_cb(int id, void *ptr, void *data)
{
	struct nbd_device *nbd = ptr;
	nbd_dev_remove(nbd);
L
Linus Torvalds 已提交
1204 1205 1206 1207 1208
	return 0;
}

static void __exit nbd_cleanup(void)
{
M
Markus Pargmann 已提交
1209 1210
	nbd_dbg_close();

1211 1212
	idr_for_each(&nbd_index_idr, &nbd_exit_cb, NULL);
	idr_destroy(&nbd_index_idr);
1213
	destroy_workqueue(recv_workqueue);
L
Linus Torvalds 已提交
1214 1215 1216 1217 1218 1219 1220 1221 1222
	unregister_blkdev(NBD_MAJOR, "nbd");
}

module_init(nbd_init);
module_exit(nbd_cleanup);

MODULE_DESCRIPTION("Network Block Device");
MODULE_LICENSE("GPL");

1223
module_param(nbds_max, int, 0444);
L
Laurent Vivier 已提交
1224 1225 1226
MODULE_PARM_DESC(nbds_max, "number of network block devices to initialize (default: 16)");
module_param(max_part, int, 0444);
MODULE_PARM_DESC(max_part, "number of partitions per device (default: 0)");