aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAdrian Hunter <adrian.hunter@intel.com>2016-05-04 07:38:12 -0400
committerUlf Hansson <ulf.hansson@linaro.org>2016-05-17 10:54:36 -0400
commit3c866568aff7dcfc0bbd5ffc7fcc34fa8f100f67 (patch)
treebfc1fac4d66074396bde169f4a4dfc26fbc6f8b5
parent7ff2760999a86e4d2b1af93dcf0f0d336c309571 (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.c8
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 */