diff options
author | Igor Konopko <igor.j.konopko@intel.com> | 2018-12-11 14:16:27 -0500 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2018-12-11 14:22:35 -0500 |
commit | 2c4d5356e64d7d538f24c23045478330fae4a065 (patch) | |
tree | 87d4d7172cf6de069f4d2fc0a9de4ffad7b12c59 /drivers/lightnvm | |
parent | 55d8ec35398e7ab001989473cf6ed6f40b5ef4a6 (diff) |
lightnvm: pblk: do not overwrite ppa list with meta list
Ehen using pblk with 0 sized metadata both ppa list and meta list
points to the same memory since pblk_dma_meta_size() returns 0 in
that case.
This patch fix that issue by ensuring that pblk_dma_meta_size()
always returns space equal to sizeof(struct pblk_sec_meta) and thus
ppa list and meta list points to different memory address.
Even that in that case drive does not really care about meta_list
pointer, this is the easiest way to fix that issue without introducing
changes in many places in the code just for 0 sized metadata case.
The same approach needs to be also done for pblk_get_sec_meta()
since we also cannot point to the same memory address in meta buffer
when we are using it for pblk recovery process
Reported-by: Hans Holmberg <hans.holmberg@cnexlabs.com>
Tested-by: Hans Holmberg <hans.holmberg@cnexlabs.com>
Signed-off-by: Igor Konopko <igor.j.konopko@intel.com>
Signed-off-by: Matias Bjørling <mb@lightnvm.io>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'drivers/lightnvm')
-rw-r--r-- | drivers/lightnvm/pblk.h | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/lightnvm/pblk.h b/drivers/lightnvm/pblk.h index bc40b1381ff6..85e38ed62f85 100644 --- a/drivers/lightnvm/pblk.h +++ b/drivers/lightnvm/pblk.h | |||
@@ -1388,12 +1388,15 @@ static inline unsigned int pblk_get_min_chks(struct pblk *pblk) | |||
1388 | static inline struct pblk_sec_meta *pblk_get_meta(struct pblk *pblk, | 1388 | static inline struct pblk_sec_meta *pblk_get_meta(struct pblk *pblk, |
1389 | void *meta, int index) | 1389 | void *meta, int index) |
1390 | { | 1390 | { |
1391 | return meta + pblk->oob_meta_size * index; | 1391 | return meta + |
1392 | max_t(int, sizeof(struct pblk_sec_meta), pblk->oob_meta_size) | ||
1393 | * index; | ||
1392 | } | 1394 | } |
1393 | 1395 | ||
1394 | static inline int pblk_dma_meta_size(struct pblk *pblk) | 1396 | static inline int pblk_dma_meta_size(struct pblk *pblk) |
1395 | { | 1397 | { |
1396 | return pblk->oob_meta_size * NVM_MAX_VLBA; | 1398 | return max_t(int, sizeof(struct pblk_sec_meta), pblk->oob_meta_size) |
1399 | * NVM_MAX_VLBA; | ||
1397 | } | 1400 | } |
1398 | 1401 | ||
1399 | static inline int pblk_is_oob_meta_supported(struct pblk *pblk) | 1402 | static inline int pblk_is_oob_meta_supported(struct pblk *pblk) |