Re: [PATCH 2/5] mmc: block: Refactor mmc_blk_part_switch()

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Jun 15, 2017 at 3:12 PM, Linus Walleij <linus.walleij@xxxxxxxxxx> wrote:
>
> Instead of passing a struct mmc_blk_data * to mmc_blk_part_switch()
> let's pass the actual partition type we want to switch to. This
> is necessary in order not to have a block device with a backing
> mmc_blk_data and request queue and all for every hardware partition,
> such as RPMB.
>
> Signed-off-by: Linus Walleij <linus.walleij@xxxxxxxxxx>
> ---
>  drivers/mmc/core/block.c | 25 +++++++++++++------------
>  1 file changed, 13 insertions(+), 12 deletions(-)
>
> diff --git a/drivers/mmc/core/block.c b/drivers/mmc/core/block.c
> index d1b824e65590..94b97f97be1a 100644
> --- a/drivers/mmc/core/block.c
> +++ b/drivers/mmc/core/block.c
> @@ -127,7 +127,7 @@ module_param(perdev_minors, int, 0444);
>  MODULE_PARM_DESC(perdev_minors, "Minors numbers to allocate per device");
>
>  static inline int mmc_blk_part_switch(struct mmc_card *card,
> -                                     struct mmc_blk_data *md);
> +                                     unsigned int part_type);

Maybe it's time to change this misleading 'part_type' name, this a bit
that represent  the actual  partition to
access and not a type of an partition. Maybe part_to_access will more
reflect the spec wording.
Need to change also  in mmc_blk_data;

>
>
>  static struct mmc_blk_data *mmc_blk_get(struct gendisk *disk)
>  {
> @@ -490,7 +490,7 @@ static int __mmc_blk_ioctl_cmd(struct mmc_card *card, struct mmc_blk_data *md,
>
>         mrq.cmd = &cmd;
>
> -       err = mmc_blk_part_switch(card, md);
> +       err = mmc_blk_part_switch(card, md->part_type);
>         if (err)
>                 return err;
>
> @@ -767,29 +767,29 @@ static int mmc_blk_part_switch_post(struct mmc_card *card,
>  }
>
>  static inline int mmc_blk_part_switch(struct mmc_card *card,
> -                                     struct mmc_blk_data *md)
> +                                     unsigned int part_type)
>  {
>         int ret = 0;
>         struct mmc_blk_data *main_md = dev_get_drvdata(&card->dev);
>
> -       if (main_md->part_curr == md->part_type)
> +       if (main_md->part_curr == part_type)
>                 return 0;
>
>         if (mmc_card_mmc(card)) {
>                 u8 part_config = card->ext_csd.part_config;
>
> -               ret = mmc_blk_part_switch_pre(card, md->part_type);
> +               ret = mmc_blk_part_switch_pre(card, part_type);
>                 if (ret)
>                         return ret;
>
>                 part_config &= ~EXT_CSD_PART_CONFIG_ACC_MASK;
> -               part_config |= md->part_type;
> +               part_config |= part_type;
>
>                 ret = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL,
>                                  EXT_CSD_PART_CONFIG, part_config,
>                                  card->ext_csd.part_time);
>                 if (ret) {
> -                       mmc_blk_part_switch_post(card, md->part_type);
> +                       mmc_blk_part_switch_post(card, part_type);
>                         return ret;
>                 }
>
> @@ -798,7 +798,7 @@ static inline int mmc_blk_part_switch(struct mmc_card *card,
>                 ret = mmc_blk_part_switch_post(card, main_md->part_curr);
>         }
>
> -       main_md->part_curr = md->part_type;
> +       main_md->part_curr = part_type;
>         return ret;
>  }
>
> @@ -1141,7 +1141,7 @@ static int mmc_blk_reset(struct mmc_blk_data *md, struct mmc_host *host,
>                 int part_err;
>
>                 main_md->part_curr = main_md->part_type;
> -               part_err = mmc_blk_part_switch(host->card, md);
> +               part_err = mmc_blk_part_switch(host->card, md->part_type);
>                 if (part_err) {
>                         /*
>                          * We have failed to get back into the correct
> @@ -1180,6 +1180,7 @@ static void mmc_blk_issue_drv_op(struct mmc_queue *mq, struct request *req)
>         struct mmc_queue_req *mq_rq;
>         struct mmc_card *card = mq->card;
>         struct mmc_blk_data *md = mq->blkdata;
> +       struct mmc_blk_data *main_md = dev_get_drvdata(&card->dev);

Doesn't apply here, maybe need rebase over next or I'm missing some patches.

>         struct mmc_blk_ioc_data **idata;
>         u8 **ext_csd;
>         u32 status;
> @@ -1198,7 +1199,7 @@ static void mmc_blk_issue_drv_op(struct mmc_queue *mq, struct request *req)
>                 }
>                 /* Always switch back to main area after RPMB access */
>                 if (md->area_type & MMC_BLK_DATA_AREA_RPMB)
> -                       mmc_blk_part_switch(card, dev_get_drvdata(&card->dev));
> +                       mmc_blk_part_switch(card, main_md->part_type);
Actually this switch back should be probably done for any partition
which is not user data area.
so this should be
 if (md->area_type != MMC_BLK_DATA_AREA_MAIN)

>                 break;
>         case MMC_DRV_OP_BOOT_WP:
>                 ret = mmc_switch(card, EXT_CSD_CMD_SET_NORMAL, EXT_CSD_BOOT_WP,
> @@ -1906,7 +1907,7 @@ void mmc_blk_issue_rq(struct mmc_queue *mq, struct request *req)
>                 /* claim host only for the first request */
>                 mmc_get_card(card);
>
> -       ret = mmc_blk_part_switch(card, md);
> +       ret = mmc_blk_part_switch(card, md->part_type);
>         if (ret) {
>                 if (req) {
>                         blk_end_request_all(req, -EIO);
> @@ -2436,7 +2437,7 @@ static void mmc_blk_remove(struct mmc_card *card)
>         mmc_blk_remove_parts(card, md);
>         pm_runtime_get_sync(&card->dev);
>         mmc_claim_host(card->host);
> -       mmc_blk_part_switch(card, md);
> +       mmc_blk_part_switch(card, md->part_type);
>         mmc_release_host(card->host);
>         if (card->type != MMC_TYPE_SD_COMBO)
>                 pm_runtime_disable(&card->dev);
> --
> 2.9.4
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-mmc" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux RAID]     [Linux SCSI]     [Linux ATA RAID]     [IDE]     [Linux Wireless]     [Linux Kernel]     [ATH6KL]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Device Mapper]

  Powered by Linux