Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751768AbdFGRym (ORCPT ); Wed, 7 Jun 2017 13:54:42 -0400 Received: from mail-wm0-f41.google.com ([74.125.82.41]:35256 "EHLO mail-wm0-f41.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751584AbdFGRyj (ORCPT ); Wed, 7 Jun 2017 13:54:39 -0400 Subject: Re: [PATCH v2] firmware: fix sending -ERESTARTSYS due to signal on fallback To: "Luis R. Rodriguez" , linux-fsdevel@vger.kernel.org, Alan Cox , "Ted Ts'o" , Andy Lutomirski , Dmitry Torokhov References: <20170524205658.GK8951@wotan.suse.de> <20170524214027.7775-1-mcgrof@kernel.org> <20170607170858.GK27288@wotan.suse.de> Cc: "Michael Kerrisk (man-pages)" , Linux API , Peter Zijlstra , Greg KH , Daniel Wagner , David Woodhouse , jewalt@lgsinnovations.com, rafal@milecki.pl, Arend Van Spriel , "Rafael J. Wysocki" , "Li, Yi" , atull@opensource.altera.com, Moritz Fischer , Petr Mladek , Johannes Berg , Emmanuel Grumbach , Luca Coelho , Kalle Valo , Linus Torvalds , Kees Cook , AKASHI Takahiro , David Howells , Peter Jones , Hans de Goede , "linux-kernel@vger.kernel.org" From: Martin Fuzzey Message-ID: <59383DDA.3040702@parkeon.com> Date: Wed, 7 Jun 2017 19:54:34 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.3.0 MIME-Version: 1.0 In-Reply-To: <20170607170858.GK27288@wotan.suse.de> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1277 Lines: 28 On 07/06/17 19:08, Luis R. Rodriguez wrote: > On Thu, May 25, 2017 at 10:28:38AM +0200, Fuzzey, Martin wrote: >> 1) Android init calls write() on the sysfs file >> 2) The sysfs .store() callback registered by a driver is called >> 3) The driver calls request_firmware() >> 4) request_firmware() sends the firmware load request to userspace and >> calls wait_for_completion_interruptible() > Martin, just for completeness on documenting on the commit log of the next > swait proposed fix for this -- what signal did the process get from which you > note the child dies below ? Exactly what in Android sent this signal ? Android didn't send the signal, the kernel did (SIGCHLD). Like this: 1) Android init (pid=1) fork()s (say pid=42) [this child process is totally unrelated to firmware loading] 2) Android init (pid=1) does a write() on a (driver custom) sysfs file which ends up calling request_firmware() kernel side 3) The firmware loading fallback mechanism is used, the request is sent to userspace and pid 1 waits in the kernel on wait_* 4) before firmware loading completes pid 42 dies (for any reason - in my case normal termination) 5) Kernel delivers SIGCHLD to pid=1 to tell it a child has died, which causes -ERESTARTSYS to be returned from wait_* Martin