latest openjdk7 triggers kernel panic

Andriy Gapon avg at FreeBSD.org
Thu Dec 26 14:33:00 UTC 2013


on 26/12/2013 16:05 Konstantin Belousov said the following:
> I provided the following patch yesterday to Peter, after the similar mail.
> 
> diff --git a/sys/vm/vm_map.c b/sys/vm/vm_map.c
> index e3842a3..51b60de 100644
> --- a/sys/vm/vm_map.c
> +++ b/sys/vm/vm_map.c
> @@ -1207,6 +1207,7 @@ charged:
>  	}
>  	else if ((prev_entry != &map->header) &&
>  		 (prev_entry->eflags == protoeflags) &&
> +		 (cow & (MAP_ENTRY_GROWS_DOWN | MAP_ENTRY_GROWS_UP)) == 0 &&
>  		 (prev_entry->end == start) &&
>  		 (prev_entry->wired_count == 0) &&
>  		 (prev_entry->cred == cred ||
> 
> But there were no core dump available, and I think that your note is also
> valid.  I do not see why cow should be cleared from the stack direction
> bits.
> 
> diff --git a/sys/vm/vm_map.c b/sys/vm/vm_map.c
> index e3842a3..e15e0ca 100644
> --- a/sys/vm/vm_map.c
> +++ b/sys/vm/vm_map.c
> @@ -3339,7 +3340,6 @@ vm_map_stack(vm_map_t map, vm_offset_t addrbos, vm_size_t max_ssize,
>  	 * NOTE: We explicitly allow bi-directional stacks.
>  	 */
>  	orient = cow & (MAP_STACK_GROWS_DOWN|MAP_STACK_GROWS_UP);
> -	cow &= ~orient;
>  	KASSERT(orient != 0, ("No stack grow direction"));
>  
>  	if (addrbos < vm_map_min(map) ||
> 

I can confirm that the patch fixes the problem for me.
Thanks!

-- 
Andriy Gapon


More information about the freebsd-current mailing list