Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Can't set CPU affinity when having more than 63 cores #443

Closed
giampaolo opened this issue May 23, 2014 · 11 comments
Closed

Can't set CPU affinity when having more than 63 cores #443

giampaolo opened this issue May 23, 2014 · 11 comments

Comments

@giampaolo
Copy link
Owner

From andr...@sandberg.pp.se on October 31, 2013 19:24:24

The current code does not support systems with more than 63 cores since this 
triggers the following exception when setting affinity masks:

  File "utils/osutils.py", line 199, in set_affinity
    p.set_cpu_affinity(tuple(cpus))
  File "/home/ansan501/.local/lib/python2.7/site-packages/psutil/__init__.py", 
line 546, in set_cpu_affinity
    return self._platform_impl.set_process_cpu_affinity(cpus)
  File "/home/ansan501/.local/lib/python2.7/site-packages/psutil/_pslinux.py", 
line 445, in wrapper
    return fun(self, *args, **kwargs)
  File "/home/ansan501/.local/lib/python2.7/site-packages/psutil/_pslinux.py", 
line 820, in set_process_cpu_affinity
    _psutil_linux.set_process_cpu_affinity(self.pid, bitmask)
OverflowError: Python int too large to convert to C long

The workaround I'm using at the moment changes the interface to the C code. 
Instead of generating a bit mask in Python, it takes a sequence of CPU IDs and 
builds the cpu_set_t structure using the CPU_SET macros.

I've attached a patch that updates the Linux implementation.

Attachment: fix_large_system.patch

Original issue: http://code.google.com/p/psutil/issues/detail?id=443

@giampaolo
Copy link
Owner Author

From g.rodola on November 08, 2013 06:24:34

Please try this and tell me if it helps:


diff --git a/psutil/_psutil_linux.c b/psutil/_psutil_linux.c
--- a/psutil/_psutil_linux.c
+++ b/psutil/_psutil_linux.c
@@ -278,7 +278,7 @@
     unsigned int len = sizeof(mask);
     long pid;

-    if (!PyArg_ParseTuple(args, "ll", &pid, &mask)) {
+    if (!PyArg_ParseTuple(args, "lk", &pid, &mask)) {
         return NULL;
     }
     if (sched_setaffinity(pid, len, (cpu_set_t *)&mask)) {


I'm also attaching a modified version of your patch fixing a couple of issues 
but I would prefer to keep calculating the bitmask in Python (as opposed to 
using macros in C) as it's easier to read/maintain.

Attachment: fix_large_system.patch

@giampaolo
Copy link
Owner Author

From g.rodola on November 13, 2013 00:54:17

Up?

@giampaolo
Copy link
Owner Author

From andr...@sandberg.pp.se on November 13, 2013 04:29:49

I'll try to look into it end of next week. I'm pretty busy at the moment, but 
there should be some slack by then.

@giampaolo
Copy link
Owner Author

From g.rodola on November 13, 2013 04:48:18

Thanks.

@giampaolo
Copy link
Owner Author

From g.rodola on November 22, 2013 13:30:12

I committed this change as of revision af898681e7be . 
I'm going to consider this closed for now. Let me know if I'm mistaken.

Status: FixedInHG
Labels: OpSys-Linux Milestone-1.2.1

@giampaolo
Copy link
Owner Author

From g.rodola on November 26, 2013 00:52:33

Closing.

@giampaolo
Copy link
Owner Author

From g.rodola on November 26, 2013 00:52:51

Status: Fixed

@giampaolo
Copy link
Owner Author

From andr...@sandberg.pp.se on November 26, 2013 07:33:18

I just got around to test it and it seems to work fine on our machine. But, 
isn't your fix going to break as soon as someone runs this on a machine with 
more than 64 threads? Besides, CPU_SET(3) is pretty clear on how cpu_set_t 
structures should be constructed: "...the data structure treated as considered 
opaque: all manipulation of CPU sets should be done via the macros described in 
this page.".

@giampaolo
Copy link
Owner Author

From g.rodola on November 26, 2013 08:50:57

> But, isn't your fix going to break as soon as someone runs this on a machine 
with more than 64 threads?

Mmm... Why do you think so?

@giampaolo
Copy link
Owner Author

From andr...@sandberg.pp.se on November 26, 2013 08:59:02

If I understand things correctly, the bitmask from Python is going to be 
converted to a 64-bit unsigned long, hence the 64 threads limit.

IIRC, the by default the recent Linux implementations use a 1024-bit cpu_set_t, 
but this can be extended to arbitrarily sizes by using CPU_ALLOC.

@giampaolo
Copy link
Owner Author

From g.rodola on December 03, 2013 00:51:42

I think you may be right. Committed the C version in revision e0df8ab562a6 .

Labels: Milestone-1.2.2

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant