mirror of
https://github.com/tobast/libunwind-eh_elf.git
synced 2025-01-25 01:30:30 +01:00
[IA64] Fix ia64-test-setjmp.c. With MAP_SHARED the kernel will try to
find a 1MiB-aligned region, which isn't what we want here.
This commit is contained in:
parent
bcca3ddcc0
commit
25739eec86
1 changed files with 9 additions and 3 deletions
|
@ -79,6 +79,7 @@ static void
|
||||||
doit (int n)
|
doit (int n)
|
||||||
{
|
{
|
||||||
uintptr_t guard_page_addr, bsp = get_bsp ();
|
uintptr_t guard_page_addr, bsp = get_bsp ();
|
||||||
|
void *ret;
|
||||||
|
|
||||||
if (n == 0)
|
if (n == 0)
|
||||||
{
|
{
|
||||||
|
@ -87,10 +88,15 @@ doit (int n)
|
||||||
guard_page_addr = (bsp + page_size - 1) & -page_size;
|
guard_page_addr = (bsp + page_size - 1) & -page_size;
|
||||||
if (verbose)
|
if (verbose)
|
||||||
printf ("guard_page_addr = 0x%lx\n", (unsigned long) guard_page_addr);
|
printf ("guard_page_addr = 0x%lx\n", (unsigned long) guard_page_addr);
|
||||||
if (mmap ((void *) guard_page_addr, page_size, PROT_NONE,
|
ret = mmap ((void *) guard_page_addr, page_size, PROT_NONE,
|
||||||
MAP_SHARED | MAP_ANONYMOUS, -1, 0) != (void *) guard_page_addr)
|
MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
|
||||||
|
if (ret != (void *) guard_page_addr)
|
||||||
{
|
{
|
||||||
|
if (ret == MAP_FAILED)
|
||||||
perror ("mmap");
|
perror ("mmap");
|
||||||
|
else
|
||||||
|
fprintf (stderr, "mmap() returned %p, expected 0x%lx\n",
|
||||||
|
ret, guard_page_addr);
|
||||||
exit (EXIT_FAILURE);
|
exit (EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue