drbd_worker.c 62.0 KB
Newer Older
P
Philipp Reisner 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
/*
   drbd_worker.c

   This file is part of DRBD by Philipp Reisner and Lars Ellenberg.

   Copyright (C) 2001-2008, LINBIT Information Technologies GmbH.
   Copyright (C) 1999-2008, Philipp Reisner <philipp.reisner@linbit.com>.
   Copyright (C) 2002-2008, Lars Ellenberg <lars.ellenberg@linbit.com>.

   drbd is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 2, or (at your option)
   any later version.

   drbd is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with drbd; see the file COPYING.  If not, write to
   the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.

24
*/
P
Philipp Reisner 已提交
25 26 27 28 29 30 31 32 33 34 35 36 37 38

#include <linux/module.h>
#include <linux/drbd.h>
#include <linux/sched.h>
#include <linux/wait.h>
#include <linux/mm.h>
#include <linux/memcontrol.h>
#include <linux/mm_inline.h>
#include <linux/slab.h>
#include <linux/random.h>
#include <linux/string.h>
#include <linux/scatterlist.h>

#include "drbd_int.h"
39
#include "drbd_protocol.h"
P
Philipp Reisner 已提交
40 41
#include "drbd_req.h"

42 43
static int make_ov_request(struct drbd_device *, int);
static int make_resync_request(struct drbd_device *, int);
P
Philipp Reisner 已提交
44

45 46
/* endio handlers:
 *   drbd_md_io_complete (defined here)
47 48
 *   drbd_request_endio (defined here)
 *   drbd_peer_request_endio (defined here)
49 50
 *   bm_async_io_complete (defined in drbd_bitmap.c)
 *
P
Philipp Reisner 已提交
51 52 53 54 55 56 57 58 59 60
 * For all these callbacks, note the following:
 * The callbacks will be called in irq context by the IDE drivers,
 * and in Softirqs/Tasklets/BH context by the SCSI drivers.
 * Try to get the locking right :)
 *
 */


/* About the global_state_lock
   Each state transition on an device holds a read lock. In case we have
61
   to evaluate the resync after dependencies, we grab a write lock, because
P
Philipp Reisner 已提交
62 63 64 65 66 67 68 69 70
   we need stable states on all devices for that.  */
rwlock_t global_state_lock;

/* used for synchronous meta data and bitmap IO
 * submitted by drbd_md_sync_page_io()
 */
void drbd_md_io_complete(struct bio *bio, int error)
{
	struct drbd_md_io *md_io;
71
	struct drbd_device *device;
P
Philipp Reisner 已提交
72 73

	md_io = (struct drbd_md_io *)bio->bi_private;
74
	device = container_of(md_io, struct drbd_device, md_io);
75

P
Philipp Reisner 已提交
76 77
	md_io->error = error;

78 79 80 81 82 83 84 85 86
	/* We grabbed an extra reference in _drbd_md_sync_page_io() to be able
	 * to timeout on the lower level device, and eventually detach from it.
	 * If this io completion runs after that timeout expired, this
	 * drbd_md_put_buffer() may allow us to finally try and re-attach.
	 * During normal operation, this only puts that extra reference
	 * down to 1 again.
	 * Make sure we first drop the reference, and only then signal
	 * completion, or we may (in drbd_al_read_log()) cycle so fast into the
	 * next drbd_md_sync_page_io(), that we trigger the
87
	 * ASSERT(atomic_read(&device->md_io_in_use) == 1) there.
88
	 */
89
	drbd_md_put_buffer(device);
90
	md_io->done = 1;
91
	wake_up(&device->misc_wait);
92
	bio_put(bio);
93 94
	if (device->ldev) /* special case: drbd_md_read() during drbd_adm_attach() */
		put_ldev(device);
P
Philipp Reisner 已提交
95 96 97 98 99
}

/* reads on behalf of the partner,
 * "submitted" by the receiver
 */
100
static void drbd_endio_read_sec_final(struct drbd_peer_request *peer_req) __releases(local)
P
Philipp Reisner 已提交
101 102
{
	unsigned long flags = 0;
103 104
	struct drbd_peer_device *peer_device = peer_req->peer_device;
	struct drbd_device *device = peer_device->device;
P
Philipp Reisner 已提交
105

106
	spin_lock_irqsave(&device->resource->req_lock, flags);
107
	device->read_cnt += peer_req->i.size >> 9;
108
	list_del(&peer_req->w.list);
109 110
	if (list_empty(&device->read_ee))
		wake_up(&device->ee_wait);
111
	if (test_bit(__EE_WAS_ERROR, &peer_req->flags))
112
		__drbd_chk_io_error(device, DRBD_READ_ERROR);
113
	spin_unlock_irqrestore(&device->resource->req_lock, flags);
P
Philipp Reisner 已提交
114

115
	drbd_queue_work(&peer_device->connection->sender_work, &peer_req->w);
116
	put_ldev(device);
P
Philipp Reisner 已提交
117 118 119
}

/* writes on behalf of the partner, or resync writes,
120
 * "submitted" by the receiver, final stage.  */
121
void drbd_endio_write_sec_final(struct drbd_peer_request *peer_req) __releases(local)
P
Philipp Reisner 已提交
122 123
{
	unsigned long flags = 0;
124 125
	struct drbd_peer_device *peer_device = peer_req->peer_device;
	struct drbd_device *device = peer_device->device;
126
	struct drbd_interval i;
P
Philipp Reisner 已提交
127
	int do_wake;
128
	u64 block_id;
P
Philipp Reisner 已提交
129 130
	int do_al_complete_io;

131
	/* after we moved peer_req to done_ee,
P
Philipp Reisner 已提交
132 133 134
	 * we may no longer access it,
	 * it may be freed/reused already!
	 * (as soon as we release the req_lock) */
135
	i = peer_req->i;
136 137
	do_al_complete_io = peer_req->flags & EE_CALL_AL_COMPLETE_IO;
	block_id = peer_req->block_id;
P
Philipp Reisner 已提交
138

139
	spin_lock_irqsave(&device->resource->req_lock, flags);
140
	device->writ_cnt += peer_req->i.size >> 9;
141
	list_move_tail(&peer_req->w.list, &device->done_ee);
P
Philipp Reisner 已提交
142

143
	/*
144
	 * Do not remove from the write_requests tree here: we did not send the
145 146
	 * Ack yet and did not wake possibly waiting conflicting requests.
	 * Removed from the tree from "drbd_process_done_ee" within the
147
	 * appropriate dw.cb (e_end_block/e_end_resync_block) or from
148 149
	 * _drbd_clear_done_ee.
	 */
P
Philipp Reisner 已提交
150

151
	do_wake = list_empty(block_id == ID_SYNCER ? &device->sync_ee : &device->active_ee);
P
Philipp Reisner 已提交
152

153 154 155
	/* FIXME do we want to detach for failed REQ_DISCARD?
	 * ((peer_req->flags & (EE_WAS_ERROR|EE_IS_TRIM)) == EE_WAS_ERROR) */
	if (peer_req->flags & EE_WAS_ERROR)
156
		__drbd_chk_io_error(device, DRBD_WRITE_ERROR);
157
	spin_unlock_irqrestore(&device->resource->req_lock, flags);
P
Philipp Reisner 已提交
158

159
	if (block_id == ID_SYNCER)
160
		drbd_rs_complete_io(device, i.sector);
P
Philipp Reisner 已提交
161 162

	if (do_wake)
163
		wake_up(&device->ee_wait);
P
Philipp Reisner 已提交
164 165

	if (do_al_complete_io)
166
		drbd_al_complete_io(device, &i);
P
Philipp Reisner 已提交
167

168
	wake_asender(peer_device->connection);
169
	put_ldev(device);
170
}
P
Philipp Reisner 已提交
171

172 173 174
/* writes on behalf of the partner, or resync writes,
 * "submitted" by the receiver.
 */
175
void drbd_peer_request_endio(struct bio *bio, int error)
176
{
177
	struct drbd_peer_request *peer_req = bio->bi_private;
178
	struct drbd_device *device = peer_req->peer_device->device;
179 180
	int uptodate = bio_flagged(bio, BIO_UPTODATE);
	int is_write = bio_data_dir(bio) == WRITE;
181
	int is_discard = !!(bio->bi_rw & REQ_DISCARD);
182

183
	if (error && __ratelimit(&drbd_ratelimit_state))
184
		drbd_warn(device, "%s: error=%d s=%llus\n",
185 186
				is_write ? (is_discard ? "discard" : "write")
					: "read", error,
187
				(unsigned long long)peer_req->i.sector);
188
	if (!error && !uptodate) {
189
		if (__ratelimit(&drbd_ratelimit_state))
190
			drbd_warn(device, "%s: setting error to -EIO s=%llus\n",
191
					is_write ? "write" : "read",
192
					(unsigned long long)peer_req->i.sector);
193 194 195 196 197 198 199
		/* strange behavior of some lower level drivers...
		 * fail the request by clearing the uptodate flag,
		 * but do not return any error?! */
		error = -EIO;
	}

	if (error)
200
		set_bit(__EE_WAS_ERROR, &peer_req->flags);
201 202

	bio_put(bio); /* no need for the bio anymore */
203
	if (atomic_dec_and_test(&peer_req->pending_bios)) {
204
		if (is_write)
205
			drbd_endio_write_sec_final(peer_req);
206
		else
207
			drbd_endio_read_sec_final(peer_req);
208
	}
P
Philipp Reisner 已提交
209 210 211 212
}

/* read, readA or write requests on R_PRIMARY coming from drbd_make_request
 */
213
void drbd_request_endio(struct bio *bio, int error)
P
Philipp Reisner 已提交
214
{
215
	unsigned long flags;
P
Philipp Reisner 已提交
216
	struct drbd_request *req = bio->bi_private;
217
	struct drbd_device *device = req->device;
218
	struct bio_and_error m;
P
Philipp Reisner 已提交
219 220 221 222
	enum drbd_req_event what;
	int uptodate = bio_flagged(bio, BIO_UPTODATE);

	if (!error && !uptodate) {
223
		drbd_warn(device, "p %s: setting error to -EIO\n",
P
Philipp Reisner 已提交
224 225 226 227 228 229 230
			 bio_data_dir(bio) == WRITE ? "write" : "read");
		/* strange behavior of some lower level drivers...
		 * fail the request by clearing the uptodate flag,
		 * but do not return any error?! */
		error = -EIO;
	}

231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261

	/* If this request was aborted locally before,
	 * but now was completed "successfully",
	 * chances are that this caused arbitrary data corruption.
	 *
	 * "aborting" requests, or force-detaching the disk, is intended for
	 * completely blocked/hung local backing devices which do no longer
	 * complete requests at all, not even do error completions.  In this
	 * situation, usually a hard-reset and failover is the only way out.
	 *
	 * By "aborting", basically faking a local error-completion,
	 * we allow for a more graceful swichover by cleanly migrating services.
	 * Still the affected node has to be rebooted "soon".
	 *
	 * By completing these requests, we allow the upper layers to re-use
	 * the associated data pages.
	 *
	 * If later the local backing device "recovers", and now DMAs some data
	 * from disk into the original request pages, in the best case it will
	 * just put random data into unused pages; but typically it will corrupt
	 * meanwhile completely unrelated data, causing all sorts of damage.
	 *
	 * Which means delayed successful completion,
	 * especially for READ requests,
	 * is a reason to panic().
	 *
	 * We assume that a delayed *error* completion is OK,
	 * though we still will complain noisily about it.
	 */
	if (unlikely(req->rq_state & RQ_LOCAL_ABORTED)) {
		if (__ratelimit(&drbd_ratelimit_state))
262
			drbd_emerg(device, "delayed completion of aborted local request; disk-timeout may be too aggressive\n");
263 264 265 266 267

		if (!error)
			panic("possible random memory corruption caused by delayed completion of aborted local request\n");
	}

P
Philipp Reisner 已提交
268 269
	/* to avoid recursion in __req_mod */
	if (unlikely(error)) {
270 271 272 273 274 275
		if (bio->bi_rw & REQ_DISCARD)
			what = (error == -EOPNOTSUPP)
				? DISCARD_COMPLETED_NOTSUPP
				: DISCARD_COMPLETED_WITH_ERROR;
		else
			what = (bio_data_dir(bio) == WRITE)
276
			? WRITE_COMPLETED_WITH_ERROR
277
			: (bio_rw(bio) == READ)
278 279
			  ? READ_COMPLETED_WITH_ERROR
			  : READ_AHEAD_COMPLETED_WITH_ERROR;
P
Philipp Reisner 已提交
280
	} else
281
		what = COMPLETED_OK;
P
Philipp Reisner 已提交
282 283 284 285

	bio_put(req->private_bio);
	req->private_bio = ERR_PTR(error);

286
	/* not req_mod(), we need irqsave here! */
287
	spin_lock_irqsave(&device->resource->req_lock, flags);
288
	__req_mod(req, what, &m);
289
	spin_unlock_irqrestore(&device->resource->req_lock, flags);
290
	put_ldev(device);
291 292

	if (m.bio)
293
		complete_master_bio(device, &m);
P
Philipp Reisner 已提交
294 295
}

296
void drbd_csum_ee(struct crypto_hash *tfm, struct drbd_peer_request *peer_req, void *digest)
297 298 299
{
	struct hash_desc desc;
	struct scatterlist sg;
300
	struct page *page = peer_req->pages;
301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316
	struct page *tmp;
	unsigned len;

	desc.tfm = tfm;
	desc.flags = 0;

	sg_init_table(&sg, 1);
	crypto_hash_init(&desc);

	while ((tmp = page_chain_next(page))) {
		/* all but the last page will be fully used */
		sg_set_page(&sg, page, PAGE_SIZE, 0);
		crypto_hash_update(&desc, &sg, sg.length);
		page = tmp;
	}
	/* and now the last, possibly only partially used page */
317
	len = peer_req->i.size & (PAGE_SIZE - 1);
318 319 320 321 322
	sg_set_page(&sg, page, len ?: PAGE_SIZE, 0);
	crypto_hash_update(&desc, &sg, sg.length);
	crypto_hash_final(&desc, digest);
}

323
void drbd_csum_bio(struct crypto_hash *tfm, struct bio *bio, void *digest)
P
Philipp Reisner 已提交
324 325 326
{
	struct hash_desc desc;
	struct scatterlist sg;
327 328
	struct bio_vec bvec;
	struct bvec_iter iter;
P
Philipp Reisner 已提交
329 330 331 332 333 334 335

	desc.tfm = tfm;
	desc.flags = 0;

	sg_init_table(&sg, 1);
	crypto_hash_init(&desc);

336 337
	bio_for_each_segment(bvec, bio, iter) {
		sg_set_page(&sg, bvec.bv_page, bvec.bv_len, bvec.bv_offset);
P
Philipp Reisner 已提交
338 339 340 341 342
		crypto_hash_update(&desc, &sg, sg.length);
	}
	crypto_hash_final(&desc, digest);
}

343
/* MAYBE merge common code with w_e_end_ov_req */
344
static int w_e_send_csum(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
345
{
346
	struct drbd_peer_request *peer_req = container_of(w, struct drbd_peer_request, w);
347 348
	struct drbd_peer_device *peer_device = peer_req->peer_device;
	struct drbd_device *device = peer_device->device;
P
Philipp Reisner 已提交
349 350
	int digest_size;
	void *digest;
351
	int err = 0;
P
Philipp Reisner 已提交
352

353 354
	if (unlikely(cancel))
		goto out;
P
Philipp Reisner 已提交
355

356
	if (unlikely((peer_req->flags & EE_WAS_ERROR) != 0))
357
		goto out;
P
Philipp Reisner 已提交
358

359
	digest_size = crypto_hash_digestsize(peer_device->connection->csums_tfm);
360 361
	digest = kmalloc(digest_size, GFP_NOIO);
	if (digest) {
362 363
		sector_t sector = peer_req->i.sector;
		unsigned int size = peer_req->i.size;
364
		drbd_csum_ee(peer_device->connection->csums_tfm, peer_req, digest);
365
		/* Free peer_req and pages before send.
366 367 368
		 * In case we block on congestion, we could otherwise run into
		 * some distributed deadlock, if the other side blocks on
		 * congestion as well, because our receiver blocks in
369
		 * drbd_alloc_pages due to pp_in_use > max_buffers. */
370
		drbd_free_peer_req(device, peer_req);
371
		peer_req = NULL;
372
		inc_rs_pending(device);
373
		err = drbd_send_drequest_csum(peer_device, sector, size,
374 375
					      digest, digest_size,
					      P_CSUM_RS_REQUEST);
376 377
		kfree(digest);
	} else {
378
		drbd_err(device, "kmalloc() of digest failed.\n");
379
		err = -ENOMEM;
380
	}
P
Philipp Reisner 已提交
381

382
out:
383
	if (peer_req)
384
		drbd_free_peer_req(device, peer_req);
P
Philipp Reisner 已提交
385

386
	if (unlikely(err))
387
		drbd_err(device, "drbd_send_drequest(..., csum) failed\n");
388
	return err;
P
Philipp Reisner 已提交
389 390 391 392
}

#define GFP_TRY	(__GFP_HIGHMEM | __GFP_NOWARN)

393
static int read_for_csum(struct drbd_peer_device *peer_device, sector_t sector, int size)
P
Philipp Reisner 已提交
394
{
395
	struct drbd_device *device = peer_device->device;
396
	struct drbd_peer_request *peer_req;
P
Philipp Reisner 已提交
397

398
	if (!get_ldev(device))
399
		return -EIO;
P
Philipp Reisner 已提交
400

401
	if (drbd_rs_should_slow_down(device, sector))
402 403
		goto defer;

P
Philipp Reisner 已提交
404 405
	/* GFP_TRY, because if there is no memory available right now, this may
	 * be rescheduled for later. It is "only" background resync, after all. */
406
	peer_req = drbd_alloc_peer_req(peer_device, ID_SYNCER /* unused */, sector,
407
				       size, true /* has real payload */, GFP_TRY);
408
	if (!peer_req)
409
		goto defer;
P
Philipp Reisner 已提交
410

411
	peer_req->w.cb = w_e_send_csum;
412
	spin_lock_irq(&device->resource->req_lock);
413
	list_add(&peer_req->w.list, &device->read_ee);
414
	spin_unlock_irq(&device->resource->req_lock);
P
Philipp Reisner 已提交
415

416 417
	atomic_add(size >> 9, &device->rs_sect_ev);
	if (drbd_submit_peer_request(device, peer_req, READ, DRBD_FAULT_RS_RD) == 0)
418
		return 0;
P
Philipp Reisner 已提交
419

420 421 422 423
	/* If it failed because of ENOMEM, retry should help.  If it failed
	 * because bio_add_page failed (probably broken lower level driver),
	 * retry may or may not help.
	 * If it does not, you may need to force disconnect. */
424
	spin_lock_irq(&device->resource->req_lock);
425
	list_del(&peer_req->w.list);
426
	spin_unlock_irq(&device->resource->req_lock);
427

428
	drbd_free_peer_req(device, peer_req);
429
defer:
430
	put_ldev(device);
431
	return -EAGAIN;
P
Philipp Reisner 已提交
432 433
}

434
int w_resync_timer(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
435
{
436 437 438
	struct drbd_device *device =
		container_of(w, struct drbd_device, resync_work);

439
	switch (device->state.conn) {
440
	case C_VERIFY_S:
441
		make_ov_request(device, cancel);
442 443
		break;
	case C_SYNC_TARGET:
444
		make_resync_request(device, cancel);
445
		break;
P
Philipp Reisner 已提交
446 447
	}

448
	return 0;
449 450 451 452
}

void resync_timer_fn(unsigned long data)
{
453
	struct drbd_device *device = (struct drbd_device *) data;
454

455 456 457
	drbd_queue_work_if_unqueued(
		&first_peer_device(device)->connection->sender_work,
		&device->resync_work);
P
Philipp Reisner 已提交
458 459
}

460 461 462 463 464
static void fifo_set(struct fifo_buffer *fb, int value)
{
	int i;

	for (i = 0; i < fb->size; i++)
465
		fb->values[i] = value;
466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488
}

static int fifo_push(struct fifo_buffer *fb, int value)
{
	int ov;

	ov = fb->values[fb->head_index];
	fb->values[fb->head_index++] = value;

	if (fb->head_index >= fb->size)
		fb->head_index = 0;

	return ov;
}

static void fifo_add_val(struct fifo_buffer *fb, int value)
{
	int i;

	for (i = 0; i < fb->size; i++)
		fb->values[i] += value;
}

489 490 491 492
struct fifo_buffer *fifo_alloc(int fifo_size)
{
	struct fifo_buffer *fb;

493
	fb = kzalloc(sizeof(struct fifo_buffer) + sizeof(int) * fifo_size, GFP_NOIO);
494 495 496 497 498 499 500 501 502 503
	if (!fb)
		return NULL;

	fb->head_index = 0;
	fb->size = fifo_size;
	fb->total = 0;

	return fb;
}

504
static int drbd_rs_controller(struct drbd_device *device, unsigned int sect_in)
505
{
P
Philipp Reisner 已提交
506
	struct disk_conf *dc;
507
	unsigned int want;     /* The number of sectors we want in-flight */
508
	int req_sect; /* Number of sectors to request in this turn */
509
	int correction; /* Number of sectors more we need in-flight */
510 511 512 513
	int cps; /* correction per invocation of drbd_rs_controller() */
	int steps; /* Number of time steps to plan ahead */
	int curr_corr;
	int max_sect;
P
Philipp Reisner 已提交
514
	struct fifo_buffer *plan;
515

516 517
	dc = rcu_dereference(device->ldev->disk_conf);
	plan = rcu_dereference(device->rs_plan_s);
518

P
Philipp Reisner 已提交
519
	steps = plan->size; /* (dc->c_plan_ahead * 10 * SLEEP_TIME) / HZ; */
520

521
	if (device->rs_in_flight + sect_in == 0) { /* At start of resync */
P
Philipp Reisner 已提交
522
		want = ((dc->resync_rate * 2 * SLEEP_TIME) / HZ) * steps;
523
	} else { /* normal path */
P
Philipp Reisner 已提交
524 525
		want = dc->c_fill_target ? dc->c_fill_target :
			sect_in * dc->c_delay_target * HZ / (SLEEP_TIME * 10);
526 527
	}

528
	correction = want - device->rs_in_flight - plan->total;
529 530 531

	/* Plan ahead */
	cps = correction / steps;
P
Philipp Reisner 已提交
532 533
	fifo_add_val(plan, cps);
	plan->total += cps * steps;
534 535

	/* What we do in this step */
P
Philipp Reisner 已提交
536 537
	curr_corr = fifo_push(plan, 0);
	plan->total -= curr_corr;
538 539 540 541 542

	req_sect = sect_in + curr_corr;
	if (req_sect < 0)
		req_sect = 0;

P
Philipp Reisner 已提交
543
	max_sect = (dc->c_max_rate * 2 * SLEEP_TIME) / HZ;
544 545 546 547
	if (req_sect > max_sect)
		req_sect = max_sect;

	/*
548
	drbd_warn(device, "si=%u if=%d wa=%u co=%d st=%d cps=%d pl=%d cc=%d rs=%d\n",
549 550
		 sect_in, device->rs_in_flight, want, correction,
		 steps, cps, device->rs_planed, curr_corr, req_sect);
551 552 553 554 555
	*/

	return req_sect;
}

556
static int drbd_rs_number_requests(struct drbd_device *device)
557
{
558 559 560 561 562
	unsigned int sect_in;  /* Number of sectors that came in since the last turn */
	int number, mxb;

	sect_in = atomic_xchg(&device->rs_sect_in, 0);
	device->rs_in_flight -= sect_in;
P
Philipp Reisner 已提交
563 564

	rcu_read_lock();
565
	mxb = drbd_get_max_buffers(device) / 2;
566
	if (rcu_dereference(device->rs_plan_s)->size) {
567
		number = drbd_rs_controller(device, sect_in) >> (BM_BLOCK_SHIFT - 9);
568
		device->c_sync_rate = number * HZ * (BM_BLOCK_SIZE / 1024) / SLEEP_TIME;
569
	} else {
570 571
		device->c_sync_rate = rcu_dereference(device->ldev->disk_conf)->resync_rate;
		number = SLEEP_TIME * device->c_sync_rate  / ((BM_BLOCK_SIZE / 1024) * HZ);
572
	}
P
Philipp Reisner 已提交
573
	rcu_read_unlock();
574

575 576 577 578 579
	/* Don't have more than "max-buffers"/2 in-flight.
	 * Otherwise we may cause the remote site to stall on drbd_alloc_pages(),
	 * potentially causing a distributed deadlock on congestion during
	 * online-verify or (checksum-based) resync, if max-buffers,
	 * socket buffer sizes and resync rate settings are mis-configured. */
580 581 582 583 584 585 586

	/* note that "number" is in units of "BM_BLOCK_SIZE" (which is 4k),
	 * mxb (as used here, and in drbd_alloc_pages on the peer) is
	 * "number of pages" (typically also 4k),
	 * but "rs_in_flight" is in "sectors" (512 Byte). */
	if (mxb - device->rs_in_flight/8 < number)
		number = mxb - device->rs_in_flight/8;
587

588 589 590
	return number;
}

591
static int make_resync_request(struct drbd_device *const device, int cancel)
P
Philipp Reisner 已提交
592
{
593 594
	struct drbd_peer_device *const peer_device = first_peer_device(device);
	struct drbd_connection *const connection = peer_device ? peer_device->connection : NULL;
P
Philipp Reisner 已提交
595 596
	unsigned long bit;
	sector_t sector;
597
	const sector_t capacity = drbd_get_capacity(device->this_bdev);
598
	int max_bio_size;
599
	int number, rollback_i, size;
600
	int align, requeue = 0;
601
	int i = 0;
P
Philipp Reisner 已提交
602 603

	if (unlikely(cancel))
604
		return 0;
P
Philipp Reisner 已提交
605

606
	if (device->rs_total == 0) {
607
		/* empty resync? */
608
		drbd_resync_finished(device);
609
		return 0;
610 611
	}

612 613 614
	if (!get_ldev(device)) {
		/* Since we only need to access device->rsync a
		   get_ldev_if_state(device,D_FAILED) would be sufficient, but
P
Philipp Reisner 已提交
615 616
		   to continue resync with a broken disk makes no sense at
		   all */
617
		drbd_err(device, "Disk broke down during resync!\n");
618
		return 0;
P
Philipp Reisner 已提交
619 620
	}

621 622
	max_bio_size = queue_max_hw_sectors(device->rq_queue) << 9;
	number = drbd_rs_number_requests(device);
623
	if (number <= 0)
624
		goto requeue;
P
Philipp Reisner 已提交
625 626

	for (i = 0; i < number; i++) {
627 628
		/* Stop generating RS requests when half of the send buffer is filled,
		 * but notify TCP that we'd like to have more space. */
629 630
		mutex_lock(&connection->data.mutex);
		if (connection->data.socket) {
631 632 633 634 635 636 637 638 639 640
			struct sock *sk = connection->data.socket->sk;
			int queued = sk->sk_wmem_queued;
			int sndbuf = sk->sk_sndbuf;
			if (queued > sndbuf / 2) {
				requeue = 1;
				if (sk->sk_socket)
					set_bit(SOCK_NOSPACE, &sk->sk_socket->flags);
			}
		} else
			requeue = 1;
641
		mutex_unlock(&connection->data.mutex);
642
		if (requeue)
P
Philipp Reisner 已提交
643 644 645 646
			goto requeue;

next_sector:
		size = BM_BLOCK_SIZE;
647
		bit  = drbd_bm_find_next(device, device->bm_resync_fo);
P
Philipp Reisner 已提交
648

649
		if (bit == DRBD_END_OF_BITMAP) {
650 651
			device->bm_resync_fo = drbd_bm_bits(device);
			put_ldev(device);
652
			return 0;
P
Philipp Reisner 已提交
653 654 655 656
		}

		sector = BM_BIT_TO_SECT(bit);

657 658 659
		if (drbd_rs_should_slow_down(device, sector) ||
		    drbd_try_rs_begin_io(device, sector)) {
			device->bm_resync_fo = bit;
P
Philipp Reisner 已提交
660 661
			goto requeue;
		}
662
		device->bm_resync_fo = bit + 1;
P
Philipp Reisner 已提交
663

664 665
		if (unlikely(drbd_bm_test_bit(device, bit) == 0)) {
			drbd_rs_complete_io(device, sector);
P
Philipp Reisner 已提交
666 667 668
			goto next_sector;
		}

669
#if DRBD_MAX_BIO_SIZE > BM_BLOCK_SIZE
P
Philipp Reisner 已提交
670 671 672 673 674 675 676
		/* try to find some adjacent bits.
		 * we stop if we have already the maximum req size.
		 *
		 * Additionally always align bigger requests, in order to
		 * be prepared for all stripe sizes of software RAIDs.
		 */
		align = 1;
677
		rollback_i = i;
678
		while (i < number) {
679
			if (size + BM_BLOCK_SIZE > max_bio_size)
P
Philipp Reisner 已提交
680 681 682 683 684 685 686 687 688 689 690 691 692 693
				break;

			/* Be always aligned */
			if (sector & ((1<<(align+3))-1))
				break;

			/* do not cross extent boundaries */
			if (((bit+1) & BM_BLOCKS_PER_BM_EXT_MASK) == 0)
				break;
			/* now, is it actually dirty, after all?
			 * caution, drbd_bm_test_bit is tri-state for some
			 * obscure reason; ( b == 0 ) would get the out-of-band
			 * only accidentally right because of the "oddly sized"
			 * adjustment below */
694
			if (drbd_bm_test_bit(device, bit+1) != 1)
P
Philipp Reisner 已提交
695 696 697 698 699 700 701 702 703 704
				break;
			bit++;
			size += BM_BLOCK_SIZE;
			if ((BM_BLOCK_SIZE << align) <= size)
				align++;
			i++;
		}
		/* if we merged some,
		 * reset the offset to start the next drbd_bm_find_next from */
		if (size > BM_BLOCK_SIZE)
705
			device->bm_resync_fo = bit + 1;
P
Philipp Reisner 已提交
706 707 708 709 710
#endif

		/* adjust very last sectors, in case we are oddly sized */
		if (sector + (size>>9) > capacity)
			size = (capacity-sector)<<9;
711 712

		if (device->use_csums) {
713
			switch (read_for_csum(peer_device, sector, size)) {
714
			case -EIO: /* Disk failure */
715
				put_ldev(device);
716
				return -EIO;
717
			case -EAGAIN: /* allocation failed, or ldev busy */
718 719
				drbd_rs_complete_io(device, sector);
				device->bm_resync_fo = BM_SECT_TO_BIT(sector);
720
				i = rollback_i;
P
Philipp Reisner 已提交
721
				goto requeue;
722 723 724 725 726
			case 0:
				/* everything ok */
				break;
			default:
				BUG();
P
Philipp Reisner 已提交
727 728
			}
		} else {
729 730
			int err;

731
			inc_rs_pending(device);
732
			err = drbd_send_drequest(peer_device, P_RS_DATA_REQUEST,
733 734
						 sector, size, ID_SYNCER);
			if (err) {
735
				drbd_err(device, "drbd_send_drequest() failed, aborting...\n");
736 737
				dec_rs_pending(device);
				put_ldev(device);
738
				return err;
P
Philipp Reisner 已提交
739 740 741 742
			}
		}
	}

743
	if (device->bm_resync_fo >= drbd_bm_bits(device)) {
P
Philipp Reisner 已提交
744 745 746 747 748 749
		/* last syncer _request_ was sent,
		 * but the P_RS_DATA_REPLY not yet received.  sync will end (and
		 * next sync group will resume), as soon as we receive the last
		 * resync data block, and the last bit is cleared.
		 * until then resync "work" is "inactive" ...
		 */
750
		put_ldev(device);
751
		return 0;
P
Philipp Reisner 已提交
752 753 754
	}

 requeue:
755 756 757
	device->rs_in_flight += (i << (BM_BLOCK_SHIFT - 9));
	mod_timer(&device->resync_timer, jiffies + SLEEP_TIME);
	put_ldev(device);
758
	return 0;
P
Philipp Reisner 已提交
759 760
}

761
static int make_ov_request(struct drbd_device *device, int cancel)
P
Philipp Reisner 已提交
762 763 764
{
	int number, i, size;
	sector_t sector;
765
	const sector_t capacity = drbd_get_capacity(device->this_bdev);
766
	bool stop_sector_reached = false;
P
Philipp Reisner 已提交
767 768 769 770

	if (unlikely(cancel))
		return 1;

771
	number = drbd_rs_number_requests(device);
P
Philipp Reisner 已提交
772

773
	sector = device->ov_position;
P
Philipp Reisner 已提交
774
	for (i = 0; i < number; i++) {
775
		if (sector >= capacity)
P
Philipp Reisner 已提交
776
			return 1;
777 778 779 780 781

		/* We check for "finished" only in the reply path:
		 * w_e_end_ov_reply().
		 * We need to send at least one request out. */
		stop_sector_reached = i > 0
782 783
			&& verify_can_do_stop_sector(device)
			&& sector >= device->ov_stop_sector;
784 785
		if (stop_sector_reached)
			break;
P
Philipp Reisner 已提交
786 787 788

		size = BM_BLOCK_SIZE;

789 790 791
		if (drbd_rs_should_slow_down(device, sector) ||
		    drbd_try_rs_begin_io(device, sector)) {
			device->ov_position = sector;
P
Philipp Reisner 已提交
792 793 794 795 796 797
			goto requeue;
		}

		if (sector + (size>>9) > capacity)
			size = (capacity-sector)<<9;

798
		inc_rs_pending(device);
799
		if (drbd_send_ov_request(first_peer_device(device), sector, size)) {
800
			dec_rs_pending(device);
P
Philipp Reisner 已提交
801 802 803 804
			return 0;
		}
		sector += BM_SECT_PER_BIT;
	}
805
	device->ov_position = sector;
P
Philipp Reisner 已提交
806 807

 requeue:
808
	device->rs_in_flight += (i << (BM_BLOCK_SHIFT - 9));
809
	if (i == 0 || !stop_sector_reached)
810
		mod_timer(&device->resync_timer, jiffies + SLEEP_TIME);
P
Philipp Reisner 已提交
811 812 813
	return 1;
}

814
int w_ov_finished(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
815
{
816 817 818 819
	struct drbd_device_work *dw =
		container_of(w, struct drbd_device_work, w);
	struct drbd_device *device = dw->device;
	kfree(dw);
820 821
	ov_out_of_sync_print(device);
	drbd_resync_finished(device);
P
Philipp Reisner 已提交
822

823
	return 0;
P
Philipp Reisner 已提交
824 825
}

826
static int w_resync_finished(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
827
{
828 829 830 831
	struct drbd_device_work *dw =
		container_of(w, struct drbd_device_work, w);
	struct drbd_device *device = dw->device;
	kfree(dw);
P
Philipp Reisner 已提交
832

833
	drbd_resync_finished(device);
P
Philipp Reisner 已提交
834

835
	return 0;
P
Philipp Reisner 已提交
836 837
}

838
static void ping_peer(struct drbd_device *device)
839
{
840
	struct drbd_connection *connection = first_peer_device(device)->connection;
841

842 843 844 845
	clear_bit(GOT_PING_ACK, &connection->flags);
	request_ping(connection);
	wait_event(connection->ping_wait,
		   test_bit(GOT_PING_ACK, &connection->flags) || device->state.conn < C_CONNECTED);
846 847
}

848
int drbd_resync_finished(struct drbd_device *device)
P
Philipp Reisner 已提交
849 850 851 852
{
	unsigned long db, dt, dbdt;
	unsigned long n_oos;
	union drbd_state os, ns;
853
	struct drbd_device_work *dw;
P
Philipp Reisner 已提交
854
	char *khelper_cmd = NULL;
855
	int verify_done = 0;
P
Philipp Reisner 已提交
856 857 858 859

	/* Remove all elements from the resync LRU. Since future actions
	 * might set bits in the (main) bitmap, then the entries in the
	 * resync LRU would be wrong. */
860
	if (drbd_rs_del_all(device)) {
P
Philipp Reisner 已提交
861 862 863 864 865
		/* In case this is not possible now, most probably because
		 * there are P_RS_DATA_REPLY Packets lingering on the worker's
		 * queue (or even the read operations for those packets
		 * is not finished by now).   Retry in 100ms. */

866
		schedule_timeout_interruptible(HZ / 10);
867 868 869 870 871 872
		dw = kmalloc(sizeof(struct drbd_device_work), GFP_ATOMIC);
		if (dw) {
			dw->w.cb = w_resync_finished;
			dw->device = device;
			drbd_queue_work(&first_peer_device(device)->connection->sender_work,
					&dw->w);
P
Philipp Reisner 已提交
873 874
			return 1;
		}
875
		drbd_err(device, "Warn failed to drbd_rs_del_all() and to kmalloc(dw).\n");
P
Philipp Reisner 已提交
876 877
	}

878
	dt = (jiffies - device->rs_start - device->rs_paused) / HZ;
P
Philipp Reisner 已提交
879 880
	if (dt <= 0)
		dt = 1;
881

882
	db = device->rs_total;
883
	/* adjust for verify start and stop sectors, respective reached position */
884 885
	if (device->state.conn == C_VERIFY_S || device->state.conn == C_VERIFY_T)
		db -= device->ov_left;
886

P
Philipp Reisner 已提交
887
	dbdt = Bit2KB(db/dt);
888
	device->rs_paused /= HZ;
P
Philipp Reisner 已提交
889

890
	if (!get_ldev(device))
P
Philipp Reisner 已提交
891 892
		goto out;

893
	ping_peer(device);
894

895
	spin_lock_irq(&device->resource->req_lock);
896
	os = drbd_read_state(device);
P
Philipp Reisner 已提交
897

898 899
	verify_done = (os.conn == C_VERIFY_S || os.conn == C_VERIFY_T);

P
Philipp Reisner 已提交
900 901 902 903 904 905 906 907
	/* This protects us against multiple calls (that can happen in the presence
	   of application IO), and against connectivity loss just before we arrive here. */
	if (os.conn <= C_CONNECTED)
		goto out_unlock;

	ns = os;
	ns.conn = C_CONNECTED;

908
	drbd_info(device, "%s done (total %lu sec; paused %lu sec; %lu K/sec)\n",
909
	     verify_done ? "Online verify" : "Resync",
910
	     dt + device->rs_paused, device->rs_paused, dbdt);
P
Philipp Reisner 已提交
911

912
	n_oos = drbd_bm_total_weight(device);
P
Philipp Reisner 已提交
913 914 915

	if (os.conn == C_VERIFY_S || os.conn == C_VERIFY_T) {
		if (n_oos) {
916
			drbd_alert(device, "Online verify found %lu %dk block out of sync!\n",
P
Philipp Reisner 已提交
917 918 919 920
			      n_oos, Bit2KB(1));
			khelper_cmd = "out-of-sync";
		}
	} else {
921
		D_ASSERT(device, (n_oos - device->rs_failed) == 0);
P
Philipp Reisner 已提交
922 923 924 925

		if (os.conn == C_SYNC_TARGET || os.conn == C_PAUSED_SYNC_T)
			khelper_cmd = "after-resync-target";

926
		if (device->use_csums && device->rs_total) {
927 928
			const unsigned long s = device->rs_same_csum;
			const unsigned long t = device->rs_total;
P
Philipp Reisner 已提交
929 930 931
			const int ratio =
				(t == 0)     ? 0 :
			(t < 100000) ? ((s*100)/t) : (s/(t/100));
932
			drbd_info(device, "%u %% had equal checksums, eliminated: %luK; "
P
Philipp Reisner 已提交
933 934
			     "transferred %luK total %luK\n",
			     ratio,
935 936 937
			     Bit2KB(device->rs_same_csum),
			     Bit2KB(device->rs_total - device->rs_same_csum),
			     Bit2KB(device->rs_total));
P
Philipp Reisner 已提交
938 939 940
		}
	}

941
	if (device->rs_failed) {
942
		drbd_info(device, "            %lu failed blocks\n", device->rs_failed);
P
Philipp Reisner 已提交
943 944 945 946 947 948 949 950 951 952 953 954 955

		if (os.conn == C_SYNC_TARGET || os.conn == C_PAUSED_SYNC_T) {
			ns.disk = D_INCONSISTENT;
			ns.pdsk = D_UP_TO_DATE;
		} else {
			ns.disk = D_UP_TO_DATE;
			ns.pdsk = D_INCONSISTENT;
		}
	} else {
		ns.disk = D_UP_TO_DATE;
		ns.pdsk = D_UP_TO_DATE;

		if (os.conn == C_SYNC_TARGET || os.conn == C_PAUSED_SYNC_T) {
956
			if (device->p_uuid) {
P
Philipp Reisner 已提交
957 958
				int i;
				for (i = UI_BITMAP ; i <= UI_HISTORY_END ; i++)
959 960 961
					_drbd_uuid_set(device, i, device->p_uuid[i]);
				drbd_uuid_set(device, UI_BITMAP, device->ldev->md.uuid[UI_CURRENT]);
				_drbd_uuid_set(device, UI_CURRENT, device->p_uuid[UI_CURRENT]);
P
Philipp Reisner 已提交
962
			} else {
963
				drbd_err(device, "device->p_uuid is NULL! BUG\n");
P
Philipp Reisner 已提交
964 965 966
			}
		}

967 968 969
		if (!(os.conn == C_VERIFY_S || os.conn == C_VERIFY_T)) {
			/* for verify runs, we don't update uuids here,
			 * so there would be nothing to report. */
970 971 972
			drbd_uuid_set_bm(device, 0UL);
			drbd_print_uuids(device, "updated UUIDs");
			if (device->p_uuid) {
973 974 975 976
				/* Now the two UUID sets are equal, update what we
				 * know of the peer. */
				int i;
				for (i = UI_CURRENT ; i <= UI_HISTORY_END ; i++)
977
					device->p_uuid[i] = device->ldev->md.uuid[i];
978
			}
P
Philipp Reisner 已提交
979 980 981
		}
	}

982
	_drbd_set_state(device, ns, CS_VERBOSE, NULL);
P
Philipp Reisner 已提交
983
out_unlock:
984
	spin_unlock_irq(&device->resource->req_lock);
985
	put_ldev(device);
P
Philipp Reisner 已提交
986
out:
987 988 989
	device->rs_total  = 0;
	device->rs_failed = 0;
	device->rs_paused = 0;
990 991

	/* reset start sector, if we reached end of device */
992 993
	if (verify_done && device->ov_left == 0)
		device->ov_start_sector = 0;
P
Philipp Reisner 已提交
994

995
	drbd_md_sync(device);
996

P
Philipp Reisner 已提交
997
	if (khelper_cmd)
998
		drbd_khelper(device, khelper_cmd);
P
Philipp Reisner 已提交
999 1000 1001 1002 1003

	return 1;
}

/* helper */
1004
static void move_to_net_ee_or_free(struct drbd_device *device, struct drbd_peer_request *peer_req)
P
Philipp Reisner 已提交
1005
{
1006
	if (drbd_peer_req_has_active_page(peer_req)) {
P
Philipp Reisner 已提交
1007
		/* This might happen if sendpage() has not finished */
1008
		int i = (peer_req->i.size + PAGE_SIZE -1) >> PAGE_SHIFT;
1009 1010
		atomic_add(i, &device->pp_in_use_by_net);
		atomic_sub(i, &device->pp_in_use);
1011
		spin_lock_irq(&device->resource->req_lock);
1012
		list_add_tail(&peer_req->w.list, &device->net_ee);
1013
		spin_unlock_irq(&device->resource->req_lock);
1014
		wake_up(&drbd_pp_wait);
P
Philipp Reisner 已提交
1015
	} else
1016
		drbd_free_peer_req(device, peer_req);
P
Philipp Reisner 已提交
1017 1018 1019 1020
}

/**
 * w_e_end_data_req() - Worker callback, to send a P_DATA_REPLY packet in response to a P_DATA_REQUEST
1021
 * @device:	DRBD device.
P
Philipp Reisner 已提交
1022 1023 1024
 * @w:		work object.
 * @cancel:	The connection will be closed anyways
 */
1025
int w_e_end_data_req(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
1026
{
1027
	struct drbd_peer_request *peer_req = container_of(w, struct drbd_peer_request, w);
1028 1029
	struct drbd_peer_device *peer_device = peer_req->peer_device;
	struct drbd_device *device = peer_device->device;
1030
	int err;
P
Philipp Reisner 已提交
1031 1032

	if (unlikely(cancel)) {
1033 1034
		drbd_free_peer_req(device, peer_req);
		dec_unacked(device);
1035
		return 0;
P
Philipp Reisner 已提交
1036 1037
	}

1038
	if (likely((peer_req->flags & EE_WAS_ERROR) == 0)) {
1039
		err = drbd_send_block(peer_device, P_DATA_REPLY, peer_req);
P
Philipp Reisner 已提交
1040 1041
	} else {
		if (__ratelimit(&drbd_ratelimit_state))
1042
			drbd_err(device, "Sending NegDReply. sector=%llus.\n",
1043
			    (unsigned long long)peer_req->i.sector);
P
Philipp Reisner 已提交
1044

1045
		err = drbd_send_ack(peer_device, P_NEG_DREPLY, peer_req);
P
Philipp Reisner 已提交
1046 1047
	}

1048
	dec_unacked(device);
P
Philipp Reisner 已提交
1049

1050
	move_to_net_ee_or_free(device, peer_req);
P
Philipp Reisner 已提交
1051

1052
	if (unlikely(err))
1053
		drbd_err(device, "drbd_send_block() failed\n");
1054
	return err;
P
Philipp Reisner 已提交
1055 1056 1057
}

/**
1058
 * w_e_end_rsdata_req() - Worker callback to send a P_RS_DATA_REPLY packet in response to a P_RS_DATA_REQUEST
P
Philipp Reisner 已提交
1059 1060 1061
 * @w:		work object.
 * @cancel:	The connection will be closed anyways
 */
1062
int w_e_end_rsdata_req(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
1063
{
1064
	struct drbd_peer_request *peer_req = container_of(w, struct drbd_peer_request, w);
1065 1066
	struct drbd_peer_device *peer_device = peer_req->peer_device;
	struct drbd_device *device = peer_device->device;
1067
	int err;
P
Philipp Reisner 已提交
1068 1069

	if (unlikely(cancel)) {
1070 1071
		drbd_free_peer_req(device, peer_req);
		dec_unacked(device);
1072
		return 0;
P
Philipp Reisner 已提交
1073 1074
	}

1075 1076 1077
	if (get_ldev_if_state(device, D_FAILED)) {
		drbd_rs_complete_io(device, peer_req->i.sector);
		put_ldev(device);
P
Philipp Reisner 已提交
1078 1079
	}

1080
	if (device->state.conn == C_AHEAD) {
1081
		err = drbd_send_ack(peer_device, P_RS_CANCEL, peer_req);
1082
	} else if (likely((peer_req->flags & EE_WAS_ERROR) == 0)) {
1083 1084
		if (likely(device->state.pdsk >= D_INCONSISTENT)) {
			inc_rs_pending(device);
1085
			err = drbd_send_block(peer_device, P_RS_DATA_REPLY, peer_req);
P
Philipp Reisner 已提交
1086 1087
		} else {
			if (__ratelimit(&drbd_ratelimit_state))
1088
				drbd_err(device, "Not sending RSDataReply, "
P
Philipp Reisner 已提交
1089
				    "partner DISKLESS!\n");
1090
			err = 0;
P
Philipp Reisner 已提交
1091 1092 1093
		}
	} else {
		if (__ratelimit(&drbd_ratelimit_state))
1094
			drbd_err(device, "Sending NegRSDReply. sector %llus.\n",
1095
			    (unsigned long long)peer_req->i.sector);
P
Philipp Reisner 已提交
1096

1097
		err = drbd_send_ack(peer_device, P_NEG_RS_DREPLY, peer_req);
P
Philipp Reisner 已提交
1098 1099

		/* update resync data with failure */
1100
		drbd_rs_failed_io(device, peer_req->i.sector, peer_req->i.size);
P
Philipp Reisner 已提交
1101 1102
	}

1103
	dec_unacked(device);
P
Philipp Reisner 已提交
1104

1105
	move_to_net_ee_or_free(device, peer_req);
P
Philipp Reisner 已提交
1106

1107
	if (unlikely(err))
1108
		drbd_err(device, "drbd_send_block() failed\n");
1109
	return err;
P
Philipp Reisner 已提交
1110 1111
}

1112
int w_e_end_csum_rs_req(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
1113
{
1114
	struct drbd_peer_request *peer_req = container_of(w, struct drbd_peer_request, w);
1115 1116
	struct drbd_peer_device *peer_device = peer_req->peer_device;
	struct drbd_device *device = peer_device->device;
P
Philipp Reisner 已提交
1117 1118 1119
	struct digest_info *di;
	int digest_size;
	void *digest = NULL;
1120
	int err, eq = 0;
P
Philipp Reisner 已提交
1121 1122

	if (unlikely(cancel)) {
1123 1124
		drbd_free_peer_req(device, peer_req);
		dec_unacked(device);
1125
		return 0;
P
Philipp Reisner 已提交
1126 1127
	}

1128 1129 1130
	if (get_ldev(device)) {
		drbd_rs_complete_io(device, peer_req->i.sector);
		put_ldev(device);
1131
	}
P
Philipp Reisner 已提交
1132

1133
	di = peer_req->digest;
P
Philipp Reisner 已提交
1134

1135
	if (likely((peer_req->flags & EE_WAS_ERROR) == 0)) {
P
Philipp Reisner 已提交
1136 1137 1138
		/* quick hack to try to avoid a race against reconfiguration.
		 * a real fix would be much more involved,
		 * introducing more locking mechanisms */
1139 1140
		if (peer_device->connection->csums_tfm) {
			digest_size = crypto_hash_digestsize(peer_device->connection->csums_tfm);
1141
			D_ASSERT(device, digest_size == di->digest_size);
P
Philipp Reisner 已提交
1142 1143 1144
			digest = kmalloc(digest_size, GFP_NOIO);
		}
		if (digest) {
1145
			drbd_csum_ee(peer_device->connection->csums_tfm, peer_req, digest);
P
Philipp Reisner 已提交
1146 1147 1148 1149 1150
			eq = !memcmp(digest, di->digest, digest_size);
			kfree(digest);
		}

		if (eq) {
1151
			drbd_set_in_sync(device, peer_req->i.sector, peer_req->i.size);
1152
			/* rs_same_csums unit is BM_BLOCK_SIZE */
1153
			device->rs_same_csum += peer_req->i.size >> BM_BLOCK_SHIFT;
1154
			err = drbd_send_ack(peer_device, P_RS_IS_IN_SYNC, peer_req);
P
Philipp Reisner 已提交
1155
		} else {
1156
			inc_rs_pending(device);
1157 1158
			peer_req->block_id = ID_SYNCER; /* By setting block_id, digest pointer becomes invalid! */
			peer_req->flags &= ~EE_HAS_DIGEST; /* This peer request no longer has a digest pointer */
1159
			kfree(di);
1160
			err = drbd_send_block(peer_device, P_RS_DATA_REPLY, peer_req);
P
Philipp Reisner 已提交
1161 1162
		}
	} else {
1163
		err = drbd_send_ack(peer_device, P_NEG_RS_DREPLY, peer_req);
P
Philipp Reisner 已提交
1164
		if (__ratelimit(&drbd_ratelimit_state))
1165
			drbd_err(device, "Sending NegDReply. I guess it gets messy.\n");
P
Philipp Reisner 已提交
1166 1167
	}

1168 1169
	dec_unacked(device);
	move_to_net_ee_or_free(device, peer_req);
P
Philipp Reisner 已提交
1170

1171
	if (unlikely(err))
1172
		drbd_err(device, "drbd_send_block/ack() failed\n");
1173
	return err;
P
Philipp Reisner 已提交
1174 1175
}

1176
int w_e_end_ov_req(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
1177
{
1178
	struct drbd_peer_request *peer_req = container_of(w, struct drbd_peer_request, w);
1179 1180
	struct drbd_peer_device *peer_device = peer_req->peer_device;
	struct drbd_device *device = peer_device->device;
1181 1182
	sector_t sector = peer_req->i.sector;
	unsigned int size = peer_req->i.size;
P
Philipp Reisner 已提交
1183 1184
	int digest_size;
	void *digest;
1185
	int err = 0;
P
Philipp Reisner 已提交
1186 1187 1188 1189

	if (unlikely(cancel))
		goto out;

1190
	digest_size = crypto_hash_digestsize(peer_device->connection->verify_tfm);
P
Philipp Reisner 已提交
1191
	digest = kmalloc(digest_size, GFP_NOIO);
1192
	if (!digest) {
1193
		err = 1;	/* terminate the connection in case the allocation failed */
1194
		goto out;
P
Philipp Reisner 已提交
1195 1196
	}

1197
	if (likely(!(peer_req->flags & EE_WAS_ERROR)))
1198
		drbd_csum_ee(peer_device->connection->verify_tfm, peer_req, digest);
1199 1200 1201
	else
		memset(digest, 0, digest_size);

1202 1203 1204 1205
	/* Free e and pages before send.
	 * In case we block on congestion, we could otherwise run into
	 * some distributed deadlock, if the other side blocks on
	 * congestion as well, because our receiver blocks in
1206
	 * drbd_alloc_pages due to pp_in_use > max_buffers. */
1207
	drbd_free_peer_req(device, peer_req);
1208
	peer_req = NULL;
1209
	inc_rs_pending(device);
1210
	err = drbd_send_drequest_csum(peer_device, sector, size, digest, digest_size, P_OV_REPLY);
1211
	if (err)
1212
		dec_rs_pending(device);
1213 1214
	kfree(digest);

P
Philipp Reisner 已提交
1215
out:
1216
	if (peer_req)
1217 1218
		drbd_free_peer_req(device, peer_req);
	dec_unacked(device);
1219
	return err;
P
Philipp Reisner 已提交
1220 1221
}

1222
void drbd_ov_out_of_sync_found(struct drbd_device *device, sector_t sector, int size)
P
Philipp Reisner 已提交
1223
{
1224 1225
	if (device->ov_last_oos_start + device->ov_last_oos_size == sector) {
		device->ov_last_oos_size += size>>9;
P
Philipp Reisner 已提交
1226
	} else {
1227 1228
		device->ov_last_oos_start = sector;
		device->ov_last_oos_size = size>>9;
P
Philipp Reisner 已提交
1229
	}
1230
	drbd_set_out_of_sync(device, sector, size);
P
Philipp Reisner 已提交
1231 1232
}

1233
int w_e_end_ov_reply(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
1234
{
1235
	struct drbd_peer_request *peer_req = container_of(w, struct drbd_peer_request, w);
1236 1237
	struct drbd_peer_device *peer_device = peer_req->peer_device;
	struct drbd_device *device = peer_device->device;
P
Philipp Reisner 已提交
1238 1239
	struct digest_info *di;
	void *digest;
1240 1241
	sector_t sector = peer_req->i.sector;
	unsigned int size = peer_req->i.size;
1242
	int digest_size;
1243
	int err, eq = 0;
1244
	bool stop_sector_reached = false;
P
Philipp Reisner 已提交
1245 1246

	if (unlikely(cancel)) {
1247 1248
		drbd_free_peer_req(device, peer_req);
		dec_unacked(device);
1249
		return 0;
P
Philipp Reisner 已提交
1250 1251 1252 1253
	}

	/* after "cancel", because after drbd_disconnect/drbd_rs_cancel_all
	 * the resync lru has been cleaned up already */
1254 1255 1256
	if (get_ldev(device)) {
		drbd_rs_complete_io(device, peer_req->i.sector);
		put_ldev(device);
1257
	}
P
Philipp Reisner 已提交
1258

1259
	di = peer_req->digest;
P
Philipp Reisner 已提交
1260

1261
	if (likely((peer_req->flags & EE_WAS_ERROR) == 0)) {
1262
		digest_size = crypto_hash_digestsize(peer_device->connection->verify_tfm);
P
Philipp Reisner 已提交
1263 1264
		digest = kmalloc(digest_size, GFP_NOIO);
		if (digest) {
1265
			drbd_csum_ee(peer_device->connection->verify_tfm, peer_req, digest);
P
Philipp Reisner 已提交
1266

1267
			D_ASSERT(device, digest_size == di->digest_size);
P
Philipp Reisner 已提交
1268 1269 1270 1271 1272
			eq = !memcmp(digest, di->digest, digest_size);
			kfree(digest);
		}
	}

1273 1274 1275 1276
	/* Free peer_req and pages before send.
	 * In case we block on congestion, we could otherwise run into
	 * some distributed deadlock, if the other side blocks on
	 * congestion as well, because our receiver blocks in
1277
	 * drbd_alloc_pages due to pp_in_use > max_buffers. */
1278
	drbd_free_peer_req(device, peer_req);
P
Philipp Reisner 已提交
1279
	if (!eq)
1280
		drbd_ov_out_of_sync_found(device, sector, size);
P
Philipp Reisner 已提交
1281
	else
1282
		ov_out_of_sync_print(device);
P
Philipp Reisner 已提交
1283

1284
	err = drbd_send_ack_ex(peer_device, P_OV_RESULT, sector, size,
1285
			       eq ? ID_IN_SYNC : ID_OUT_OF_SYNC);
P
Philipp Reisner 已提交
1286

1287
	dec_unacked(device);
P
Philipp Reisner 已提交
1288

1289
	--device->ov_left;
1290 1291

	/* let's advance progress step marks only for every other megabyte */
1292 1293
	if ((device->ov_left & 0x200) == 0x200)
		drbd_advance_rs_marks(device, device->ov_left);
1294

1295 1296
	stop_sector_reached = verify_can_do_stop_sector(device) &&
		(sector + (size>>9)) >= device->ov_stop_sector;
1297

1298 1299 1300
	if (device->ov_left == 0 || stop_sector_reached) {
		ov_out_of_sync_print(device);
		drbd_resync_finished(device);
P
Philipp Reisner 已提交
1301 1302
	}

1303
	return err;
P
Philipp Reisner 已提交
1304 1305
}

1306 1307 1308 1309 1310
/* FIXME
 * We need to track the number of pending barrier acks,
 * and to be able to wait for them.
 * See also comment in drbd_adm_attach before drbd_suspend_io.
 */
1311
static int drbd_send_barrier(struct drbd_connection *connection)
P
Philipp Reisner 已提交
1312
{
1313
	struct p_barrier *p;
1314
	struct drbd_socket *sock;
P
Philipp Reisner 已提交
1315

1316 1317
	sock = &connection->data;
	p = conn_prepare_command(connection, sock);
1318 1319
	if (!p)
		return -EIO;
1320
	p->barrier = connection->send.current_epoch_nr;
1321
	p->pad = 0;
1322
	connection->send.current_epoch_writes = 0;
1323

1324
	return conn_send_command(connection, sock, P_BARRIER, sizeof(*p), NULL, 0);
P
Philipp Reisner 已提交
1325 1326
}

1327
int w_send_write_hint(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
1328
{
1329 1330
	struct drbd_device *device =
		container_of(w, struct drbd_device, unplug_work);
1331 1332
	struct drbd_socket *sock;

P
Philipp Reisner 已提交
1333
	if (cancel)
1334
		return 0;
1335
	sock = &first_peer_device(device)->connection->data;
1336
	if (!drbd_prepare_command(first_peer_device(device), sock))
1337
		return -EIO;
1338
	return drbd_send_command(first_peer_device(device), sock, P_UNPLUG_REMOTE, 0, NULL, 0);
P
Philipp Reisner 已提交
1339 1340
}

1341
static void re_init_if_first_write(struct drbd_connection *connection, unsigned int epoch)
1342
{
1343 1344 1345 1346
	if (!connection->send.seen_any_write_yet) {
		connection->send.seen_any_write_yet = true;
		connection->send.current_epoch_nr = epoch;
		connection->send.current_epoch_writes = 0;
1347 1348 1349
	}
}

1350
static void maybe_send_barrier(struct drbd_connection *connection, unsigned int epoch)
1351 1352
{
	/* re-init if first write on this connection */
1353
	if (!connection->send.seen_any_write_yet)
1354
		return;
1355 1356 1357 1358
	if (connection->send.current_epoch_nr != epoch) {
		if (connection->send.current_epoch_writes)
			drbd_send_barrier(connection);
		connection->send.current_epoch_nr = epoch;
1359 1360 1361
	}
}

1362
int w_send_out_of_sync(struct drbd_work *w, int cancel)
1363 1364
{
	struct drbd_request *req = container_of(w, struct drbd_request, w);
1365
	struct drbd_device *device = req->device;
1366 1367
	struct drbd_peer_device *const peer_device = first_peer_device(device);
	struct drbd_connection *const connection = peer_device->connection;
1368
	int err;
1369 1370

	if (unlikely(cancel)) {
1371
		req_mod(req, SEND_CANCELED);
1372
		return 0;
1373 1374
	}

1375
	/* this time, no connection->send.current_epoch_writes++;
1376 1377 1378
	 * If it was sent, it was the closing barrier for the last
	 * replicated epoch, before we went into AHEAD mode.
	 * No more barriers will be sent, until we leave AHEAD mode again. */
1379
	maybe_send_barrier(connection, req->epoch);
1380

1381
	err = drbd_send_out_of_sync(peer_device, req);
1382
	req_mod(req, OOS_HANDED_TO_NETWORK);
1383

1384
	return err;
1385 1386
}

P
Philipp Reisner 已提交
1387 1388 1389 1390 1391
/**
 * w_send_dblock() - Worker callback to send a P_DATA packet in order to mirror a write request
 * @w:		work object.
 * @cancel:	The connection will be closed anyways
 */
1392
int w_send_dblock(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
1393 1394
{
	struct drbd_request *req = container_of(w, struct drbd_request, w);
1395
	struct drbd_device *device = req->device;
1396 1397
	struct drbd_peer_device *const peer_device = first_peer_device(device);
	struct drbd_connection *connection = peer_device->connection;
1398
	int err;
P
Philipp Reisner 已提交
1399 1400

	if (unlikely(cancel)) {
1401
		req_mod(req, SEND_CANCELED);
1402
		return 0;
P
Philipp Reisner 已提交
1403 1404
	}

1405 1406 1407
	re_init_if_first_write(connection, req->epoch);
	maybe_send_barrier(connection, req->epoch);
	connection->send.current_epoch_writes++;
1408

1409
	err = drbd_send_dblock(peer_device, req);
1410
	req_mod(req, err ? SEND_FAILED : HANDED_OVER_TO_NETWORK);
P
Philipp Reisner 已提交
1411

1412
	return err;
P
Philipp Reisner 已提交
1413 1414 1415 1416 1417 1418 1419
}

/**
 * w_send_read_req() - Worker callback to send a read request (P_DATA_REQUEST) packet
 * @w:		work object.
 * @cancel:	The connection will be closed anyways
 */
1420
int w_send_read_req(struct drbd_work *w, int cancel)
P
Philipp Reisner 已提交
1421 1422
{
	struct drbd_request *req = container_of(w, struct drbd_request, w);
1423
	struct drbd_device *device = req->device;
1424 1425
	struct drbd_peer_device *const peer_device = first_peer_device(device);
	struct drbd_connection *connection = peer_device->connection;
1426
	int err;
P
Philipp Reisner 已提交
1427 1428

	if (unlikely(cancel)) {
1429
		req_mod(req, SEND_CANCELED);
1430
		return 0;
P
Philipp Reisner 已提交
1431 1432
	}

1433 1434
	/* Even read requests may close a write epoch,
	 * if there was any yet. */
1435
	maybe_send_barrier(connection, req->epoch);
1436

1437
	err = drbd_send_drequest(peer_device, P_DATA_REQUEST, req->i.sector, req->i.size,
1438
				 (unsigned long)req);
P
Philipp Reisner 已提交
1439

1440
	req_mod(req, err ? SEND_FAILED : HANDED_OVER_TO_NETWORK);
P
Philipp Reisner 已提交
1441

1442
	return err;
P
Philipp Reisner 已提交
1443 1444
}

1445
int w_restart_disk_io(struct drbd_work *w, int cancel)
1446 1447
{
	struct drbd_request *req = container_of(w, struct drbd_request, w);
1448
	struct drbd_device *device = req->device;
1449

1450
	if (bio_data_dir(req->master_bio) == WRITE && req->rq_state & RQ_IN_ACT_LOG)
1451
		drbd_al_begin_io(device, &req->i);
1452 1453

	drbd_req_make_private_bio(req, req->master_bio);
1454
	req->private_bio->bi_bdev = device->ldev->backing_bdev;
1455 1456
	generic_make_request(req->private_bio);

1457
	return 0;
1458 1459
}

1460
static int _drbd_may_sync_now(struct drbd_device *device)
P
Philipp Reisner 已提交
1461
{
1462
	struct drbd_device *odev = device;
1463
	int resync_after;
P
Philipp Reisner 已提交
1464 1465

	while (1) {
1466
		if (!odev->ldev || odev->state.disk == D_DISKLESS)
1467
			return 1;
P
Philipp Reisner 已提交
1468
		rcu_read_lock();
1469
		resync_after = rcu_dereference(odev->ldev->disk_conf)->resync_after;
P
Philipp Reisner 已提交
1470
		rcu_read_unlock();
1471
		if (resync_after == -1)
P
Philipp Reisner 已提交
1472
			return 1;
1473
		odev = minor_to_device(resync_after);
1474
		if (!odev)
1475
			return 1;
P
Philipp Reisner 已提交
1476 1477 1478 1479 1480 1481 1482 1483 1484 1485
		if ((odev->state.conn >= C_SYNC_SOURCE &&
		     odev->state.conn <= C_PAUSED_SYNC_T) ||
		    odev->state.aftr_isp || odev->state.peer_isp ||
		    odev->state.user_isp)
			return 0;
	}
}

/**
 * _drbd_pause_after() - Pause resync on all devices that may not resync now
1486
 * @device:	DRBD device.
P
Philipp Reisner 已提交
1487 1488 1489
 *
 * Called from process context only (admin command and after_state_ch).
 */
1490
static int _drbd_pause_after(struct drbd_device *device)
P
Philipp Reisner 已提交
1491
{
1492
	struct drbd_device *odev;
P
Philipp Reisner 已提交
1493 1494
	int i, rv = 0;

1495
	rcu_read_lock();
1496
	idr_for_each_entry(&drbd_devices, odev, i) {
P
Philipp Reisner 已提交
1497 1498 1499 1500 1501 1502
		if (odev->state.conn == C_STANDALONE && odev->state.disk == D_DISKLESS)
			continue;
		if (!_drbd_may_sync_now(odev))
			rv |= (__drbd_set_state(_NS(odev, aftr_isp, 1), CS_HARD, NULL)
			       != SS_NOTHING_TO_DO);
	}
1503
	rcu_read_unlock();
P
Philipp Reisner 已提交
1504 1505 1506 1507 1508 1509

	return rv;
}

/**
 * _drbd_resume_next() - Resume resync on all devices that may resync now
1510
 * @device:	DRBD device.
P
Philipp Reisner 已提交
1511 1512 1513
 *
 * Called from process context only (admin command and worker).
 */
1514
static int _drbd_resume_next(struct drbd_device *device)
P
Philipp Reisner 已提交
1515
{
1516
	struct drbd_device *odev;
P
Philipp Reisner 已提交
1517 1518
	int i, rv = 0;

1519
	rcu_read_lock();
1520
	idr_for_each_entry(&drbd_devices, odev, i) {
P
Philipp Reisner 已提交
1521 1522 1523 1524 1525 1526 1527 1528 1529
		if (odev->state.conn == C_STANDALONE && odev->state.disk == D_DISKLESS)
			continue;
		if (odev->state.aftr_isp) {
			if (_drbd_may_sync_now(odev))
				rv |= (__drbd_set_state(_NS(odev, aftr_isp, 0),
							CS_HARD, NULL)
				       != SS_NOTHING_TO_DO) ;
		}
	}
1530
	rcu_read_unlock();
P
Philipp Reisner 已提交
1531 1532 1533
	return rv;
}

1534
void resume_next_sg(struct drbd_device *device)
P
Philipp Reisner 已提交
1535 1536
{
	write_lock_irq(&global_state_lock);
1537
	_drbd_resume_next(device);
P
Philipp Reisner 已提交
1538 1539 1540
	write_unlock_irq(&global_state_lock);
}

1541
void suspend_other_sg(struct drbd_device *device)
P
Philipp Reisner 已提交
1542 1543
{
	write_lock_irq(&global_state_lock);
1544
	_drbd_pause_after(device);
P
Philipp Reisner 已提交
1545 1546 1547
	write_unlock_irq(&global_state_lock);
}

1548
/* caller must hold global_state_lock */
1549
enum drbd_ret_code drbd_resync_after_valid(struct drbd_device *device, int o_minor)
P
Philipp Reisner 已提交
1550
{
1551
	struct drbd_device *odev;
1552
	int resync_after;
P
Philipp Reisner 已提交
1553 1554 1555

	if (o_minor == -1)
		return NO_ERROR;
1556
	if (o_minor < -1 || o_minor > MINORMASK)
1557
		return ERR_RESYNC_AFTER;
P
Philipp Reisner 已提交
1558 1559

	/* check for loops */
1560
	odev = minor_to_device(o_minor);
P
Philipp Reisner 已提交
1561
	while (1) {
1562
		if (odev == device)
1563
			return ERR_RESYNC_AFTER_CYCLE;
P
Philipp Reisner 已提交
1564

1565 1566 1567 1568 1569 1570 1571 1572 1573
		/* You are free to depend on diskless, non-existing,
		 * or not yet/no longer existing minors.
		 * We only reject dependency loops.
		 * We cannot follow the dependency chain beyond a detached or
		 * missing minor.
		 */
		if (!odev || !odev->ldev || odev->state.disk == D_DISKLESS)
			return NO_ERROR;

P
Philipp Reisner 已提交
1574
		rcu_read_lock();
1575
		resync_after = rcu_dereference(odev->ldev->disk_conf)->resync_after;
P
Philipp Reisner 已提交
1576
		rcu_read_unlock();
P
Philipp Reisner 已提交
1577
		/* dependency chain ends here, no cycles. */
1578
		if (resync_after == -1)
P
Philipp Reisner 已提交
1579 1580 1581
			return NO_ERROR;

		/* follow the dependency chain */
1582
		odev = minor_to_device(resync_after);
P
Philipp Reisner 已提交
1583 1584 1585
	}
}

1586
/* caller must hold global_state_lock */
1587
void drbd_resync_after_changed(struct drbd_device *device)
P
Philipp Reisner 已提交
1588 1589 1590
{
	int changes;

1591
	do {
1592 1593
		changes  = _drbd_pause_after(device);
		changes |= _drbd_resume_next(device);
1594
	} while (changes);
P
Philipp Reisner 已提交
1595 1596
}

1597
void drbd_rs_controller_reset(struct drbd_device *device)
1598
{
P
Philipp Reisner 已提交
1599 1600
	struct fifo_buffer *plan;

1601 1602 1603
	atomic_set(&device->rs_sect_in, 0);
	atomic_set(&device->rs_sect_ev, 0);
	device->rs_in_flight = 0;
P
Philipp Reisner 已提交
1604 1605 1606 1607 1608 1609

	/* Updating the RCU protected object in place is necessary since
	   this function gets called from atomic context.
	   It is valid since all other updates also lead to an completely
	   empty fifo */
	rcu_read_lock();
1610
	plan = rcu_dereference(device->rs_plan_s);
P
Philipp Reisner 已提交
1611 1612 1613
	plan->total = 0;
	fifo_set(plan, 0);
	rcu_read_unlock();
1614 1615
}

P
Philipp Reisner 已提交
1616 1617
void start_resync_timer_fn(unsigned long data)
{
1618
	struct drbd_device *device = (struct drbd_device *) data;
1619
	drbd_device_post_work(device, RS_START);
P
Philipp Reisner 已提交
1620 1621
}

1622
static void do_start_resync(struct drbd_device *device)
P
Philipp Reisner 已提交
1623
{
1624
	if (atomic_read(&device->unacked_cnt) || atomic_read(&device->rs_pending_cnt)) {
1625
		drbd_warn(device, "postponing start_resync ...\n");
1626 1627
		device->start_resync_timer.expires = jiffies + HZ/10;
		add_timer(&device->start_resync_timer);
1628
		return;
P
Philipp Reisner 已提交
1629 1630
	}

1631 1632
	drbd_start_resync(device, C_SYNC_SOURCE);
	clear_bit(AHEAD_TO_SYNC_SOURCE, &device->flags);
P
Philipp Reisner 已提交
1633 1634
}

1635 1636 1637 1638 1639 1640 1641 1642 1643 1644 1645 1646
static bool use_checksum_based_resync(struct drbd_connection *connection, struct drbd_device *device)
{
	bool csums_after_crash_only;
	rcu_read_lock();
	csums_after_crash_only = rcu_dereference(connection->net_conf)->csums_after_crash_only;
	rcu_read_unlock();
	return connection->agreed_pro_version >= 89 &&		/* supported? */
		connection->csums_tfm &&			/* configured? */
		(csums_after_crash_only == 0			/* use for each resync? */
		 || test_bit(CRASHED_PRIMARY, &device->flags));	/* or only after Primary crash? */
}

P
Philipp Reisner 已提交
1647 1648
/**
 * drbd_start_resync() - Start the resync process
1649
 * @device:	DRBD device.
P
Philipp Reisner 已提交
1650 1651 1652 1653 1654
 * @side:	Either C_SYNC_SOURCE or C_SYNC_TARGET
 *
 * This function might bring you directly into one of the
 * C_PAUSED_SYNC_* states.
 */
1655
void drbd_start_resync(struct drbd_device *device, enum drbd_conns side)
P
Philipp Reisner 已提交
1656
{
1657 1658
	struct drbd_peer_device *peer_device = first_peer_device(device);
	struct drbd_connection *connection = peer_device ? peer_device->connection : NULL;
P
Philipp Reisner 已提交
1659 1660 1661
	union drbd_state ns;
	int r;

1662
	if (device->state.conn >= C_SYNC_SOURCE && device->state.conn < C_AHEAD) {
1663
		drbd_err(device, "Resync already running!\n");
P
Philipp Reisner 已提交
1664 1665 1666
		return;
	}

1667
	if (!test_bit(B_RS_H_DONE, &device->flags)) {
1668 1669 1670 1671
		if (side == C_SYNC_TARGET) {
			/* Since application IO was locked out during C_WF_BITMAP_T and
			   C_WF_SYNC_UUID we are still unmodified. Before going to C_SYNC_TARGET
			   we check that we might make the data inconsistent. */
1672
			r = drbd_khelper(device, "before-resync-target");
1673 1674
			r = (r >> 8) & 0xff;
			if (r > 0) {
1675
				drbd_info(device, "before-resync-target handler returned %d, "
1676
					 "dropping connection.\n", r);
1677
				conn_request_state(connection, NS(conn, C_DISCONNECTING), CS_HARD);
1678 1679
				return;
			}
1680
		} else /* C_SYNC_SOURCE */ {
1681
			r = drbd_khelper(device, "before-resync-source");
1682 1683 1684
			r = (r >> 8) & 0xff;
			if (r > 0) {
				if (r == 3) {
1685
					drbd_info(device, "before-resync-source handler returned %d, "
1686 1687
						 "ignoring. Old userland tools?", r);
				} else {
1688
					drbd_info(device, "before-resync-source handler returned %d, "
1689
						 "dropping connection.\n", r);
1690
					conn_request_state(connection,
1691
							   NS(conn, C_DISCONNECTING), CS_HARD);
1692 1693 1694
					return;
				}
			}
1695
		}
P
Philipp Reisner 已提交
1696 1697
	}

1698
	if (current == connection->worker.task) {
1699
		/* The worker should not sleep waiting for state_mutex,
1700
		   that can take long */
1701 1702 1703 1704
		if (!mutex_trylock(device->state_mutex)) {
			set_bit(B_RS_H_DONE, &device->flags);
			device->start_resync_timer.expires = jiffies + HZ/5;
			add_timer(&device->start_resync_timer);
1705 1706 1707
			return;
		}
	} else {
1708
		mutex_lock(device->state_mutex);
1709
	}
1710
	clear_bit(B_RS_H_DONE, &device->flags);
P
Philipp Reisner 已提交
1711

1712 1713 1714 1715
	/* req_lock: serialize with drbd_send_and_submit() and others
	 * global_state_lock: for stable sync-after dependencies */
	spin_lock_irq(&device->resource->req_lock);
	write_lock(&global_state_lock);
1716
	/* Did some connection breakage or IO error race with us? */
1717 1718
	if (device->state.conn < C_CONNECTED
	|| !get_ldev_if_state(device, D_NEGOTIATING)) {
1719 1720
		write_unlock(&global_state_lock);
		spin_unlock_irq(&device->resource->req_lock);
1721
		mutex_unlock(device->state_mutex);
P
Philipp Reisner 已提交
1722 1723 1724
		return;
	}

1725
	ns = drbd_read_state(device);
P
Philipp Reisner 已提交
1726

1727
	ns.aftr_isp = !_drbd_may_sync_now(device);
P
Philipp Reisner 已提交
1728 1729 1730 1731 1732 1733 1734 1735

	ns.conn = side;

	if (side == C_SYNC_TARGET)
		ns.disk = D_INCONSISTENT;
	else /* side == C_SYNC_SOURCE */
		ns.pdsk = D_INCONSISTENT;

1736 1737
	r = __drbd_set_state(device, ns, CS_VERBOSE, NULL);
	ns = drbd_read_state(device);
P
Philipp Reisner 已提交
1738 1739 1740 1741 1742

	if (ns.conn < C_CONNECTED)
		r = SS_UNKNOWN_ERROR;

	if (r == SS_SUCCESS) {
1743
		unsigned long tw = drbd_bm_total_weight(device);
1744 1745 1746
		unsigned long now = jiffies;
		int i;

1747 1748 1749 1750 1751 1752 1753
		device->rs_failed    = 0;
		device->rs_paused    = 0;
		device->rs_same_csum = 0;
		device->rs_last_events = 0;
		device->rs_last_sect_ev = 0;
		device->rs_total     = tw;
		device->rs_start     = now;
1754
		for (i = 0; i < DRBD_SYNC_MARKS; i++) {
1755 1756
			device->rs_mark_left[i] = tw;
			device->rs_mark_time[i] = now;
1757
		}
1758
		_drbd_pause_after(device);
1759 1760 1761 1762 1763 1764 1765 1766
		/* Forget potentially stale cached per resync extent bit-counts.
		 * Open coded drbd_rs_cancel_all(device), we already have IRQs
		 * disabled, and know the disk state is ok. */
		spin_lock(&device->al_lock);
		lc_reset(device->resync);
		device->resync_locked = 0;
		device->resync_wenr = LC_FREE;
		spin_unlock(&device->al_lock);
P
Philipp Reisner 已提交
1767
	}
1768 1769
	write_unlock(&global_state_lock);
	spin_unlock_irq(&device->resource->req_lock);
1770

P
Philipp Reisner 已提交
1771
	if (r == SS_SUCCESS) {
1772
		wake_up(&device->al_wait); /* for lc_reset() above */
1773 1774
		/* reset rs_last_bcast when a resync or verify is started,
		 * to deal with potential jiffies wrap. */
1775
		device->rs_last_bcast = jiffies - HZ;
1776

1777
		drbd_info(device, "Began resync as %s (will sync %lu KB [%lu bits set]).\n",
P
Philipp Reisner 已提交
1778
		     drbd_conn_str(ns.conn),
1779 1780
		     (unsigned long) device->rs_total << (BM_BLOCK_SHIFT-10),
		     (unsigned long) device->rs_total);
1781
		if (side == C_SYNC_TARGET) {
1782
			device->bm_resync_fo = 0;
1783 1784 1785 1786
			device->use_csums = use_checksum_based_resync(connection, device);
		} else {
			device->use_csums = 0;
		}
1787 1788 1789 1790 1791 1792 1793 1794

		/* Since protocol 96, we must serialize drbd_gen_and_send_sync_uuid
		 * with w_send_oos, or the sync target will get confused as to
		 * how much bits to resync.  We cannot do that always, because for an
		 * empty resync and protocol < 95, we need to do it here, as we call
		 * drbd_resync_finished from here in that case.
		 * We drbd_gen_and_send_sync_uuid here for protocol < 96,
		 * and from after_state_ch otherwise. */
1795 1796
		if (side == C_SYNC_SOURCE && connection->agreed_pro_version < 96)
			drbd_gen_and_send_sync_uuid(peer_device);
P
Philipp Reisner 已提交
1797

1798
		if (connection->agreed_pro_version < 95 && device->rs_total == 0) {
1799 1800 1801 1802 1803 1804 1805 1806 1807 1808
			/* This still has a race (about when exactly the peers
			 * detect connection loss) that can lead to a full sync
			 * on next handshake. In 8.3.9 we fixed this with explicit
			 * resync-finished notifications, but the fix
			 * introduces a protocol change.  Sleeping for some
			 * time longer than the ping interval + timeout on the
			 * SyncSource, to give the SyncTarget the chance to
			 * detect connection loss, then waiting for a ping
			 * response (implicit in drbd_resync_finished) reduces
			 * the race considerably, but does not solve it. */
1809 1810 1811 1812 1813
			if (side == C_SYNC_SOURCE) {
				struct net_conf *nc;
				int timeo;

				rcu_read_lock();
1814
				nc = rcu_dereference(connection->net_conf);
1815 1816 1817 1818
				timeo = nc->ping_int * HZ + nc->ping_timeo * HZ / 9;
				rcu_read_unlock();
				schedule_timeout_interruptible(timeo);
			}
1819
			drbd_resync_finished(device);
P
Philipp Reisner 已提交
1820 1821
		}

1822 1823
		drbd_rs_controller_reset(device);
		/* ns.conn may already be != device->state.conn,
P
Philipp Reisner 已提交
1824 1825 1826 1827
		 * we may have been paused in between, or become paused until
		 * the timer triggers.
		 * No matter, that is handled in resync_timer_fn() */
		if (ns.conn == C_SYNC_TARGET)
1828
			mod_timer(&device->resync_timer, jiffies);
P
Philipp Reisner 已提交
1829

1830
		drbd_md_sync(device);
P
Philipp Reisner 已提交
1831
	}
1832 1833
	put_ldev(device);
	mutex_unlock(device->state_mutex);
P
Philipp Reisner 已提交
1834 1835
}

1836
static void update_on_disk_bitmap(struct drbd_device *device, bool resync_done)
1837 1838 1839 1840 1841 1842 1843 1844
{
	struct sib_info sib = { .sib_reason = SIB_SYNC_PROGRESS, };
	device->rs_last_bcast = jiffies;

	if (!get_ldev(device))
		return;

	drbd_bm_write_lazy(device, 0);
1845
	if (resync_done && is_sync_state(device->state.conn))
1846
		drbd_resync_finished(device);
1847

1848 1849 1850 1851 1852 1853
	drbd_bcast_event(device, &sib);
	/* update timestamp, in case it took a while to write out stuff */
	device->rs_last_bcast = jiffies;
	put_ldev(device);
}

1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 1893 1894 1895 1896 1897 1898 1899 1900 1901 1902 1903 1904
static void drbd_ldev_destroy(struct drbd_device *device)
{
	lc_destroy(device->resync);
	device->resync = NULL;
	lc_destroy(device->act_log);
	device->act_log = NULL;
	__no_warn(local,
		drbd_free_ldev(device->ldev);
		device->ldev = NULL;);
	clear_bit(GOING_DISKLESS, &device->flags);
	wake_up(&device->misc_wait);
}

static void go_diskless(struct drbd_device *device)
{
	D_ASSERT(device, device->state.disk == D_FAILED);
	/* we cannot assert local_cnt == 0 here, as get_ldev_if_state will
	 * inc/dec it frequently. Once we are D_DISKLESS, no one will touch
	 * the protected members anymore, though, so once put_ldev reaches zero
	 * again, it will be safe to free them. */

	/* Try to write changed bitmap pages, read errors may have just
	 * set some bits outside the area covered by the activity log.
	 *
	 * If we have an IO error during the bitmap writeout,
	 * we will want a full sync next time, just in case.
	 * (Do we want a specific meta data flag for this?)
	 *
	 * If that does not make it to stable storage either,
	 * we cannot do anything about that anymore.
	 *
	 * We still need to check if both bitmap and ldev are present, we may
	 * end up here after a failed attach, before ldev was even assigned.
	 */
	if (device->bitmap && device->ldev) {
		/* An interrupted resync or similar is allowed to recounts bits
		 * while we detach.
		 * Any modifications would not be expected anymore, though.
		 */
		if (drbd_bitmap_io_from_worker(device, drbd_bm_write,
					"detach", BM_LOCKED_TEST_ALLOWED)) {
			if (test_bit(WAS_READ_ERROR, &device->flags)) {
				drbd_md_set_flag(device, MDF_FULL_SYNC);
				drbd_md_sync(device);
			}
		}
	}

	drbd_force_state(device, NS(disk, D_DISKLESS));
}

1905 1906 1907 1908 1909 1910 1911
static int do_md_sync(struct drbd_device *device)
{
	drbd_warn(device, "md_sync_timer expired! Worker calls drbd_md_sync().\n");
	drbd_md_sync(device);
	return 0;
}

1912 1913 1914
#define WORK_PENDING(work_bit, todo)	(todo & (1UL << work_bit))
static void do_device_work(struct drbd_device *device, const unsigned long todo)
{
1915 1916
	if (WORK_PENDING(MD_SYNC, todo))
		do_md_sync(device);
1917 1918 1919 1920 1921 1922 1923
	if (WORK_PENDING(RS_DONE, todo) ||
	    WORK_PENDING(RS_PROGRESS, todo))
		update_on_disk_bitmap(device, WORK_PENDING(RS_DONE, todo));
	if (WORK_PENDING(GO_DISKLESS, todo))
		go_diskless(device);
	if (WORK_PENDING(DESTROY_DISK, todo))
		drbd_ldev_destroy(device);
1924 1925
	if (WORK_PENDING(RS_START, todo))
		do_start_resync(device);
1926 1927 1928 1929 1930
}

#define DRBD_DEVICE_WORK_MASK	\
	((1UL << GO_DISKLESS)	\
	|(1UL << DESTROY_DISK)	\
1931 1932
	|(1UL << MD_SYNC)	\
	|(1UL << RS_START)	\
1933 1934 1935 1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947
	|(1UL << RS_PROGRESS)	\
	|(1UL << RS_DONE)	\
	)

static unsigned long get_work_bits(unsigned long *flags)
{
	unsigned long old, new;
	do {
		old = *flags;
		new = old & ~DRBD_DEVICE_WORK_MASK;
	} while (cmpxchg(flags, old, new) != old);
	return old & DRBD_DEVICE_WORK_MASK;
}

static void do_unqueued_work(struct drbd_connection *connection)
1948 1949 1950 1951 1952 1953 1954
{
	struct drbd_peer_device *peer_device;
	int vnr;

	rcu_read_lock();
	idr_for_each_entry(&connection->peer_devices, peer_device, vnr) {
		struct drbd_device *device = peer_device->device;
1955 1956
		unsigned long todo = get_work_bits(&device->flags);
		if (!todo)
1957
			continue;
1958

1959 1960
		kref_get(&device->kref);
		rcu_read_unlock();
1961
		do_device_work(device, todo);
1962 1963 1964 1965 1966 1967
		kref_put(&device->kref, drbd_destroy_device);
		rcu_read_lock();
	}
	rcu_read_unlock();
}

1968
static bool dequeue_work_batch(struct drbd_work_queue *queue, struct list_head *work_list)
1969 1970
{
	spin_lock_irq(&queue->q_lock);
1971
	list_splice_tail_init(&queue->q, work_list);
1972 1973 1974 1975
	spin_unlock_irq(&queue->q_lock);
	return !list_empty(work_list);
}

1976
static bool dequeue_work_item(struct drbd_work_queue *queue, struct list_head *work_list)
1977 1978 1979 1980 1981 1982 1983 1984
{
	spin_lock_irq(&queue->q_lock);
	if (!list_empty(&queue->q))
		list_move(queue->q.next, work_list);
	spin_unlock_irq(&queue->q_lock);
	return !list_empty(work_list);
}

1985
static void wait_for_work(struct drbd_connection *connection, struct list_head *work_list)
1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 2004 2005 2006 2007 2008 2009 2010 2011 2012 2013 2014
{
	DEFINE_WAIT(wait);
	struct net_conf *nc;
	int uncork, cork;

	dequeue_work_item(&connection->sender_work, work_list);
	if (!list_empty(work_list))
		return;

	/* Still nothing to do?
	 * Maybe we still need to close the current epoch,
	 * even if no new requests are queued yet.
	 *
	 * Also, poke TCP, just in case.
	 * Then wait for new work (or signal). */
	rcu_read_lock();
	nc = rcu_dereference(connection->net_conf);
	uncork = nc ? nc->tcp_cork : 0;
	rcu_read_unlock();
	if (uncork) {
		mutex_lock(&connection->data.mutex);
		if (connection->data.socket)
			drbd_tcp_uncork(connection->data.socket);
		mutex_unlock(&connection->data.mutex);
	}

	for (;;) {
		int send_barrier;
		prepare_to_wait(&connection->sender_work.q_wait, &wait, TASK_INTERRUPTIBLE);
2015
		spin_lock_irq(&connection->resource->req_lock);
2016
		spin_lock(&connection->sender_work.q_lock);	/* FIXME get rid of this one? */
2017 2018 2019
		/* dequeue single item only,
		 * we still use drbd_queue_work_front() in some places */
		if (!list_empty(&connection->sender_work.q))
2020
			list_splice_tail_init(&connection->sender_work.q, work_list);
2021 2022
		spin_unlock(&connection->sender_work.q_lock);	/* FIXME get rid of this one? */
		if (!list_empty(work_list) || signal_pending(current)) {
2023
			spin_unlock_irq(&connection->resource->req_lock);
2024 2025
			break;
		}
2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036

		/* We found nothing new to do, no to-be-communicated request,
		 * no other work item.  We may still need to close the last
		 * epoch.  Next incoming request epoch will be connection ->
		 * current transfer log epoch number.  If that is different
		 * from the epoch of the last request we communicated, it is
		 * safe to send the epoch separating barrier now.
		 */
		send_barrier =
			atomic_read(&connection->current_tle_nr) !=
			connection->send.current_epoch_nr;
2037
		spin_unlock_irq(&connection->resource->req_lock);
2038 2039 2040 2041

		if (send_barrier)
			maybe_send_barrier(connection,
					connection->send.current_epoch_nr + 1);
2042

2043
		if (test_bit(DEVICE_WORK_PENDING, &connection->flags))
2044 2045
			break;

2046 2047 2048
		/* drbd_send() may have called flush_signals() */
		if (get_t_state(&connection->worker) != RUNNING)
			break;
2049

2050 2051 2052 2053 2054 2055 2056 2057 2058 2059 2060 2061 2062 2063 2064 2065 2066 2067 2068 2069 2070 2071
		schedule();
		/* may be woken up for other things but new work, too,
		 * e.g. if the current epoch got closed.
		 * In which case we send the barrier above. */
	}
	finish_wait(&connection->sender_work.q_wait, &wait);

	/* someone may have changed the config while we have been waiting above. */
	rcu_read_lock();
	nc = rcu_dereference(connection->net_conf);
	cork = nc ? nc->tcp_cork : 0;
	rcu_read_unlock();
	mutex_lock(&connection->data.mutex);
	if (connection->data.socket) {
		if (cork)
			drbd_tcp_cork(connection->data.socket);
		else if (!uncork)
			drbd_tcp_uncork(connection->data.socket);
	}
	mutex_unlock(&connection->data.mutex);
}

P
Philipp Reisner 已提交
2072 2073
int drbd_worker(struct drbd_thread *thi)
{
2074
	struct drbd_connection *connection = thi->connection;
2075
	struct drbd_work *w = NULL;
2076
	struct drbd_peer_device *peer_device;
P
Philipp Reisner 已提交
2077
	LIST_HEAD(work_list);
2078
	int vnr;
P
Philipp Reisner 已提交
2079

2080
	while (get_t_state(thi) == RUNNING) {
2081
		drbd_thread_current_set_cpu(thi);
P
Philipp Reisner 已提交
2082

2083
		if (list_empty(&work_list))
2084
			wait_for_work(connection, &work_list);
P
Philipp Reisner 已提交
2085

2086 2087
		if (test_and_clear_bit(DEVICE_WORK_PENDING, &connection->flags))
			do_unqueued_work(connection);
2088

2089
		if (signal_pending(current)) {
P
Philipp Reisner 已提交
2090
			flush_signals(current);
2091
			if (get_t_state(thi) == RUNNING) {
2092
				drbd_warn(connection, "Worker got an unexpected signal\n");
P
Philipp Reisner 已提交
2093
				continue;
2094
			}
P
Philipp Reisner 已提交
2095 2096 2097
			break;
		}

2098
		if (get_t_state(thi) != RUNNING)
P
Philipp Reisner 已提交
2099 2100
			break;

2101
		while (!list_empty(&work_list)) {
2102 2103 2104
			w = list_first_entry(&work_list, struct drbd_work, list);
			list_del_init(&w->list);
			if (w->cb(w, connection->cstate < C_WF_REPORT_PARAMS) == 0)
2105
				continue;
2106 2107
			if (connection->cstate >= C_WF_REPORT_PARAMS)
				conn_request_state(connection, NS(conn, C_NETWORK_FAILURE), CS_HARD);
P
Philipp Reisner 已提交
2108 2109 2110
		}
	}

2111
	do {
2112 2113
		if (test_and_clear_bit(DEVICE_WORK_PENDING, &connection->flags))
			do_unqueued_work(connection);
P
Philipp Reisner 已提交
2114
		while (!list_empty(&work_list)) {
2115 2116 2117
			w = list_first_entry(&work_list, struct drbd_work, list);
			list_del_init(&w->list);
			w->cb(w, 1);
P
Philipp Reisner 已提交
2118
		}
2119
		dequeue_work_batch(&connection->sender_work, &work_list);
2120
	} while (!list_empty(&work_list) || test_bit(DEVICE_WORK_PENDING, &connection->flags));
P
Philipp Reisner 已提交
2121

P
Philipp Reisner 已提交
2122
	rcu_read_lock();
2123 2124
	idr_for_each_entry(&connection->peer_devices, peer_device, vnr) {
		struct drbd_device *device = peer_device->device;
2125
		D_ASSERT(device, device->state.disk == D_DISKLESS && device->state.conn == C_STANDALONE);
2126
		kref_get(&device->kref);
P
Philipp Reisner 已提交
2127
		rcu_read_unlock();
2128
		drbd_device_cleanup(device);
2129
		kref_put(&device->kref, drbd_destroy_device);
P
Philipp Reisner 已提交
2130
		rcu_read_lock();
2131
	}
P
Philipp Reisner 已提交
2132
	rcu_read_unlock();
P
Philipp Reisner 已提交
2133 2134 2135

	return 0;
}