diff options
author | Adrian Hunter <adrian.hunter@intel.com> | 2016-05-04 07:38:12 -0400 |
---|---|---|
committer | Ulf Hansson <ulf.hansson@linaro.org> | 2016-05-17 10:54:36 -0400 |
commit | 3c866568aff7dcfc0bbd5ffc7fcc34fa8f100f67 (patch) | |
tree | bfc1fac4d66074396bde169f4a4dfc26fbc6f8b5 | |
parent | 7ff2760999a86e4d2b1af93dcf0f0d336c309571 (diff) |
mmc: block: Always switch back to main area after RPMB access
In preparation to support the use of the RPMB partition with transfer
modes that might require re-tuning, always switch back to the main
area after RPMB access.
RPMB is accessible only via IOCTL so only those paths are affected.
Signed-off-by: Adrian Hunter <adrian.hunter@intel.com>
Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org>
-rw-r--r-- | drivers/mmc/card/block.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/mmc/card/block.c b/drivers/mmc/card/block.c index 5f2a3d69344f..48a5d2e04cea 100644 --- a/drivers/mmc/card/block.c +++ b/drivers/mmc/card/block.c | |||
@@ -618,6 +618,10 @@ static int mmc_blk_ioctl_cmd(struct block_device *bdev, | |||
618 | 618 | ||
619 | ioc_err = __mmc_blk_ioctl_cmd(card, md, idata); | 619 | ioc_err = __mmc_blk_ioctl_cmd(card, md, idata); |
620 | 620 | ||
621 | /* Always switch back to main area after RPMB access */ | ||
622 | if (md->area_type & MMC_BLK_DATA_AREA_RPMB) | ||
623 | mmc_blk_part_switch(card, dev_get_drvdata(&card->dev)); | ||
624 | |||
621 | mmc_put_card(card); | 625 | mmc_put_card(card); |
622 | 626 | ||
623 | err = mmc_blk_ioctl_copy_to_user(ic_ptr, idata); | 627 | err = mmc_blk_ioctl_copy_to_user(ic_ptr, idata); |
@@ -685,6 +689,10 @@ static int mmc_blk_ioctl_multi_cmd(struct block_device *bdev, | |||
685 | for (i = 0; i < num_of_cmds && !ioc_err; i++) | 689 | for (i = 0; i < num_of_cmds && !ioc_err; i++) |
686 | ioc_err = __mmc_blk_ioctl_cmd(card, md, idata[i]); | 690 | ioc_err = __mmc_blk_ioctl_cmd(card, md, idata[i]); |
687 | 691 | ||
692 | /* Always switch back to main area after RPMB access */ | ||
693 | if (md->area_type & MMC_BLK_DATA_AREA_RPMB) | ||
694 | mmc_blk_part_switch(card, dev_get_drvdata(&card->dev)); | ||
695 | |||
688 | mmc_put_card(card); | 696 | mmc_put_card(card); |
689 | 697 | ||
690 | /* copy to user if data and response */ | 698 | /* copy to user if data and response */ |