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

[Xen-ia64-devel] RE: Xen/ia64 - global or per VP VHPT



> > In my opinion, performance when emulating physical mode is
> > a moot point.  
> 
> Linux IPF TLB miss handlers turn off PRS.dt. This is very performance
> sensitive.

Um, true, but that's largely irrelevant to discussion of
VHPT capability/performance isn't it?
 
> The way I see you applying this argument here is a bit 
> different, though:
> there are things that Linux does today that will cause 
> trouble with this
> particular design choice, but all I have to do is to make sure these
> troublesome things get designed out of the paravirtualized OS.

Yes, that's basically what I am saying.  I understand why a
VTi implementation needs to handle every possibly situation
because silicon rolls are very expensive.  It's not nearly
as important for paravirtualized.  For example, Vmware didn't
support Linux 2.6 until their "next release" (I don't remember
what the release number was).
 
> In any case, I think it is critical to define exactly what an IPF
> paravirtualized guest is (maybe this has already been done 
> and I missed it)
> before making assumptions as to what the guest will and will not do
> (specially when those things are done by native guests 
> today). I don't think
> it is quiet the same as an X-86 XenoLinux, as a number of the 
> hypercalls are
> very specific to addressing X-86 virtualization holes, which 
> do not have
> equivalents in IPF. 

There is a paravirtualized design and Xenlinux implementation
available. (See an earlier posting.) It's still a work in
progress but its proceeding nicely.

> I know that there have been attempts at paravirtualizing 
> (actually more like
> dynamically patching) IPF Linux before (e.g., vBlades, you 
> may be familiar
> with it :-), but I am not sure if the Xen project for IPF has decided
> exactly what an IPF paravirtualized XenoLinux will look like. 
> I am also not
> sure if it has also been decided that no native IPF guests (no binary
> patching) will be supported.

An entirely paravirtualized guest (no patching) is certainly
feasible.  I could have it running in a couple weeks time,
but haven't considered it high on the priority list.

Another interesting case (I think suggested by Arun) is a
"semi-paravirtualized" system where some paravirtualization
is done but priv-sensitive instructions are handled by
hardware (VT) rather than binary patching.  Or perhaps that's
what you meant?

In any case, there's a lot of interesting possibilities here
and, although there are many opinions about which is best,
I think we should preserve the option of trying/implementing
as many as possible.  I'm not "black and white"... I'm more
of an RGB kinda guy :-)
 
> Let's define "big" in an environment where there are multiple 
> cores per die...

Not sure what your point is.  Yes, SMP systems are becoming
more common, but that doesn't mean that every system is
going to be running Oracle or data mining.  In other words,
it may be better to model a "big" system as an independent
collection of small systems (e.g. utility data center).

> > E.g., assume an administrator automatically configures all domains
> > with a nominal 4GB but ability to dynamically grow up to 64GB.  The
> > per-guest VHPT would need to pre-allocate a shadow VHPT for the
> > largest of these (say 1% of 64GB) even if each of the domains never
> > grew beyond the 4GB, right?  (Either that or some kind of VHPT
> > resizing might be required whenever memory is "hot-plugged"?)
> 
> I am not sure I understand your example. As I said in my 
> previous posting,
> experience has shown that the optimal size of the VHPT (for 
> performance) is
> dependent of the number of physical pages it supports (not 
> how many domains,
> but how many total pages those domains will be using). In 
> other words, the
> problem of having a VHPT support more memory is independent 
> of whether it
> represents one domain or multiple domains. It depends on how 
> many total
> memory pages are being supported. 

OK, let me try again.  Let's assume a system has 64GB and (by whatever
means) we determine that a 1GB VHPT is the ideal size for a 64GB
system.  Now let's assume an environment where the "load" (as measured
by number of active guests competing for a processor) is widely
variable... say maybe a national lab where one or two hardy allnighters
run their domains during the night but 16 or more run during the day.
Assume also that all those domains are running apps that are heavily
memory intensive, that is they will use whatever memory is made
available but can operate as necessary with less memory.  So
when the one domain is running, it balloons up to a full 64GB
but when many are running, they chug along with 4GB or less each.

The global VHPT allocates 1GB at Xen boot time.

How big a VHPT do you allocate for each of the 16 domains?  Surely
not 
Or are you ballooning the VHPT size along with memory size?

On a related note, I think you said something about needing to
guarantee forward progress.  In your implementation, is the VHPT
required for this?  If so, what happens when a domain migrates
at the exact point where the VHPT is needed to guarantee forward
progress?  Or do you plan on moving the VHPT as part of migration?
 
> I see it a bit more black and white than you do.

Black and white invariably implies a certain set of assumptions.
I'm not questioning your position given your set of assumptions,
I'm questioning your assumptions -- as those assumption may
make good sense in some situations (e.g. VT has to implement
all possible cases) but less so in others (e.g. paravirtualized).

Dan

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


 


Rackspace

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