0001-core-fix-x86-PIC-code-compilation.patch 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. From ea50be0529c248961e1b66293f8a9e4b807294a6 Mon Sep 17 00:00:00 2001
  2. From: Samuel Martin <s.martin49@gmail.com>
  3. Date: Sun, 12 Oct 2014 10:17:23 +0200
  4. Subject: [PATCH] core: fix x86 PIC code compilation
  5. This bug was triggered by Buildroot autobuilders [1,2], causing this
  6. kind of failures [3,4]:
  7. [ 14%] Building CXX object modules/core/CMakeFiles/opencv_core.dir/src/system.cpp.o
  8. /home/test/autobuild/instance-0/output/build/opencv-2.4.10/modules/core/src/system.cpp: In function '(static initializers for /home/test/autobuild/instance-0/output/build/opencv-2.4.10/modules/core/src/system.cpp)':
  9. /home/test/autobuild/instance-0/output/build/opencv-2.4.10/modules/core/src/system.cpp:280:10: error: inconsistent operand constraints in an 'asm'
  10. make[3]: *** [modules/core/CMakeFiles/opencv_core.dir/src/system.cpp.o] Error 1
  11. [1] http://buildroot.org/
  12. [2] http://autobuild.buildroot.org/
  13. [3] http://autobuild.buildroot.org/?reason=opencv-2.4.10
  14. [4] http://autobuild.buildroot.org/results/483/4838285b25d6293a5cf0bb9eadd5040a7c75d766/build-end.log
  15. Signed-off-by: Samuel Martin <s.martin49@gmail.com>
  16. ---
  17. modules/core/src/system.cpp | 5 ++++-
  18. 1 file changed, 4 insertions(+), 1 deletion(-)
  19. diff --git a/modules/core/src/system.cpp b/modules/core/src/system.cpp
  20. index 5a970d5..e9ffdc7 100644
  21. --- a/modules/core/src/system.cpp
  22. +++ b/modules/core/src/system.cpp
  23. @@ -267,14 +267,17 @@ struct HWFeatures
  24. : "cc"
  25. );
  26. #else
  27. + // We need to preserve ebx since we are compiling PIC code.
  28. + // This means we cannot use "=b" for the 2nd output register.
  29. asm volatile
  30. (
  31. "pushl %%ebx\n\t"
  32. "movl $7,%%eax\n\t"
  33. "movl $0,%%ecx\n\t"
  34. "cpuid\n\t"
  35. + "movl %%ebx,%1\n\t"
  36. "popl %%ebx\n\t"
  37. - : "=a"(cpuid_data[0]), "=b"(cpuid_data[1]), "=c"(cpuid_data[2]), "=d"(cpuid_data[3])
  38. + : "=a"(cpuid_data[0]), "=r"(cpuid_data[1]), "=c"(cpuid_data[2]), "=d"(cpuid_data[3])
  39. :
  40. : "cc"
  41. );
  42. --
  43. 2.1.2