summaryrefslogtreecommitdiffstats
path: root/drivers/block/drbd/drbd_main.c
diff options
context:
space:
mode:
authorAndreas Gruenbacher2011-03-16 11:52:58 +0100
committerPhilipp Reisner2012-11-08 16:44:42 +0100
commit6bdb9b0e230aae94b084d8a375363ada056653b5 (patch)
tree86e1e2bd14efc539f80be89b05d2d6e6603883d5 /drivers/block/drbd/drbd_main.c
parentdrbd: _drbd_send_bio(), _drbd_send_zc_bio(): Return 0 upon success and an err... (diff)
downloadkernel-qcow2-linux-6bdb9b0e230aae94b084d8a375363ada056653b5.tar.gz
kernel-qcow2-linux-6bdb9b0e230aae94b084d8a375363ada056653b5.tar.xz
kernel-qcow2-linux-6bdb9b0e230aae94b084d8a375363ada056653b5.zip
drbd: drbd_send_dblock(): Return 0 upon success and an error code otherwise
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_main.c')
-rw-r--r--drivers/block/drbd/drbd_main.c23
1 files changed, 12 insertions, 11 deletions
diff --git a/drivers/block/drbd/drbd_main.c b/drivers/block/drbd/drbd_main.c
index 77c957ff7a0e..2f203bab5933 100644
--- a/drivers/block/drbd/drbd_main.c
+++ b/drivers/block/drbd/drbd_main.c
@@ -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 ok = 1;
+ int err;
struct p_data p;
unsigned int dp_flags = 0;
void *dgb;
int dgs;
- if (drbd_get_data_sock(mdev->tconn))
- return 0;
+ err = drbd_get_data_sock(mdev->tconn);
+ if (err)
+ return err;
dgs = (mdev->tconn->agreed_pro_version >= 87 && mdev->tconn->integrity_w_tfm) ?
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)
p.dp_flags = cpu_to_be32(dp_flags);
set_bit(UNPLUG_REMOTE, &mdev->flags);
- ok = (sizeof(p) ==
- drbd_send(mdev->tconn, mdev->tconn->data.socket, &p, sizeof(p), dgs ? MSG_MORE : 0));
- if (ok && dgs) {
+ err = drbd_send_all(mdev->tconn, mdev->tconn->data.socket, &p,
+ sizeof(p), dgs ? MSG_MORE : 0);
+ if (!err && dgs) {
dgb = mdev->tconn->int_dig_out;
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
* socket buffers, as we may complete right away
* 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)
* receiving side, we sure have detected corruption elsewhere.
*/
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
- 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. */
if (dgs > 0 && dgs <= 64) {
@@ -1604,7 +1605,7 @@ int drbd_send_dblock(struct drbd_conf *mdev, struct drbd_request *req)
drbd_put_data_sock(mdev->tconn);
- return ok;
+ return err;
}
/* answer packet, used to send data back for read requests: