[U-Boot] [PATCH] bootcount: Fix misaligned cache operation
Stefano Babic
sbabic at denx.de
Wed Jul 25 12:04:06 UTC 2018
On 25/07/2018 13:45, Alex Kiernan wrote:
> 1947c2d2a0 introduces cache line flushes for the bootcounter, but if
> the start address is not aligned then the flush causes warnings of
> the form:
>
> CACHE: Misaligned operation at range [4030b7fc, 4030b83c]
>
> Align both the start and end of the buffer (possibly crossing multiple
> lines).
>
Thanks - not noted because I just used already aligned addresses :-)
> Fixes: 1947c2d2a0 ("bootcount: flush after storing the bootcounter")
> Signed-off-by: Alex Kiernan <alex.kiernan at gmail.com>
> ---
>
> drivers/bootcount/bootcount.c | 13 ++++++++++---
> 1 file changed, 10 insertions(+), 3 deletions(-)
>
> diff --git a/drivers/bootcount/bootcount.c b/drivers/bootcount/bootcount.c
> index a3162c97ed..646c563f8a 100644
> --- a/drivers/bootcount/bootcount.c
> +++ b/drivers/bootcount/bootcount.c
> @@ -11,16 +11,23 @@
> __weak void bootcount_store(ulong a)
> {
> void *reg = (void *)CONFIG_SYS_BOOTCOUNT_ADDR;
> + uintptr_t flush_start = rounddown(CONFIG_SYS_BOOTCOUNT_ADDR,
> + CONFIG_SYS_CACHELINE_SIZE);
> + uintptr_t flush_end;
>
> #if defined(CONFIG_SYS_BOOTCOUNT_SINGLEWORD)
> raw_bootcount_store(reg, (BOOTCOUNT_MAGIC & 0xffff0000) | a);
> +
> + flush_end = roundup(CONFIG_SYS_BOOTCOUNT_ADDR + 4,
> + CONFIG_SYS_CACHELINE_SIZE);
> #else
> raw_bootcount_store(reg, a);
> raw_bootcount_store(reg + 4, BOOTCOUNT_MAGIC);
> +
> + flush_end = roundup(CONFIG_SYS_BOOTCOUNT_ADDR + 8,
> + CONFIG_SYS_CACHELINE_SIZE);
> #endif /* defined(CONFIG_SYS_BOOTCOUNT_SINGLEWORD */
> - flush_dcache_range(CONFIG_SYS_BOOTCOUNT_ADDR,
> - CONFIG_SYS_BOOTCOUNT_ADDR +
> - CONFIG_SYS_CACHELINE_SIZE);
> + flush_dcache_range(flush_start, flush_end);
> }
>
> __weak ulong bootcount_load(void)
>
Acked-by: Stefano Babic <sbabic at denx.de>
Best regards,
Stefano Babic
--
=====================================================================
DENX Software Engineering GmbH, Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: +49-8142-66989-53 Fax: +49-8142-66989-80 Email: sbabic at denx.de
=====================================================================
More information about the U-Boot
mailing list