Skip to content

Commit 45c5fcb

Browse files
igorkonopkoaxboe
authored andcommitted
lightnvm: pblk: use nvm_rq_to_ppa_list()
This patch replaces few remaining usages of rqd->ppa_list[] with existing nvm_rq_to_ppa_list() helpers. This is needed for theoretical devices with ws_min/ws_opt equal to 1. Signed-off-by: Igor Konopko <[email protected]> Reviewed-by: Javier González <[email protected]> Signed-off-by: Matias Bjørling <[email protected]> Signed-off-by: Jens Axboe <[email protected]>
1 parent a96de64 commit 45c5fcb

File tree

2 files changed

+22
-17
lines changed

2 files changed

+22
-17
lines changed

drivers/lightnvm/pblk-core.c

Lines changed: 14 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -562,11 +562,9 @@ int pblk_submit_io_sync(struct pblk *pblk, struct nvm_rq *rqd)
562562

563563
int pblk_submit_io_sync_sem(struct pblk *pblk, struct nvm_rq *rqd)
564564
{
565-
struct ppa_addr *ppa_list;
565+
struct ppa_addr *ppa_list = nvm_rq_to_ppa_list(rqd);
566566
int ret;
567567

568-
ppa_list = (rqd->nr_ppas > 1) ? rqd->ppa_list : &rqd->ppa_addr;
569-
570568
pblk_down_chunk(pblk, ppa_list[0]);
571569
ret = pblk_submit_io_sync(pblk, rqd);
572570
pblk_up_chunk(pblk, ppa_list[0]);
@@ -725,6 +723,7 @@ int pblk_line_smeta_read(struct pblk *pblk, struct pblk_line *line)
725723
struct nvm_tgt_dev *dev = pblk->dev;
726724
struct pblk_line_meta *lm = &pblk->lm;
727725
struct bio *bio;
726+
struct ppa_addr *ppa_list;
728727
struct nvm_rq rqd;
729728
u64 paddr = pblk_line_smeta_start(pblk, line);
730729
int i, ret;
@@ -748,9 +747,10 @@ int pblk_line_smeta_read(struct pblk *pblk, struct pblk_line *line)
748747
rqd.opcode = NVM_OP_PREAD;
749748
rqd.nr_ppas = lm->smeta_sec;
750749
rqd.is_seq = 1;
750+
ppa_list = nvm_rq_to_ppa_list(&rqd);
751751

752752
for (i = 0; i < lm->smeta_sec; i++, paddr++)
753-
rqd.ppa_list[i] = addr_to_gen_ppa(pblk, paddr, line->id);
753+
ppa_list[i] = addr_to_gen_ppa(pblk, paddr, line->id);
754754

755755
ret = pblk_submit_io_sync(pblk, &rqd);
756756
if (ret) {
@@ -777,6 +777,7 @@ static int pblk_line_smeta_write(struct pblk *pblk, struct pblk_line *line,
777777
struct nvm_tgt_dev *dev = pblk->dev;
778778
struct pblk_line_meta *lm = &pblk->lm;
779779
struct bio *bio;
780+
struct ppa_addr *ppa_list;
780781
struct nvm_rq rqd;
781782
__le64 *lba_list = emeta_to_lbas(pblk, line->emeta->buf);
782783
__le64 addr_empty = cpu_to_le64(ADDR_EMPTY);
@@ -801,12 +802,13 @@ static int pblk_line_smeta_write(struct pblk *pblk, struct pblk_line *line,
801802
rqd.opcode = NVM_OP_PWRITE;
802803
rqd.nr_ppas = lm->smeta_sec;
803804
rqd.is_seq = 1;
805+
ppa_list = nvm_rq_to_ppa_list(&rqd);
804806

805807
for (i = 0; i < lm->smeta_sec; i++, paddr++) {
806808
struct pblk_sec_meta *meta = pblk_get_meta(pblk,
807809
rqd.meta_list, i);
808810

809-
rqd.ppa_list[i] = addr_to_gen_ppa(pblk, paddr, line->id);
811+
ppa_list[i] = addr_to_gen_ppa(pblk, paddr, line->id);
810812
meta->lba = lba_list[paddr] = addr_empty;
811813
}
812814

@@ -836,8 +838,9 @@ int pblk_line_emeta_read(struct pblk *pblk, struct pblk_line *line,
836838
struct nvm_geo *geo = &dev->geo;
837839
struct pblk_line_mgmt *l_mg = &pblk->l_mg;
838840
struct pblk_line_meta *lm = &pblk->lm;
839-
void *ppa_list, *meta_list;
841+
void *ppa_list_buf, *meta_list;
840842
struct bio *bio;
843+
struct ppa_addr *ppa_list;
841844
struct nvm_rq rqd;
842845
u64 paddr = line->emeta_ssec;
843846
dma_addr_t dma_ppa_list, dma_meta_list;
@@ -853,7 +856,7 @@ int pblk_line_emeta_read(struct pblk *pblk, struct pblk_line *line,
853856
if (!meta_list)
854857
return -ENOMEM;
855858

856-
ppa_list = meta_list + pblk_dma_meta_size(pblk);
859+
ppa_list_buf = meta_list + pblk_dma_meta_size(pblk);
857860
dma_ppa_list = dma_meta_list + pblk_dma_meta_size(pblk);
858861

859862
next_rq:
@@ -874,11 +877,12 @@ int pblk_line_emeta_read(struct pblk *pblk, struct pblk_line *line,
874877

875878
rqd.bio = bio;
876879
rqd.meta_list = meta_list;
877-
rqd.ppa_list = ppa_list;
880+
rqd.ppa_list = ppa_list_buf;
878881
rqd.dma_meta_list = dma_meta_list;
879882
rqd.dma_ppa_list = dma_ppa_list;
880883
rqd.opcode = NVM_OP_PREAD;
881884
rqd.nr_ppas = rq_ppas;
885+
ppa_list = nvm_rq_to_ppa_list(&rqd);
882886

883887
for (i = 0; i < rqd.nr_ppas; ) {
884888
struct ppa_addr ppa = addr_to_gen_ppa(pblk, paddr, line_id);
@@ -906,7 +910,7 @@ int pblk_line_emeta_read(struct pblk *pblk, struct pblk_line *line,
906910
}
907911

908912
for (j = 0; j < min; j++, i++, paddr++)
909-
rqd.ppa_list[i] = addr_to_gen_ppa(pblk, paddr, line_id);
913+
ppa_list[i] = addr_to_gen_ppa(pblk, paddr, line_id);
910914
}
911915

912916
ret = pblk_submit_io_sync(pblk, &rqd);
@@ -1525,11 +1529,9 @@ void pblk_ppa_to_line_put(struct pblk *pblk, struct ppa_addr ppa)
15251529

15261530
void pblk_rq_to_line_put(struct pblk *pblk, struct nvm_rq *rqd)
15271531
{
1528-
struct ppa_addr *ppa_list;
1532+
struct ppa_addr *ppa_list = nvm_rq_to_ppa_list(rqd);
15291533
int i;
15301534

1531-
ppa_list = (rqd->nr_ppas > 1) ? rqd->ppa_list : &rqd->ppa_addr;
1532-
15331535
for (i = 0; i < rqd->nr_ppas; i++)
15341536
pblk_ppa_to_line_put(pblk, ppa_list[i]);
15351537
}

drivers/lightnvm/pblk-recovery.c

Lines changed: 8 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -179,6 +179,7 @@ static int pblk_recov_pad_line(struct pblk *pblk, struct pblk_line *line,
179179
struct pblk_pad_rq *pad_rq;
180180
struct nvm_rq *rqd;
181181
struct bio *bio;
182+
struct ppa_addr *ppa_list;
182183
void *data;
183184
__le64 *lba_list = emeta_to_lbas(pblk, line->emeta->buf);
184185
u64 w_ptr = line->cur_sec;
@@ -239,6 +240,7 @@ static int pblk_recov_pad_line(struct pblk *pblk, struct pblk_line *line,
239240
rqd->end_io = pblk_end_io_recov;
240241
rqd->private = pad_rq;
241242

243+
ppa_list = nvm_rq_to_ppa_list(rqd);
242244
meta_list = rqd->meta_list;
243245

244246
for (i = 0; i < rqd->nr_ppas; ) {
@@ -266,17 +268,17 @@ static int pblk_recov_pad_line(struct pblk *pblk, struct pblk_line *line,
266268
lba_list[w_ptr] = addr_empty;
267269
meta = pblk_get_meta(pblk, meta_list, i);
268270
meta->lba = addr_empty;
269-
rqd->ppa_list[i] = dev_ppa;
271+
ppa_list[i] = dev_ppa;
270272
}
271273
}
272274

273275
kref_get(&pad_rq->ref);
274-
pblk_down_chunk(pblk, rqd->ppa_list[0]);
276+
pblk_down_chunk(pblk, ppa_list[0]);
275277

276278
ret = pblk_submit_io(pblk, rqd);
277279
if (ret) {
278280
pblk_err(pblk, "I/O submission failed: %d\n", ret);
279-
pblk_up_chunk(pblk, rqd->ppa_list[0]);
281+
pblk_up_chunk(pblk, ppa_list[0]);
280282
kref_put(&pad_rq->ref, pblk_recov_complete);
281283
pblk_free_rqd(pblk, rqd, PBLK_WRITE_INT);
282284
bio_put(bio);
@@ -420,6 +422,7 @@ static int pblk_recov_scan_oob(struct pblk *pblk, struct pblk_line *line,
420422
rqd->ppa_list = ppa_list;
421423
rqd->dma_ppa_list = dma_ppa_list;
422424
rqd->dma_meta_list = dma_meta_list;
425+
ppa_list = nvm_rq_to_ppa_list(rqd);
423426

424427
if (pblk_io_aligned(pblk, rq_ppas))
425428
rqd->is_seq = 1;
@@ -438,7 +441,7 @@ static int pblk_recov_scan_oob(struct pblk *pblk, struct pblk_line *line,
438441
}
439442

440443
for (j = 0; j < pblk->min_write_pgs; j++, i++)
441-
rqd->ppa_list[i] =
444+
ppa_list[i] =
442445
addr_to_gen_ppa(pblk, paddr + j, line->id);
443446
}
444447

@@ -486,7 +489,7 @@ static int pblk_recov_scan_oob(struct pblk *pblk, struct pblk_line *line,
486489
continue;
487490

488491
line->nr_valid_lbas++;
489-
pblk_update_map(pblk, lba, rqd->ppa_list[i]);
492+
pblk_update_map(pblk, lba, ppa_list[i]);
490493
}
491494

492495
left_ppas -= rq_ppas;

0 commit comments

Comments
 (0)