[openwrt/openwrt] generic: 5.15: fix FIT partition parser on block partitions

LEDE Commits lede-commits at lists.infradead.org
Mon Mar 28 17:56:20 PDT 2022


dangole pushed a commit to openwrt/openwrt.git, branch master:
https://git.openwrt.org/506ddce90fc99d08d7bc0c9ef4277756f54473bb

commit 506ddce90fc99d08d7bc0c9ef4277756f54473bb
Author: Daniel Golle <daniel at makrotopia.org>
AuthorDate: Tue Mar 29 01:53:08 2022 +0100

    generic: 5.15: fix FIT partition parser on block partitions
    
    Using set_disk_ro() doesn't have the desired effect and instead of
    just setting the single partition to be read-only it affects the
    whole disk. Use the bd_read_only flag in struct block_device instead
    to mark a partition being read-only.
    
    Signed-off-by: Daniel Golle <daniel at makrotopia.org>
---
 .../hack-5.15/410-block-fit-partition-parser.patch      | 17 +++++++++++++----
 1 file changed, 13 insertions(+), 4 deletions(-)

diff --git a/target/linux/generic/hack-5.15/410-block-fit-partition-parser.patch b/target/linux/generic/hack-5.15/410-block-fit-partition-parser.patch
index 560196ac72..5edacd5eae 100644
--- a/target/linux/generic/hack-5.15/410-block-fit-partition-parser.patch
+++ b/target/linux/generic/hack-5.15/410-block-fit-partition-parser.patch
@@ -74,16 +74,25 @@
  #ifdef CONFIG_SGI_PARTITION
  	sgi_partition,
  #endif
-@@ -598,6 +605,14 @@ static bool blk_add_partition(struct gen
+@@ -408,6 +415,11 @@ static struct block_device *add_partitio
+ 			goto out_del;
+ 	}
+ 
++#ifdef CONFIG_FIT_PARTITION
++	if (flags & ADDPART_FLAG_READONLY)
++		bdev->bd_read_only = true;
++#endif
++
+ 	/* everything is up and running, commence */
+ 	err = xa_insert(&disk->part_tbl, partno, bdev, GFP_KERNEL);
+ 	if (err)
+@@ -598,6 +610,11 @@ static bool blk_add_partition(struct gen
  	    (state->parts[p].flags & ADDPART_FLAG_RAID))
  		md_autodetect_dev(part->bd_dev);
  
 +#ifdef CONFIG_FIT_PARTITION
 +	if ((state->parts[p].flags & ADDPART_FLAG_ROOTDEV) && ROOT_DEV == 0)
 +		ROOT_DEV = part->bd_dev;
-+
-+	if (state->parts[p].flags & ADDPART_FLAG_READONLY)
-+		set_disk_ro(disk, true);
 +#endif
 +
  	return true;




More information about the lede-commits mailing list