mirror of
				https://github.com/Ysurac/openmptcprouter.git
				synced 2025-03-09 15:40:20 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			47 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0e71cac033bb7689c4dfa2e6814191337ef770f5 Mon Sep 17 00:00:00 2001
 | |
| From: INAGAKI Hiroshi <musashino.open@gmail.com>
 | |
| Date: Thu, 13 Oct 2022 00:51:33 +0900
 | |
| Subject: [PATCH] nvmem: u-boot-env: align endianness of crc32 values
 | |
| MIME-Version: 1.0
 | |
| Content-Type: text/plain; charset=UTF-8
 | |
| Content-Transfer-Encoding: 8bit
 | |
| 
 | |
| This patch fixes crc32 error on Big-Endianness system by conversion of
 | |
| calculated crc32 value.
 | |
| 
 | |
| Little-Endianness system:
 | |
| 
 | |
|   obtained crc32: Little
 | |
| calculated crc32: Little
 | |
| 
 | |
| Big-Endianness system:
 | |
| 
 | |
|   obtained crc32: Little
 | |
| calculated crc32: Big
 | |
| 
 | |
| log (APRESIA ApresiaLightGS120GT-SS, RTL8382M, Big-Endianness):
 | |
| 
 | |
| [    8.570000] u_boot_env 18001200.spi:flash@0:partitions:partition@c0000: Invalid calculated CRC32: 0x88cd6f09 (expected: 0x096fcd88)
 | |
| [    8.580000] u_boot_env: probe of 18001200.spi:flash@0:partitions:partition@c0000 failed with error -22
 | |
| 
 | |
| Fixes: f955dc1445069 ("nvmem: add driver handling U-Boot environment variables")
 | |
| 
 | |
| Signed-off-by: INAGAKI Hiroshi <musashino.open@gmail.com>
 | |
| Acked-by: Rafał Miłecki <rafal@milecki.pl>
 | |
| Tested-by: Christian Lamparter <chunkeey@gmail.com>
 | |
| Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
 | |
| ---
 | |
|  drivers/nvmem/u-boot-env.c | 2 +-
 | |
|  1 file changed, 1 insertion(+), 1 deletion(-)
 | |
| 
 | |
| --- a/drivers/nvmem/u-boot-env.c
 | |
| +++ b/drivers/nvmem/u-boot-env.c
 | |
| @@ -182,7 +182,7 @@ static int u_boot_env_parse(struct u_boo
 | |
|  	crc32_data_len = priv->mtd->size - crc32_data_offset;
 | |
|  	data_len = priv->mtd->size - data_offset;
 | |
|  
 | |
| -	calc = crc32(~0, buf + crc32_data_offset, crc32_data_len) ^ ~0L;
 | |
| +	calc = le32_to_cpu((__le32)crc32(~0, buf + crc32_data_offset, crc32_data_len) ^ ~0L);
 | |
|  	if (calc != crc32) {
 | |
|  		dev_err(dev, "Invalid calculated CRC32: 0x%08x (expected: 0x%08x)\n", calc, crc32);
 | |
|  		err = -EINVAL;
 |