nbd.c 28.7 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
	bd_set_size(bdev, 0);
130 131 132 133 134 135 136 137
	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)
{
138 139 140
	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);
141 142 143 144
	set_capacity(nbd->disk, nbd->bytesize >> 9);
	kobject_uevent(&nbd_to_dev(nbd)->kobj, KOBJ_CHANGE);
}

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

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

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

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

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

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

J
Josef Bacik 已提交
178 179 180 181 182 183 184
	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");
185 186
}

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

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

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

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

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

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

223
	current->flags |= PF_MEMALLOC;
L
Linus Torvalds 已提交
224
	do {
225
		sock->sk->sk_allocation = GFP_NOIO | __GFP_MEMALLOC;
L
Linus Torvalds 已提交
226 227 228 229 230 231
		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 已提交
232
		if (send)
233
			result = sock_sendmsg(sock, &msg);
M
Markus Pargmann 已提交
234
		else
235
			result = sock_recvmsg(sock, &msg, msg.msg_flags);
L
Linus Torvalds 已提交
236 237 238 239 240 241

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

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

	return result;
}

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

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

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

285 286 287 288 289 290 291
	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 已提交
292 293 294 295 296 297 298 299 300 301 302
	/* 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 已提交
303
	request.type = htonl(type);
J
Josef Bacik 已提交
304
	if (type != NBD_CMD_FLUSH) {
A
Alex Bligh 已提交
305 306 307
		request.from = cpu_to_be64((u64)blk_rq_pos(req) << 9);
		request.len = htonl(size);
	}
J
Josef Bacik 已提交
308
	memcpy(request.handle, &tag, sizeof(tag));
L
Linus Torvalds 已提交
309

310
	dev_dbg(nbd_to_dev(nbd), "request %p: sending control (%s@%llu,%uB)\n",
J
Josef Bacik 已提交
311
		cmd, nbdcmd_to_ascii(type),
312
		(unsigned long long)blk_rq_pos(req) << 9, blk_rq_bytes(req));
A
Al Viro 已提交
313
	result = sock_xmit(nbd, index, 1, &from,
J
Josef Bacik 已提交
314
			(type == NBD_CMD_WRITE) ? MSG_MORE : 0, &sent);
L
Linus Torvalds 已提交
315
	if (result <= 0) {
J
Josef Bacik 已提交
316 317 318 319 320 321 322 323 324 325 326 327
		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;
		}
328
		dev_err_ratelimited(disk_to_dev(nbd->disk),
329
			"Send control failed (result %d)\n", result);
330
		return -EIO;
L
Linus Torvalds 已提交
331
	}
J
Josef Bacik 已提交
332
send_pages:
333
	if (type != NBD_CMD_WRITE)
J
Josef Bacik 已提交
334
		goto out;
335 336 337 338 339

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

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

346
			dev_dbg(nbd_to_dev(nbd), "request %p: sending %d bytes data\n",
J
Josef Bacik 已提交
347
				cmd, bvec.bv_len);
A
Al Viro 已提交
348 349
			iov_iter_bvec(&from, ITER_BVEC | WRITE,
				      &bvec, 1, bvec.bv_len);
J
Josef Bacik 已提交
350 351 352 353 354 355 356 357 358
			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);
359
			if (result <= 0) {
J
Josef Bacik 已提交
360 361 362 363 364 365 366 367 368
				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;
				}
369
				dev_err(disk_to_dev(nbd->disk),
370 371
					"Send data failed (result %d)\n",
					result);
372
				return -EIO;
373
			}
374 375 376 377 378 379 380 381
			/*
			 * 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 已提交
382
		}
383
		bio = next;
L
Linus Torvalds 已提交
384
	}
J
Josef Bacik 已提交
385 386 387
out:
	nsock->pending = NULL;
	nsock->sent = 0;
L
Linus Torvalds 已提交
388 389 390 391
	return 0;
}

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

	reply.magic = 0;
A
Al Viro 已提交
404
	iov_iter_kvec(&to, READ | ITER_KVEC, &iov, 1, sizeof(reply));
J
Josef Bacik 已提交
405
	result = sock_xmit(nbd, index, 0, &to, MSG_WAITALL, NULL);
L
Linus Torvalds 已提交
406
	if (result <= 0) {
J
Josef Bacik 已提交
407 408 409 410
		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);
411
		return ERR_PTR(result);
L
Linus Torvalds 已提交
412
	}
413 414

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

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

J
Josef Bacik 已提交
422 423 424 425 426 427 428 429
	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 已提交
430
	}
J
Josef Bacik 已提交
431
	cmd = blk_mq_rq_to_pdu(req);
L
Linus Torvalds 已提交
432
	if (ntohl(reply.error)) {
433
		dev_err(disk_to_dev(nbd->disk), "Other side returned error (%d)\n",
434
			ntohl(reply.error));
435
		req->errors = -EIO;
J
Josef Bacik 已提交
436
		return cmd;
L
Linus Torvalds 已提交
437 438
	}

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

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

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

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

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

J
Josef Bacik 已提交
478 479 480 481 482 483 484
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 已提交
485
{
J
Josef Bacik 已提交
486 487 488 489
	struct recv_thread_args *args = container_of(work,
						     struct recv_thread_args,
						     work);
	struct nbd_device *nbd = args->nbd;
J
Josef Bacik 已提交
490
	struct nbd_cmd *cmd;
J
Josef Bacik 已提交
491
	int ret = 0;
L
Linus Torvalds 已提交
492

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

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

J
Josef Bacik 已提交
504 505 506 507 508 509 510 511
	/*
	 * 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 已提交
512 513
}

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

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

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

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

533

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

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

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

553 554
	req->errors = 0;

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

J
Josef Bacik 已提交
564 565 566 567 568 569 570 571 572
	/* 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;
573
	}
J
Josef Bacik 已提交
574 575
	ret = nbd_send_cmd(nbd, cmd, index);
out:
J
Josef Bacik 已提交
576
	mutex_unlock(&nsock->tx_lock);
J
Josef Bacik 已提交
577
	return ret;
578 579
}

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

J
Josef Bacik 已提交
586 587 588 589 590 591 592 593 594 595
	/*
	 * 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 已提交
596
	blk_mq_start_request(bd->rq);
J
Josef Bacik 已提交
597 598 599 600 601 602 603 604 605 606 607

	/* 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 已提交
608 609
	complete(&cmd->send_complete);

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

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

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

J
Josef Bacik 已提交
625 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");
		return -EINVAL;
M
Markus Pargmann 已提交
631 632
	}

J
Josef Bacik 已提交
633 634 635 636 637 638 639 640 641
	socks = krealloc(nbd->socks, (nbd->num_connections + 1) *
			 sizeof(struct nbd_sock *), GFP_KERNEL);
	if (!socks)
		return -ENOMEM;
	nsock = kzalloc(sizeof(struct nbd_sock), GFP_KERNEL);
	if (!nsock)
		return -ENOMEM;

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

J
Josef Bacik 已提交
643 644
	mutex_init(&nsock->tx_lock);
	nsock->sock = sock;
J
Josef Bacik 已提交
645 646
	nsock->pending = NULL;
	nsock->sent = 0;
J
Josef Bacik 已提交
647
	socks[nbd->num_connections++] = nsock;
M
Markus Pargmann 已提交
648

J
Josef Bacik 已提交
649 650
	if (max_part)
		bdev->bd_invalidated = 1;
J
Josef Bacik 已提交
651
	return 0;
M
Markus Pargmann 已提交
652 653
}

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

static void nbd_bdev_reset(struct block_device *bdev)
{
	set_device_ro(bdev, false);
	bdev->bd_inode->i_size = 0;
	if (max_part > 0) {
		blkdev_reread_part(bdev);
		bdev->bd_invalidated = 1;
	}
}

676 677 678 679 680 681 682
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)
683
		blk_queue_write_cache(nbd->disk->queue, true, false);
684
	else
685
		blk_queue_write_cache(nbd->disk->queue, false, false);
686 687
}

J
Josef Bacik 已提交
688 689
static void send_disconnects(struct nbd_device *nbd)
{
A
Al Viro 已提交
690 691 692 693 694 695
	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 已提交
696 697 698
	int i, ret;

	for (i = 0; i < nbd->num_connections; i++) {
A
Al Viro 已提交
699
		iov_iter_kvec(&from, WRITE | ITER_KVEC, &iov, 1, sizeof(request));
J
Josef Bacik 已提交
700
		ret = sock_xmit(nbd, i, 1, &from, 0, NULL);
J
Josef Bacik 已提交
701 702 703 704 705 706
		if (ret <= 0)
			dev_err(disk_to_dev(nbd->disk),
				"Send disconnect failed %d\n", ret);
	}
}

J
Josef Bacik 已提交
707 708 709 710 711
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 已提交
712

J
Josef Bacik 已提交
713 714 715 716 717 718 719 720 721 722 723 724 725 726 727
	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 已提交
728
{
J
Josef Bacik 已提交
729 730 731 732 733 734 735 736 737 738 739 740
	sock_shutdown(nbd);
	nbd_clear_que(nbd);
	kill_bdev(bdev);
	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 已提交
741 742
		for (i = 0; i < nbd->num_connections; i++) {
			sockfd_put(nbd->socks[i]->sock);
J
Josef Bacik 已提交
743
			kfree(nbd->socks[i]);
J
Josef Bacik 已提交
744
		}
J
Josef Bacik 已提交
745 746 747
		kfree(nbd->socks);
		nbd->socks = NULL;
		nbd->num_connections = 0;
P
Pavel Machek 已提交
748
	}
J
Josef Bacik 已提交
749
	nbd->task_setup = NULL;
J
Josef Bacik 已提交
750

J
Josef Bacik 已提交
751 752 753 754 755 756 757 758
	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 已提交
759

J
Josef Bacik 已提交
760 761 762 763 764 765 766 767 768 769
	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 已提交
770

J
Josef Bacik 已提交
771 772 773 774 775 776 777 778 779
	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 已提交
780

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

J
Josef Bacik 已提交
783 784 785 786
	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 已提交
787 788
	}

J
Josef Bacik 已提交
789
	nbd_size_update(nbd, bdev);
790

J
Josef Bacik 已提交
791 792 793 794 795 796 797 798
	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);
799
	}
J
Josef Bacik 已提交
800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818
	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 已提交
819

J
Josef Bacik 已提交
820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835
	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:
836 837 838
		nbd_size_set(nbd, bdev, arg,
			     div_s64(nbd->bytesize, arg));
		return 0;
L
Linus Torvalds 已提交
839
	case NBD_SET_SIZE:
840 841 842
		nbd_size_set(nbd, bdev, nbd->blksize,
			     div_s64(arg, nbd->blksize));
		return 0;
843
	case NBD_SET_SIZE_BLOCKS:
844 845
		nbd_size_set(nbd, bdev, nbd->blksize, arg);
		return 0;
846
	case NBD_SET_TIMEOUT:
847
		nbd->tag_set.timeout = arg * HZ;
848
		return 0;
P
Pavel Machek 已提交
849

P
Paul Clements 已提交
850 851 852
	case NBD_SET_FLAGS:
		nbd->flags = arg;
		return 0;
J
Josef Bacik 已提交
853 854
	case NBD_DO_IT:
		return nbd_start_device(nbd, bdev);
L
Linus Torvalds 已提交
855
	case NBD_CLEAR_QUE:
856 857 858 859
		/*
		 * This is for compatibility only.  The queue is always cleared
		 * by NBD_DO_IT or NBD_CLEAR_SOCK.
		 */
L
Linus Torvalds 已提交
860 861
		return 0;
	case NBD_PRINT_DEBUG:
J
Josef Bacik 已提交
862 863 864 865
		/*
		 * For compatibility only, we no longer keep a list of
		 * outstanding requests.
		 */
L
Linus Torvalds 已提交
866 867
		return 0;
	}
P
Pavel Machek 已提交
868 869 870 871 872 873
	return -ENOTTY;
}

static int nbd_ioctl(struct block_device *bdev, fmode_t mode,
		     unsigned int cmd, unsigned long arg)
{
874
	struct nbd_device *nbd = bdev->bd_disk->private_data;
P
Pavel Machek 已提交
875 876 877 878 879
	int error;

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

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

J
Josef Bacik 已提交
882
	mutex_lock(&nbd->config_lock);
883
	error = __nbd_ioctl(bdev, nbd, cmd, arg);
J
Josef Bacik 已提交
884
	mutex_unlock(&nbd->config_lock);
P
Pavel Machek 已提交
885 886

	return error;
L
Linus Torvalds 已提交
887 888
}

889
static const struct block_device_operations nbd_fops =
L
Linus Torvalds 已提交
890 891
{
	.owner =	THIS_MODULE,
892
	.ioctl =	nbd_ioctl,
A
Al Viro 已提交
893
	.compat_ioctl =	nbd_ioctl,
L
Linus Torvalds 已提交
894 895
};

