dm crypt: tidy crypt_endio
authorMilan Broz <mbroz@redhat.com>
Fri, 8 Feb 2008 02:10:46 +0000 (02:10 +0000)
committerAlasdair G Kergon <agk@redhat.com>
Fri, 8 Feb 2008 02:10:46 +0000 (02:10 +0000)
Simplify crypt_endio function.

Signed-off-by: Milan Broz <mbroz@redhat.com>
Signed-off-by: Alasdair G Kergon <agk@redhat.com>
drivers/md/dm-crypt.c

index cc189a2bc533b3d4c00edadc70ed8c722003f47f..278659975d729a95d0ccc529eb6da02d61236f79 100644 (file)
@@ -504,7 +504,7 @@ static void crypt_endio(struct bio *clone, int error)
 {
        struct dm_crypt_io *io = clone->bi_private;
        struct crypt_config *cc = io->target->private;
-       unsigned read_io = bio_data_dir(clone) == READ;
+       unsigned rw = bio_data_dir(clone);
 
        if (unlikely(!bio_flagged(clone, BIO_UPTODATE) && !error))
                error = -EIO;
@@ -512,20 +512,15 @@ static void crypt_endio(struct bio *clone, int error)
        /*
         * free the processed pages
         */
-       if (!read_io) {
+       if (rw == WRITE)
                crypt_free_buffer_pages(cc, clone);
-               goto out;
-       }
-
-       if (unlikely(error))
-               goto out;
 
        bio_put(clone);
-       kcryptd_queue_crypt(io);
-       return;
 
-out:
-       bio_put(clone);
+       if (rw == READ && !error) {
+               kcryptd_queue_crypt(io);
+               return;
+       }
 
        if (unlikely(error))
                io->error = error;