aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/block/drbd/drbd_worker.c
diff options
context:
space:
mode:
authorAndreas Gruenbacher <agruen@linbit.com>2011-05-12 05:15:34 -0400
committerPhilipp Reisner <philipp.reisner@linbit.com>2012-11-08 10:55:51 -0500
commit95f8efd08bcce65df994049a292b94e56c7ada67 (patch)
treea4a943aea52b65adc4ddabf736a30f66f83f6ed0 /drivers/block/drbd/drbd_worker.c
parent69ef82dea4c34e4a0541fc3f415b0fef70fe12b0 (diff)
drbd: Fix the upper limit of resync-after
The 32-bit resync_after netlink field takes a device minor number as parameter, which is no longer limited to 255. We cannot statically verify which device numbers are valid, so set the ummer limit to the highest possible signed 32-bit integer. Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com> Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
Diffstat (limited to 'drivers/block/drbd/drbd_worker.c')
-rw-r--r--drivers/block/drbd/drbd_worker.c26
1 files changed, 13 insertions, 13 deletions
diff --git a/drivers/block/drbd/drbd_worker.c b/drivers/block/drbd/drbd_worker.c
index ec8f4245ef9a..6410c55831e0 100644
--- a/drivers/block/drbd/drbd_worker.c
+++ b/drivers/block/drbd/drbd_worker.c
@@ -57,7 +57,7 @@ static int w_make_ov_request(struct drbd_work *w, int cancel);
57 57
58/* About the global_state_lock 58/* About the global_state_lock
59 Each state transition on an device holds a read lock. In case we have 59 Each state transition on an device holds a read lock. In case we have
60 to evaluate the sync after dependencies, we grab a write lock, because 60 to evaluate the resync after dependencies, we grab a write lock, because
61 we need stable states on all devices for that. */ 61 we need stable states on all devices for that. */
62rwlock_t global_state_lock; 62rwlock_t global_state_lock;
63 63
@@ -1340,17 +1340,17 @@ int w_restart_disk_io(struct drbd_work *w, int cancel)
1340static int _drbd_may_sync_now(struct drbd_conf *mdev) 1340static int _drbd_may_sync_now(struct drbd_conf *mdev)
1341{ 1341{
1342 struct drbd_conf *odev = mdev; 1342 struct drbd_conf *odev = mdev;
1343 int ra; 1343 int resync_after;
1344 1344
1345 while (1) { 1345 while (1) {
1346 if (!odev->ldev) 1346 if (!odev->ldev)
1347 return 1; 1347 return 1;
1348 rcu_read_lock(); 1348 rcu_read_lock();
1349 ra = rcu_dereference(odev->ldev->disk_conf)->resync_after; 1349 resync_after = rcu_dereference(odev->ldev->disk_conf)->resync_after;
1350 rcu_read_unlock(); 1350 rcu_read_unlock();
1351 if (ra == -1) 1351 if (resync_after == -1)
1352 return 1; 1352 return 1;
1353 odev = minor_to_mdev(ra); 1353 odev = minor_to_mdev(resync_after);
1354 if (!expect(odev)) 1354 if (!expect(odev))
1355 return 1; 1355 return 1;
1356 if ((odev->state.conn >= C_SYNC_SOURCE && 1356 if ((odev->state.conn >= C_SYNC_SOURCE &&
@@ -1426,36 +1426,36 @@ void suspend_other_sg(struct drbd_conf *mdev)
1426} 1426}
1427 1427
1428/* caller must hold global_state_lock */ 1428/* caller must hold global_state_lock */
1429enum drbd_ret_code drbd_sync_after_valid(struct drbd_conf *mdev, int o_minor) 1429enum drbd_ret_code drbd_resync_after_valid(struct drbd_conf *mdev, int o_minor)
1430{ 1430{
1431 struct drbd_conf *odev; 1431 struct drbd_conf *odev;
1432 int ra; 1432 int resync_after;
1433 1433
1434 if (o_minor == -1) 1434 if (o_minor == -1)
1435 return NO_ERROR; 1435 return NO_ERROR;
1436 if (o_minor < -1 || minor_to_mdev(o_minor) == NULL) 1436 if (o_minor < -1 || minor_to_mdev(o_minor) == NULL)
1437 return ERR_SYNC_AFTER; 1437 return ERR_RESYNC_AFTER;
1438 1438
1439 /* check for loops */ 1439 /* check for loops */
1440 odev = minor_to_mdev(o_minor); 1440 odev = minor_to_mdev(o_minor);
1441 while (1) { 1441 while (1) {
1442 if (odev == mdev) 1442 if (odev == mdev)
1443 return ERR_SYNC_AFTER_CYCLE; 1443 return ERR_RESYNC_AFTER_CYCLE;
1444 1444
1445 rcu_read_lock(); 1445 rcu_read_lock();
1446 ra = rcu_dereference(odev->ldev->disk_conf)->resync_after; 1446 resync_after = rcu_dereference(odev->ldev->disk_conf)->resync_after;
1447 rcu_read_unlock(); 1447 rcu_read_unlock();
1448 /* dependency chain ends here, no cycles. */ 1448 /* dependency chain ends here, no cycles. */
1449 if (ra == -1) 1449 if (resync_after == -1)
1450 return NO_ERROR; 1450 return NO_ERROR;
1451 1451
1452 /* follow the dependency chain */ 1452 /* follow the dependency chain */
1453 odev = minor_to_mdev(ra); 1453 odev = minor_to_mdev(resync_after);
1454 } 1454 }
1455} 1455}
1456 1456
1457/* caller must hold global_state_lock */ 1457/* caller must hold global_state_lock */
1458void drbd_sync_after_changed(struct drbd_conf *mdev) 1458void drbd_resync_after_changed(struct drbd_conf *mdev)
1459{ 1459{
1460 int changes; 1460 int changes;
1461 1461