Nakajima, Jun
2005-Jun-22  15:56 UTC
[Xen-devel] pickle_domptr and unpickle_domptr issue with >4GB
When Chris and I were debugging x86_64 SMP xenlinux, I noticed that
(include/asm-x86/mm.h):
#if defined(__i386__)
#define pickle_domptr(_d)   ((u32)(unsigned long)(_d))
#define unpickle_domptr(_d) ((struct domain *)(unsigned long)(_d))
#elif defined(__x86_64__)
static inline struct domain *unpickle_domptr(u32 _domain)
{ return (_domain == 0) ? NULL : __va(_domain); }
static inline u32 pickle_domptr(struct domain *domain)
{ return (domain == NULL) ? 0 : (u32)__pa(domain); }
#endif
__pa(domain) will be truncated (and be set to that pfn as the owner)
when we have physical pages >4GB, and unpickle_domptr will return a
wrong address. Then get_page(), for example, checks if the domain is the
ownwer for the page like (=>), and it fails...:
static inline int get_page(struct pfn_info *page,
                           struct domain *domain)
{
    u32 x, nx, y = page->count_info;
    u32 d, nd = page->u.inuse._domain;
    u32 _domain = pickle_domptr(domain);
    do {
        x  = y;
        nx = x + 1;
        d  = nd;
        if ( unlikely((x & PGC_count_mask) == 0) ||  /* Not allocated?
*/
             unlikely((nx & PGC_count_mask) == 0) || /* Count overflow?
*/
   =>        unlikely(d != _domain) )                /* Wrong owner? */
        {
            if ( !_shadow_mode_refcounts(domain) )
                DPRINTK("Error pfn %lx: rd=%p, od=%p, caf=%08x,
taf=%08x\n",
                        page_to_pfn(page), domain, unpickle_domptr(d),
                        x, page->u.inuse.type_info);
            return 0;
        }
Jun
---
Intel Open Source Technology Center 
_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xensource.com
http://lists.xensource.com/xen-devel
Keir Fraser
2005-Jun-22  17:36 UTC
Re: [Xen-devel] pickle_domptr and unpickle_domptr issue with >4GB
On 22 Jun 2005, at 16:56, Nakajima, Jun wrote:> __pa(domain) will be truncated (and be set to that pfn as the owner) > when we have physical pages >4GB, and unpickle_domptr will return a > wrong address. Then get_page(), for example, checks if the domain is > the > ownwer for the page like (=>), and it fails...:The Xen heap allocator (from which domain structs are taken) is limited to the bottom few megabytes of physmem. So you will never have a domain struct whose phys address overflows 32 bits. Longer term I''d like to relax the restriction on Xen heap allocations on x86/64 so that most of physmem can be shared between Xen and domain heap allocators. At that point we''ll just have to ensure that Xen allocations, or at least domain-struct allocations, only occur from bottom 4GB of memory map. Not very onerous I believe. :-) -- Keir _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel