Welcome! Log In Create A New Profile

Advanced

Re: Potential bug in ngx_event.c

Maxim Dounin
August 31, 2019 02:30PM
Hello!

On Fri, Aug 30, 2019 at 06:26:57PM -0700, Rian Hunter wrote:

> On 2019-08-30 07:19, Maxim Dounin wrote:
> > Hello!
> >
> > On Fri, Aug 23, 2019 at 11:00:41AM -0700, Rian Hunter wrote:
> >
> >> While browsing the source I noticed something that seemed wrong, even
> >> though I haven't observed any buggy behavior or have reproduced this
> >> bug
> >> myself. In ngx_event.c there is a line:
> >>
> >> if (ngx_shmtx_create(&ngx_accept_mutex, (ngx_shmtx_sh_t *)
> >> shared,
> >> cycle->lock_file.data)
> >> != NGX_OK)
> >> {
> >> return NGX_ERROR;
> >> }
> >>
> >> ngx_shmtx_create() is passed &ngx_accept_mutex, but this must be a
> >> pointer to a shared memory region otherwise the sem_wait()/sem_post()
> >> calls in ngx_shmtx.c will not function correctly. &ngx_accept_mutex is
> >> a
> >> pointer to BSS, ngx_accept_mutex_ptr is a pointer to shared memory. Is
> >> this intentional?
> >
> > Yes, this is intentional.
> >
> > The first agument of the ngx_shmtx_create() function is a pointer
> > to the ngx_shmtx_t structure, which is not expected to be shared
> > between processes. Copy of the structure as created by fork() is
> > enough.
>
> The POSIX sem_t member (called "sem") needs to reside in shared memory
> if sem_wait()/sem_post() are to have an effect across processes. Memory
> copied across fork is not sufficient.

No, fork() is explicitly documented to preserve semaphores
(http://pubs.opengroup.org/onlinepubs/9699919799/functions/fork.html):

: Any semaphores that are open in the parent process shall also be
: open in the child process.

--
Maxim Dounin
http://mdounin.ru/
_______________________________________________
nginx-devel mailing list
nginx-devel@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx-devel
Subject Author Views Posted

Potential bug in ngx_event.c

Rian Hunter 596 August 23, 2019 02:02PM

Re: Potential bug in ngx_event.c

Maxim Dounin 266 August 30, 2019 10:20AM

Re: Potential bug in ngx_event.c

Rian Hunter 268 August 30, 2019 09:28PM

Re: Potential bug in ngx_event.c

Maxim Dounin 266 August 31, 2019 02:30PM

Re: Potential bug in ngx_event.c

Rian Hunter 262 September 01, 2019 02:46PM

Re: Potential bug in ngx_event.c

Maxim Dounin 262 September 02, 2019 12:24PM

Re: Potential bug in ngx_event.c

Rian Hunter 291 September 02, 2019 12:50PM



Sorry, you do not have permission to post/reply in this forum.

Online Users

Guests: 307
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready