Commit 0e1b6bb5 authored by Russ Cox's avatar Russ Cox

runtime: use mincore correctly in addrspace_free

Fixes #7476.

LGTM=iant
R=iant
CC=golang-codereviews
https://golang.org/cl/84000043
parent f3ecb298
...@@ -20,15 +20,22 @@ addrspace_free(void *v, uintptr n) ...@@ -20,15 +20,22 @@ addrspace_free(void *v, uintptr n)
int32 errval; int32 errval;
uintptr chunk; uintptr chunk;
uintptr off; uintptr off;
static byte vec[4096];
// NOTE: vec must be just 1 byte long here.
// Mincore returns ENOMEM if any of the pages are unmapped,
// but we want to know that all of the pages are unmapped.
// To make these the same, we can only ask about one page
// at a time. See golang.org/issue/7476.
static byte vec[1];
for(off = 0; off < n; off += chunk) { for(off = 0; off < n; off += chunk) {
chunk = _PAGE_SIZE * sizeof vec; chunk = _PAGE_SIZE * sizeof vec;
if(chunk > (n - off)) if(chunk > (n - off))
chunk = n - off; chunk = n - off;
errval = runtime·mincore((int8*)v + off, chunk, vec); errval = runtime·mincore((int8*)v + off, chunk, vec);
// errval is 0 if success, or -(error_code) if error. // ENOMEM means unmapped, which is what we want.
if (errval == 0 || errval != -ENOMEM) // Anything else we assume means the pages are mapped.
if (errval != -ENOMEM)
return 0; return 0;
} }
return 1; return 1;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment