diff options
author | cinap_lenrek <cinap_lenrek@felloff.net> | 2020-06-06 14:43:24 +0200 |
---|---|---|
committer | cinap_lenrek <cinap_lenrek@felloff.net> | 2020-06-06 14:43:24 +0200 |
commit | 21e4d88a51303bc41cc28aba77d8f65d7776e39e (patch) | |
tree | b271ba195089c9b24911f0d7fae9e9cbee748d07 /sys/src/9/pc/mmu.c | |
parent | 5f3e72eb844582693e1b0bd4f73be59ab822531e (diff) |
pc, pc64: use 64-bit physical addresses for vmap() and upaalloc()
Diffstat (limited to 'sys/src/9/pc/mmu.c')
-rw-r--r-- | sys/src/9/pc/mmu.c | 15 |
1 files changed, 7 insertions, 8 deletions
diff --git a/sys/src/9/pc/mmu.c b/sys/src/9/pc/mmu.c index 614339295..df0c23520 100644 --- a/sys/src/9/pc/mmu.c +++ b/sys/src/9/pc/mmu.c @@ -71,7 +71,6 @@ mmuinit(void) { ulong x, *p; ushort ptr[3]; - vlong v; if(0) print("vpt=%#.8ux vpd=%#p kmap=%#.8ux\n", VPT, vpd, KMAP); @@ -537,11 +536,16 @@ static void pdbunmap(ulong*, ulong, int); * Add a device mapping to the vmap range. */ void* -vmap(ulong pa, int size) +vmap(uvlong pa, int size) { int osize; ulong o, va; + if(pa < BY2PG || size <= 0 || ((pa+size) >> 32) != 0 || size > VMAPSIZE){ + print("vmap pa=%llux size=%d pc=%#p\n", pa, size, getcallerpc(&pa)); + return nil; + } + /* * might be asking for less than a page. */ @@ -549,17 +553,12 @@ vmap(ulong pa, int size) o = pa & (BY2PG-1); pa -= o; size += o; - size = ROUND(size, BY2PG); - if(pa == 0){ - print("vmap pa=0 pc=%#p\n", getcallerpc(&pa)); - return nil; - } ilock(&vmaplock); if((va = vmapalloc(size)) == 0 || pdbmap(MACHP(0)->pdb, pa|PTEUNCACHED|PTEWRITE, va, size) < 0){ iunlock(&vmaplock); - return 0; + return nil; } iunlock(&vmaplock); /* avoid trap on local processor |