On Sun, Mar 29, 2015 at 11:25:14PM -0700, Don Lewis wrote:
> On amd64, with an amd64 jail, and kernel rev r280326, I observe the
> following:
>       One gcc process calls mmap() with addr=0 and len=0x657a000, and
>         the value 0x811400000 is returned.  Subsequent gcc processes
>         call mmap() with addr=0x811400000 and len=0x657a000, getting
>         0x811400000 in return.
> 
> With kernel rev r280327 I see:
>       One gcc process calls mmap() with addr=0 and len=0x657a000, and
>       the value 0x811400000 is returned.  Subsequent gcc processes
>       call mmap() with addr=0x811400000 and len=0x657a000, getting
>       0x8115f4000 in return.  What I later noticed is that the subsequent
>       calls are passing offset=0x1f4000.  Not so coincidentally,
>       0x811400000 + 0x1f4000 = 0x8115F4000.
> 
> My first attempt at a fix subtracted offset from address, but the mmap()
> return value changed to 0x8113f4000 instead of the 0x811400000 I was
> expecting.  It looked to me like the code must be doing superpage
> alignment on the start of the file and then adding the offset to get the
> start of the mapped region.
So the real fix is to make gcc pass MAP_FIXED.

> 
> This somewhat hacking patch disables this alignment if a non-zero
> address is passed as a hint, and allows the code to make the start of
> the mapped region match the hint.  With this patch, I've been able to
> build openjdk7 in a FreeBSD 9.3 amd64 jail.
> 
This is for precompiled headers, right ?  Could port disable pch ?
_______________________________________________
svn-src-head@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to