M
Markus Pargmann 已提交
896 897 898 899 900 901 902 903 904 905 906 907 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
#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;
956 957 958

	if (!nbd_dbg_dir)
		return -EIO;
M
Markus Pargmann 已提交
959 960

	dir = debugfs_create_dir(nbd_name(nbd), nbd_dbg_dir);
961 962 963 964
	if (!dir) {
		dev_err(nbd_to_dev(nbd), "Failed to create debugfs dir for '%s'\n",
			nbd_name(nbd));
		return -EIO;
M
Markus Pargmann 已提交
965 966 967
	}
	nbd->dbg_dir = dir;

968 969
	debugfs_create_file("tasks", 0444, dir, nbd, &nbd_dbg_tasks_ops);
	debugfs_create_u64("size_bytes", 0444, dir, &nbd->bytesize);
970
	debugfs_create_u32("timeout", 0444, dir, &nbd->tag_set.timeout);
971
	debugfs_create_u64("blocksize", 0444, dir, &nbd->blksize);
972
	debugfs_create_file("flags", 0444, dir, nbd, &nbd_dbg_flags_ops);
M
Markus Pargmann 已提交
973 974 975 976 977 978 979 980 981 982 983 984 985 986

	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);
987 988
	if (!dbg_dir)
		return -EIO;
