[LTP] [PATCH] mem/mmapstress10: fix hangs with recent glibc

Jan Stancek jstancek@redhat.com
Wed Sep 19 09:32:52 CEST 2018



----- Original Message -----
> Hi!
> > There haven't been any major changes to this test in years,
> > so presumably something in recent glibc changed, that exposed
> > this problem.
> 
> I guess that it may have been elsewhere as well, such as kernel
> scheduller changes, etc.
> 
> > I confirmed with glibc-2.28, that this test can hang quite reliably
> > on 2 CPU KVM guest. It reproduces easier with smaller number of loops
> > for child_mapper() and overall test runtime reduced (-p 20 -t 0.02).
> > 
> > The problem is that childs' signal handler and main function both
> > call exit(), which can deadlock on __exit_funcs_lock:
> > 
> >   #0  0x00007f0619d72f8c in __lll_lock_wait_private () from
> >   /lib64/libc.so.6
> >   #1  0x00007f0619ca2f4b in __run_exit_handlers () from /lib64/libc.so.6
> >   #2  0x00007f0619ca3160 in exit () from /lib64/libc.so.6
> >   #3  0x00000000004039d8 in clean_mapper (sig=<optimized out>) at
> >   mmapstress10.c:898
> >   #4  <signal handler called>
> >   #5  0x00007f0619ca2fbd in __run_exit_handlers () from /lib64/libc.so.6
> >   #6  0x00007f0619ca3160 in exit () from /lib64/libc.so.6
> >   #7  0x0000000000403e7f in child_mapper (file=file@entry=0x40f530
> >   "mmapstress10.out", procno=<optimized out>,
> >       nprocs=nprocs@entry=20) at mmapstress10.c:676
> >   #8  0x0000000000403833 in main (argc=<optimized out>, argv=<optimized
> >   out>) at mmapstress10.c:458
> > 
> > Switch all signal handlers to _exit().
> 
> Looks like a reasonable band aid for the problem. I looked shortly at
> the source code and anything cleaner would require larger rewrite, so
> acked.

Pushed.

Regards,
Jan


More information about the ltp mailing list