Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp394992ybt; Fri, 26 Jun 2020 02:01:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwr/BvBHA6RaREoi35C0dHHNufsp7oTvUCsM5/FlaKMcUNa3Zbxc3RKWcwpLz4ArdFfr+Fa X-Received: by 2002:a17:906:1414:: with SMTP id p20mr1611457ejc.247.1593162117430; Fri, 26 Jun 2020 02:01:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593162117; cv=none; d=google.com; s=arc-20160816; b=oy9Vx9QK4kSmfMzQCyFtU6/+0PLRO8GT3I+6MKZcyXWwoyPV4PmUcXh17C/GbFXusV rAjg6vYhEpvVB6Ituiev9scBkCP7Lp9IF6cb/cdz81Fe8/skhzes+21n6O9vN94ZnXjE UIZE1Bm1ha3QRRcRPvCYV0JAn/StHDdpwBUPam9vcrDJSgmHlwScP+BoUVPE27wYkt6v dKu4OcNS58xBvqLhvHz0jLWAb9DlnTHmiBxg5l/tFeRNtNOtXxgvAHVIasBTbe4U8RNT miCPhG2jBAwzW4GkROzf30/JmqB1+MPOWjxfIXrDnkMmaElRWq0LGhmkCryJMTKL6+LX KumA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=PW5Ju7i2z/xdb7PaCVtfmKC/YY2ETFHvsdEj0WQnO9U=; b=wsVLoKEMygrEU0LyWKqY3wT4QdfepSNM0OtV8W9G7RLWnsn4nfmiPzlWVFASWwZytB tMibaMcisiUeUU4W91z3vushn+52CIlfXZPiOZ71Y61Gxp7OhPhM3ciJFXl6IwtIx2To ceNnvpjIBk30Wk1IPO+z0zYzHFugujPEd82H6EoqzvFVNwDPFID1IaWmoO/Q+VwV8pfv BKlnFFOL4w+7I4ref8ZKGmBkIt72h6QZ9NQzRBa30KxajgorrPk+FUMLl4dIfwSEW8aL 60MogaDvyMfJaDVXjnwwfERj8cbC6seE6lAsktiJMmGqpI9EX1sW36xdmtYH62m1mGYY YBNA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=casper.20170209 header.b=H0t9tcKO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r23si237310edy.317.2020.06.26.02.01.33; Fri, 26 Jun 2020 02:01:57 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=fail header.i=@infradead.org header.s=casper.20170209 header.b=H0t9tcKO; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726165AbgFZJBS (ORCPT + 99 others); Fri, 26 Jun 2020 05:01:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49280 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725820AbgFZJBR (ORCPT ); Fri, 26 Jun 2020 05:01:17 -0400 Received: from casper.infradead.org (unknown [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2FD36C08C5C1; Fri, 26 Jun 2020 02:01:17 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=PW5Ju7i2z/xdb7PaCVtfmKC/YY2ETFHvsdEj0WQnO9U=; b=H0t9tcKO/oe2xP19f0tqZ2btQ2 JydK0qH+x4SGaETRrERKdMOpP621gT0V3kPnsFp86jSzNYd24TuXWryuHydxSYYaOE1tFaSz7xDmh rftH0TCYRw7oTvAnQAZT3kQwbGv6xjkmFVSUfAu3Vedud733FNTz/Yp3HW0Fl2W6H/0VE0DEckB9s fvQjjc574P7/dfEj2sLldqMG5TzexTqTAAkV7qWphtWgkzgmQTX3sSJy0UOTFW6iYfKnOZAY061Mp GXVh1/UHj5bzI6Yit0MKd/wtbdVF+8i0N5bVT6NPR3SUUiA39SuWJMG9gkiKlUm76y44fglbXvRzT sftdo1RQ==; Received: from hch by casper.infradead.org with local (Exim 4.92.3 #3 (Red Hat Linux)) id 1jokDJ-0008JE-71; Fri, 26 Jun 2020 09:00:01 +0000 Date: Fri, 26 Jun 2020 10:00:01 +0100 From: Christoph Hellwig To: Christian Borntraeger Cc: Luis Chamberlain , Christoph Hellwig , ast@kernel.org, axboe@kernel.dk, bfields@fieldses.org, bridge@lists.linux-foundation.org, chainsaw@gentoo.org, christian.brauner@ubuntu.com, chuck.lever@oracle.com, davem@davemloft.net, dhowells@redhat.com, gregkh@linuxfoundation.org, jarkko.sakkinen@linux.intel.com, jmorris@namei.org, josh@joshtriplett.org, keescook@chromium.org, keyrings@vger.kernel.org, kuba@kernel.org, lars.ellenberg@linbit.com, linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, linux-nfs@vger.kernel.org, linux-security-module@vger.kernel.org, nikolay@cumulusnetworks.com, philipp.reisner@linbit.com, ravenexp@gmail.com, roopa@cumulusnetworks.com, serge@hallyn.com, slyfox@gentoo.org, viro@zeniv.linux.org.uk, yangtiezhu@loongson.cn, netdev@vger.kernel.org, markward@linux.ibm.com, linux-s390 Subject: Re: linux-next: umh: fix processed error when UMH_WAIT_PROC is used seems to break linux bridge on s390x (bisected) Message-ID: <20200626090001.GA30103@infradead.org> References: <3118dc0d-a3af-9337-c897-2380062a8644@de.ibm.com> <20200624144311.GA5839@infradead.org> <9e767819-9bbe-2181-521e-4d8ca28ca4f7@de.ibm.com> <20200624160953.GH4332@42.do-not-panic.com> <4e27098e-ac8d-98f0-3a9a-ea25242e24ec@de.ibm.com> <4d8fbcea-a892-3453-091f-d57c03f9aa90@de.ibm.com> <1263e370-7cee-24d8-b98c-117bf7c90a83@de.ibm.com> <20200626025410.GJ4332@42.do-not-panic.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-SRS-Rewrite: SMTP reverse-path rewritten from by casper.infradead.org. See http://www.infradead.org/rpr.html Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jun 26, 2020 at 07:22:34AM +0200, Christian Borntraeger wrote: > > > On 26.06.20 04:54, Luis Chamberlain wrote: > > On Wed, Jun 24, 2020 at 08:37:55PM +0200, Christian Borntraeger wrote: > >> > >> > >> On 24.06.20 20:32, Christian Borntraeger wrote: > >> [...]> > >>> So the translations look correct. But your change is actually a sematic change > >>> if(ret) will only trigger if there is an error > >>> if (KWIFEXITED(ret)) will always trigger when the process ends. So we will always overwrite -ECHILD > >>> and we did not do it before. > >>> > >> > >> So the right fix is > >> > >> diff --git a/kernel/umh.c b/kernel/umh.c > >> index f81e8698e36e..a3a3196e84d1 100644 > >> --- a/kernel/umh.c > >> +++ b/kernel/umh.c > >> @@ -154,7 +154,7 @@ static void call_usermodehelper_exec_sync(struct subprocess_info *sub_info) > >> * the real error code is already in sub_info->retval or > >> * sub_info->retval is 0 anyway, so don't mess with it then. > >> */ > >> - if (KWIFEXITED(ret)) > >> + if (KWEXITSTATUS(ret)) > >> sub_info->retval = KWEXITSTATUS(ret); > >> } > >> > >> I think. > > > > Nope, the right form is to check for WIFEXITED() before using WEXITSTATUS(). > > But this IS a change over the previous code, no? > I will test next week as I am travelling right now. I'm all for reverting back to the previous behavior. If someone wants a behavior change it should be a separate patch. And out of pure self interest I'd like to see that change after my addition of the kernel_wait helper to replace the kernel_wait4 abuse :)