mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-31 14:04:26 -04:00 
			
		
		
		
	* properly format/comment all patches * merge debloat patches * merge Kconfig patches * merge swconfig patches * merge hotplug patches * drop 200-fix_localversion.patch - upstream * drop 222-arm_zimage_none.patch - unused * drop 252-mv_cesa_depends.patch - no longer required * drop 410-mtd-move-forward-declaration-of-struct-mtd_info.patch - unused * drop 661-fq_codel_keep_dropped_stats.patch - outdated * drop 702-phy_add_aneg_done_function.patch - upstream * drop 840-rtc7301.patch - unused * drop 841-rtc_pt7c4338.patch - upstream * drop 921-use_preinit_as_init.patch - unused * drop spio-gpio-old and gpio-mmc - unused Signed-off-by: John Crispin <john@phrozen.org>
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| --- a/drivers/mtd/ubi/attach.c
 | |
| +++ b/drivers/mtd/ubi/attach.c
 | |
| @@ -803,6 +803,13 @@ out_unlock:
 | |
|  	return err;
 | |
|  }
 | |
|  
 | |
| +static bool ec_hdr_has_eof(struct ubi_ec_hdr *ech)
 | |
| +{
 | |
| +	return ech->padding1[0] == 'E' &&
 | |
| +	       ech->padding1[1] == 'O' &&
 | |
| +	       ech->padding1[2] == 'F';
 | |
| +}
 | |
| +
 | |
|  /**
 | |
|   * scan_peb - scan and process UBI headers of a PEB.
 | |
|   * @ubi: UBI device description object
 | |
| @@ -833,9 +840,21 @@ static int scan_peb(struct ubi_device *u
 | |
|  		return 0;
 | |
|  	}
 | |
|  
 | |
| -	err = ubi_io_read_ec_hdr(ubi, pnum, ech, 0);
 | |
| -	if (err < 0)
 | |
| -		return err;
 | |
| +	if (!ai->eof_found) {
 | |
| +		err = ubi_io_read_ec_hdr(ubi, pnum, ech, 0);
 | |
| +		if (err < 0)
 | |
| +			return err;
 | |
| +
 | |
| +		if (ec_hdr_has_eof(ech)) {
 | |
| +			pr_notice("UBI: EOF marker found, PEBs from %d will be erased",
 | |
| +				pnum);
 | |
| +			ai->eof_found = true;
 | |
| +		}
 | |
| +	}
 | |
| +
 | |
| +	if (ai->eof_found)
 | |
| +		err = UBI_IO_FF_BITFLIPS;
 | |
| +
 | |
|  	switch (err) {
 | |
|  	case 0:
 | |
|  		break;
 | |
| --- a/drivers/mtd/ubi/ubi.h
 | |
| +++ b/drivers/mtd/ubi/ubi.h
 | |
| @@ -741,6 +741,7 @@ struct ubi_attach_info {
 | |
|  	int mean_ec;
 | |
|  	uint64_t ec_sum;
 | |
|  	int ec_count;
 | |
| +	bool eof_found;
 | |
|  	struct kmem_cache *aeb_slab_cache;
 | |
|  };
 | |
|  
 |