From e1bd49a1e1823eab71c293efd1bd0c9b83c350c9 Mon Sep 17 00:00:00 2001 From: "Charles.Forsyth" Date: Sat, 7 Apr 2007 12:52:27 +0000 Subject: 20070407-1350 more updates from plan 9 pc kernel, and a few unreachable fixes(!) --- os/pc/memory.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'os/pc/memory.c') diff --git a/os/pc/memory.c b/os/pc/memory.c index a58119c6..85658248 100644 --- a/os/pc/memory.c +++ b/os/pc/memory.c @@ -568,3 +568,21 @@ upafree(ulong pa, int size) { mapfree(&xrmapupa, pa, size); } + +void +upareserve(ulong pa, int size) +{ + ulong a; + + a = mapalloc(&rmapupa, pa, size, 0); + if(a != pa){ + /* + * This can happen when we're using the E820 + * map, which might have already reserved some + * of the regions claimed by the pci devices. + */ + // print("upareserve: cannot reserve pa=%#.8lux size=%d\n", pa, size); + if(a != 0) + mapfree(&rmapupa, a, size); + } +} -- cgit v1.2.3