diff options
| author | Maxim Dounin <mdounin@mdounin.ru> | 2012-02-05 19:25:24 +0000 |
|---|---|---|
| committer | Maxim Dounin <mdounin@mdounin.ru> | 2012-02-05 19:25:24 +0000 |
| commit | a491bd5799bf04ac6ea85d5090ac22f603a981b4 (patch) | |
| tree | cf0e93af06a15ddb6c01a3ddbb25e74aa506d9fa /src/os/unix/ngx_process_cycle.c | |
| parent | c8d012d425137f36ee0b509ce1e95f339cfe5cbc (diff) | |
| download | nginx-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.
Diffstat (limited to 'src/os/unix/ngx_process_cycle.c')
| -rw-r--r-- | src/os/unix/ngx_process_cycle.c | 5 |
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); } |
