lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <e22067325dffb02739a7bd7c20419b43@milecki.pl>
Date:   Fri, 04 Nov 2022 11:04:57 +0100
From:   Rafał Miłecki <rafal@...ecki.pl>
To:     Christian Lamparter <chunkeey@...il.com>
Cc:     linux-kernel@...r.kernel.org, srinivas.kandagatla@...aro.org,
        gregkh@...uxfoundation.org, a.fatoum@...gutronix.de
Subject: Re: [PATCH v1] nvmem: address crc32 check on redundant-layout powerpc
 machines

On 2022-11-04 10:47, Christian Lamparter wrote:
> The Western Digital MyBook Live (PowerPC 464/APM82181)
> has a set of redundant u-boot-env. Loading up the driver
> causes it to error out with:
> 
> | u_boot_env: Invalid calculated CRC32: 0x4f8f2c86 (expected: 
> 0x98b14514)
> | u_boot_env: probe of partition@...00 failed with error -22
> 
> Looking up the userspace libubootenv utilities source [0],
> it looks like the "mark" or "flag" is not part of the
> crc32 sum... which is unfortunate :(
> 
> |static int libuboot_load(struct uboot_ctx *ctx)
> |{
> |[...]
> |       if (ctx->redundant) {
> |		[...]
> |               offsetdata = offsetof(struct uboot_env_redund, data);
> |		[...]
> |       }
> |       usable_envsize = ctx->size - offsetdata;
> |       buf[0] = malloc(bufsize);
> |[...]
> |	for (i = 0; i < copies; i++) {
> |		data = (uint8_t *)(buf[i] + offsetdata);
> |               uint32_t crc;
> |
> |		ret = devread(ctx, i, buf[i]);
> |		[...]
> |		crc = *(uint32_t *)(buf[i] + offsetcrc);
> |               dev->crc = crc32(0, (uint8_t *)data, usable_envsize);
> |

Thanks for the fix, it may be I didn't actually test that code.

That change has nothing to do with byte swapping so I' suggest TWO
separated patches.


> Now, this alone didn't fully fix the kernel's uboot-env nvmem
> driver. The driver then ran into an endian error on the
> big-endian powerpc device:
> 
> | u_boot_env: Invalid calculated CRC32: 0x1445b198 (expected: 
> 0x98b14514)
> 
> however the __le32 type for the crc32 value is justified because the
> the crc32() is just a macro for crc32_le(). So, to side-step that
> problem, the crc32 check gets extended to also accept a byteswapped
> crc32.

Can you try this pending patch, please?
[PATCH v2] nvmem: u-boot-env: align endianness of crc32 values
https://lore.kernel.org/lkml/20221012155133.287-1-musashino.open@gmail.com/

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