Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 10 Aug 2009 19:02:10 +0100 (BST)
From:      Robert Watson <rwatson@FreeBSD.org>
To:        Julian Elischer <julian@elischer.org>
Cc:        freebsd-current@freebsd.org, Jeff Roberson <jeff@FreeBSD.org>, "Bjoern A. Zeeb" <bz@FreeBSD.org>, kib@FreeBSD.org, Navdeep Parhar <np@FreeBSD.org>, Larry Rosenman <ler@lerctr.org>, lstewart@FreeBSD.org
Subject:   Re: reproducible panic in netisr
Message-ID:  <alpine.BSF.2.00.0908101859260.36842@fledge.watson.org>
In-Reply-To: <4A805E5B.5000103@elischer.org>
References:  <20090804225806.GA54680@hub.freebsd.org> <20090805054115.O93661@maildrop.int.zabbadoz.net> <20090805063417.GA10969@doormat.home> <alpine.BSF.2.00.0908060011490.59996@fledge.watson.org> <alpine.BSF.2.00.0908060834120.21318@thebighonker.lerctr.org> <alpine.BSF.2.00.0908061508520.62916@fledge.watson.org> <20090810133111.C93661@maildrop.int.zabbadoz.net> <4A805E5B.5000103@elischer.org>

next in thread | previous in thread | raw e-mail | index | archive | help

On Mon, 10 Aug 2009, Julian Elischer wrote:

>> One possible workaround would be to force the __start_ symbol and the 
>> section to be equally aligned and thus on the same address using linker 
>> scripts.  The drawbacks are that we need to touch the fragile linker 
>> scripts for each of the sections we add and for all architectures 
>> individually.  As the enforcement of alignment would be at a different 
>> place to the actual set creation, putting the alignment in might be easily 
>> forgotten.
>
> personally I'd see if there is a way to align the section on a page 
> boundary..

I'm not sure it matters for the master copy, but I believe some (if not all) 
architecture MD parts already allocate the per-CPU data areas as page-aligned, 
and we extend the master copy out to a page boundary.  That said, it would be 
worth checking on a run-time kernel to make sure it works out that way in 
practice.  In the future, we'll want the pages allocated to the DPCPU area to 
be local to the CPU from a NUMA perspective.

>> --- sys/net/vnet.h    (revision 196086)
>> +++ sys/net/vnet.h    (working copy)
>> @@ -185,12 +185,14 @@
>>   * Virtual network stack memory allocator, which allows global variables 
>> to
>>   * be automatically instantiated for each network stack instance.
>>   */
>> +__asm__(
>>  #if defined(__arm__)
>> -__asm__(".section " VNET_SETNAME ", \"aw\", %progbits");
>> +    ".section " VNET_SETNAME ", \"aw\", %progbits\n"
>>  #else
>> -__asm__(".section " VNET_SETNAME ", \"aw\", @progbits");
>> +    ".section " VNET_SETNAME ", \"aw\", @progbits\n"
>>  #endif
>
> I may be visually impaired but I'm not seeing a reason for the ifdef arm..

I stared at Jeff's original DPCPU code for a while before I saw it -- it's the 
"%" vs "@" difference.

Robert N M Watson
Computer Laboratory
University of Cambridge



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?alpine.BSF.2.00.0908101859260.36842>