summaryrefslogtreecommitdiffhomepage
path: root/src/mysql/ngx_http_mysql_test.c
diff options
context:
space:
mode:
authorRoman Arutyunyan <arut@nginx.com>2015-02-04 16:22:43 +0300
committerRoman Arutyunyan <arut@nginx.com>2015-02-04 16:22:43 +0300
commit06d72320ff5d5cd717b576920bc27c3e26329774 (patch)
treebf147e552ab2e14606ee828464a7207c28b7a127 /src/mysql/ngx_http_mysql_test.c
parentcb451bd6a46dd4b3053bc4ec2f667d4970c41665 (diff)
downloadnginx-06d72320ff5d5cd717b576920bc27c3e26329774.tar.gz
nginx-06d72320ff5d5cd717b576920bc27c3e26329774.tar.bz2
Core: fixed a race resulting in extra sem_post()'s.
The mtx->wait counter was not decremented if we were able to obtain the lock right after incrementing it. This resulted in unneeded sem_post() calls, eventually leading to EOVERFLOW errors being logged, "sem_post() failed while wake shmtx (75: Value too large for defined data type)". To close the race, mtx->wait is now decremented if we obtain the lock right after incrementing it in ngx_shmtx_lock(). The result can become -1 if a concurrent ngx_shmtx_unlock() decrements mtx->wait before the added code does. However, that only leads to one extra iteration in the next call of ngx_shmtx_lock().
Diffstat (limited to 'src/mysql/ngx_http_mysql_test.c')
0 files changed, 0 insertions, 0 deletions