forked from Minki/linux
drbd: Allow packet handler functions that take a connection
That is necessary in case a connection does not have a volume 0 Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com> Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
This commit is contained in:
parent
8169e41b3e
commit
d9ae84e790
@ -3853,39 +3853,45 @@ static int receive_out_of_sync(struct drbd_conf *mdev, enum drbd_packet cmd,
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef int (*drbd_cmd_handler_f)(struct drbd_conf *, enum drbd_packet cmd,
|
|
||||||
unsigned int to_receive);
|
|
||||||
|
|
||||||
struct data_cmd {
|
struct data_cmd {
|
||||||
int expect_payload;
|
int expect_payload;
|
||||||
size_t pkt_size;
|
size_t pkt_size;
|
||||||
drbd_cmd_handler_f function;
|
enum {
|
||||||
|
MDEV,
|
||||||
|
CONN,
|
||||||
|
} type;
|
||||||
|
union {
|
||||||
|
int (*mdev_fn)(struct drbd_conf *, enum drbd_packet cmd,
|
||||||
|
unsigned int to_receive);
|
||||||
|
int (*conn_fn)(struct drbd_tconn *, enum drbd_packet cmd,
|
||||||
|
unsigned int to_receive);
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct data_cmd drbd_cmd_handler[] = {
|
static struct data_cmd drbd_cmd_handler[] = {
|
||||||
[P_DATA] = { 1, sizeof(struct p_data), receive_Data },
|
[P_DATA] = { 1, sizeof(struct p_data), MDEV, { receive_Data } },
|
||||||
[P_DATA_REPLY] = { 1, sizeof(struct p_data), receive_DataReply },
|
[P_DATA_REPLY] = { 1, sizeof(struct p_data), MDEV, { receive_DataReply } },
|
||||||
[P_RS_DATA_REPLY] = { 1, sizeof(struct p_data), receive_RSDataReply } ,
|
[P_RS_DATA_REPLY] = { 1, sizeof(struct p_data), MDEV, { receive_RSDataReply } } ,
|
||||||
[P_BARRIER] = { 0, sizeof(struct p_barrier), receive_Barrier } ,
|
[P_BARRIER] = { 0, sizeof(struct p_barrier), MDEV, { receive_Barrier } } ,
|
||||||
[P_BITMAP] = { 1, sizeof(struct p_header), receive_bitmap } ,
|
[P_BITMAP] = { 1, sizeof(struct p_header), MDEV, { receive_bitmap } } ,
|
||||||
[P_COMPRESSED_BITMAP] = { 1, sizeof(struct p_header), receive_bitmap } ,
|
[P_COMPRESSED_BITMAP] = { 1, sizeof(struct p_header), MDEV, { receive_bitmap } } ,
|
||||||
[P_UNPLUG_REMOTE] = { 0, sizeof(struct p_header), receive_UnplugRemote },
|
[P_UNPLUG_REMOTE] = { 0, sizeof(struct p_header), MDEV, { receive_UnplugRemote } },
|
||||||
[P_DATA_REQUEST] = { 0, sizeof(struct p_block_req), receive_DataRequest },
|
[P_DATA_REQUEST] = { 0, sizeof(struct p_block_req), MDEV, { receive_DataRequest } },
|
||||||
[P_RS_DATA_REQUEST] = { 0, sizeof(struct p_block_req), receive_DataRequest },
|
[P_RS_DATA_REQUEST] = { 0, sizeof(struct p_block_req), MDEV, { receive_DataRequest } },
|
||||||
[P_SYNC_PARAM] = { 1, sizeof(struct p_header), receive_SyncParam },
|
[P_SYNC_PARAM] = { 1, sizeof(struct p_header), MDEV, { receive_SyncParam } },
|
||||||
[P_SYNC_PARAM89] = { 1, sizeof(struct p_header), receive_SyncParam },
|
[P_SYNC_PARAM89] = { 1, sizeof(struct p_header), MDEV, { receive_SyncParam } },
|
||||||
[P_PROTOCOL] = { 1, sizeof(struct p_protocol), receive_protocol },
|
[P_PROTOCOL] = { 1, sizeof(struct p_protocol), MDEV, { receive_protocol } },
|
||||||
[P_UUIDS] = { 0, sizeof(struct p_uuids), receive_uuids },
|
[P_UUIDS] = { 0, sizeof(struct p_uuids), MDEV, { receive_uuids } },
|
||||||
[P_SIZES] = { 0, sizeof(struct p_sizes), receive_sizes },
|
[P_SIZES] = { 0, sizeof(struct p_sizes), MDEV, { receive_sizes } },
|
||||||
[P_STATE] = { 0, sizeof(struct p_state), receive_state },
|
[P_STATE] = { 0, sizeof(struct p_state), MDEV, { receive_state } },
|
||||||
[P_STATE_CHG_REQ] = { 0, sizeof(struct p_req_state), receive_req_state },
|
[P_STATE_CHG_REQ] = { 0, sizeof(struct p_req_state), MDEV, { receive_req_state } },
|
||||||
[P_SYNC_UUID] = { 0, sizeof(struct p_rs_uuid), receive_sync_uuid },
|
[P_SYNC_UUID] = { 0, sizeof(struct p_rs_uuid), MDEV, { receive_sync_uuid } },
|
||||||
[P_OV_REQUEST] = { 0, sizeof(struct p_block_req), receive_DataRequest },
|
[P_OV_REQUEST] = { 0, sizeof(struct p_block_req), MDEV, { receive_DataRequest } },
|
||||||
[P_OV_REPLY] = { 1, sizeof(struct p_block_req), receive_DataRequest },
|
[P_OV_REPLY] = { 1, sizeof(struct p_block_req), MDEV, { receive_DataRequest } },
|
||||||
[P_CSUM_RS_REQUEST] = { 1, sizeof(struct p_block_req), receive_DataRequest },
|
[P_CSUM_RS_REQUEST] = { 1, sizeof(struct p_block_req), MDEV, { receive_DataRequest } },
|
||||||
[P_DELAY_PROBE] = { 0, sizeof(struct p_delay_probe93), receive_skip },
|
[P_DELAY_PROBE] = { 0, sizeof(struct p_delay_probe93), MDEV, { receive_skip } },
|
||||||
[P_OUT_OF_SYNC] = { 0, sizeof(struct p_block_desc), receive_out_of_sync },
|
[P_OUT_OF_SYNC] = { 0, sizeof(struct p_block_desc), MDEV, { receive_out_of_sync } },
|
||||||
[P_CONN_ST_CHG_REQ] = { 0, sizeof(struct p_req_state), receive_req_state },
|
[P_CONN_ST_CHG_REQ] = { 0, sizeof(struct p_req_state), MDEV, { receive_req_state } },
|
||||||
};
|
};
|
||||||
|
|
||||||
/* All handler functions that expect a sub-header get that sub-heder in
|
/* All handler functions that expect a sub-header get that sub-heder in
|
||||||
@ -3898,7 +3904,6 @@ static struct data_cmd drbd_cmd_handler[] = {
|
|||||||
static void drbdd(struct drbd_tconn *tconn)
|
static void drbdd(struct drbd_tconn *tconn)
|
||||||
{
|
{
|
||||||
struct p_header *header = &tconn->data.rbuf.header;
|
struct p_header *header = &tconn->data.rbuf.header;
|
||||||
struct drbd_conf *mdev;
|
|
||||||
struct packet_info pi;
|
struct packet_info pi;
|
||||||
size_t shs; /* sub header size */
|
size_t shs; /* sub header size */
|
||||||
int rv;
|
int rv;
|
||||||
@ -3909,7 +3914,7 @@ static void drbdd(struct drbd_tconn *tconn)
|
|||||||
goto err_out;
|
goto err_out;
|
||||||
|
|
||||||
if (unlikely(pi.cmd >= ARRAY_SIZE(drbd_cmd_handler) ||
|
if (unlikely(pi.cmd >= ARRAY_SIZE(drbd_cmd_handler) ||
|
||||||
!drbd_cmd_handler[pi.cmd].function)) {
|
!drbd_cmd_handler[pi.cmd].mdev_fn)) {
|
||||||
conn_err(tconn, "unknown packet type %d, l: %d!\n", pi.cmd, pi.size);
|
conn_err(tconn, "unknown packet type %d, l: %d!\n", pi.cmd, pi.size);
|
||||||
goto err_out;
|
goto err_out;
|
||||||
}
|
}
|
||||||
@ -3929,10 +3934,14 @@ static void drbdd(struct drbd_tconn *tconn)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mdev = vnr_to_mdev(tconn, pi.vnr);
|
if (drbd_cmd_handler[pi.cmd].type == CONN) {
|
||||||
rv = mdev ?
|
rv = drbd_cmd_handler[pi.cmd].conn_fn(tconn, pi.cmd, pi.size - shs);
|
||||||
drbd_cmd_handler[pi.cmd].function(mdev, pi.cmd, pi.size - shs) :
|
} else {
|
||||||
tconn_receive_skip(tconn, pi.cmd, pi.size - shs);
|
struct drbd_conf *mdev = vnr_to_mdev(tconn, pi.vnr);
|
||||||
|
rv = mdev ?
|
||||||
|
drbd_cmd_handler[pi.cmd].mdev_fn(mdev, pi.cmd, pi.size - shs) :
|
||||||
|
tconn_receive_skip(tconn, pi.cmd, pi.size - shs);
|
||||||
|
}
|
||||||
|
|
||||||
if (unlikely(!rv)) {
|
if (unlikely(!rv)) {
|
||||||
conn_err(tconn, "error receiving %s, l: %d!\n",
|
conn_err(tconn, "error receiving %s, l: %d!\n",
|
||||||
|
Loading…
Reference in New Issue
Block a user