From mboxrd@z Thu Jan 1 00:00:00 1970 From: Andrew Cooper Subject: Re: Segment registers at top of stack Date: Thu, 3 Jan 2013 17:14:54 +0000 Message-ID: <50E5BC8E.9090702@citrix.com> References: <50E5AB2E.7030608@citrix.com> <50E5C11502000078000B2CF2@nat28.tlf.novell.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii"; Format="flowed" Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <50E5C11502000078000B2CF2@nat28.tlf.novell.com> List-Unsubscribe: , List-Post: List-Help: List-Subscribe: , Sender: xen-devel-bounces@lists.xen.org Errors-To: xen-devel-bounces@lists.xen.org To: Jan Beulich Cc: "Tim (Xen.org)" , "Keir (Xen.org)" , Xen-devel List List-Id: xen-devel@lists.xenproject.org On 03/01/13 16:34, Jan Beulich wrote: >>>> On 03.01.13 at 17:00, Andrew Cooper wrote: >> While debugging an issue of 0xdeadbeef's appearing in a crash report, I >> have discovered that the es thru gs entries in cpu_user_regs appear to >> be completely unused on a 64bit hypervisor per-cpu stack. >> >> In 64bit mode, all segment register changes happen in >> {load,save}segments(). The only code I can find which ever sets these >> values is the NDEBUG poisoning on the VMX/SVM vmexit hypervisor entry paths. >> >> If the values are indeed completely unused, would it be sensible to >> remove them from the per-cpu stacks as we have now dropped support for >> the 32bit hypervisor (which certainly does use them)? > Doing that would imply breaking the association of there being > a struct cpu_user_regs close to the end of the stack - I'm sure > you realize that you can't drop these fields from that structure. I do realize that, hence the problem of doing this in a neat fashion. > I think that would uglify the code enough to warrant keeping > the fields instead. Of course you're free to prove the contrary. > > Jan > Ok - I was just wondering how much we cared about half a cache line. (The neatest way I can think of doing this would be to create a shadow structure and tweak the macros in current.h to always typecast it. Which is quite ugly under the surface, and problematic if some unknowing programmer does try and use the segment register values.) ~Andrew