blk: Invalidate block cache when switching hwpart
authorWeijie Gao <weijie.gao@mediatek.com>
Thu, 11 Jul 2019 07:10:23 +0000 (15:10 +0800)
committerTom Rini <trini@konsulko.com>
Thu, 18 Jul 2019 15:31:31 +0000 (11:31 -0400)
Some storage devices have multiple hw partitions and both address from
zero, for example eMMC.
However currently block cache invalidation only applies to block
write/erase.
This can cause a problem that data of current hw partition is cached
before switching to another hw partition. And the following read
operation of the latter hw partition will get wrong data when reading
from the addresses that have been cached previously.

To solve this problem, invalidate block cache after a successful
select_hwpart operation.

Signed-off-by: Weijie Gao <weijie.gao@mediatek.com>
drivers/block/blk-uclass.c

index baaf431e5e0c3ce64af9b934fa140af496e0b2b5..c23b6682a6cc4857b7a52f5eb0e291e874773a91 100644 (file)
@@ -208,7 +208,11 @@ int blk_select_hwpart_devnum(enum if_type if_type, int devnum, int hwpart)
        if (ret)
                return ret;
 
-       return blk_select_hwpart(dev, hwpart);
+       ret = blk_select_hwpart(dev, hwpart);
+       if (!ret)
+               blkcache_invalidate(if_type, devnum);
+
+       return ret;
 }
 
 int blk_list_part(enum if_type if_type)
@@ -348,7 +352,13 @@ int blk_select_hwpart(struct udevice *dev, int hwpart)
 
 int blk_dselect_hwpart(struct blk_desc *desc, int hwpart)
 {
-       return blk_select_hwpart(desc->bdev, hwpart);
+       int ret;
+
+       ret = blk_select_hwpart(desc->bdev, hwpart);
+       if (!ret)
+               blkcache_invalidate(desc->if_type, desc->devnum);
+
+       return ret;
 }
 
 int blk_first_device(int if_type, struct udevice **devp)