diff options
Diffstat (limited to 'drivers/lightnvm/sysblk.c')
-rw-r--r-- | drivers/lightnvm/sysblk.c | 29 |
1 files changed, 20 insertions, 9 deletions
diff --git a/drivers/lightnvm/sysblk.c b/drivers/lightnvm/sysblk.c index b6971f8ae3c0..7fce58833a07 100644 --- a/drivers/lightnvm/sysblk.c +++ b/drivers/lightnvm/sysblk.c | |||
@@ -93,12 +93,16 @@ void nvm_setup_sysblk_scan(struct nvm_dev *dev, struct sysblk_scan *s, | |||
93 | s->nr_rows = nvm_setup_sysblks(dev, sysblk_ppas); | 93 | s->nr_rows = nvm_setup_sysblks(dev, sysblk_ppas); |
94 | } | 94 | } |
95 | 95 | ||
96 | static int sysblk_get_host_blks(struct ppa_addr ppa, int nr_blks, u8 *blks, | 96 | static int sysblk_get_host_blks(struct nvm_dev *dev, struct ppa_addr ppa, |
97 | void *private) | 97 | u8 *blks, int nr_blks, void *private) |
98 | { | 98 | { |
99 | struct sysblk_scan *s = private; | 99 | struct sysblk_scan *s = private; |
100 | int i, nr_sysblk = 0; | 100 | int i, nr_sysblk = 0; |
101 | 101 | ||
102 | nr_blks = nvm_bb_tbl_fold(dev, blks, nr_blks); | ||
103 | if (nr_blks < 0) | ||
104 | return nr_blks; | ||
105 | |||
102 | for (i = 0; i < nr_blks; i++) { | 106 | for (i = 0; i < nr_blks; i++) { |
103 | if (blks[i] != NVM_BLK_T_HOST) | 107 | if (blks[i] != NVM_BLK_T_HOST) |
104 | continue; | 108 | continue; |
@@ -130,7 +134,7 @@ static int nvm_get_all_sysblks(struct nvm_dev *dev, struct sysblk_scan *s, | |||
130 | dppa = generic_to_dev_addr(dev, ppas[i]); | 134 | dppa = generic_to_dev_addr(dev, ppas[i]); |
131 | s->row = i; | 135 | s->row = i; |
132 | 136 | ||
133 | ret = dev->ops->get_bb_tbl(dev, dppa, dev->blks_per_lun, fn, s); | 137 | ret = dev->ops->get_bb_tbl(dev, dppa, fn, s); |
134 | if (ret) { | 138 | if (ret) { |
135 | pr_err("nvm: failed bb tbl for ppa (%u %u)\n", | 139 | pr_err("nvm: failed bb tbl for ppa (%u %u)\n", |
136 | ppas[i].g.ch, | 140 | ppas[i].g.ch, |
@@ -235,13 +239,17 @@ static int nvm_set_bb_tbl(struct nvm_dev *dev, struct sysblk_scan *s, int type) | |||
235 | return 0; | 239 | return 0; |
236 | } | 240 | } |
237 | 241 | ||
238 | static int sysblk_get_free_blks(struct ppa_addr ppa, int nr_blks, u8 *blks, | 242 | static int sysblk_get_free_blks(struct nvm_dev *dev, struct ppa_addr ppa, |
239 | void *private) | 243 | u8 *blks, int nr_blks, void *private) |
240 | { | 244 | { |
241 | struct sysblk_scan *s = private; | 245 | struct sysblk_scan *s = private; |
242 | struct ppa_addr *sppa; | 246 | struct ppa_addr *sppa; |
243 | int i, blkid = 0; | 247 | int i, blkid = 0; |
244 | 248 | ||
249 | nr_blks = nvm_bb_tbl_fold(dev, blks, nr_blks); | ||
250 | if (nr_blks < 0) | ||
251 | return nr_blks; | ||
252 | |||
245 | for (i = 0; i < nr_blks; i++) { | 253 | for (i = 0; i < nr_blks; i++) { |
246 | if (blks[i] == NVM_BLK_T_HOST) | 254 | if (blks[i] == NVM_BLK_T_HOST) |
247 | return -EEXIST; | 255 | return -EEXIST; |
@@ -578,13 +586,16 @@ static unsigned int factory_blk_offset(struct nvm_dev *dev, int ch, int lun) | |||
578 | BITS_PER_LONG; | 586 | BITS_PER_LONG; |
579 | } | 587 | } |
580 | 588 | ||
581 | static int nvm_factory_blks(struct ppa_addr ppa, int nr_blks, u8 *blks, | 589 | static int nvm_factory_blks(struct nvm_dev *dev, struct ppa_addr ppa, |
582 | void *private) | 590 | u8 *blks, int nr_blks, void *private) |
583 | { | 591 | { |
584 | struct factory_blks *f = private; | 592 | struct factory_blks *f = private; |
585 | struct nvm_dev *dev = f->dev; | ||
586 | int i, lunoff; | 593 | int i, lunoff; |
587 | 594 | ||
595 | nr_blks = nvm_bb_tbl_fold(dev, blks, nr_blks); | ||
596 | if (nr_blks < 0) | ||
597 | return nr_blks; | ||
598 | |||
588 | lunoff = factory_blk_offset(dev, ppa.g.ch, ppa.g.lun); | 599 | lunoff = factory_blk_offset(dev, ppa.g.ch, ppa.g.lun); |
589 | 600 | ||
590 | /* non-set bits correspond to the block must be erased */ | 601 | /* non-set bits correspond to the block must be erased */ |
@@ -661,7 +672,7 @@ static int nvm_fact_get_bb_tbl(struct nvm_dev *dev, struct ppa_addr ppa, | |||
661 | 672 | ||
662 | dev_ppa = generic_to_dev_addr(dev, ppa); | 673 | dev_ppa = generic_to_dev_addr(dev, ppa); |
663 | 674 | ||
664 | ret = dev->ops->get_bb_tbl(dev, dev_ppa, dev->blks_per_lun, fn, priv); | 675 | ret = dev->ops->get_bb_tbl(dev, dev_ppa, fn, priv); |
665 | if (ret) | 676 | if (ret) |
666 | pr_err("nvm: failed bb tbl for ch%u lun%u\n", | 677 | pr_err("nvm: failed bb tbl for ch%u lun%u\n", |
667 | ppa.g.ch, ppa.g.blk); | 678 | ppa.g.ch, ppa.g.blk); |