ptw32_getprocessors.c 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. /*
  2. * ptw32_getprocessors.c
  3. *
  4. * Description:
  5. * This translation unit implements routines which are private to
  6. * the implementation and may be used throughout it.
  7. *
  8. * --------------------------------------------------------------------------
  9. *
  10. * Pthreads-win32 - POSIX Threads Library for Win32
  11. * Copyright(C) 1998 John E. Bossom
  12. * Copyright(C) 1999,2005 Pthreads-win32 contributors
  13. *
  14. * Contact Email: [email protected]
  15. *
  16. * The current list of contributors is contained
  17. * in the file CONTRIBUTORS included with the source
  18. * code distribution. The list can also be seen at the
  19. * following World Wide Web location:
  20. * http://sources.redhat.com/pthreads-win32/contributors.html
  21. *
  22. * This library is free software; you can redistribute it and/or
  23. * modify it under the terms of the GNU Lesser General Public
  24. * License as published by the Free Software Foundation; either
  25. * version 2 of the License, or (at your option) any later version.
  26. *
  27. * This library is distributed in the hope that it will be useful,
  28. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  29. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  30. * Lesser General Public License for more details.
  31. *
  32. * You should have received a copy of the GNU Lesser General Public
  33. * License along with this library in the file COPYING.LIB;
  34. * if not, write to the Free Software Foundation, Inc.,
  35. * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
  36. */
  37. #include "pthread.h"
  38. #include "implement.h"
  39. /*
  40. * ptw32_getprocessors()
  41. *
  42. * Get the number of CPUs available to the process.
  43. *
  44. * If the available number of CPUs is 1 then pthread_spin_lock()
  45. * will block rather than spin if the lock is already owned.
  46. *
  47. * pthread_spin_init() calls this routine when initialising
  48. * a spinlock. If the number of available processors changes
  49. * (after a call to SetProcessAffinityMask()) then only
  50. * newly initialised spinlocks will notice.
  51. */
  52. int
  53. ptw32_getprocessors (int *count)
  54. {
  55. DWORD_PTR vProcessCPUs;
  56. DWORD_PTR vSystemCPUs;
  57. int result = 0;
  58. #if defined(NEED_PROCESS_AFFINITY_MASK)
  59. *count = 1;
  60. #else
  61. if (GetProcessAffinityMask (GetCurrentProcess (),
  62. &vProcessCPUs, &vSystemCPUs))
  63. {
  64. DWORD_PTR bit;
  65. int CPUs = 0;
  66. for (bit = 1; bit != 0; bit <<= 1)
  67. {
  68. if (vProcessCPUs & bit)
  69. {
  70. CPUs++;
  71. }
  72. }
  73. *count = CPUs;
  74. }
  75. else
  76. {
  77. result = EAGAIN;
  78. }
  79. #endif
  80. return (result);
  81. }