RE: [RFC PATCH v2 4/5] scsi: ufs: L2P map management for HPB read

From: Daejun Park
Date: Thu Jun 18 2020 - 20:19:18 EST


> +static void ufshpb_run_active_subregion_list(struct ufshpb_lu *hpb)
> > +{
> > + struct ufshpb_region *rgn;
> > + struct ufshpb_subregion *srgn;
> > + struct ufshpb_map_ctx *mctx;
> mctx doesn't really do anything here

OK, I will delete it.

> > + unsigned long flags;
> > + int ret = 0;
> > +
> > + spin_lock_irqsave(&hpb->rsp_list_lock, flags);
> > + while ((srgn = list_first_entry_or_null(&hpb->lh_act_srgn,
> > + struct ufshpb_subregion,
> > + list_act_srgn))) {
> > + list_del_init(&srgn->list_act_srgn);
> > + spin_unlock_irqrestore(&hpb->rsp_list_lock, flags);
> > +
> > + rgn = hpb->rgn_tbl + srgn->rgn_idx;
> > + mctx = NULL;
> > + ret = ufshpb_add_region(hpb, rgn);
> > + if (ret)
> > + break;
> > +
> > + ret = ufshpb_issue_map_req(hpb, rgn, srgn);
> > + if (ret) {
> > + dev_notice(&hpb->hpb_lu_dev,
> > + "issue map_req failed. ret %d, region %d - %d\n",
> > + ret, rgn->rgn_idx, srgn->srgn_idx);
> > + break;
> > + }
> > + spin_lock_irqsave(&hpb->rsp_list_lock, flags);
> > + }
> > +
> > + if (ret) {
> > + dev_notice(&hpb->hpb_lu_dev, "region %d - %d, will retry\n",
> > + rgn->rgn_idx, srgn->srgn_idx);
> > + spin_lock_irqsave(&hpb->rsp_list_lock, flags);
> > + ufshpb_add_active_list(hpb, rgn, srgn);
> > + }
> > + spin_unlock_irqrestore(&hpb->rsp_list_lock, flags);
> > +}
>
>