Commit 6bdb9b0e authored by Andreas Gruenbacher's avatar Andreas Gruenbacher Committed by Philipp Reisner

drbd: drbd_send_dblock(): Return 0 upon success and an error code otherwise

Signed-off-by: default avatarPhilipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: default avatarLars Ellenberg <lars.ellenberg@linbit.com>
parent 7fae55da
...@@ -1537,14 +1537,15 @@ static u32 bio_flags_to_wire(struct drbd_conf *mdev, unsigned long bi_rw) ...@@ -1537,14 +1537,15 @@ static u32 bio_flags_to_wire(struct drbd_conf *mdev, unsigned long bi_rw)
*/ */
int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req) int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req)
{ {
int ok = 1; int err;
struct p_data p; struct p_data p;
unsigned int dp_flags = 0; unsigned int dp_flags = 0;
void *dgb; void *dgb;
int dgs; int dgs;
if (drbd_get_data_sock(mdev->tconn)) err = drbd_get_data_sock(mdev->tconn);
return 0; if (err)
return err;
dgs = (mdev->tconn->agreed_pro_version >= 87 && mdev->tconn->integrity_w_tfm) ? dgs = (mdev->tconn->agreed_pro_version >= 87 && mdev->tconn->integrity_w_tfm) ?
crypto_hash_digestsize(mdev->tconn->integrity_w_tfm) : 0; crypto_hash_digestsize(mdev->tconn->integrity_w_tfm) : 0;
...@@ -1562,14 +1563,14 @@ int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req) ...@@ -1562,14 +1563,14 @@ int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req)
p.dp_flags = cpu_to_be32(dp_flags); p.dp_flags = cpu_to_be32(dp_flags);
set_bit(UNPLUG_REMOTE, &mdev->flags); set_bit(UNPLUG_REMOTE, &mdev->flags);
ok = (sizeof(p) == err = drbd_send_all(mdev->tconn, mdev->tconn->data.socket, &p,
drbd_send(mdev->tconn, mdev->tconn->data.socket, &p, sizeof(p), dgs ? MSG_MORE : 0)); sizeof(p), dgs ? MSG_MORE : 0);
if (ok && dgs) { if (!err && dgs) {
dgb = mdev->tconn->int_dig_out; dgb = mdev->tconn->int_dig_out;
drbd_csum_bio(mdev, mdev->tconn->integrity_w_tfm, req->master_bio, dgb); drbd_csum_bio(mdev, mdev->tconn->integrity_w_tfm, req->master_bio, dgb);
ok = dgs == drbd_send(mdev->tconn, mdev->tconn->data.socket, dgb, dgs, 0); err = drbd_send_all(mdev->tconn, mdev->tconn->data.socket, dgb, dgs, 0);
} }
if (ok) { if (!err) {
/* For protocol A, we have to memcpy the payload into /* For protocol A, we have to memcpy the payload into
* socket buffers, as we may complete right away * socket buffers, as we may complete right away
* as soon as we handed it over to tcp, at which point the data * as soon as we handed it over to tcp, at which point the data
...@@ -1582,9 +1583,9 @@ int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req) ...@@ -1582,9 +1583,9 @@ int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req)
* receiving side, we sure have detected corruption elsewhere. * receiving side, we sure have detected corruption elsewhere.
*/ */
if (mdev->tconn->net_conf->wire_protocol == DRBD_PROT_A || dgs) if (mdev->tconn->net_conf->wire_protocol == DRBD_PROT_A || dgs)
ok = !_drbd_send_bio(mdev, req->master_bio); err = _drbd_send_bio(mdev, req->master_bio);
else else
ok = !_drbd_send_zc_bio(mdev, req->master_bio); err = _drbd_send_zc_bio(mdev, req->master_bio);
/* double check digest, sometimes buffers have been modified in flight. */ /* double check digest, sometimes buffers have been modified in flight. */
if (dgs > 0 && dgs <= 64) { if (dgs > 0 && dgs <= 64) {
...@@ -1604,7 +1605,7 @@ int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req) ...@@ -1604,7 +1605,7 @@ int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req)
drbd_put_data_sock(mdev->tconn); drbd_put_data_sock(mdev->tconn);
return ok; return err;
} }
/* answer packet, used to send data back for read requests: /* answer packet, used to send data back for read requests:
......
...@@ -1264,7 +1264,7 @@ int w_send_dblock(struct drbd_work *w, int cancel) ...@@ -1264,7 +1264,7 @@ int w_send_dblock(struct drbd_work *w, int cancel)
return 1; return 1;
} }
ok = drbd_send_dblock(mdev, req); ok = !drbd_send_dblock(mdev, req);
req_mod(req, ok ? HANDED_OVER_TO_NETWORK : SEND_FAILED); req_mod(req, ok ? HANDED_OVER_TO_NETWORK : SEND_FAILED);
return ok; return ok;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment