Hi Oleg, Thanks for taking a look! On Thu, May 17, 2018 at 05:33:24PM +0200, Oleg Nesterov wrote: > I didn't read this series yet, and I don't even understand what are you > trying to do, just one question... > > On 05/17, Tycho Andersen wrote: > > > > +static struct file *init_listener(struct task_struct *task, > > + struct seccomp_filter *filter) > > +{ > > + struct file *ret = ERR_PTR(-EBUSY); > > + struct seccomp_filter *cur; > > + bool have_listener = false; > > + > > + for (cur = task->seccomp.filter; cur; cur = cur->prev) { > > + mutex_lock(&cur->notify_lock); > > Did you test this patch with CONFIG_LOCKDEP ? Yes, with, CONFIG_LOCKDEP=y CONFIG_DEBUG_LOCKDEP=y CONFIG_DEBUG_ATOMIC_SLEEP=y > From lockdep pov this loop tries to take the same lock twice or more, it shoul > complain. I didn't, but I guess that's because it's not trying to take the same lock twice -- the pointer cur is changing in the loop. Unless I'm misunderstanding what you're saying. The idea behind this code is to lock the entire chain of filters up to the parent so that we can ensure none of them have a listener installed. This is based on a suggestion from Andy last review cycle to not allow two listeners, since nesting would be confusing. Tycho _______________________________________________ Containers mailing list Containers@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linuxfoundation.org/mailman/listinfo/containers