svn commit: r397114 - in head/graphics/appleseed: . files
    Alexey Dokuchaev 
    danfe at FreeBSD.org
       
    Thu Sep 17 14:10:13 UTC 2015
    
    
  
Author: danfe
Date: Thu Sep 17 14:10:12 2015
New Revision: 397114
URL: https://svnweb.freebsd.org/changeset/ports/397114
Log:
  Improve cpuid() implementation:
  - Correctly denote register use: for CPUID, %eax and %ecx are input/output
    and %ebx and %edx are output only
  - Do not insist on using %esi and %edi, let the compiler choose a register
  - Always preserve %ebx/%rbx because ABI defines them as callee-saved
  - Use xchg[lq] instead of mov[lq] to restore %ebx/%rbx
  - Use separate implementation for x86-64 to preserve %rbx because 32-bit
    operations would set the upper 32 bits to zero
  
  Submitted by:	tijl
Modified:
  head/graphics/appleseed/Makefile
  head/graphics/appleseed/files/patch-src_appleseed_foundation_platform_system.cpp
Modified: head/graphics/appleseed/Makefile
==============================================================================
--- head/graphics/appleseed/Makefile	Thu Sep 17 13:55:48 2015	(r397113)
+++ head/graphics/appleseed/Makefile	Thu Sep 17 14:10:12 2015	(r397114)
@@ -3,6 +3,7 @@
 
 PORTNAME=	appleseed
 DISTVERSION=	1.2.0-beta
+PORTREVISION=	1
 CATEGORIES=	graphics
 
 MAINTAINER=	danfe at FreeBSD.org
Modified: head/graphics/appleseed/files/patch-src_appleseed_foundation_platform_system.cpp
==============================================================================
--- head/graphics/appleseed/files/patch-src_appleseed_foundation_platform_system.cpp	Thu Sep 17 13:55:48 2015	(r397113)
+++ head/graphics/appleseed/files/patch-src_appleseed_foundation_platform_system.cpp	Thu Sep 17 14:10:12 2015	(r397114)
@@ -15,7 +15,7 @@
  // Other platforms.
  #else
  
-@@ -421,6 +429,386 @@ uint64 System::get_process_virtual_memor
+@@ -421,6 +429,390 @@ uint64 System::get_process_virtual_memor
      return static_cast<uint64>(rss) * sysconf(_SC_PAGESIZE);
  }
  
@@ -43,26 +43,30 @@
 +    size_t linesize;
 +} mycaches[3];
 +
-+// %ebx is used to point to GOT (Global Offset Table) for PIC (Position
-+// Independent Code) on 32-bit x86, so use %edi to preserve %ebx across
-+// the call and %esi when passing CPUID arguments and return values.
++// %ebx may be used to point to GOT (Global Offset Table) for PIC (Position
++// Independent Code) on 32-bit x86, so it must be preserved.  Normally
++// compilers handle this implicitly because %ebx is also callee saved, but
++// GCC before 5.0 forbids any use of %ebx with PIC, so it must be performed
++// explicitly.  Unfortunately, we need a separate implementation for x86-64
++// to preserve %rbx because 32-bit operations would set the upper 32 bits
++// to zero.
 +static inline void
-+cpuid(uint32_t* data)
++cpuid(uint32_t* regs)
 +{
-+    asm("movl %%ebx, %%edi\n\t"
-+        "movl %%esi, %%ebx\n\t"
++    asm(
++#if __x86_64__
++        "movq %%rbx, %q1\n\t"
 +        "cpuid\n\t"
-+        "movl %%ebx, %%esi\n\t"
-+        "movl %%edi, %%ebx"
-+      : "=a" (data[eax]),
-+        "=S" (data[ebx]),
-+        "=c" (data[ecx]),
-+        "=d" (data[edx])
-+      :  "a" (data[eax]),
-+         "S" (data[ebx]),
-+         "c" (data[ecx]),
-+         "d" (data[edx])
-+      : "%edi");
++        "xchgq %%rbx, %q1"
++#else
++        "movl %%ebx, %1\n\t"
++        "cpuid\n\t"
++        "xchgl %%ebx, %1"
++#endif
++      : "+a" (regs[eax]),
++        "=r" (regs[ebx]),
++        "+c" (regs[ecx]),
++        "=d" (regs[edx]));
 +}
 +
 +// For modern CPUs, we use Deterministic Cache Parameters (Function 04h) to
    
    
More information about the svn-ports-head
mailing list