Magenheimer, Dan (HP Labs Fort Collins)
2005-Apr-27  17:25 UTC
[Xen-devel] RE: Xen/ia64 presentation
Hi Hollis -- I hope its OK that I respond to you in xen-devel. I know you posted a similar question before the Xen summit and I apologize that the message got buried and I never replied.> In general, why are you so determined to track Linux code? Although > Xen/x86 started that way, it has since diverged, and I think > that makes > a lot of sense. There is likely to be a ton of Linux code supporting > features that don''t make sense in a hypervisor, right? That has > certainly been my experience working on the PowerPC hypervisor over a > few years...Here''s a few reasons (apologies for the free associating :-)... It is true that there is a "ton" of Linux code supporting features that don''t make sense in a hypervisor. But there is a "couple hundred pounds of gold/platinum" Linux code that DOES virtually identical things to a hypervisor -- at least that is the case for ia64. Unlike Linux/x86, much of the core archdep code for Linux/ia64 is still changing relatively rapidly (bug fixes and performance improvements). When Xen was originally derived from Linux (2.4.7-ish), Linux/ia64 was very immature. I really had no choice other than to leverage a much later version. And there have been many useful changes in Linux/ia64 between 2.6.4 (where I started Xen/ia64) and 2.6.11 (which is currently being used for Xen/ia64). A friend likes to say that "good programmers are lazy... VERY good programmers are VERY lazy". While I can claim only to be lazy (and the converse of this aphorism may not be true anyway :-), I hate to waste my time writing code that has already been written by someone else better than I could have written it anyway. Assembly coding on ia64 is very complicated and error prone; code like kernel entry/exit on Linux/ia64 is some of the most intricate and cryptic code you may ever see. I have the highest level of respect for people like David Mosberger who wrote this code but, frankly, I don''t want to try to maintain a parallel version of it. IBM''s pHype and vHype were written as closed source (and pHype still is). Xen and Xen/ia64 were written with open source and GPL in mind and so there was no problem with leveraging Linux code directly. I''d venture to guess that 40%-60% of the code in Xen/x86 is directly taken or indirectly derived (e.g. minor syntactic changes) from Linux. Ian argues that, although this might be true, the other 40-60% is the core value of Xen. Which exactly supports my point: why should the Xen team waste time on developing/changing the "non-core" part of Xen when it can be directly leveraged from Linux? It''s true that Xen is slowly diverging from the original Linux code. You see this as a good thing. I disagree. There are few good examples of highly portable systems code, but Linux is one of them. Many things look "a little weird" in Linux because the code supports multiple architectures. A good example is allocating a task struct (see below). I''d argue that one of the key factors for Linux''s current and future success is its ubiquity due its portability; and Xen would do well to follow in its footsteps rather than diverge in ways that will very likely make it less portable. Maintaining close ties to Linux makes it much easier to "go back to the well". I remember that Xen 1.0 removed a lot of the early "start of day" code for other (e.g. Cyrix) processors; when the user community grew and some users wanted to run on other processors, the Xen team went back and grabbed the code from Linux. When the ACPI tables needed to be more fully parsed, the Xen team grabbed the ACPI code from Linux. Recently, when I needed to add "user access" capability to Xen/ia64, I grabbed the exception table code from Linux/ia64 (and Linux common code); it basically just worked, in part because Keir had grabbed the x86 equivalent code earlier. And I expect this trend to continue and not slow down. For example, when I start SMP support, all the important places are marked in Linux code by CONFIG_SMP. When I want to implement hot plug memory/CPUs or NUMA or jiffieless timer support, I''ll know where to look. Let''s face it: Linux has and will always have a larger community than Xen. It just makes sense to me to leverage as much as we can from that community as easily as we can. Some may argue that this is all a good reason to put Xen and Linux in the same source tree. I''m not sure I would go that far. But, please, let''s not kill the golden goose for what amounts to a little convenience and aesthetics. Whew... sorry to be so long-winded!> You said SMP support is still on the TODO list, and sure enough > CONFIG_SMP is undefined in the unstable tree. But when I did that for > PowerPC, I found build breakage in common code. x86 doesn''t > even build > without CONFIG_SMP. Does that work for you?Yes it does work, although I remember I had to add an ugly hack or two in asm-ia64/config.h to allow it to compile without CONFIG_SMP. Personally I think Xen should compile and work properly with CONFIG_SMP not specified, but once I found a workaround, I gave up the battle.> What do you mean by this statement regarding Xen/x86: "struct > exec_domain is a state vector (not a memory area)"?Sorry this was cryptic... I did a poor job of condensing a complicated topic to a single bullet. On Linux/x86 and Xen/x86, a task_struct (called an exec_domain in Xen but the concept is very similar) is just a C struct which is used to save state. On Linux/ia64 (and I think some other architectures) and Xen/ia64, a task_struct is really a page of memory. It contains two stacks and state is sprinkled liberally throughout. Why? Because ia64 has so many registers that lots of optimizations are done to only save/restore registers "lazily" so registers may be saved at seemingly random places in one of the stacks. (This is why kernel entry/exit code is so intricate.) BTW this is a good example of the "portability" issue with divergence of Xen from Linux. Long ago, Keir looked at the code for alloc_task_struct and decided: "Why bother making a function call to something which just kmalloc''s a struct?" and so he moved it inline. The reason became clear with Xen/ia64 and I got him to change it "back". But recently, when cleaning up the code, he nearly removed the abstraction again.> Unrelated to the presentation, I''ve noticed a large amount of > commented-out code and definitions in Xen/ia64 code, and > other oddities > like "typedef struct exec_domain VCPU". Are these artifacts of > borrowing code from other sources? Are you planning on doing some > cleanup in the future?Yeah, there are some artifacts and some cleanup would be good. The typedef predates exec_domain (used to be a typedef of struct domain) and I used it because I knew that exec_domain was coming. Personally, I prefer VCPU (virtual CPU) to exec_domain. Dan> -----Original Message----- > From: Hollis Blanchard [mailto:hollisb@us.ibm.com] > Sent: Wednesday, April 27, 2005 6:59 AM > To: Magenheimer, Dan (HP Labs Fort Collins) > Subject: Xen/ia64 presentation > > Hi Dan, now that the Xen Summit PDFs are online, I just read through > your presentation on Xen/ia64. A few questions... > > You said SMP support is still on the TODO list, and sure enough > CONFIG_SMP is undefined in the unstable tree. But when I did that for > PowerPC, I found build breakage in common code. x86 doesn''t > even build > without CONFIG_SMP. Does that work for you? > > What do you mean by this statement regarding Xen/x86: "struct > exec_domain is a state vector (not a memory area)"? > > Unrelated to the presentation, I''ve noticed a large amount of > commented-out code and definitions in Xen/ia64 code, and > other oddities > like "typedef struct exec_domain VCPU". Are these artifacts of > borrowing code from other sources? Are you planning on doing some > cleanup in the future? > > In general, why are you so determined to track Linux code? Although > Xen/x86 started that way, it has since diverged, and I think > that makes > a lot of sense. There is likely to be a ton of Linux code supporting > features that don''t make sense in a hypervisor, right? That has > certainly been my experience working on the PowerPC hypervisor over a > few years... > > -- > Hollis Blanchard > IBM Linux Technology Center > >_______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
Magenheimer, Dan (HP Labs Fort Collins) wrote:> >>In general, why are you so determined to track Linux code? Although >>Xen/x86 started that way, it has since diverged, and I think >>that makes >>a lot of sense. There is likely to be a ton of Linux code supporting >>features that don''t make sense in a hypervisor, right? That has >>certainly been my experience working on the PowerPC hypervisor over a >>few years... > > It is true that there is a "ton" of Linux code supporting features > that don''t make sense in a hypervisor. But there is a "couple hundred > pounds of gold/platinum" Linux code that DOES virtually identical things > to a hypervisor -- at least that is the case for ia64. Unlike > Linux/x86, much of the core archdep code for Linux/ia64 is still > changing relatively rapidly (bug fixes and performance improvements). > When Xen was originally derived from Linux (2.4.7-ish), Linux/ia64 > was very immature. I really had no choice other than to leverage > a much later version. And there have been many useful changes in > Linux/ia64 between 2.6.4 (where I started Xen/ia64) and 2.6.11 (which > is currently being used for Xen/ia64).Yeah, I can see how rapid evolution is a good reason to try to track Linux code.> A friend likes to say that "good programmers are lazy... VERY good > programmers are VERY lazy". While I can claim only to be lazy (and > the converse of this aphorism may not be true anyway :-), I hate to > waste my time writing code that has already been written by someone > else better than I could have written it anyway. Assembly coding on > ia64 is very complicated and error prone; code like kernel entry/exit > on Linux/ia64 is some of the most intricate and cryptic code you may > ever see. I have the highest level of respect for people like David > Mosberger who wrote this code but, frankly, I don''t want to try to > maintain a parallel version of it.It is a bit scary that IA64 assembly is so difficult that HP Research doesn''t want to touch it with a 10-foot pole. ;) Actually I''m a bit surprised that you can reuse Linux assembly so easily. Exception vectors are exactly one of the places I would expect hypervisor code to differ the most from OS code.> IBM''s pHype and vHype were written as closed source (and pHype still > is). > Xen and Xen/ia64 were written with open source and GPL in mind and > so there was no problem with leveraging Linux code directly. I''d > venture to guess that 40%-60% of the code in Xen/x86 is directly > taken or indirectly derived (e.g. minor syntactic changes) from Linux. > Ian argues that, although this might be true, the other 40-60% is > the core value of Xen. Which exactly supports my point: why should > the Xen team waste time on developing/changing the "non-core" part of > Xen when it can be directly leveraged from Linux?But at what cost? It is not direct leverage -- you need look no further than xen/arch/ia64/patch/ for evidence of that. And even with the patching, the result is inconsistent at best; for example, "struct pt_regs" used in Linux code and "struct xen_regs" used in native Xen code. That really hurts readability and maintainability. And unless you run through the IA64 patch process, tools like cscope won''t even see all that Linux code.> It''s true that Xen is slowly diverging from the original Linux code. > You see this as a good thing. I disagree. There are few good examples > of highly portable systems code, but Linux is one of them. Many > things look "a little weird" in Linux because the code supports > multiple architectures. A good example is allocating a task struct > (see below). I''d argue that one of the key factors for Linux''s current > and future success is its ubiquity due its portability; and Xen would > do well to follow in its footsteps rather than diverge in ways that > will very likely make it less portable.I''m all about the portability, but it may turn out that the architecture API is drawn at a different level in a hypervisor than in an OS. I think that''s something we should see for ourselves, rather than copying Linux verbatim. Don''t get me wrong; I definitely think Linux is an excellent model for portable systems code. But it is just that -- a model.> Maintaining close ties to Linux makes it much easier to "go back to > the well". I remember that Xen 1.0 removed a lot of the early > "start of day" code for other (e.g. Cyrix) processors; when the > user community grew and some users wanted to run on other processors, > the Xen team went back and grabbed the code from Linux.I don''t necessarily see divergence as good or bad, but I don''t rule it out. The Cyrix thing you described is a fine example of a lazy algorithm, which I can see you have lots of respect for. :) Remove dubious code, and if it turns out somebody complains (causing a code fault ;), it can be re-added. Any code that''s kept has to be maintained, and if no users even excercise it then it''s quite likely to bitrot anyways. For example, Linux supports i386 processors as well, but I suspect it would be counter-productive to attempt that in Xen.> When the > ACPI tables needed to be more fully parsed, the Xen team grabbed > the ACPI code from Linux. Recently, when I needed to add "user access" > capability to Xen/ia64, I grabbed the exception table code from > Linux/ia64 (and Linux common code); it basically just worked, in part > because Keir had grabbed the x86 equivalent code earlier. > > And I expect this trend to continue and not slow down. For example, > when I start SMP support, all the important places are marked in > Linux code by CONFIG_SMP. When I want to implement hot plug memory/CPUs > or NUMA or jiffieless timer support, I''ll know where to look.Oh absolutely, but I think you''re doing a lot more than just looking. When I want to know how something works, Linux code is at the top of my reading list, but having looked I can then implement it myself. Being able to copy/paste/modify isn''t a requirement IMHO.> Some may argue that this is all a good reason to put Xen and Linux > in the same source tree. I''m not sure I would go that far. But, > please, let''s not kill the golden goose for what amounts to a little > convenience and aesthetics.Maybe it''s just me, but I find the Xen/ia64 code confusing enough that I wouldn''t call it just a little aesthetics... :)>>Unrelated to the presentation, I''ve noticed a large amount of >>commented-out code and definitions in Xen/ia64 code, and >>other oddities >>like "typedef struct exec_domain VCPU". Are these artifacts of >>borrowing code from other sources? Are you planning on doing some >>cleanup in the future? > > Yeah, there are some artifacts and some cleanup would be good. > The typedef predates exec_domain (used to be a typedef of > struct domain) and I used it because I knew that exec_domain > was coming. Personally, I prefer VCPU (virtual CPU) to exec_domain.I''ve had the same thought actually... an "exec_domain" is really a virtual CPU state, and having a separate vcpu_info_t is rather confusing. However, I don''t think it helps things to go renaming core structures in arch code because it sounds better... :) -- Hollis Blanchard IBM Linux Technology Center _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
On 27 Apr 2005, at 20:12, Hollis Blanchard wrote:>> Yeah, there are some artifacts and some cleanup would be good. >> The typedef predates exec_domain (used to be a typedef of >> struct domain) and I used it because I knew that exec_domain >> was coming. Personally, I prefer VCPU (virtual CPU) to exec_domain. > > I''ve had the same thought actually... an "exec_domain" is really a > virtual CPU state, and having a separate vcpu_info_t is rather > confusing. > > However, I don''t think it helps things to go renaming core structures > in > arch code because it sounds better... :)I think I agree that ''struct vcpu'' is nicer than ''struct exec_domain''. exec_domain appears hardly at all at the hypervisor interface, and having two different terms used interchangeably within Xen itself is weird. Another I can think of is cpuset vs. cpumask: I went with the former but I like the latter equally well and there is no good reason not to go with the Linux convention on this one. Perhaps we should have a flag day to move to agreed consistent naming on some of these? The changes are trivially scriptable for the most part, but annoying for those with pending patches. -- Keir _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
Keir Fraser wrote:> > I think I agree that ''struct vcpu'' is nicer than ''struct exec_domain''. > exec_domain appears hardly at all at the hypervisor interface, and > having two different terms used interchangeably within Xen itself is weird. > > Another I can think of is cpuset vs. cpumask: I went with the former but > I like the latter equally well and there is no good reason not to go > with the Linux convention on this one. > > Perhaps we should have a flag day to move to agreed consistent naming on > some of these? The changes are trivially scriptable for the most part, > but annoying for those with pending patches.Sounds good to me. On this subject, I''d also like to ask about full_execution_context_t. execution_context_t is used in a fair number of places in the Xen core; however full_execution_context_t seems to only be used in the dom0 interface. The in-Xen analog to full_execution_context_t is arch_exec_domain, with many fields duplicated between the two. Could we consolidate these, or at least give full_execution_context_t a name that better describes its purpose? -- Hollis Blanchard IBM Linux Technology Center _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
On 27 Apr 2005, at 20:12, Hollis Blanchard wrote:>> Maintaining close ties to Linux makes it much easier to "go back to >> the well". I remember that Xen 1.0 removed a lot of the early >> "start of day" code for other (e.g. Cyrix) processors; when the >> user community grew and some users wanted to run on other processors, >> the Xen team went back and grabbed the code from Linux. > > I don''t necessarily see divergence as good or bad, but I don''t rule it > out. The Cyrix thing you described is a fine example of a lazy > algorithm, which I can see you have lots of respect for. :) Remove > dubious code, and if it turns out somebody complains (causing a code > fault ;), it can be re-added. Any code that''s kept has to be > maintained, > and if no users even excercise it then it''s quite likely to bitrot > anyways. For example, Linux supports i386 processors as well, but I > suspect it would be counter-productive to attempt that in Xen.Exactly: within an architecture I think it makes sense to keep it simple but fault in features. I personally fear premature feature-itis and flexibility: I''d much rather add things in as they become necessary, whatever the project. In the case of Xen, we would otherwise forever be a gross hard-to-maintain patch on the side of Linux. The other concern that Dan talks about is what the arch-independent interface should look like -- I think that this will look really rather different between an OS and a hypervisor. For example, an arch with a software-managed TLB will not want to cope with generic interfaces supporting 3- or 4-level page tables, although that might well make sense in an OS (where you need some kind of address-space management structure anyway, and might as well look like a pagetable). -- Keir _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
On 27 Apr 2005, at 20:31, Hollis Blanchard wrote:> Sounds good to me. > > On this subject, I''d also like to ask about full_execution_context_t. > execution_context_t is used in a fair number of places in the Xen core; > however full_execution_context_t seems to only be used in the dom0 > interface. > > The in-Xen analog to full_execution_context_t is arch_exec_domain, with > many fields duplicated between the two. Could we consolidate these, or > at least give full_execution_context_t a name that better describes its > purpose?Yes, that''s another one that''s gross. Maybe rename full_execution_context_t to execution_context_t, and rename existing execution_context_t to something else (cpu_reg_t, or something like that)? -- Keir _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
Keir Fraser wrote:> > On 27 Apr 2005, at 20:31, Hollis Blanchard wrote: >> >> On this subject, I''d also like to ask about full_execution_context_t. >> execution_context_t is used in a fair number of places in the Xen core; >> however full_execution_context_t seems to only be used in the dom0 >> interface. >> >> The in-Xen analog to full_execution_context_t is arch_exec_domain, with >> many fields duplicated between the two. Could we consolidate these, or >> at least give full_execution_context_t a name that better describes its >> purpose? > > Yes, that''s another one that''s gross. Maybe rename > full_execution_context_t to execution_context_t, and rename existing > execution_context_t to something else (cpu_reg_t, or something like that)?execution_context_t is also struct xen_regs, so if we like typedefs then xen_regs_t would be consistent. Right now, lots of code uses xen_regs and lots uses execution_context_t... should that be made consistent? xen_regs/execution_context_t seems to mean "state which xen code could alter", so something to distinguish it from "all CPU state" would be nice. Maybe something like this: struct xen_state: (now xen_regs) state which xen C/asm code could alter struct vcpu_state: (now exec_domain) all virtual CPU state struct arch_vcpu_state ("vcpu_regs" might not be good, since we could need to save other context like software-controlled TLBs, and so "xen_state" would match "vcpu_state".) I guess you want to keep a separate virtual CPU struct for the dom0 interface to preserve the ABI? Calling that "execution_context_t" could work; I don''t know what else to call it. -- Hollis Blanchard IBM Linux Technology Center _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
On 27 Apr 2005, at 21:08, Hollis Blanchard wrote:> xen_regs/execution_context_t seems to mean "state which xen code could > alter", so something to distinguish it from "all CPU state" would be > nice. Maybe something like this: > > struct xen_state: (now xen_regs) state which xen C/asm code could > alter > struct vcpu_state: (now exec_domain) all virtual CPU state > struct arch_vcpu_state > > ("vcpu_regs" might not be good, since we could need to save other > context like software-controlled TLBs, and so "xen_state" would match > "vcpu_state".)x86 Xen makes the distinction between xen_regs and full_execution_context only because xen_regs is what gets saved on the stack on entry to / exit from Xen. More advanced state like TLB info could probably be saved directly into ''struct vcpu_state'' where you detect that you have interrupted a guest activation. xen_regs/xen_state should probably be entirely arch-specific anyway. Even now it only pokes through into common code in interrupt-handler definitions (the final parameter is a xen_regs pointer). It''d be great to nuke those last few from common code. :-) -- Keir _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
On 28 Apr 2005, at 09:32, Keir Fraser wrote:>> struct xen_state: (now xen_regs) state which xen C/asm code could >> alter >> struct vcpu_state: (now exec_domain) all virtual CPU state >> struct arch_vcpu_state >> >> ("vcpu_regs" might not be good, since we could need to save other >> context like software-controlled TLBs, and so "xen_state" would match >> "vcpu_state".)How about: xen_regs/execution_context_t --> user_cpureg_state (registers visible from user space) full_execution_context_t --> guest_vcpu_state (entire guest execution state; includes a user_cpureg_state) The former isn''t user_vcpureg_state because it contains registers visible from user space. Those are the same in number and format regardless of whether you are running natively on a real CPU or on a Xen-based virtual CPU. -- Keir _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
Keir Fraser wrote:> > x86 Xen makes the distinction between xen_regs and > full_execution_context only because xen_regs is what gets saved on the > stack on entry to / exit from Xen. More advanced state like TLB info > could probably be saved directly into ''struct vcpu_state'' where you > detect that you have interrupted a guest activation.Absolutely; I have the same thing in PPC code. I see you just renamed some structures in the unstable tree... now how about exec_domain? Are we happy with "vcpu_state"?> xen_regs/xen_state should probably be entirely arch-specific anyway. > Even now it only pokes through into common code in interrupt-handler > definitions (the final parameter is a xen_regs pointer). It''d be great > to nuke those last few from common code. :-)Yup. I think this could be done by passing ''current'' to show_registers(), and let the arch code figure out what to do from there. After I get PPC to a more useful state I will see about the patch, if somebody hasn''t beaten me to it... -- Hollis Blanchard IBM Linux Technology Center _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
On 28 Apr 2005, at 19:10, Hollis Blanchard wrote:> I see you just renamed some structures in the unstable tree... now how > about exec_domain? Are we happy with "vcpu_state"?The ''_state'' seems a bit superfluous. How about just ''struct vcpu''?>> xen_regs/xen_state should probably be entirely arch-specific anyway. >> Even now it only pokes through into common code in interrupt-handler >> definitions (the final parameter is a xen_regs pointer). It''d be great >> to nuke those last few from common code. :-) > > Yup. I think this could be done by passing ''current'' to > show_registers(), and let the arch code figure out what to do from > there. After I get PPC to a more useful state I will see about the > patch, if somebody hasn''t beaten me to it...I''ve decided to backtracked on this one. Every architecture will have the concept of an interrupted activation, and a stack frame containing (at least some of) that activation''s state. The pointer passed to IRQ handlers is a pointer to that state on the stack. If we do not pass it explicitly to the handler then it is very hard to reliably recalculate it if it is needed, and it is useful for debugging purposes at the very least. A ''cpu_user_regs'' seems like something every arch can provide, right? -- Keir _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
Keir Fraser wrote:> > On 28 Apr 2005, at 19:10, Hollis Blanchard wrote: > >> I see you just renamed some structures in the unstable tree... now how >> about exec_domain? Are we happy with "vcpu_state"? > > The ''_state'' seems a bit superfluous. How about just ''struct vcpu''?Sure.>>> xen_regs/xen_state should probably be entirely arch-specific anyway. >>> Even now it only pokes through into common code in interrupt-handler >>> definitions (the final parameter is a xen_regs pointer). It''d be great >>> to nuke those last few from common code. :-) >> >> >> Yup. I think this could be done by passing ''current'' to >> show_registers(), and let the arch code figure out what to do from >> there. After I get PPC to a more useful state I will see about the >> patch, if somebody hasn''t beaten me to it... > > > I''ve decided to backtracked on this one. Every architecture will have > the concept of an interrupted activation, and a stack frame containing > (at least some of) that activation''s state.Doesn''t necessarily have to be on the stack; on PowerPC we are currently using a separately-allocated piece of memory.> The pointer passed to IRQ > handlers is a pointer to that state on the stack. If we do not pass it > explicitly to the handler then it is very hard to reliably recalculate > it if it is needed, and it is useful for debugging purposes at the very > least.What "debugging purposes"? We''ve already seen that the only common code using that type is to pass to (architecture-specific) show_registers(). x86 can get at its state by masking off ESP. PPC can get at it via ''current''. Why then pass a pointer through all interrupt handlers when none of them care?> A ''cpu_user_regs'' seems like something every arch can provide, right?PowerPC can, yes. -- Hollis Blanchard IBM Linux Technology Center _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
On 28 Apr 2005, at 19:58, Hollis Blanchard wrote:>> The pointer passed to IRQ >> handlers is a pointer to that state on the stack. If we do not pass it >> explicitly to the handler then it is very hard to reliably recalculate >> it if it is needed, and it is useful for debugging purposes at the >> very >> least. > > What "debugging purposes"?e.e., the ''d'' key handler that dumps register state.> We''ve already seen that the only common code > using that type is to pass to (architecture-specific) show_registers().Yes. Common code never dereferences cpu_user_regs, but it needs to receive it and pass it on.> x86 can get at its state by masking off ESP. PPC can get at it via > ''current''. Why then pass a pointer through all interrupt handlers when > none of them care?No, that gets you an exec_domain (or ''vcpu'', as we plan to rename it). Or it can get you the guest''s cpu_user_regs. But if you interrupted a Xen activation then there is no way of getting at that outer activation''s register state. Even Linux has a pt_regs parameter passed to every interrupt handler, so it must surely be a good thing to do. ;-) -- Keir _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel
Keir Fraser wrote:>> We''ve already seen that the only common code >> using that type is to pass to (architecture-specific) show_registers(). > > Yes. Common code never dereferences cpu_user_regs, but it needs to > receive it and pass it on.Shrug, I don''t mind things how they are, especially since Dan says it works for him. It just seems silly to pass it everywhere for a single user.>> x86 can get at its state by masking off ESP. PPC can get at it via >> ''current''. Why then pass a pointer through all interrupt handlers when >> none of them care? > > No, that gets you an exec_domain (or ''vcpu'', as we plan to rename it). > Or it can get you the guest''s cpu_user_regs. But if you interrupted a > Xen activation then there is no way of getting at that outer > activation''s register state.Ah, ok. I will have to think more about these activations.> Even Linux has a pt_regs parameter passed to every interrupt handler, so > it must surely be a good thing to do. ;-)Yes yes... :) -- Hollis Blanchard IBM Linux Technology Center _______________________________________________ Xen-devel mailing list Xen-devel@lists.xensource.com http://lists.xensource.com/xen-devel