diff options
author | jan.nijtmans <nijtmans@users.sourceforge.net> | 2012-05-02 14:37:55 (GMT) |
---|---|---|
committer | jan.nijtmans <nijtmans@users.sourceforge.net> | 2012-05-02 14:37:55 (GMT) |
commit | 65478b5874aec3cbe6f044dd9c35efa54df06e16 (patch) | |
tree | ed9c39cddc7f1e2bf89be36562757c032f4f323e /unix/tclUnixCompat.c | |
parent | 705a4980e3edde26965b3f0558fc55158527d618 (diff) | |
download | tcl-65478b5874aec3cbe6f044dd9c35efa54df06e16.zip tcl-65478b5874aec3cbe6f044dd9c35efa54df06e16.tar.gz tcl-65478b5874aec3cbe6f044dd9c35efa54df06e16.tar.bz2 |
cpuid-on-unix
Diffstat (limited to 'unix/tclUnixCompat.c')
-rw-r--r-- | unix/tclUnixCompat.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/unix/tclUnixCompat.c b/unix/tclUnixCompat.c index a39dbbe..1424ab3 100644 --- a/unix/tclUnixCompat.c +++ b/unix/tclUnixCompat.c @@ -990,14 +990,13 @@ TclWinCPUID( { int status = TCL_ERROR; -#if defined(HAVE_CPUID) && defined(__CYGWIN__) - __asm__ __volatile__("pushl %%ebx \n\t" /* save %ebx */ +#if defined(HAVE_CPUID) + __asm__ __volatile__("mov %%ebx, %%edi \n\t" /* save %ebx */ "cpuid \n\t" - "movl %%ebx, %1 \n\t" /* save what cpuid just put in %ebx */ - "popl %%ebx \n\t" /* restore the old %ebx */ - : "=a"(regsPtr[0]), "=r"(regsPtr[1]), "=c"(regsPtr[2]), "=d"(regsPtr[3]) - : "a"(index) - : "cc"); + "mov %%ebx, %%esi \n\t" /* save what cpuid just put in %ebx */ + "mov %%edi, %%ebx \n\t" /* restore the old %ebx */ + : "=a"(regsPtr[0]), "=S"(regsPtr[1]), "=c"(regsPtr[2]), "=d"(regsPtr[3]) + : "a"(index)); status = TCL_OK; #endif return status; |