[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen-unstable] libxc: Fix cpuid() inline asm.
# HG changeset patch # User Keir Fraser <keir.fraser@xxxxxxxxxx> # Date 1267037334 0 # Node ID f8692cc67d6706bf8fbbf65ce78113925cdf3004 # Parent 9c0793e75f541c58bf99b2c480e89497a537114f libxc: Fix cpuid() inline asm. Signed-off-by: Keir Fraser <keir.fraser@xxxxxxxxxx> --- tools/libxc/xc_cpuid_x86.c | 17 +++++++++++++---- 1 files changed, 13 insertions(+), 4 deletions(-) diff -r 9c0793e75f54 -r f8692cc67d67 tools/libxc/xc_cpuid_x86.c --- a/tools/libxc/xc_cpuid_x86.c Wed Feb 24 11:03:56 2010 +0000 +++ b/tools/libxc/xc_cpuid_x86.c Wed Feb 24 18:48:54 2010 +0000 @@ -43,12 +43,21 @@ static void cpuid(const unsigned int *in unsigned int count = (input[1] == XEN_CPUID_INPUT_UNUSED) ? 0 : input[1]; asm ( #ifdef __i386__ - "push %%ebx; cpuid; mov %%ebx,%1; pop %%ebx" + "push %%ebx; push %%edx\n\t" #else - "push %%rbx; cpuid; mov %%ebx,%1; pop %%rbx" + "push %%rbx; push %%rdx\n\t" #endif - : "=a" (regs[0]), "=r" (regs[1]), "=c" (regs[2]), "=d" (regs[3]) - : "0" (input[0]), "2" (count) ); + "cpuid\n\t" + "mov %%ebx,4(%4)\n\t" + "mov %%edx,12(%4)\n\t" +#ifdef __i386__ + "pop %%edx; pop %%ebx\n\t" +#else + "pop %%rdx; pop %%rbx\n\t" +#endif + : "=a" (regs[0]), "=c" (regs[2]) + : "0" (input[0]), "1" (count), "S" (regs) + : "memory" ); } /* Get the manufacturer brand name of the host processor. */ _______________________________________________ Xen-changelog mailing list Xen-changelog@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-changelog
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |