Module Name: src Committed By: mlelstv Date: Fri Dec 20 07:55:45 UTC 2024
Modified Files: src/sys/dev/fdt: fdt_boot.c Log Message: Allocate enough address space for unaligned start/end values. To generate a diff of this commit: cvs rdiff -u -r1.6 -r1.7 src/sys/dev/fdt/fdt_boot.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/fdt/fdt_boot.c diff -u src/sys/dev/fdt/fdt_boot.c:1.6 src/sys/dev/fdt/fdt_boot.c:1.7 --- src/sys/dev/fdt/fdt_boot.c:1.6 Sun Jan 21 15:10:07 2024 +++ src/sys/dev/fdt/fdt_boot.c Fri Dec 20 07:55:45 2024 @@ -1,4 +1,4 @@ -/* $NetBSD: fdt_boot.c,v 1.6 2024/01/21 15:10:07 kre Exp $ */ +/* $NetBSD: fdt_boot.c,v 1.7 2024/12/20 07:55:45 mlelstv Exp $ */ /*- * Copyright (c) 2015-2017 Jared McNeill <jmcne...@invisible.ca> @@ -56,7 +56,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: fdt_boot.c,v 1.6 2024/01/21 15:10:07 kre Exp $"); +__KERNEL_RCSID(0, "$NetBSD: fdt_boot.c,v 1.7 2024/12/20 07:55:45 mlelstv Exp $"); #include "opt_efi.h" #include "opt_md.h" @@ -160,7 +160,8 @@ fdt_map_range(uint64_t start, uint64_t e const vaddr_t voff = start & PAGE_MASK; // XXX NH add an align so map_chunk works betterer? - va = uvm_km_alloc(kernel_map, *psize, 0, UVM_KMF_VAONLY | UVM_KMF_NOWAIT); + va = uvm_km_alloc(kernel_map, endpa - startpa, 0, + UVM_KMF_VAONLY | UVM_KMF_NOWAIT); if (va == 0) { printf("Failed to allocate VA for %s\n", purpose); return NULL;