M
Markus Pargmann 已提交
989 990 991 992 993 994 995 996 997 998 999 1000 1001 1002 1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021

	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 已提交
1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033
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;
}

static struct blk_mq_ops nbd_mq_ops = {
	.queue_rq	= nbd_queue_rq,
	.init_request	= nbd_init_request,
1034
	.timeout	= nbd_xmit_timeout,
J
Josef Bacik 已提交
1035 1036
};

1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 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
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);
	disk->queue->limits.discard_zeroes_data = 0;
	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 已提交
1134 1135 1136 1137 1138 1139 1140 1141 1142
/*
 * And here should be modules and kernel interface 
 *  (Just smiley confuses emacs :-)
 */

static int __init nbd_init(void)
{
	int i;

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

L
Laurent Vivier 已提交
1145
	if (max_part < 0) {
1146
		printk(KERN_ERR "nbd: max_part must be >= 0\n");
L
Laurent Vivier 已提交
1147 1148 1149 1150
		return -EINVAL;
	}

	part_shift = 0;
1151
	if (max_part > 0) {
L
Laurent Vivier 已提交
1152 1153
		part_shift = fls(max_part);

1154 1155 1156 1157 1158 1159 1160 1161 1162 1163 1164
		/*
		 * 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;
	}

1165 1166 1167 1168 1169
	if ((1UL << part_shift) > DISK_MAX_PARTS)
		return -EINVAL;

	if (nbds_max > 1UL << (MINORBITS - part_shift))
		return -EINVAL;
1170 1171 1172 1173
	recv_workqueue = alloc_workqueue("knbd-recv",
					 WQ_MEM_RECLAIM | WQ_HIGHPRI, 0);
	if (!recv_workqueue)
		return -ENOMEM;
1174

1175 1176
	if (register_blkdev(NBD_MAJOR, "nbd")) {
		destroy_workqueue(recv_workqueue);
1177
		return -EIO;
1178
	}
L
Linus Torvalds 已提交
1179

M
Markus Pargmann 已提交
1180 1181
	nbd_dbg_init();

1182 1183 1184 1185 1186 1187
	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 已提交
1188

1189 1190 1191 1192
static int nbd_exit_cb(int id, void *ptr, void *data)
{
	struct nbd_device *nbd = ptr;
	nbd_dev_remove(nbd);
L
Linus Torvalds 已提交
1193 1194 1195 1196 1197
	return 0;
}

static void __exit nbd_cleanup(void)
{
M
Markus Pargmann 已提交
1198 1199
	nbd_dbg_close();

1200 1201
	idr_for_each(&nbd_index_idr, &nbd_exit_cb, NULL);
	idr_destroy(&nbd_index_idr);
1202
	destroy_workqueue(recv_workqueue);
L
Linus Torvalds 已提交
1203 1204 1205 1206 1207 1208 1209 1210 1211
	unregister_blkdev(NBD_MAJOR, "nbd");
}

module_init(nbd_init);
module_exit(nbd_cleanup);

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

1212
module_param(nbds_max, int, 0444);
L
Laurent Vivier 已提交
1213 1214 1215
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)");