summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorMaxim Dounin <mdounin@mdounin.ru>2012-02-05 19:25:24 +0000
committerMaxim Dounin <mdounin@mdounin.ru>2012-02-05 19:25:24 +0000
commita491bd5799bf04ac6ea85d5090ac22f603a981b4 (patch)
treecf0e93af06a15ddb6c01a3ddbb25e74aa506d9fa
parentc8d012d425137f36ee0b509ce1e95f339cfe5cbc (diff)
downloadnginx-a491bd5799bf04ac6ea85d5090ac22f603a981b4.tar.gz
nginx-a491bd5799bf04ac6ea85d5090ac22f603a981b4.tar.bz2
Merge of r4404:
Fixed sched_setaffinity(2) to correctly pass size. Second argument (cpusetsize) is size in bytes, not in bits. Previously used constant 32 resulted in reading of uninitialized memory and caused EINVAL to be returned on some Linux kernels.
-rw-r--r--src/os/unix/ngx_process_cycle.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/os/unix/ngx_process_cycle.c b/src/os/unix/ngx_process_cycle.c
index 863176fac..fbf18a5f2 100644
--- a/src/os/unix/ngx_process_cycle.c
+++ b/src/os/unix/ngx_process_cycle.c
@@ -914,7 +914,10 @@ ngx_worker_process_init(ngx_cycle_t *cycle, ngx_uint_t priority)
ngx_log_error(NGX_LOG_NOTICE, cycle->log, 0,
"sched_setaffinity(0x%08Xl)", cpu_affinity);
- if (sched_setaffinity(0, 32, (cpu_set_t *) &cpu_affinity) == -1) {
+ if (sched_setaffinity(0, sizeof(cpu_affinity),
+ (cpu_set_t *) &cpu_affinity)
+ == -1)
+ {
ngx_log_error(NGX_LOG_ALERT, cycle->log, ngx_errno,
"sched_setaffinity(0x%08Xl) failed", cpu_affinity);
}