svn commit: r334030 - head/sys/arm/arm
Andrew Turner
andrew at FreeBSD.org
Tue May 22 10:31:07 UTC 2018
Author: andrew
Date: Tue May 22 10:31:06 2018
New Revision: 334030
URL: https://svnweb.freebsd.org/changeset/base/334030
Log:
Allow the 32-bit arm physmem code to work on arm64.
This will help simplify the arm64 code and allow us to properly exclude
memory that should never be mapped.
Obtained from: ABT Systems Ltd
Sponsored by: Turing Robotic Industries
Modified:
head/sys/arm/arm/physmem.c
Modified: head/sys/arm/arm/physmem.c
==============================================================================
--- head/sys/arm/arm/physmem.c Tue May 22 10:23:12 2018 (r334029)
+++ head/sys/arm/arm/physmem.c Tue May 22 10:31:06 2018 (r334030)
@@ -39,7 +39,7 @@ __FBSDID("$FreeBSD$");
#include <sys/systm.h>
#include <vm/vm.h>
#include <machine/md_var.h>
-#include <machine/physmem.h>
+#include <arm/include/physmem.h>
/*
* These structures are used internally to keep track of regions of physical
@@ -51,7 +51,13 @@ __FBSDID("$FreeBSD$");
#define MAX_HWCNT 10
#define MAX_EXCNT 10
+#if defined(__arm__)
#define MAX_PHYS_ADDR 0xFFFFFFFFull
+#define pm_btop(x) arm32_btop(x)
+#elif defined(__aarch64__)
+#define MAX_PHYS_ADDR 0xFFFFFFFFFFFFFFFFull
+#define pm_btop(x) arm64_btop(x)
+#endif
struct region {
vm_paddr_t addr;
@@ -175,7 +181,7 @@ regions_to_avail(vm_paddr_t *avail, uint32_t exflags,
for (hwi = 0, hwp = hwregions; hwi < hwcnt; ++hwi, ++hwp) {
start = hwp->addr;
end = hwp->size + start;
- realmem += arm32_btop((vm_offset_t)(end - start));
+ realmem += pm_btop((vm_offset_t)(end - start));
for (exi = 0, exp = exregions; exi < excnt; ++exi, ++exp) {
/*
* If the excluded region does not match given flags,
@@ -223,8 +229,8 @@ regions_to_avail(vm_paddr_t *avail, uint32_t exflags,
avail[acnt++] = (vm_paddr_t)start;
avail[acnt++] = (vm_paddr_t)xstart;
}
- availmem +=
- arm32_btop((vm_offset_t)(xstart - start));
+ availmem +=
+ pm_btop((vm_offset_t)(xstart - start));
start = xend;
continue;
}
@@ -249,7 +255,7 @@ regions_to_avail(vm_paddr_t *avail, uint32_t exflags,
avail[acnt++] = (vm_paddr_t)start;
avail[acnt++] = (vm_paddr_t)end;
}
- availmem += arm32_btop((vm_offset_t)(end - start));
+ availmem += pm_btop((vm_offset_t)(end - start));
}
if (acnt >= MAX_AVAIL_ENTRIES)
panic("Not enough space in the dump/phys_avail arrays");
More information about the svn-src-all
mailing list