svn commit: r249605 - head/sys/vm
Alan Cox
alc at rice.edu
Thu May 2 17:16:56 UTC 2013
On 05/01/2013 22:47, David Xu wrote:
> On 2013/04/18 13:34, Alan Cox wrote:
>> Author: alc
>> Date: Thu Apr 18 05:34:33 2013
>> New Revision: 249605
>> URL: http://svnweb.freebsd.org/changeset/base/249605
>>
>> Log:
>> When calculating the number of reserved nodes, discount the pages
>> that will
>> be used to store the nodes.
>>
>> Sponsored by: EMC / Isilon Storage Division
>>
>> Modified:
>> head/sys/vm/vm_radix.c
>>
>> Modified: head/sys/vm/vm_radix.c
>> ==============================================================================
>>
>> --- head/sys/vm/vm_radix.c Thu Apr 18 05:12:11 2013 (r249604)
>> +++ head/sys/vm/vm_radix.c Thu Apr 18 05:34:33 2013 (r249605)
>> @@ -360,10 +360,17 @@ vm_radix_node_zone_init(void *mem, int s
>> static void
>> vm_radix_prealloc(void *arg __unused)
>> {
>> + int nodes;
>>
>> - if (!uma_zone_reserve_kva(vm_radix_node_zone, cnt.v_page_count))
>> + /*
>> + * Calculate the number of reserved nodes, discounting the pages
>> that
>> + * are needed to store them.
>> + */
>> + nodes = ((vm_paddr_t)cnt.v_page_count * PAGE_SIZE) / (PAGE_SIZE +
>> + sizeof(struct vm_radix_node));
>> + if (!uma_zone_reserve_kva(vm_radix_node_zone, nodes))
>> panic("%s: unable to create new zone", __func__);
>> - uma_prealloc(vm_radix_node_zone, cnt.v_page_count);
>> + uma_prealloc(vm_radix_node_zone, nodes);
>> }
>> SYSINIT(vm_radix_prealloc, SI_SUB_KMEM, SI_ORDER_SECOND,
>> vm_radix_prealloc,
>> NULL);
>>
>
> FYI, after this change, my network card no longer works, the
> driver /sys/dev/if_msk.c reports watchdog timeout, backing out
> this change works again for me.
The only effect of this change should be to reduce the amount of kernel
virtual and physical memory preallocated for radix tree nodes by a few
percent. I really can't imagine how that impacts the operation of the
if_msk.c driver. Can you send me additional info on the affected
machine off list? Also, if possible, I'd like to know the values of
"nodes" and "cnt.v_page_count".
Alan
More information about the svn-src-all
mailing list