lightnvm: pblk: fix resubmission of overwritten write err lbas
authorHans Holmberg <hans.holmberg@cnexlabs.com>
Tue, 11 Dec 2018 19:16:10 +0000 (20:16 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 12 Feb 2019 18:47:08 +0000 (19:47 +0100)
[ Upstream commit c12fa401ac8c94a74aff68bb5736b3f1dc695fa8 ]

Make sure we only look up valid lba addresses on the resubmission path.

If an lba is invalidated in the write buffer, that sector will be
submitted to disk (as it is already mapped to a ppa), and that write
might fail, resulting in a crash when trying to look up the lba in the
mapping table (as the lba is marked as invalid).

Signed-off-by: Hans Holmberg <hans.holmberg@cnexlabs.com>
Reviewed-by: Javier González <javier@javigon.com>
Signed-off-by: Matias Bjørling <mb@lightnvm.io>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/lightnvm/pblk-write.c

index 879227d584e7db3041ac34b3d2b4eb13a4f14ca4..c3e038d4b22e17fe0d09a319a0e6864c7d92836c 100644 (file)
@@ -158,9 +158,11 @@ static void pblk_prepare_resubmit(struct pblk *pblk, unsigned int sentry,
                w_ctx = &entry->w_ctx;
 
                /* Check if the lba has been overwritten */
-               ppa_l2p = pblk_trans_map_get(pblk, w_ctx->lba);
-               if (!pblk_ppa_comp(ppa_l2p, entry->cacheline))
-                       w_ctx->lba = ADDR_EMPTY;
+               if (w_ctx->lba != ADDR_EMPTY) {
+                       ppa_l2p = pblk_trans_map_get(pblk, w_ctx->lba);
+                       if (!pblk_ppa_comp(ppa_l2p, entry->cacheline))
+                               w_ctx->lba = ADDR_EMPTY;
+               }
 
                /* Mark up the entry as submittable again */
                flags = READ_ONCE(w_ctx->flags);