[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-devel] RE: [Question] Why code differs in construct_dom0?



I think I may not have described the problem clearly. The system has 4G memory. 
From E820 table, there was near 3.5G usable ram below 4G and about 0.5G above 
4G. Of all the ram, most of the memory was allocated to dom0, leaving only 
those for xen itself such as xenheap and xen's reservations.
We were using an onboard graphic card. When starting X, agpgart allocated 
memory from kernel, then asked xen to exchange these pages to contiguous pages 
below 4G. Each time agpgart module did this job, some pages in kernel (which 
are actually above 4G in physical memory) were replaced with contiguous pages 
below 4G. These kind of demands were rather high, about 256M in our platform. 
Finally, xen's reservation (128M) was not enough to fulfill this requirement.
Why was the reservation exhausted? Because kernel kept asking for memory below 
4G but only returning to xen memory above 4G. 
Then why is agpgart's allocation always in effect from above 4G? According to 
the code I pasted in my first mail, when pfn in dom0 was small in number, mfn 
was large. The smaller the pfn was, the larger the corresponding mfn was. 
Apggart allocated memory with GFP_DMA32 set, so the pfns allocated was likely 
to be small. Then the mfns were likely to be actually quite large (above 4G).

Either increasing the reservation (like 384M) or changing the initial p2m 
mapping in dom0 can solve the problem, and our tests verified this judgment.
We do not know which solution is better. That's why we are seeking your kindly 
help.
I am not sure if I have explained clearly enough so far. So any questions on 
the problem itself, Keir?

Shan Haitao

-----Original Message-----
From: xen-devel-bounces@xxxxxxxxxxxxxxxxxxx 
[mailto:xen-devel-bounces@xxxxxxxxxxxxxxxxxxx] On Behalf Of Shan, Haitao
Sent: 2008年11月20日 18:00
To: 'Keir Fraser'
Cc: 'xen-devel@xxxxxxxxxxxxxxxxxxx'
Subject: [Xen-devel] RE: [Question] Why code differs in construct_dom0?

Keir Fraser wrote:
> On 20/11/08 09:41, "Shan, Haitao" <haitao.shan@xxxxxxxxx> wrote:
> 
>> So you mean in the release build we make the mapping discontiguous
>> to detect possible bugs, while in debug build it is not
>> discontiguous? 
> 
> It's the other way round.
> 
>> And another question from problems we encountered recently, system
>> with more than 4G memory installed will crash when X server
>> shutdown. The reason is: 1> dom0 allocates memory for agp by calling
>> agp_allocate_memory with GFP_DMA32 set. This implies the pfn comes
>> from memory lower than 4G, while mfn are likely to be from memory
>> above 4G. 2> dom0 then call map_pages_to_apg, since the kernel of
>> handles 32bit gart table, dom0 uses hypercall to change its memory
>> mappings (xen_create_contiguous_region). Xen will pick proper memory
>> below 4G and free those from the guest (likely to be from memory
>> above 4G). 3> As the process goes on. More and more memory below 4G
>> is return to dom0 while leaving memory above 4G in xen. Finally,
>> xen's reservation of memory below 4G for DMA are exhausted. This
>> creates severe problems for us. 
>> 
>> What is your comments on this? Both increase the reservation in Xen
>> and using contiguous mappings are helpful in this cases. Which one
>> do you prefer? 
> 
> I'd need more info on the problem. I will point out that 64-bit Xen
> only allocates memory below 4G when asked, or when there is no memory
> available above 4G. Actually 32-bit Xen is the same, except the first
> chunk of dom0 memory allocated has to be below 1GB (because of
> limitations of Xen's domain_build.c). So I'm not sure what more Xen
> can do? 
In our problem, most of memory is allocate to dom0 by not specifying 
dom0_mem=xxx in grub. Dom0 actually has near 4G memory. So in this case, xen 
only has little memory below 4G, which is from the reservation pool.
> 
>  -- Keir
> 
> 
> 
> _______________________________________________
> Xen-devel mailing list
> Xen-devel@xxxxxxxxxxxxxxxxxxx
> http://lists.xensource.com/xen-devel
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel

_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.