From mboxrd@z Thu Jan 1 00:00:00 1970 From: Steven Rostedt Subject: Re: [RFC][PATCH RT 0/3] RT: Fix trylock deadlock without msleep() hack Date: Sat, 5 Sep 2015 08:50:48 -0400 Message-ID: <20150905085048.5cefbf5b@gandalf.local.home> References: <20150904011900.730816481@goodmis.org> <20150905081836.2967d80d@gandalf.local.home> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Cc: linux-kernel@vger.kernel.org, linux-rt-users , Carsten Emde , Sebastian Andrzej Siewior , John Kacur , Paul Gortmaker , Peter Zijlstra , Clark Williams , Arnaldo Carvalho de Melo , Ingo Molnar To: Thomas Gleixner Return-path: Received: from smtprelay0181.hostedemail.com ([216.40.44.181]:36163 "EHLO smtprelay.hostedemail.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1750810AbbIEMuv (ORCPT ); Sat, 5 Sep 2015 08:50:51 -0400 In-Reply-To: <20150905081836.2967d80d@gandalf.local.home> Sender: linux-rt-users-owner@vger.kernel.org List-ID: On Sat, 5 Sep 2015 08:18:36 -0400 Steven Rostedt wrote: > On Sat, 5 Sep 2015 12:30:59 +0200 (CEST) > Thomas Gleixner wrote: > > > > So instead of doing that proposed magic boost, we can do something > > more straight forward: > > > > retry: > > lock(B); > > if (!try_lock(A)) { > > lock_and_drop(A, B); > > unlock(A); > > goto retry; > > } > > > > lock_and_drop() queues the task as a waiter on A, drops B and then > > does the PI adjustment on A. > > That was my original solution, and I believe I added patches to do > exactly that to the networking code in the past. I remember writing > that helper function such that on non PREEMPT_RT it was a nop. Just to point out again that I misread what you wrote. That's what I get for responding to email 10 minutes after I get out of bed ;-) You need to be careful about adding the waiter on A. If the owner of A is blocked on B, the pi inheritance may detect that as a deadlock. -- Steve