]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
Revert "blk: Invalidate block cache when switching hwpart"
authorWeijie Gao <weijie.gao@mediatek.com>
Tue, 27 Aug 2019 07:32:18 +0000 (15:32 +0800)
committerTom Rini <trini@konsulko.com>
Fri, 30 Aug 2019 18:17:11 +0000 (14:17 -0400)
This reverts commit 0ebe112d09b48230ba4be833cd3504b06997d9a4.

Most block devices have only one hwpart. Multiple hwparts only found used
by eMMC devices in u-boot. The mmc driver do blk_dselect_hwpart() at the
beginning of mmc_bread() which causes block cache being invalidated too
frequently and makes block cache useless.

So it's not a good idea to put blkcache_invalidate() in the common
functions. It should be called inside mmc_select_hwpart().

Signed-off-by: Weijie Gao <weijie.gao@mediatek.com>
Tested-by: Felix Brack <fb@ltec.ch>
drivers/block/blk-uclass.c

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