aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/block/drbd/drbd_int.h74
-rw-r--r--drivers/block/drbd/drbd_main.c79
-rw-r--r--drivers/block/drbd/drbd_receiver.c94
-rw-r--r--drivers/block/drbd/drbd_worker.c2
-rw-r--r--include/linux/drbd.h2
5 files changed, 139 insertions, 112 deletions
diff --git a/drivers/block/drbd/drbd_int.h b/drivers/block/drbd/drbd_int.h
index 0fedcc0b8dc9..3f10efc2ac14 100644
--- a/drivers/block/drbd/drbd_int.h
+++ b/drivers/block/drbd/drbd_int.h
@@ -337,13 +337,25 @@ static inline void bm_xfer_ctx_bit_to_word_offset(struct bm_xfer_ctx *c)
337 * NOTE that the payload starts at a long aligned offset, 337 * NOTE that the payload starts at a long aligned offset,
338 * regardless of 32 or 64 bit arch! 338 * regardless of 32 or 64 bit arch!
339 */ 339 */
340struct p_header { 340struct p_header80 {
341 u32 magic; 341 u32 magic;
342 u16 command; 342 u16 command;
343 u16 length; /* bytes of data after this header */ 343 u16 length; /* bytes of data after this header */
344 u8 payload[0]; 344 u8 payload[0];
345} __packed; 345} __packed;
346/* 8 bytes. packet FIXED for the next century! */ 346
347/* Header for big packets, Used for data packets exceeding 64kB */
348struct p_header95 {
349 u16 magic; /* use DRBD_MAGIC_BIG here */
350 u16 command;
351 u32 length;
352 u8 payload[0];
353} __packed;
354
355union p_header {
356 struct p_header80 h80;
357 struct p_header95 h95;
358};
347 359
348/* 360/*
349 * short commands, packets without payload, plain p_header: 361 * short commands, packets without payload, plain p_header:
@@ -367,7 +379,7 @@ struct p_header {
367#define DP_MAY_SET_IN_SYNC 4 379#define DP_MAY_SET_IN_SYNC 4
368 380
369struct p_data { 381struct p_data {
370 struct p_header head; 382 union p_header head;
371 u64 sector; /* 64 bits sector number */ 383 u64 sector; /* 64 bits sector number */
372 u64 block_id; /* to identify the request in protocol B&C */ 384 u64 block_id; /* to identify the request in protocol B&C */
373 u32 seq_num; 385 u32 seq_num;
@@ -383,7 +395,7 @@ struct p_data {
383 * P_DATA_REQUEST, P_RS_DATA_REQUEST 395 * P_DATA_REQUEST, P_RS_DATA_REQUEST
384 */ 396 */
385struct p_block_ack { 397struct p_block_ack {
386 struct p_header head; 398 struct p_header80 head;
387 u64 sector; 399 u64 sector;
388 u64 block_id; 400 u64 block_id;
389 u32 blksize; 401 u32 blksize;
@@ -392,7 +404,7 @@ struct p_block_ack {
392 404
393 405
394struct p_block_req { 406struct p_block_req {
395 struct p_header head; 407 struct p_header80 head;
396 u64 sector; 408 u64 sector;
397 u64 block_id; 409 u64 block_id;
398 u32 blksize; 410 u32 blksize;
@@ -409,7 +421,7 @@ struct p_block_req {
409 */ 421 */
410 422
411struct p_handshake { 423struct p_handshake {
412 struct p_header head; /* 8 bytes */ 424 struct p_header80 head; /* 8 bytes */
413 u32 protocol_min; 425 u32 protocol_min;
414 u32 feature_flags; 426 u32 feature_flags;
415 u32 protocol_max; 427 u32 protocol_max;
@@ -424,19 +436,19 @@ struct p_handshake {
424/* 80 bytes, FIXED for the next century */ 436/* 80 bytes, FIXED for the next century */
425 437
426struct p_barrier { 438struct p_barrier {
427 struct p_header head; 439 struct p_header80 head;
428 u32 barrier; /* barrier number _handle_ only */ 440 u32 barrier; /* barrier number _handle_ only */
429 u32 pad; /* to multiple of 8 Byte */ 441 u32 pad; /* to multiple of 8 Byte */
430} __packed; 442} __packed;
431 443
432struct p_barrier_ack { 444struct p_barrier_ack {
433 struct p_header head; 445 struct p_header80 head;
434 u32 barrier; 446 u32 barrier;
435 u32 set_size; 447 u32 set_size;
436} __packed; 448} __packed;
437 449
438struct p_rs_param { 450struct p_rs_param {
439 struct p_header head; 451 struct p_header80 head;
440 u32 rate; 452 u32 rate;
441 453
442 /* Since protocol version 88 and higher. */ 454 /* Since protocol version 88 and higher. */
@@ -444,7 +456,7 @@ struct p_rs_param {
444} __packed; 456} __packed;
445 457
446struct p_rs_param_89 { 458struct p_rs_param_89 {
447 struct p_header head; 459 struct p_header80 head;
448 u32 rate; 460 u32 rate;
449 /* protocol version 89: */ 461 /* protocol version 89: */
450 char verify_alg[SHARED_SECRET_MAX]; 462 char verify_alg[SHARED_SECRET_MAX];
@@ -452,7 +464,7 @@ struct p_rs_param_89 {
452} __packed; 464} __packed;
453 465
454struct p_rs_param_95 { 466struct p_rs_param_95 {
455 struct p_header head; 467 struct p_header80 head;
456 u32 rate; 468 u32 rate;
457 char verify_alg[SHARED_SECRET_MAX]; 469 char verify_alg[SHARED_SECRET_MAX];
458 char csums_alg[SHARED_SECRET_MAX]; 470 char csums_alg[SHARED_SECRET_MAX];
@@ -468,7 +480,7 @@ enum drbd_conn_flags {
468}; 480};
469 481
470struct p_protocol { 482struct p_protocol {
471 struct p_header head; 483 struct p_header80 head;
472 u32 protocol; 484 u32 protocol;
473 u32 after_sb_0p; 485 u32 after_sb_0p;
474 u32 after_sb_1p; 486 u32 after_sb_1p;
@@ -482,17 +494,17 @@ struct p_protocol {
482} __packed; 494} __packed;
483 495
484struct p_uuids { 496struct p_uuids {
485 struct p_header head; 497 struct p_header80 head;
486 u64 uuid[UI_EXTENDED_SIZE]; 498 u64 uuid[UI_EXTENDED_SIZE];
487} __packed; 499} __packed;
488 500
489struct p_rs_uuid { 501struct p_rs_uuid {
490 struct p_header head; 502 struct p_header80 head;
491 u64 uuid; 503 u64 uuid;
492} __packed; 504} __packed;
493 505
494struct p_sizes { 506struct p_sizes {
495 struct p_header head; 507 struct p_header80 head;
496 u64 d_size; /* size of disk */ 508 u64 d_size; /* size of disk */
497 u64 u_size; /* user requested size */ 509 u64 u_size; /* user requested size */
498 u64 c_size; /* current exported size */ 510 u64 c_size; /* current exported size */
@@ -502,18 +514,18 @@ struct p_sizes {
502} __packed; 514} __packed;
503 515
504struct p_state { 516struct p_state {
505 struct p_header head; 517 struct p_header80 head;
506 u32 state; 518 u32 state;
507} __packed; 519} __packed;
508 520
509struct p_req_state { 521struct p_req_state {
510 struct p_header head; 522 struct p_header80 head;
511 u32 mask; 523 u32 mask;
512 u32 val; 524 u32 val;
513} __packed; 525} __packed;
514 526
515struct p_req_state_reply { 527struct p_req_state_reply {
516 struct p_header head; 528 struct p_header80 head;
517 u32 retcode; 529 u32 retcode;
518} __packed; 530} __packed;
519 531
@@ -528,7 +540,7 @@ struct p_drbd06_param {
528} __packed; 540} __packed;
529 541
530struct p_discard { 542struct p_discard {
531 struct p_header head; 543 struct p_header80 head;
532 u64 block_id; 544 u64 block_id;
533 u32 seq_num; 545 u32 seq_num;
534 u32 pad; 546 u32 pad;
@@ -544,7 +556,7 @@ enum drbd_bitmap_code {
544}; 556};
545 557
546struct p_compressed_bm { 558struct p_compressed_bm {
547 struct p_header head; 559 struct p_header80 head;
548 /* (encoding & 0x0f): actual encoding, see enum drbd_bitmap_code 560 /* (encoding & 0x0f): actual encoding, see enum drbd_bitmap_code
549 * (encoding & 0x80): polarity (set/unset) of first runlength 561 * (encoding & 0x80): polarity (set/unset) of first runlength
550 * ((encoding >> 4) & 0x07): pad_bits, number of trailing zero bits 562 * ((encoding >> 4) & 0x07): pad_bits, number of trailing zero bits
@@ -555,10 +567,10 @@ struct p_compressed_bm {
555 u8 code[0]; 567 u8 code[0];
556} __packed; 568} __packed;
557 569
558struct p_delay_probe { 570struct p_delay_probe93 {
559 struct p_header head; 571 struct p_header80 head;
560 u32 seq_num; /* sequence number to match the two probe packets */ 572 u32 seq_num; /* sequence number to match the two probe packets */
561 u32 offset; /* usecs the probe got sent after the reference time point */ 573 u32 offset; /* usecs the probe got sent after the reference time point */
562} __packed; 574} __packed;
563 575
564/* DCBP: Drbd Compressed Bitmap Packet ... */ 576/* DCBP: Drbd Compressed Bitmap Packet ... */
@@ -605,7 +617,7 @@ DCBP_set_pad_bits(struct p_compressed_bm *p, int n)
605 * so we need to use the fixed size 4KiB page size 617 * so we need to use the fixed size 4KiB page size
606 * most architechtures have used for a long time. 618 * most architechtures have used for a long time.
607 */ 619 */
608#define BM_PACKET_PAYLOAD_BYTES (4096 - sizeof(struct p_header)) 620#define BM_PACKET_PAYLOAD_BYTES (4096 - sizeof(struct p_header80))
609#define BM_PACKET_WORDS (BM_PACKET_PAYLOAD_BYTES/sizeof(long)) 621#define BM_PACKET_WORDS (BM_PACKET_PAYLOAD_BYTES/sizeof(long))
610#define BM_PACKET_VLI_BYTES_MAX (4096 - sizeof(struct p_compressed_bm)) 622#define BM_PACKET_VLI_BYTES_MAX (4096 - sizeof(struct p_compressed_bm))
611#if (PAGE_SIZE < 4096) 623#if (PAGE_SIZE < 4096)
@@ -614,7 +626,7 @@ DCBP_set_pad_bits(struct p_compressed_bm *p, int n)
614#endif 626#endif
615 627
616union p_polymorph { 628union p_polymorph {
617 struct p_header header; 629 struct p_header80 header;
618 struct p_handshake handshake; 630 struct p_handshake handshake;
619 struct p_data data; 631 struct p_data data;
620 struct p_block_ack block_ack; 632 struct p_block_ack block_ack;
@@ -1188,12 +1200,12 @@ extern int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply, enum dds_f
1188extern int _drbd_send_state(struct drbd_conf *mdev); 1200extern int _drbd_send_state(struct drbd_conf *mdev);
1189extern int drbd_send_state(struct drbd_conf *mdev); 1201extern int drbd_send_state(struct drbd_conf *mdev);
1190extern int _drbd_send_cmd(struct drbd_conf *mdev, struct socket *sock, 1202extern int _drbd_send_cmd(struct drbd_conf *mdev, struct socket *sock,
1191 enum drbd_packets cmd, struct p_header *h, 1203 enum drbd_packets cmd, struct p_header80 *h,
1192 size_t size, unsigned msg_flags); 1204 size_t size, unsigned msg_flags);
1193#define USE_DATA_SOCKET 1 1205#define USE_DATA_SOCKET 1
1194#define USE_META_SOCKET 0 1206#define USE_META_SOCKET 0
1195extern int drbd_send_cmd(struct drbd_conf *mdev, int use_data_socket, 1207extern int drbd_send_cmd(struct drbd_conf *mdev, int use_data_socket,
1196 enum drbd_packets cmd, struct p_header *h, 1208 enum drbd_packets cmd, struct p_header80 *h,
1197 size_t size); 1209 size_t size);
1198extern int drbd_send_cmd2(struct drbd_conf *mdev, enum drbd_packets cmd, 1210extern int drbd_send_cmd2(struct drbd_conf *mdev, enum drbd_packets cmd,
1199 char *data, size_t size); 1211 char *data, size_t size);
@@ -1936,19 +1948,19 @@ static inline void request_ping(struct drbd_conf *mdev)
1936static inline int drbd_send_short_cmd(struct drbd_conf *mdev, 1948static inline int drbd_send_short_cmd(struct drbd_conf *mdev,
1937 enum drbd_packets cmd) 1949 enum drbd_packets cmd)
1938{ 1950{
1939 struct p_header h; 1951 struct p_header80 h;
1940 return drbd_send_cmd(mdev, USE_DATA_SOCKET, cmd, &h, sizeof(h)); 1952 return drbd_send_cmd(mdev, USE_DATA_SOCKET, cmd, &h, sizeof(h));
1941} 1953}
1942 1954
1943static inline int drbd_send_ping(struct drbd_conf *mdev) 1955static inline int drbd_send_ping(struct drbd_conf *mdev)
1944{ 1956{
1945 struct p_header h; 1957 struct p_header80 h;
1946 return drbd_send_cmd(mdev, USE_META_SOCKET, P_PING, &h, sizeof(h)); 1958 return drbd_send_cmd(mdev, USE_META_SOCKET, P_PING, &h, sizeof(h));
1947} 1959}
1948 1960
1949static inline int drbd_send_ping_ack(struct drbd_conf *mdev) 1961static inline int drbd_send_ping_ack(struct drbd_conf *mdev)
1950{ 1962{
1951 struct p_header h; 1963 struct p_header80 h;
1952 return drbd_send_cmd(mdev, USE_META_SOCKET, P_PING_ACK, &h, sizeof(h)); 1964 return drbd_send_cmd(mdev, USE_META_SOCKET, P_PING_ACK, &h, sizeof(h));
1953} 1965}
1954 1966
diff --git a/drivers/block/drbd/drbd_main.c b/drivers/block/drbd/drbd_main.c
index db93eee7e543..f3f4ea9c5eb9 100644
--- a/drivers/block/drbd/drbd_main.c
+++ b/drivers/block/drbd/drbd_main.c
@@ -1647,7 +1647,7 @@ void drbd_thread_current_set_cpu(struct drbd_conf *mdev)
1647 1647
1648/* the appropriate socket mutex must be held already */ 1648/* the appropriate socket mutex must be held already */
1649int _drbd_send_cmd(struct drbd_conf *mdev, struct socket *sock, 1649int _drbd_send_cmd(struct drbd_conf *mdev, struct socket *sock,
1650 enum drbd_packets cmd, struct p_header *h, 1650 enum drbd_packets cmd, struct p_header80 *h,
1651 size_t size, unsigned msg_flags) 1651 size_t size, unsigned msg_flags)
1652{ 1652{
1653 int sent, ok; 1653 int sent, ok;
@@ -1657,7 +1657,7 @@ int _drbd_send_cmd(struct drbd_conf *mdev, struct socket *sock,
1657 1657
1658 h->magic = BE_DRBD_MAGIC; 1658 h->magic = BE_DRBD_MAGIC;
1659 h->command = cpu_to_be16(cmd); 1659 h->command = cpu_to_be16(cmd);
1660 h->length = cpu_to_be16(size-sizeof(struct p_header)); 1660 h->length = cpu_to_be16(size-sizeof(struct p_header80));
1661 1661
1662 sent = drbd_send(mdev, sock, h, size, msg_flags); 1662 sent = drbd_send(mdev, sock, h, size, msg_flags);
1663 1663
@@ -1672,7 +1672,7 @@ int _drbd_send_cmd(struct drbd_conf *mdev, struct socket *sock,
1672 * when we hold the appropriate socket mutex. 1672 * when we hold the appropriate socket mutex.
1673 */ 1673 */
1674int drbd_send_cmd(struct drbd_conf *mdev, int use_data_socket, 1674int drbd_send_cmd(struct drbd_conf *mdev, int use_data_socket,
1675 enum drbd_packets cmd, struct p_header *h, size_t size) 1675 enum drbd_packets cmd, struct p_header80 *h, size_t size)
1676{ 1676{
1677 int ok = 0; 1677 int ok = 0;
1678 struct socket *sock; 1678 struct socket *sock;
@@ -1700,7 +1700,7 @@ int drbd_send_cmd(struct drbd_conf *mdev, int use_data_socket,
1700int drbd_send_cmd2(struct drbd_conf *mdev, enum drbd_packets cmd, char *data, 1700int drbd_send_cmd2(struct drbd_conf *mdev, enum drbd_packets cmd, char *data,
1701 size_t size) 1701 size_t size)
1702{ 1702{
1703 struct p_header h; 1703 struct p_header80 h;
1704 int ok; 1704 int ok;
1705 1705
1706 h.magic = BE_DRBD_MAGIC; 1706 h.magic = BE_DRBD_MAGIC;
@@ -1807,7 +1807,7 @@ int drbd_send_protocol(struct drbd_conf *mdev)
1807 strcpy(p->integrity_alg, mdev->net_conf->integrity_alg); 1807 strcpy(p->integrity_alg, mdev->net_conf->integrity_alg);
1808 1808
1809 rv = drbd_send_cmd(mdev, USE_DATA_SOCKET, P_PROTOCOL, 1809 rv = drbd_send_cmd(mdev, USE_DATA_SOCKET, P_PROTOCOL,
1810 (struct p_header *)p, size); 1810 (struct p_header80 *)p, size);
1811 kfree(p); 1811 kfree(p);
1812 return rv; 1812 return rv;
1813} 1813}
@@ -1833,7 +1833,7 @@ int _drbd_send_uuids(struct drbd_conf *mdev, u64 uuid_flags)
1833 put_ldev(mdev); 1833 put_ldev(mdev);
1834 1834
1835 return drbd_send_cmd(mdev, USE_DATA_SOCKET, P_UUIDS, 1835 return drbd_send_cmd(mdev, USE_DATA_SOCKET, P_UUIDS,
1836 (struct p_header *)&p, sizeof(p)); 1836 (struct p_header80 *)&p, sizeof(p));
1837} 1837}
1838 1838
1839int drbd_send_uuids(struct drbd_conf *mdev) 1839int drbd_send_uuids(struct drbd_conf *mdev)
@@ -1854,7 +1854,7 @@ int drbd_send_sync_uuid(struct drbd_conf *mdev, u64 val)
1854 p.uuid = cpu_to_be64(val); 1854 p.uuid = cpu_to_be64(val);
1855 1855
1856 return drbd_send_cmd(mdev, USE_DATA_SOCKET, P_SYNC_UUID, 1856 return drbd_send_cmd(mdev, USE_DATA_SOCKET, P_SYNC_UUID,
1857 (struct p_header *)&p, sizeof(p)); 1857 (struct p_header80 *)&p, sizeof(p));
1858} 1858}
1859 1859
1860int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply, enum dds_flags flags) 1860int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply, enum dds_flags flags)
@@ -1884,7 +1884,7 @@ int drbd_send_sizes(struct drbd_conf *mdev, int trigger_reply, enum dds_flags fl
1884 p.dds_flags = cpu_to_be16(flags); 1884 p.dds_flags = cpu_to_be16(flags);
1885 1885
1886 ok = drbd_send_cmd(mdev, USE_DATA_SOCKET, P_SIZES, 1886 ok = drbd_send_cmd(mdev, USE_DATA_SOCKET, P_SIZES,
1887 (struct p_header *)&p, sizeof(p)); 1887 (struct p_header80 *)&p, sizeof(p));
1888 return ok; 1888 return ok;
1889} 1889}
1890 1890
@@ -1909,7 +1909,7 @@ int drbd_send_state(struct drbd_conf *mdev)
1909 1909
1910 if (likely(sock != NULL)) { 1910 if (likely(sock != NULL)) {
1911 ok = _drbd_send_cmd(mdev, sock, P_STATE, 1911 ok = _drbd_send_cmd(mdev, sock, P_STATE,
1912 (struct p_header *)&p, sizeof(p), 0); 1912 (struct p_header80 *)&p, sizeof(p), 0);
1913 } 1913 }
1914 1914
1915 mutex_unlock(&mdev->data.mutex); 1915 mutex_unlock(&mdev->data.mutex);
@@ -1927,7 +1927,7 @@ int drbd_send_state_req(struct drbd_conf *mdev,
1927 p.val = cpu_to_be32(val.i); 1927 p.val = cpu_to_be32(val.i);
1928 1928
1929 return drbd_send_cmd(mdev, USE_DATA_SOCKET, P_STATE_CHG_REQ, 1929 return drbd_send_cmd(mdev, USE_DATA_SOCKET, P_STATE_CHG_REQ,
1930 (struct p_header *)&p, sizeof(p)); 1930 (struct p_header80 *)&p, sizeof(p));
1931} 1931}
1932 1932
1933int drbd_send_sr_reply(struct drbd_conf *mdev, int retcode) 1933int drbd_send_sr_reply(struct drbd_conf *mdev, int retcode)
@@ -1937,7 +1937,7 @@ int drbd_send_sr_reply(struct drbd_conf *mdev, int retcode)
1937 p.retcode = cpu_to_be32(retcode); 1937 p.retcode = cpu_to_be32(retcode);
1938 1938
1939 return drbd_send_cmd(mdev, USE_META_SOCKET, P_STATE_CHG_REPLY, 1939 return drbd_send_cmd(mdev, USE_META_SOCKET, P_STATE_CHG_REPLY,
1940 (struct p_header *)&p, sizeof(p)); 1940 (struct p_header80 *)&p, sizeof(p));
1941} 1941}
1942 1942
1943int fill_bitmap_rle_bits(struct drbd_conf *mdev, 1943int fill_bitmap_rle_bits(struct drbd_conf *mdev,
@@ -2036,7 +2036,7 @@ int fill_bitmap_rle_bits(struct drbd_conf *mdev,
2036 2036
2037enum { OK, FAILED, DONE } 2037enum { OK, FAILED, DONE }
2038send_bitmap_rle_or_plain(struct drbd_conf *mdev, 2038send_bitmap_rle_or_plain(struct drbd_conf *mdev,
2039 struct p_header *h, struct bm_xfer_ctx *c) 2039 struct p_header80 *h, struct bm_xfer_ctx *c)
2040{ 2040{
2041 struct p_compressed_bm *p = (void*)h; 2041 struct p_compressed_bm *p = (void*)h;
2042 unsigned long num_words; 2042 unsigned long num_words;
@@ -2066,12 +2066,12 @@ send_bitmap_rle_or_plain(struct drbd_conf *mdev,
2066 if (len) 2066 if (len)
2067 drbd_bm_get_lel(mdev, c->word_offset, num_words, (unsigned long*)h->payload); 2067 drbd_bm_get_lel(mdev, c->word_offset, num_words, (unsigned long*)h->payload);
2068 ok = _drbd_send_cmd(mdev, mdev->data.socket, P_BITMAP, 2068 ok = _drbd_send_cmd(mdev, mdev->data.socket, P_BITMAP,
2069 h, sizeof(struct p_header) + len, 0); 2069 h, sizeof(struct p_header80) + len, 0);
2070 c->word_offset += num_words; 2070 c->word_offset += num_words;
2071 c->bit_offset = c->word_offset * BITS_PER_LONG; 2071 c->bit_offset = c->word_offset * BITS_PER_LONG;
2072 2072
2073 c->packets[1]++; 2073 c->packets[1]++;
2074 c->bytes[1] += sizeof(struct p_header) + len; 2074 c->bytes[1] += sizeof(struct p_header80) + len;
2075 2075
2076 if (c->bit_offset > c->bm_bits) 2076 if (c->bit_offset > c->bm_bits)
2077 c->bit_offset = c->bm_bits; 2077 c->bit_offset = c->bm_bits;
@@ -2087,14 +2087,14 @@ send_bitmap_rle_or_plain(struct drbd_conf *mdev,
2087int _drbd_send_bitmap(struct drbd_conf *mdev) 2087int _drbd_send_bitmap(struct drbd_conf *mdev)
2088{ 2088{
2089 struct bm_xfer_ctx c; 2089 struct bm_xfer_ctx c;
2090 struct p_header *p; 2090 struct p_header80 *p;
2091 int ret; 2091 int ret;
2092 2092
2093 ERR_IF(!mdev->bitmap) return FALSE; 2093 ERR_IF(!mdev->bitmap) return FALSE;
2094 2094
2095 /* maybe we should use some per thread scratch page, 2095 /* maybe we should use some per thread scratch page,
2096 * and allocate that during initial device creation? */ 2096 * and allocate that during initial device creation? */
2097 p = (struct p_header *) __get_free_page(GFP_NOIO); 2097 p = (struct p_header80 *) __get_free_page(GFP_NOIO);
2098 if (!p) { 2098 if (!p) {
2099 dev_err(DEV, "failed to allocate one page buffer in %s\n", __func__); 2099 dev_err(DEV, "failed to allocate one page buffer in %s\n", __func__);
2100 return FALSE; 2100 return FALSE;
@@ -2152,7 +2152,7 @@ int drbd_send_b_ack(struct drbd_conf *mdev, u32 barrier_nr, u32 set_size)
2152 if (mdev->state.conn < C_CONNECTED) 2152 if (mdev->state.conn < C_CONNECTED)
2153 return FALSE; 2153 return FALSE;
2154 ok = drbd_send_cmd(mdev, USE_META_SOCKET, P_BARRIER_ACK, 2154 ok = drbd_send_cmd(mdev, USE_META_SOCKET, P_BARRIER_ACK,
2155 (struct p_header *)&p, sizeof(p)); 2155 (struct p_header80 *)&p, sizeof(p));
2156 return ok; 2156 return ok;
2157} 2157}
2158 2158
@@ -2180,7 +2180,7 @@ static int _drbd_send_ack(struct drbd_conf *mdev, enum drbd_packets cmd,
2180 if (!mdev->meta.socket || mdev->state.conn < C_CONNECTED) 2180 if (!mdev->meta.socket || mdev->state.conn < C_CONNECTED)
2181 return FALSE; 2181 return FALSE;
2182 ok = drbd_send_cmd(mdev, USE_META_SOCKET, cmd, 2182 ok = drbd_send_cmd(mdev, USE_META_SOCKET, cmd,
2183 (struct p_header *)&p, sizeof(p)); 2183 (struct p_header80 *)&p, sizeof(p));
2184 return ok; 2184 return ok;
2185} 2185}
2186 2186
@@ -2188,8 +2188,8 @@ int drbd_send_ack_dp(struct drbd_conf *mdev, enum drbd_packets cmd,
2188 struct p_data *dp) 2188 struct p_data *dp)
2189{ 2189{
2190 const int header_size = sizeof(struct p_data) 2190 const int header_size = sizeof(struct p_data)
2191 - sizeof(struct p_header); 2191 - sizeof(struct p_header80);
2192 int data_size = ((struct p_header *)dp)->length - header_size; 2192 int data_size = ((struct p_header80 *)dp)->length - header_size;
2193 2193
2194 return _drbd_send_ack(mdev, cmd, dp->sector, cpu_to_be32(data_size), 2194 return _drbd_send_ack(mdev, cmd, dp->sector, cpu_to_be32(data_size),
2195 dp->block_id); 2195 dp->block_id);
@@ -2238,7 +2238,7 @@ int drbd_send_drequest(struct drbd_conf *mdev, int cmd,
2238 p.blksize = cpu_to_be32(size); 2238 p.blksize = cpu_to_be32(size);
2239 2239
2240 ok = drbd_send_cmd(mdev, USE_DATA_SOCKET, cmd, 2240 ok = drbd_send_cmd(mdev, USE_DATA_SOCKET, cmd,
2241 (struct p_header *)&p, sizeof(p)); 2241 (struct p_header80 *)&p, sizeof(p));
2242 return ok; 2242 return ok;
2243} 2243}
2244 2244
@@ -2256,7 +2256,7 @@ int drbd_send_drequest_csum(struct drbd_conf *mdev,
2256 2256
2257 p.head.magic = BE_DRBD_MAGIC; 2257 p.head.magic = BE_DRBD_MAGIC;
2258 p.head.command = cpu_to_be16(cmd); 2258 p.head.command = cpu_to_be16(cmd);
2259 p.head.length = cpu_to_be16(sizeof(p) - sizeof(struct p_header) + digest_size); 2259 p.head.length = cpu_to_be16(sizeof(p) - sizeof(struct p_header80) + digest_size);
2260 2260
2261 mutex_lock(&mdev->data.mutex); 2261 mutex_lock(&mdev->data.mutex);
2262 2262
@@ -2278,7 +2278,7 @@ int drbd_send_ov_request(struct drbd_conf *mdev, sector_t sector, int size)
2278 p.blksize = cpu_to_be32(size); 2278 p.blksize = cpu_to_be32(size);
2279 2279
2280 ok = drbd_send_cmd(mdev, USE_DATA_SOCKET, P_OV_REQUEST, 2280 ok = drbd_send_cmd(mdev, USE_DATA_SOCKET, P_OV_REQUEST,
2281 (struct p_header *)&p, sizeof(p)); 2281 (struct p_header80 *)&p, sizeof(p));
2282 return ok; 2282 return ok;
2283} 2283}
2284 2284
@@ -2447,10 +2447,17 @@ int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req)
2447 dgs = (mdev->agreed_pro_version >= 87 && mdev->integrity_w_tfm) ? 2447 dgs = (mdev->agreed_pro_version >= 87 && mdev->integrity_w_tfm) ?
2448 crypto_hash_digestsize(mdev->integrity_w_tfm) : 0; 2448 crypto_hash_digestsize(mdev->integrity_w_tfm) : 0;
2449 2449
2450 p.head.magic = BE_DRBD_MAGIC; 2450 if (req->size <= (1 << 15)) {
2451 p.head.command = cpu_to_be16(P_DATA); 2451 p.head.h80.magic = BE_DRBD_MAGIC;
2452 p.head.length = 2452 p.head.h80.command = cpu_to_be16(P_DATA);
2453 cpu_to_be16(sizeof(p) - sizeof(struct p_header) + dgs + req->size); 2453 p.head.h80.length =
2454 cpu_to_be16(sizeof(p) - sizeof(union p_header) + dgs + req->size);
2455 } else {
2456 p.head.h95.magic = BE_DRBD_MAGIC_BIG;
2457 p.head.h95.command = cpu_to_be16(P_DATA);
2458 p.head.h95.length =
2459 cpu_to_be32(sizeof(p) - sizeof(union p_header) + dgs + req->size);
2460 }
2454 2461
2455 p.sector = cpu_to_be64(req->sector); 2462 p.sector = cpu_to_be64(req->sector);
2456 p.block_id = (unsigned long)req; 2463 p.block_id = (unsigned long)req;
@@ -2511,10 +2518,17 @@ int drbd_send_block(struct drbd_conf *mdev, enum drbd_packets cmd,
2511 dgs = (mdev->agreed_pro_version >= 87 && mdev->integrity_w_tfm) ? 2518 dgs = (mdev->agreed_pro_version >= 87 && mdev->integrity_w_tfm) ?
2512 crypto_hash_digestsize(mdev->integrity_w_tfm) : 0; 2519 crypto_hash_digestsize(mdev->integrity_w_tfm) : 0;
2513 2520
2514 p.head.magic = BE_DRBD_MAGIC; 2521 if (e->size <= (1 << 15)) {
2515 p.head.command = cpu_to_be16(cmd); 2522 p.head.h80.magic = BE_DRBD_MAGIC;
2516 p.head.length = 2523 p.head.h80.command = cpu_to_be16(cmd);
2517 cpu_to_be16(sizeof(p) - sizeof(struct p_header) + dgs + e->size); 2524 p.head.h80.length =
2525 cpu_to_be16(sizeof(p) - sizeof(struct p_header80) + dgs + e->size);
2526 } else {
2527 p.head.h95.magic = BE_DRBD_MAGIC_BIG;
2528 p.head.h95.command = cpu_to_be16(cmd);
2529 p.head.h95.length =
2530 cpu_to_be32(sizeof(p) - sizeof(struct p_header80) + dgs + e->size);
2531 }
2518 2532
2519 p.sector = cpu_to_be64(e->sector); 2533 p.sector = cpu_to_be64(e->sector);
2520 p.block_id = e->block_id; 2534 p.block_id = e->block_id;
@@ -2527,8 +2541,7 @@ int drbd_send_block(struct drbd_conf *mdev, enum drbd_packets cmd,
2527 if (!drbd_get_data_sock(mdev)) 2541 if (!drbd_get_data_sock(mdev))
2528 return 0; 2542 return 0;
2529 2543
2530 ok = sizeof(p) == drbd_send(mdev, mdev->data.socket, &p, 2544 ok = sizeof(p) == drbd_send(mdev, mdev->data.socket, &p, sizeof(p), dgs ? MSG_MORE : 0);
2531 sizeof(p), dgs ? MSG_MORE : 0);
2532 if (ok && dgs) { 2545 if (ok && dgs) {
2533 dgb = mdev->int_dig_out; 2546 dgb = mdev->int_dig_out;
2534 drbd_csum_ee(mdev, mdev->integrity_w_tfm, e, dgb); 2547 drbd_csum_ee(mdev, mdev->integrity_w_tfm, e, dgb);
diff --git a/drivers/block/drbd/drbd_receiver.c b/drivers/block/drbd/drbd_receiver.c
index 591a171291d9..9b3321e2c3cd 100644
--- a/drivers/block/drbd/drbd_receiver.c
+++ b/drivers/block/drbd/drbd_receiver.c
@@ -720,14 +720,14 @@ out:
720static int drbd_send_fp(struct drbd_conf *mdev, 720static int drbd_send_fp(struct drbd_conf *mdev,
721 struct socket *sock, enum drbd_packets cmd) 721 struct socket *sock, enum drbd_packets cmd)
722{ 722{
723 struct p_header *h = (struct p_header *) &mdev->data.sbuf.header; 723 struct p_header80 *h = (struct p_header80 *) &mdev->data.sbuf.header;
724 724
725 return _drbd_send_cmd(mdev, sock, cmd, h, sizeof(*h), 0); 725 return _drbd_send_cmd(mdev, sock, cmd, h, sizeof(*h), 0);
726} 726}
727 727
728static enum drbd_packets drbd_recv_fp(struct drbd_conf *mdev, struct socket *sock) 728static enum drbd_packets drbd_recv_fp(struct drbd_conf *mdev, struct socket *sock)
729{ 729{
730 struct p_header *h = (struct p_header *) &mdev->data.sbuf.header; 730 struct p_header80 *h = (struct p_header80 *) &mdev->data.sbuf.header;
731 int rr; 731 int rr;
732 732
733 rr = drbd_recv_short(mdev, sock, h, sizeof(*h), 0); 733 rr = drbd_recv_short(mdev, sock, h, sizeof(*h), 0);
@@ -944,7 +944,7 @@ out_release_sockets:
944 return -1; 944 return -1;
945} 945}
946 946
947static int drbd_recv_header(struct drbd_conf *mdev, struct p_header *h) 947static int drbd_recv_header(struct drbd_conf *mdev, struct p_header80 *h)
948{ 948{
949 int r; 949 int r;
950 950
@@ -1266,7 +1266,7 @@ int w_e_reissue(struct drbd_conf *mdev, struct drbd_work *w, int cancel) __relea
1266 return 1; 1266 return 1;
1267} 1267}
1268 1268
1269static int receive_Barrier(struct drbd_conf *mdev, struct p_header *h) 1269static int receive_Barrier(struct drbd_conf *mdev, struct p_header80 *h)
1270{ 1270{
1271 int rv, issue_flush; 1271 int rv, issue_flush;
1272 struct p_barrier *p = (struct p_barrier *)h; 1272 struct p_barrier *p = (struct p_barrier *)h;
@@ -1570,7 +1570,7 @@ fail:
1570 return FALSE; 1570 return FALSE;
1571} 1571}
1572 1572
1573static int receive_DataReply(struct drbd_conf *mdev, struct p_header *h) 1573static int receive_DataReply(struct drbd_conf *mdev, struct p_header80 *h)
1574{ 1574{
1575 struct drbd_request *req; 1575 struct drbd_request *req;
1576 sector_t sector; 1576 sector_t sector;
@@ -1610,7 +1610,7 @@ static int receive_DataReply(struct drbd_conf *mdev, struct p_header *h)
1610 return ok; 1610 return ok;
1611} 1611}
1612 1612
1613static int receive_RSDataReply(struct drbd_conf *mdev, struct p_header *h) 1613static int receive_RSDataReply(struct drbd_conf *mdev, struct p_header80 *h)
1614{ 1614{
1615 sector_t sector; 1615 sector_t sector;
1616 unsigned int header_size, data_size; 1616 unsigned int header_size, data_size;
@@ -1767,7 +1767,7 @@ static int drbd_wait_peer_seq(struct drbd_conf *mdev, const u32 packet_seq)
1767} 1767}
1768 1768
1769/* mirrored write */ 1769/* mirrored write */
1770static int receive_Data(struct drbd_conf *mdev, struct p_header *h) 1770static int receive_Data(struct drbd_conf *mdev, struct p_header80 *h)
1771{ 1771{
1772 sector_t sector; 1772 sector_t sector;
1773 struct drbd_epoch_entry *e; 1773 struct drbd_epoch_entry *e;
@@ -2066,7 +2066,7 @@ int drbd_rs_should_slow_down(struct drbd_conf *mdev)
2066} 2066}
2067 2067
2068 2068
2069static int receive_DataRequest(struct drbd_conf *mdev, struct p_header *h) 2069static int receive_DataRequest(struct drbd_conf *mdev, struct p_header80 *h)
2070{ 2070{
2071 sector_t sector; 2071 sector_t sector;
2072 const sector_t capacity = drbd_get_capacity(mdev->this_bdev); 2072 const sector_t capacity = drbd_get_capacity(mdev->this_bdev);
@@ -2756,7 +2756,7 @@ static int cmp_after_sb(enum drbd_after_sb_p peer, enum drbd_after_sb_p self)
2756 return 1; 2756 return 1;
2757} 2757}
2758 2758
2759static int receive_protocol(struct drbd_conf *mdev, struct p_header *h) 2759static int receive_protocol(struct drbd_conf *mdev, struct p_header80 *h)
2760{ 2760{
2761 struct p_protocol *p = (struct p_protocol *)h; 2761 struct p_protocol *p = (struct p_protocol *)h;
2762 int header_size, data_size; 2762 int header_size, data_size;
@@ -2862,7 +2862,7 @@ struct crypto_hash *drbd_crypto_alloc_digest_safe(const struct drbd_conf *mdev,
2862 return tfm; 2862 return tfm;
2863} 2863}
2864 2864
2865static int receive_SyncParam(struct drbd_conf *mdev, struct p_header *h) 2865static int receive_SyncParam(struct drbd_conf *mdev, struct p_header80 *h)
2866{ 2866{
2867 int ok = TRUE; 2867 int ok = TRUE;
2868 struct p_rs_param_95 *p = (struct p_rs_param_95 *)h; 2868 struct p_rs_param_95 *p = (struct p_rs_param_95 *)h;
@@ -3032,7 +3032,7 @@ static void warn_if_differ_considerably(struct drbd_conf *mdev,
3032 (unsigned long long)a, (unsigned long long)b); 3032 (unsigned long long)a, (unsigned long long)b);
3033} 3033}
3034 3034
3035static int receive_sizes(struct drbd_conf *mdev, struct p_header *h) 3035static int receive_sizes(struct drbd_conf *mdev, struct p_header80 *h)
3036{ 3036{
3037 struct p_sizes *p = (struct p_sizes *)h; 3037 struct p_sizes *p = (struct p_sizes *)h;
3038 enum determine_dev_size dd = unchanged; 3038 enum determine_dev_size dd = unchanged;
@@ -3148,7 +3148,7 @@ static int receive_sizes(struct drbd_conf *mdev, struct p_header *h)
3148 return TRUE; 3148 return TRUE;
3149} 3149}
3150 3150
3151static int receive_uuids(struct drbd_conf *mdev, struct p_header *h) 3151static int receive_uuids(struct drbd_conf *mdev, struct p_header80 *h)
3152{ 3152{
3153 struct p_uuids *p = (struct p_uuids *)h; 3153 struct p_uuids *p = (struct p_uuids *)h;
3154 u64 *p_uuid; 3154 u64 *p_uuid;
@@ -3241,7 +3241,7 @@ static union drbd_state convert_state(union drbd_state ps)
3241 return ms; 3241 return ms;
3242} 3242}
3243 3243
3244static int receive_req_state(struct drbd_conf *mdev, struct p_header *h) 3244static int receive_req_state(struct drbd_conf *mdev, struct p_header80 *h)
3245{ 3245{
3246 struct p_req_state *p = (struct p_req_state *)h; 3246 struct p_req_state *p = (struct p_req_state *)h;
3247 union drbd_state mask, val; 3247 union drbd_state mask, val;
@@ -3271,7 +3271,7 @@ static int receive_req_state(struct drbd_conf *mdev, struct p_header *h)
3271 return TRUE; 3271 return TRUE;
3272} 3272}
3273 3273
3274static int receive_state(struct drbd_conf *mdev, struct p_header *h) 3274static int receive_state(struct drbd_conf *mdev, struct p_header80 *h)
3275{ 3275{
3276 struct p_state *p = (struct p_state *)h; 3276 struct p_state *p = (struct p_state *)h;
3277 enum drbd_conns nconn, oconn; 3277 enum drbd_conns nconn, oconn;
@@ -3395,7 +3395,7 @@ static int receive_state(struct drbd_conf *mdev, struct p_header *h)
3395 return TRUE; 3395 return TRUE;
3396} 3396}
3397 3397
3398static int receive_sync_uuid(struct drbd_conf *mdev, struct p_header *h) 3398static int receive_sync_uuid(struct drbd_conf *mdev, struct p_header80 *h)
3399{ 3399{
3400 struct p_rs_uuid *p = (struct p_rs_uuid *)h; 3400 struct p_rs_uuid *p = (struct p_rs_uuid *)h;
3401 3401
@@ -3428,7 +3428,7 @@ static int receive_sync_uuid(struct drbd_conf *mdev, struct p_header *h)
3428enum receive_bitmap_ret { OK, DONE, FAILED }; 3428enum receive_bitmap_ret { OK, DONE, FAILED };
3429 3429
3430static enum receive_bitmap_ret 3430static enum receive_bitmap_ret
3431receive_bitmap_plain(struct drbd_conf *mdev, struct p_header *h, 3431receive_bitmap_plain(struct drbd_conf *mdev, struct p_header80 *h,
3432 unsigned long *buffer, struct bm_xfer_ctx *c) 3432 unsigned long *buffer, struct bm_xfer_ctx *c)
3433{ 3433{
3434 unsigned num_words = min_t(size_t, BM_PACKET_WORDS, c->bm_words - c->word_offset); 3434 unsigned num_words = min_t(size_t, BM_PACKET_WORDS, c->bm_words - c->word_offset);
@@ -3533,7 +3533,7 @@ void INFO_bm_xfer_stats(struct drbd_conf *mdev,
3533 const char *direction, struct bm_xfer_ctx *c) 3533 const char *direction, struct bm_xfer_ctx *c)
3534{ 3534{
3535 /* what would it take to transfer it "plaintext" */ 3535 /* what would it take to transfer it "plaintext" */
3536 unsigned plain = sizeof(struct p_header) * 3536 unsigned plain = sizeof(struct p_header80) *
3537 ((c->bm_words+BM_PACKET_WORDS-1)/BM_PACKET_WORDS+1) 3537 ((c->bm_words+BM_PACKET_WORDS-1)/BM_PACKET_WORDS+1)
3538 + c->bm_words * sizeof(long); 3538 + c->bm_words * sizeof(long);
3539 unsigned total = c->bytes[0] + c->bytes[1]; 3539 unsigned total = c->bytes[0] + c->bytes[1];
@@ -3571,7 +3571,7 @@ void INFO_bm_xfer_stats(struct drbd_conf *mdev,
3571 in order to be agnostic to the 32 vs 64 bits issue. 3571 in order to be agnostic to the 32 vs 64 bits issue.
3572 3572
3573 returns 0 on failure, 1 if we successfully received it. */ 3573 returns 0 on failure, 1 if we successfully received it. */
3574static int receive_bitmap(struct drbd_conf *mdev, struct p_header *h) 3574static int receive_bitmap(struct drbd_conf *mdev, struct p_header80 *h)
3575{ 3575{
3576 struct bm_xfer_ctx c; 3576 struct bm_xfer_ctx c;
3577 void *buffer; 3577 void *buffer;
@@ -3623,7 +3623,7 @@ static int receive_bitmap(struct drbd_conf *mdev, struct p_header *h)
3623 } 3623 }
3624 3624
3625 c.packets[h->command == P_BITMAP]++; 3625 c.packets[h->command == P_BITMAP]++;
3626 c.bytes[h->command == P_BITMAP] += sizeof(struct p_header) + h->length; 3626 c.bytes[h->command == P_BITMAP] += sizeof(struct p_header80) + h->length;
3627 3627
3628 if (ret != OK) 3628 if (ret != OK)
3629 break; 3629 break;
@@ -3659,7 +3659,7 @@ static int receive_bitmap(struct drbd_conf *mdev, struct p_header *h)
3659 return ok; 3659 return ok;
3660} 3660}
3661 3661
3662static int receive_skip_(struct drbd_conf *mdev, struct p_header *h, int silent) 3662static int receive_skip_(struct drbd_conf *mdev, struct p_header80 *h, int silent)
3663{ 3663{
3664 /* TODO zero copy sink :) */ 3664 /* TODO zero copy sink :) */
3665 static char sink[128]; 3665 static char sink[128];
@@ -3679,17 +3679,17 @@ static int receive_skip_(struct drbd_conf *mdev, struct p_header *h, int silent)
3679 return size == 0; 3679 return size == 0;
3680} 3680}
3681 3681
3682static int receive_skip(struct drbd_conf *mdev, struct p_header *h) 3682static int receive_skip(struct drbd_conf *mdev, struct p_header80 *h)
3683{ 3683{
3684 return receive_skip_(mdev, h, 0); 3684 return receive_skip_(mdev, h, 0);
3685} 3685}
3686 3686
3687static int receive_skip_silent(struct drbd_conf *mdev, struct p_header *h) 3687static int receive_skip_silent(struct drbd_conf *mdev, struct p_header80 *h)
3688{ 3688{
3689 return receive_skip_(mdev, h, 1); 3689 return receive_skip_(mdev, h, 1);
3690} 3690}
3691 3691
3692static int receive_UnplugRemote(struct drbd_conf *mdev, struct p_header *h) 3692static int receive_UnplugRemote(struct drbd_conf *mdev, struct p_header80 *h)
3693{ 3693{
3694 if (mdev->state.disk >= D_INCONSISTENT) 3694 if (mdev->state.disk >= D_INCONSISTENT)
3695 drbd_kick_lo(mdev); 3695 drbd_kick_lo(mdev);
@@ -3701,7 +3701,7 @@ static int receive_UnplugRemote(struct drbd_conf *mdev, struct p_header *h)
3701 return TRUE; 3701 return TRUE;
3702} 3702}
3703 3703
3704typedef int (*drbd_cmd_handler_f)(struct drbd_conf *, struct p_header *); 3704typedef int (*drbd_cmd_handler_f)(struct drbd_conf *, struct p_header80 *);
3705 3705
3706static drbd_cmd_handler_f drbd_default_handler[] = { 3706static drbd_cmd_handler_f drbd_default_handler[] = {
3707 [P_DATA] = receive_Data, 3707 [P_DATA] = receive_Data,
@@ -3736,7 +3736,7 @@ static drbd_cmd_handler_f *drbd_opt_cmd_handler;
3736static void drbdd(struct drbd_conf *mdev) 3736static void drbdd(struct drbd_conf *mdev)
3737{ 3737{
3738 drbd_cmd_handler_f handler; 3738 drbd_cmd_handler_f handler;
3739 struct p_header *header = &mdev->data.rbuf.header; 3739 struct p_header80 *header = &mdev->data.rbuf.header;
3740 3740
3741 while (get_t_state(&mdev->receiver) == Running) { 3741 while (get_t_state(&mdev->receiver) == Running) {
3742 drbd_thread_current_set_cpu(mdev); 3742 drbd_thread_current_set_cpu(mdev);
@@ -3964,7 +3964,7 @@ static int drbd_send_handshake(struct drbd_conf *mdev)
3964 p->protocol_min = cpu_to_be32(PRO_VERSION_MIN); 3964 p->protocol_min = cpu_to_be32(PRO_VERSION_MIN);
3965 p->protocol_max = cpu_to_be32(PRO_VERSION_MAX); 3965 p->protocol_max = cpu_to_be32(PRO_VERSION_MAX);
3966 ok = _drbd_send_cmd( mdev, mdev->data.socket, P_HAND_SHAKE, 3966 ok = _drbd_send_cmd( mdev, mdev->data.socket, P_HAND_SHAKE,
3967 (struct p_header *)p, sizeof(*p), 0 ); 3967 (struct p_header80 *)p, sizeof(*p), 0 );
3968 mutex_unlock(&mdev->data.mutex); 3968 mutex_unlock(&mdev->data.mutex);
3969 return ok; 3969 return ok;
3970} 3970}
@@ -3981,7 +3981,7 @@ static int drbd_do_handshake(struct drbd_conf *mdev)
3981 /* ASSERT current == mdev->receiver ... */ 3981 /* ASSERT current == mdev->receiver ... */
3982 struct p_handshake *p = &mdev->data.rbuf.handshake; 3982 struct p_handshake *p = &mdev->data.rbuf.handshake;
3983 const int expect = sizeof(struct p_handshake) 3983 const int expect = sizeof(struct p_handshake)
3984 -sizeof(struct p_header); 3984 -sizeof(struct p_header80);
3985 int rv; 3985 int rv;
3986 3986
3987 rv = drbd_send_handshake(mdev); 3987 rv = drbd_send_handshake(mdev);
@@ -4058,7 +4058,7 @@ static int drbd_do_auth(struct drbd_conf *mdev)
4058 char *response = NULL; 4058 char *response = NULL;
4059 char *right_response = NULL; 4059 char *right_response = NULL;
4060 char *peers_ch = NULL; 4060 char *peers_ch = NULL;
4061 struct p_header p; 4061 struct p_header80 p;
4062 unsigned int key_len = strlen(mdev->net_conf->shared_secret); 4062 unsigned int key_len = strlen(mdev->net_conf->shared_secret);
4063 unsigned int resp_size; 4063 unsigned int resp_size;
4064 struct hash_desc desc; 4064 struct hash_desc desc;
@@ -4231,7 +4231,7 @@ int drbdd_init(struct drbd_thread *thi)
4231 4231
4232/* ********* acknowledge sender ******** */ 4232/* ********* acknowledge sender ******** */
4233 4233
4234static int got_RqSReply(struct drbd_conf *mdev, struct p_header *h) 4234static int got_RqSReply(struct drbd_conf *mdev, struct p_header80 *h)
4235{ 4235{
4236 struct p_req_state_reply *p = (struct p_req_state_reply *)h; 4236 struct p_req_state_reply *p = (struct p_req_state_reply *)h;
4237 4237
@@ -4249,13 +4249,13 @@ static int got_RqSReply(struct drbd_conf *mdev, struct p_header *h)
4249 return TRUE; 4249 return TRUE;
4250} 4250}
4251 4251
4252static int got_Ping(struct drbd_conf *mdev, struct p_header *h) 4252static int got_Ping(struct drbd_conf *mdev, struct p_header80 *h)
4253{ 4253{
4254 return drbd_send_ping_ack(mdev); 4254 return drbd_send_ping_ack(mdev);
4255 4255
4256} 4256}
4257 4257
4258static int got_PingAck(struct drbd_conf *mdev, struct p_header *h) 4258static int got_PingAck(struct drbd_conf *mdev, struct p_header80 *h)
4259{ 4259{
4260 /* restore idle timeout */ 4260 /* restore idle timeout */
4261 mdev->meta.socket->sk->sk_rcvtimeo = mdev->net_conf->ping_int*HZ; 4261 mdev->meta.socket->sk->sk_rcvtimeo = mdev->net_conf->ping_int*HZ;
@@ -4265,7 +4265,7 @@ static int got_PingAck(struct drbd_conf *mdev, struct p_header *h)
4265 return TRUE; 4265 return TRUE;
4266} 4266}
4267 4267
4268static int got_IsInSync(struct drbd_conf *mdev, struct p_header *h) 4268static int got_IsInSync(struct drbd_conf *mdev, struct p_header80 *h)
4269{ 4269{
4270 struct p_block_ack *p = (struct p_block_ack *)h; 4270 struct p_block_ack *p = (struct p_block_ack *)h;
4271 sector_t sector = be64_to_cpu(p->sector); 4271 sector_t sector = be64_to_cpu(p->sector);
@@ -4336,7 +4336,7 @@ static int validate_req_change_req_state(struct drbd_conf *mdev,
4336 return TRUE; 4336 return TRUE;
4337} 4337}
4338 4338
4339static int got_BlockAck(struct drbd_conf *mdev, struct p_header *h) 4339static int got_BlockAck(struct drbd_conf *mdev, struct p_header80 *h)
4340{ 4340{
4341 struct p_block_ack *p = (struct p_block_ack *)h; 4341 struct p_block_ack *p = (struct p_block_ack *)h;
4342 sector_t sector = be64_to_cpu(p->sector); 4342 sector_t sector = be64_to_cpu(p->sector);
@@ -4376,7 +4376,7 @@ static int got_BlockAck(struct drbd_conf *mdev, struct p_header *h)
4376 _ack_id_to_req, __func__ , what); 4376 _ack_id_to_req, __func__ , what);
4377} 4377}
4378 4378
4379static int got_NegAck(struct drbd_conf *mdev, struct p_header *h) 4379static int got_NegAck(struct drbd_conf *mdev, struct p_header80 *h)
4380{ 4380{
4381 struct p_block_ack *p = (struct p_block_ack *)h; 4381 struct p_block_ack *p = (struct p_block_ack *)h;
4382 sector_t sector = be64_to_cpu(p->sector); 4382 sector_t sector = be64_to_cpu(p->sector);
@@ -4396,7 +4396,7 @@ static int got_NegAck(struct drbd_conf *mdev, struct p_header *h)
4396 _ack_id_to_req, __func__ , neg_acked); 4396 _ack_id_to_req, __func__ , neg_acked);
4397} 4397}
4398 4398
4399static int got_NegDReply(struct drbd_conf *mdev, struct p_header *h) 4399static int got_NegDReply(struct drbd_conf *mdev, struct p_header80 *h)
4400{ 4400{
4401 struct p_block_ack *p = (struct p_block_ack *)h; 4401 struct p_block_ack *p = (struct p_block_ack *)h;
4402 sector_t sector = be64_to_cpu(p->sector); 4402 sector_t sector = be64_to_cpu(p->sector);
@@ -4409,7 +4409,7 @@ static int got_NegDReply(struct drbd_conf *mdev, struct p_header *h)
4409 _ar_id_to_req, __func__ , neg_acked); 4409 _ar_id_to_req, __func__ , neg_acked);
4410} 4410}
4411 4411
4412static int got_NegRSDReply(struct drbd_conf *mdev, struct p_header *h) 4412static int got_NegRSDReply(struct drbd_conf *mdev, struct p_header80 *h)
4413{ 4413{
4414 sector_t sector; 4414 sector_t sector;
4415 int size; 4415 int size;
@@ -4431,7 +4431,7 @@ static int got_NegRSDReply(struct drbd_conf *mdev, struct p_header *h)
4431 return TRUE; 4431 return TRUE;
4432} 4432}
4433 4433
4434static int got_BarrierAck(struct drbd_conf *mdev, struct p_header *h) 4434static int got_BarrierAck(struct drbd_conf *mdev, struct p_header80 *h)
4435{ 4435{
4436 struct p_barrier_ack *p = (struct p_barrier_ack *)h; 4436 struct p_barrier_ack *p = (struct p_barrier_ack *)h;
4437 4437
@@ -4440,7 +4440,7 @@ static int got_BarrierAck(struct drbd_conf *mdev, struct p_header *h)
4440 return TRUE; 4440 return TRUE;
4441} 4441}
4442 4442
4443static int got_OVResult(struct drbd_conf *mdev, struct p_header *h) 4443static int got_OVResult(struct drbd_conf *mdev, struct p_header80 *h)
4444{ 4444{
4445 struct p_block_ack *p = (struct p_block_ack *)h; 4445 struct p_block_ack *p = (struct p_block_ack *)h;
4446 struct drbd_work *w; 4446 struct drbd_work *w;
@@ -4474,7 +4474,7 @@ static int got_OVResult(struct drbd_conf *mdev, struct p_header *h)
4474 return TRUE; 4474 return TRUE;
4475} 4475}
4476 4476
4477static int got_something_to_ignore_m(struct drbd_conf *mdev, struct p_header *h) 4477static int got_something_to_ignore_m(struct drbd_conf *mdev, struct p_header80 *h)
4478{ 4478{
4479 /* IGNORE */ 4479 /* IGNORE */
4480 return TRUE; 4480 return TRUE;
@@ -4482,7 +4482,7 @@ static int got_something_to_ignore_m(struct drbd_conf *mdev, struct p_header *h)
4482 4482
4483struct asender_cmd { 4483struct asender_cmd {
4484 size_t pkt_size; 4484 size_t pkt_size;
4485 int (*process)(struct drbd_conf *mdev, struct p_header *h); 4485 int (*process)(struct drbd_conf *mdev, struct p_header80 *h);
4486}; 4486};
4487 4487
4488static struct asender_cmd *get_asender_cmd(int cmd) 4488static struct asender_cmd *get_asender_cmd(int cmd)
@@ -4491,8 +4491,8 @@ static struct asender_cmd *get_asender_cmd(int cmd)
4491 /* anything missing from this table is in 4491 /* anything missing from this table is in
4492 * the drbd_cmd_handler (drbd_default_handler) table, 4492 * the drbd_cmd_handler (drbd_default_handler) table,
4493 * see the beginning of drbdd() */ 4493 * see the beginning of drbdd() */
4494 [P_PING] = { sizeof(struct p_header), got_Ping }, 4494 [P_PING] = { sizeof(struct p_header80), got_Ping },
4495 [P_PING_ACK] = { sizeof(struct p_header), got_PingAck }, 4495 [P_PING_ACK] = { sizeof(struct p_header80), got_PingAck },
4496 [P_RECV_ACK] = { sizeof(struct p_block_ack), got_BlockAck }, 4496 [P_RECV_ACK] = { sizeof(struct p_block_ack), got_BlockAck },
4497 [P_WRITE_ACK] = { sizeof(struct p_block_ack), got_BlockAck }, 4497 [P_WRITE_ACK] = { sizeof(struct p_block_ack), got_BlockAck },
4498 [P_RS_WRITE_ACK] = { sizeof(struct p_block_ack), got_BlockAck }, 4498 [P_RS_WRITE_ACK] = { sizeof(struct p_block_ack), got_BlockAck },
@@ -4504,7 +4504,7 @@ static struct asender_cmd *get_asender_cmd(int cmd)
4504 [P_BARRIER_ACK] = { sizeof(struct p_barrier_ack), got_BarrierAck }, 4504 [P_BARRIER_ACK] = { sizeof(struct p_barrier_ack), got_BarrierAck },
4505 [P_STATE_CHG_REPLY] = { sizeof(struct p_req_state_reply), got_RqSReply }, 4505 [P_STATE_CHG_REPLY] = { sizeof(struct p_req_state_reply), got_RqSReply },
4506 [P_RS_IS_IN_SYNC] = { sizeof(struct p_block_ack), got_IsInSync }, 4506 [P_RS_IS_IN_SYNC] = { sizeof(struct p_block_ack), got_IsInSync },
4507 [P_DELAY_PROBE] = { sizeof(struct p_delay_probe), got_something_to_ignore_m }, 4507 [P_DELAY_PROBE] = { sizeof(struct p_delay_probe93), got_something_to_ignore_m },
4508 [P_MAX_CMD] = { 0, NULL }, 4508 [P_MAX_CMD] = { 0, NULL },
4509 }; 4509 };
4510 if (cmd > P_MAX_CMD || asender_tbl[cmd].process == NULL) 4510 if (cmd > P_MAX_CMD || asender_tbl[cmd].process == NULL)
@@ -4515,13 +4515,13 @@ static struct asender_cmd *get_asender_cmd(int cmd)
4515int drbd_asender(struct drbd_thread *thi) 4515int drbd_asender(struct drbd_thread *thi)
4516{ 4516{
4517 struct drbd_conf *mdev = thi->mdev; 4517 struct drbd_conf *mdev = thi->mdev;
4518 struct p_header *h = &mdev->meta.rbuf.header; 4518 struct p_header80 *h = &mdev->meta.rbuf.header;
4519 struct asender_cmd *cmd = NULL; 4519 struct asender_cmd *cmd = NULL;
4520 4520
4521 int rv, len; 4521 int rv, len;
4522 void *buf = h; 4522 void *buf = h;
4523 int received = 0; 4523 int received = 0;
4524 int expect = sizeof(struct p_header); 4524 int expect = sizeof(struct p_header80);
4525 int empty; 4525 int empty;
4526 4526
4527 sprintf(current->comm, "drbd%d_asender", mdev_to_minor(mdev)); 4527 sprintf(current->comm, "drbd%d_asender", mdev_to_minor(mdev));
@@ -4621,7 +4621,7 @@ int drbd_asender(struct drbd_thread *thi)
4621 goto disconnect; 4621 goto disconnect;
4622 } 4622 }
4623 expect = cmd->pkt_size; 4623 expect = cmd->pkt_size;
4624 ERR_IF(len != expect-sizeof(struct p_header)) 4624 ERR_IF(len != expect-sizeof(struct p_header80))
4625 goto reconnect; 4625 goto reconnect;
4626 } 4626 }
4627 if (received == expect) { 4627 if (received == expect) {
@@ -4631,7 +4631,7 @@ int drbd_asender(struct drbd_thread *thi)
4631 4631
4632 buf = h; 4632 buf = h;
4633 received = 0; 4633 received = 0;
4634 expect = sizeof(struct p_header); 4634 expect = sizeof(struct p_header80);
4635 cmd = NULL; 4635 cmd = NULL;
4636 } 4636 }
4637 } 4637 }
diff --git a/drivers/block/drbd/drbd_worker.c b/drivers/block/drbd/drbd_worker.c
index 1eeb55423b3e..3d0e14e3ade3 100644
--- a/drivers/block/drbd/drbd_worker.c
+++ b/drivers/block/drbd/drbd_worker.c
@@ -1204,7 +1204,7 @@ int w_send_barrier(struct drbd_conf *mdev, struct drbd_work *w, int cancel)
1204 * dec_ap_pending will be done in got_BarrierAck 1204 * dec_ap_pending will be done in got_BarrierAck
1205 * or (on connection loss) in w_clear_epoch. */ 1205 * or (on connection loss) in w_clear_epoch. */
1206 ok = _drbd_send_cmd(mdev, mdev->data.socket, P_BARRIER, 1206 ok = _drbd_send_cmd(mdev, mdev->data.socket, P_BARRIER,
1207 (struct p_header *)p, sizeof(*p), 0); 1207 (struct p_header80 *)p, sizeof(*p), 0);
1208 drbd_put_data_sock(mdev); 1208 drbd_put_data_sock(mdev);
1209 1209
1210 return ok; 1210 return ok;
diff --git a/include/linux/drbd.h b/include/linux/drbd.h
index 0b2bfb58d9c5..89718a39791e 100644
--- a/include/linux/drbd.h
+++ b/include/linux/drbd.h
@@ -318,6 +318,8 @@ enum drbd_timeout_flag {
318 318
319#define DRBD_MAGIC 0x83740267 319#define DRBD_MAGIC 0x83740267
320#define BE_DRBD_MAGIC __constant_cpu_to_be32(DRBD_MAGIC) 320#define BE_DRBD_MAGIC __constant_cpu_to_be32(DRBD_MAGIC)
321#define DRBD_MAGIC_BIG 0x835a
322#define BE_DRBD_MAGIC_BIG __constant_cpu_to_be16(DRBD_MAGIC_BIG)
321 323
322/* these are of type "int" */ 324/* these are of type "int" */
323#define DRBD_MD_INDEX_INTERNAL -1 325#define DRBD_MD_INDEX_INTERNAL -1