aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/block/drbd/drbd_int.h14
-rw-r--r--drivers/block/drbd/drbd_main.c8
-rw-r--r--drivers/block/drbd/drbd_nl.c2
-rw-r--r--drivers/block/drbd/drbd_receiver.c19
4 files changed, 25 insertions, 18 deletions
diff --git a/drivers/block/drbd/drbd_int.h b/drivers/block/drbd/drbd_int.h
index 37a25a6084dd..e09132483980 100644
--- a/drivers/block/drbd/drbd_int.h
+++ b/drivers/block/drbd/drbd_int.h
@@ -481,7 +481,8 @@ struct p_sizes {
481 u64 u_size; /* user requested size */ 481 u64 u_size; /* user requested size */
482 u64 c_size; /* current exported size */ 482 u64 c_size; /* current exported size */
483 u32 max_segment_size; /* Maximal size of a BIO */ 483 u32 max_segment_size; /* Maximal size of a BIO */
484 u32 queue_order_type; 484 u16 queue_order_type; /* not yet implemented in DRBD*/
485 u16 dds_flags; /* use enum dds_flags here. */
485} __packed; 486} __packed;
486 487
487struct p_state { 488struct p_state {
@@ -1081,6 +1082,11 @@ enum chg_state_flags {
1081 CS_ORDERED = CS_WAIT_COMPLETE + CS_SERIALIZE, 1082 CS_ORDERED = CS_WAIT_COMPLETE + CS_SERIALIZE,
1082}; 1083};
1083 1084
1085enum dds_flags {
1086 DDSF_FORCED = 1,
1087 DDSF_NO_RESYNC = 2, /* Do not run a resync for the new space */
1088};
1089
1084extern void drbd_init_set_defaults(struct drbd_conf *mdev); 1090extern void drbd_init_set_defaults(struct drbd_conf *mdev);
1085extern int drbd_change_state(struct drbd_conf *mdev, enum chg_state_flags f, 1091extern int drbd_change_state(struct drbd_conf *mdev, enum chg_state_flags f,
1086 union drbd_state mask, union drbd_state val); 1092 union drbd_state mask, union drbd_state val);
@@ -1113,7 +1119,7 @@ extern int drbd_send_protocol(struct drbd_conf *mdev);
1113extern int drbd_send_uuids(struct drbd_conf *mdev); 1119extern int drbd_send_uuids(struct drbd_conf *mdev);
1114extern int drbd_send_uuids_skip_initial_sync(struct drbd_conf *mdev); 1120extern int drbd_send_uuids_skip_initial_sync(struct drbd_conf *mdev);
1115extern int drbd_send_sync_uuid(struct drbd_conf *mdev, u64 val); 1121extern int drbd_send_sync_uuid(struct drbd_conf *mdev, u64 val);
1116extern int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply); 1122extern int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply, enum dds_flags flags);
1117extern int _drbd_send_state(struct drbd_conf *mdev); 1123extern int _drbd_send_state(struct drbd_conf *mdev);
1118extern int drbd_send_state(struct drbd_conf *mdev); 1124extern int drbd_send_state(struct drbd_conf *mdev);
1119extern int _drbd_send_cmd(struct drbd_conf *mdev, struct socket *sock, 1125extern int _drbd_send_cmd(struct drbd_conf *mdev, struct socket *sock,
@@ -1382,10 +1388,6 @@ extern void drbd_suspend_io(struct drbd_conf *mdev);
1382extern void drbd_resume_io(struct drbd_conf *mdev); 1388extern void drbd_resume_io(struct drbd_conf *mdev);
1383extern char *ppsize(char *buf, unsigned long long size); 1389extern char *ppsize(char *buf, unsigned long long size);
1384extern sector_t drbd_new_dev_size(struct drbd_conf *, struct drbd_backing_dev *, int); 1390extern sector_t drbd_new_dev_size(struct drbd_conf *, struct drbd_backing_dev *, int);
1385enum dds_flags {
1386 DDSF_FORCED = 1,
1387 DDSF_NO_RESYNC = 2, /* Do not run a resync for the new space */
1388};
1389enum determine_dev_size { dev_size_error = -1, unchanged = 0, shrunk = 1, grew = 2 }; 1391enum determine_dev_size { dev_size_error = -1, unchanged = 0, shrunk = 1, grew = 2 };
1390extern enum determine_dev_size drbd_determin_dev_size(struct drbd_conf *, enum dds_flags) __must_hold(local); 1392extern enum determine_dev_size drbd_determin_dev_size(struct drbd_conf *, enum dds_flags) __must_hold(local);
1391extern void resync_after_online_grow(struct drbd_conf *); 1393extern void resync_after_online_grow(struct drbd_conf *);
diff --git a/drivers/block/drbd/drbd_main.c b/drivers/block/drbd/drbd_main.c
index 65c2a65d3d64..a478dad82dae 100644
--- a/drivers/block/drbd/drbd_main.c
+++ b/drivers/block/drbd/drbd_main.c
@@ -1240,7 +1240,7 @@ static void after_state_ch(struct drbd_conf *mdev, union drbd_state os,
1240 os.disk == D_ATTACHING && ns.disk == D_NEGOTIATING) { 1240 os.disk == D_ATTACHING && ns.disk == D_NEGOTIATING) {
1241 kfree(mdev->p_uuid); /* We expect to receive up-to-date UUIDs soon. */ 1241 kfree(mdev->p_uuid); /* We expect to receive up-to-date UUIDs soon. */
1242 mdev->p_uuid = NULL; /* ...to not use the old ones in the mean time */ 1242 mdev->p_uuid = NULL; /* ...to not use the old ones in the mean time */
1243 drbd_send_sizes(mdev, 0); /* to start sync... */ 1243 drbd_send_sizes(mdev, 0, 0); /* to start sync... */
1244 drbd_send_uuids(mdev); 1244 drbd_send_uuids(mdev);
1245 drbd_send_state(mdev); 1245 drbd_send_state(mdev);
1246 } 1246 }
@@ -1763,7 +1763,7 @@ int drbd_send_sync_uuid(struct drbd_conf *mdev, u64 val)
1763 (struct p_header *)&p, sizeof(p)); 1763 (struct p_header *)&p, sizeof(p));
1764} 1764}
1765 1765
1766int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply) 1766int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply, enum dds_flags flags)
1767{ 1767{
1768 struct p_sizes p; 1768 struct p_sizes p;
1769 sector_t d_size, u_size; 1769 sector_t d_size, u_size;
@@ -1775,7 +1775,6 @@ int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply)
1775 d_size = drbd_get_max_capacity(mdev->ldev); 1775 d_size = drbd_get_max_capacity(mdev->ldev);
1776 u_size = mdev->ldev->dc.disk_size; 1776 u_size = mdev->ldev->dc.disk_size;
1777 q_order_type = drbd_queue_order_type(mdev); 1777 q_order_type = drbd_queue_order_type(mdev);
1778 p.queue_order_type = cpu_to_be32(drbd_queue_order_type(mdev));
1779 put_ldev(mdev); 1778 put_ldev(mdev);
1780 } else { 1779 } else {
1781 d_size = 0; 1780 d_size = 0;
@@ -1787,7 +1786,8 @@ int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply)
1787 p.u_size = cpu_to_be64(u_size); 1786 p.u_size = cpu_to_be64(u_size);
1788 p.c_size = cpu_to_be64(trigger_reply ? 0 : drbd_get_capacity(mdev->this_bdev)); 1787 p.c_size = cpu_to_be64(trigger_reply ? 0 : drbd_get_capacity(mdev->this_bdev));
1789 p.max_segment_size = cpu_to_be32(queue_max_segment_size(mdev->rq_queue)); 1788 p.max_segment_size = cpu_to_be32(queue_max_segment_size(mdev->rq_queue));
1790 p.queue_order_type = cpu_to_be32(q_order_type); 1789 p.queue_order_type = cpu_to_be16(q_order_type);
1790 p.dds_flags = cpu_to_be16(flags);
1791 1791
1792 ok = drbd_send_cmd(mdev, USE_DATA_SOCKET, P_SIZES, 1792 ok = drbd_send_cmd(mdev, USE_DATA_SOCKET, P_SIZES,
1793 (struct p_header *)&p, sizeof(p)); 1793 (struct p_header *)&p, sizeof(p));
diff --git a/drivers/block/drbd/drbd_nl.c b/drivers/block/drbd/drbd_nl.c
index 360e506426b0..6f7933376a11 100644
--- a/drivers/block/drbd/drbd_nl.c
+++ b/drivers/block/drbd/drbd_nl.c
@@ -1521,7 +1521,7 @@ static int drbd_nl_resize(struct drbd_conf *mdev, struct drbd_nl_cfg_req *nlp,
1521 set_bit(RESIZE_PENDING, &mdev->flags); 1521 set_bit(RESIZE_PENDING, &mdev->flags);
1522 1522
1523 drbd_send_uuids(mdev); 1523 drbd_send_uuids(mdev);
1524 drbd_send_sizes(mdev, 1); 1524 drbd_send_sizes(mdev, 1, 0);
1525 } 1525 }
1526 1526
1527 fail: 1527 fail:
diff --git a/drivers/block/drbd/drbd_receiver.c b/drivers/block/drbd/drbd_receiver.c
index 6876041fc3d8..11b1bafde28b 100644
--- a/drivers/block/drbd/drbd_receiver.c
+++ b/drivers/block/drbd/drbd_receiver.c
@@ -902,7 +902,7 @@ retry:
902 if (!drbd_send_protocol(mdev)) 902 if (!drbd_send_protocol(mdev))
903 return -1; 903 return -1;
904 drbd_send_sync_param(mdev, &mdev->sync_conf); 904 drbd_send_sync_param(mdev, &mdev->sync_conf);
905 drbd_send_sizes(mdev, 0); 905 drbd_send_sizes(mdev, 0, 0);
906 drbd_send_uuids(mdev); 906 drbd_send_uuids(mdev);
907 drbd_send_state(mdev); 907 drbd_send_state(mdev);
908 clear_bit(USE_DEGR_WFC_T, &mdev->flags); 908 clear_bit(USE_DEGR_WFC_T, &mdev->flags);
@@ -2866,6 +2866,7 @@ static int receive_sizes(struct drbd_conf *mdev, struct p_header *h)
2866 unsigned int max_seg_s; 2866 unsigned int max_seg_s;
2867 sector_t p_size, p_usize, my_usize; 2867 sector_t p_size, p_usize, my_usize;
2868 int ldsc = 0; /* local disk size changed */ 2868 int ldsc = 0; /* local disk size changed */
2869 enum dds_flags ddsf;
2869 2870
2870 ERR_IF(h->length != (sizeof(*p)-sizeof(*h))) return FALSE; 2871 ERR_IF(h->length != (sizeof(*p)-sizeof(*h))) return FALSE;
2871 if (drbd_recv(mdev, h->payload, h->length) != h->length) 2872 if (drbd_recv(mdev, h->payload, h->length) != h->length)
@@ -2921,8 +2922,9 @@ static int receive_sizes(struct drbd_conf *mdev, struct p_header *h)
2921 } 2922 }
2922#undef min_not_zero 2923#undef min_not_zero
2923 2924
2925 ddsf = be16_to_cpu(p->dds_flags);
2924 if (get_ldev(mdev)) { 2926 if (get_ldev(mdev)) {
2925 dd = drbd_determin_dev_size(mdev, 0); 2927 dd = drbd_determin_dev_size(mdev, ddsf);
2926 put_ldev(mdev); 2928 put_ldev(mdev);
2927 if (dd == dev_size_error) 2929 if (dd == dev_size_error)
2928 return FALSE; 2930 return FALSE;
@@ -2942,7 +2944,7 @@ static int receive_sizes(struct drbd_conf *mdev, struct p_header *h)
2942 if (max_seg_s != queue_max_segment_size(mdev->rq_queue)) 2944 if (max_seg_s != queue_max_segment_size(mdev->rq_queue))
2943 drbd_setup_queue_param(mdev, max_seg_s); 2945 drbd_setup_queue_param(mdev, max_seg_s);
2944 2946
2945 drbd_setup_order_type(mdev, be32_to_cpu(p->queue_order_type)); 2947 drbd_setup_order_type(mdev, be16_to_cpu(p->queue_order_type));
2946 put_ldev(mdev); 2948 put_ldev(mdev);
2947 } 2949 }
2948 2950
@@ -2951,14 +2953,17 @@ static int receive_sizes(struct drbd_conf *mdev, struct p_header *h)
2951 drbd_get_capacity(mdev->this_bdev) || ldsc) { 2953 drbd_get_capacity(mdev->this_bdev) || ldsc) {
2952 /* we have different sizes, probably peer 2954 /* we have different sizes, probably peer
2953 * needs to know my new size... */ 2955 * needs to know my new size... */
2954 drbd_send_sizes(mdev, 0); 2956 drbd_send_sizes(mdev, 0, ddsf);
2955 } 2957 }
2956 if (test_and_clear_bit(RESIZE_PENDING, &mdev->flags) || 2958 if (test_and_clear_bit(RESIZE_PENDING, &mdev->flags) ||
2957 (dd == grew && mdev->state.conn == C_CONNECTED)) { 2959 (dd == grew && mdev->state.conn == C_CONNECTED)) {
2958 if (mdev->state.pdsk >= D_INCONSISTENT && 2960 if (mdev->state.pdsk >= D_INCONSISTENT &&
2959 mdev->state.disk >= D_INCONSISTENT) 2961 mdev->state.disk >= D_INCONSISTENT) {
2960 resync_after_online_grow(mdev); 2962 if (ddsf & DDSF_NO_RESYNC)
2961 else 2963 dev_info(DEV, "Resync of new storage suppressed with --assume-clean\n");
2964 else
2965 resync_after_online_grow(mdev);
2966 } else
2962 set_bit(RESYNC_AFTER_NEG, &mdev->flags); 2967 set_bit(RESYNC_AFTER_NEG, &mdev->flags);
2963 } 2968 }
2964 } 2969 }