summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjan.nijtmans <nijtmans@users.sourceforge.net>2013-01-26 17:04:32 (GMT)
committerjan.nijtmans <nijtmans@users.sourceforge.net>2013-01-26 17:04:32 (GMT)
commit3913f5f7ae7a33c61fc920be7e80a852dce3dd7c (patch)
treed938997fea3a822a6d235147cf1cc814c753dbb8
parente8c69aa65400fd70a846835460c27f6a5f4d962e (diff)
parent13dcbf7d2f2bef37cc4b71beb494d7a3cd140b72 (diff)
downloadtcl-3913f5f7ae7a33c61fc920be7e80a852dce3dd7c.zip
tcl-3913f5f7ae7a33c61fc920be7e80a852dce3dd7c.tar.gz
tcl-3913f5f7ae7a33c61fc920be7e80a852dce3dd7c.tar.bz2
merge trunk
-rw-r--r--ChangeLog5
-rw-r--r--unix/tclUnixCompat.c8
2 files changed, 13 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 0b853e4..0c000b5 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2013-01-26 Jan Nijtmans <nijtmans@users.sf.net>
+
+ * unix/tclUnixCompat.c: [Bug 3601804]: platformCPUID segmentation
+ fault on Darwin.
+
2013-01-23 Donal K. Fellows <dkf@users.sf.net>
* library/http/http.tcl (http::geturl): [Bug 2911139]: Do not do vwait
diff --git a/unix/tclUnixCompat.c b/unix/tclUnixCompat.c
index c1e1075..2a68f7f 100644
--- a/unix/tclUnixCompat.c
+++ b/unix/tclUnixCompat.c
@@ -995,11 +995,19 @@ TclWinCPUID(
/* See: <http://en.wikipedia.org/wiki/CPUID> */
#if defined(HAVE_CPUID)
+#if defined(__x86_64__) || defined(_M_AMD64) || defined (_M_X64)
+ __asm__ __volatile__("movq %%rbx, %%rsi \n\t" /* save %rbx */
+ "cpuid \n\t"
+ "xchgq %%rsi, %%rbx \n\t" /* restore the old %rbx */
+ : "=a"(regsPtr[0]), "=S"(regsPtr[1]), "=c"(regsPtr[2]), "=d"(regsPtr[3])
+ : "a"(index));
+#else
__asm__ __volatile__("mov %%ebx, %%esi \n\t" /* save %ebx */
"cpuid \n\t"
"xchg %%esi, %%ebx \n\t" /* restore the old %ebx */
: "=a"(regsPtr[0]), "=S"(regsPtr[1]), "=c"(regsPtr[2]), "=d"(regsPtr[3])
: "a"(index));
+#endif
status = TCL_OK;
#endif
return status;