Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp2617364pxb; Tue, 21 Sep 2021 04:04:22 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwy+GpZYAqbn9TTrXu2nS0ne4Wz0PjDU3dYiPBC91Mnv00X7vKfflzH/AduR6I/hEftmxp5 X-Received: by 2002:a17:906:8151:: with SMTP id z17mr33526464ejw.468.1632222261814; Tue, 21 Sep 2021 04:04:21 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632222261; cv=none; d=google.com; s=arc-20160816; b=UskSbMu+LKXQWbcgtIqulw3+bMJkVNkzR4sapSE7kw0cwkEiShi1m6/fjvJEKo7EYX Lz4iKBFDHHrYhGdJNA1Qw6Vj9EiOpySFx/Dd0COx4bBppvfY82RF+dbGeXMrKeldMTUx ydCrNNTbl4ajFu1NU1kCAczdNJACIG3odrsVWiayc/Xj9YI++c83cEt0HRLwTtF3ycpD tFJcq+FvOQcncQbPt28RMI2Wtxis8qldRCkqa9gRwavqyhF700INHK3xSj6o+9yi0Twc xzsoYYOLHl+Rohu72JzAwBMZkoKizZOFAFe/WUH2lszS7yxKFGJpxOV1JlUTgtXb7Sbh TP+g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=RP1t6F1ow/8OQN+izm78Y9bJ9MVZd+yMFKLR4PsDpvY=; b=TmulcSy0chsbhBZh+0VlB8T1QP5JaFReYjkKCekbYfkAJhuYQepvWiOQco4WD6Ui4n 47ce8wkTqumMXYYEAj1w/Ias/EHyms4LAouWwKzbGnN6wqJjSigBGjANITXYzBDmtnbb lAtw/ZB+c9RJXQ8Q6D+5kHqNbr0jbenkdlJDVb31siKaUCsnifzCninCWQm9Sbh5NQUs 596uVv6rZ73uiLaF/d4rw8ocAclUCEg1NqmhQM0gwM9VOIQ5KA57gVlrN8Yl36bLD1Q3 NNPrOEzepqabZqupiNYYhpGb9gkUH5Gj9dLhYtDZLdhZAQm7PHBpBt1G2f8ANhCdgK+X ogmw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=dNYC1TlF; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ch10si19361021edb.4.2021.09.21.04.03.56; Tue, 21 Sep 2021 04:04:21 -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=pass header.i=@linaro.org header.s=google header.b=dNYC1TlF; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232221AbhIULAP (ORCPT + 99 others); Tue, 21 Sep 2021 07:00:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44252 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231956AbhIULAP (ORCPT ); Tue, 21 Sep 2021 07:00:15 -0400 Received: from mail-ed1-x52c.google.com (mail-ed1-x52c.google.com [IPv6:2a00:1450:4864:20::52c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E0A1DC061574 for ; Tue, 21 Sep 2021 03:58:46 -0700 (PDT) Received: by mail-ed1-x52c.google.com with SMTP id bx4so28268738edb.4 for ; Tue, 21 Sep 2021 03:58:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=RP1t6F1ow/8OQN+izm78Y9bJ9MVZd+yMFKLR4PsDpvY=; b=dNYC1TlF4OiaopZt2R6nRivqbgyYgnbN3v8OhCvwyorE/5RGAWb3kO/pkQcgonl00r 7qxUhIpiCupJEMDxoHJ+2HWYa0RsC3IT48AS2KoAbTL94FU+1QgfYdn3TFzbx4H7mLvX ekbq9mhGySKGUIGlpnehR7dUtQU9k5dptnTdRUyVANV/scuPe1gPMfxVG5Arf8wVXKtk eJ0vWVF2xj8rXf0Oqxv0+D95r7T6er6unkKDae+JRW6qN8OUIZ2/iNXVnaOLyQyGmJhL 17AulVxZ/MR95Ra/i1lF6Ti6EhwqIVgNj6XcSC6f5K+RcBifB5PynzD3UUo9bZFU954e ERkg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=RP1t6F1ow/8OQN+izm78Y9bJ9MVZd+yMFKLR4PsDpvY=; b=xXawgNe3h3OY/kfxeOmBWrdagjHXTvYRxPqb+dDKkuC7mSmV3lgcmyCh/224bAeR/k /ry9tgbiVstlFKVUm48prVWrh1nReriq5zQZ61kERIOyhL0ZZc1lH4/z45HWsg2HIZAg HG+BmhFi9wNc26Kli8skBctVg/2/emydAp4cnVBrqOna7xNPKUFLnBCBF6jY5Ycocxl7 4bUMI83FAjUdijkLqkXZ7OelMH1oFo5avY3lTBISYye491gIY+JEeh1GK9Zv3aoyilVB g+mhmsbvD+0sk1lBbvzI0RZvzo9ZXEkR+xzi2XW6Xmkg7w6P78wIc+Lsn+DIE6cEcOYm o4OA== X-Gm-Message-State: AOAM531MPLMMdJs+Ho7o8F1GqXej6wR9m+DfoiIU+DuuRtZzq9v5NIrg KzPnK/Wmw7TNl6yOFH/J2LB+TSV9R6pJ3zyUBr1kvA== X-Received: by 2002:aa7:c988:: with SMTP id c8mr34846134edt.105.1632221925394; Tue, 21 Sep 2021 03:58:45 -0700 (PDT) MIME-Version: 1.0 References: <20210908130922.118265849@linutronix.de> <20210908132525.794334915@linutronix.de> In-Reply-To: <20210908132525.794334915@linutronix.de> From: Anders Roxell Date: Tue, 21 Sep 2021 12:58:34 +0200 Message-ID: Subject: Re: [patch V3 15/20] x86/fpu/signal: Change return type of copy_fpregs_to_sigframe() helpers to boolean To: Thomas Gleixner Cc: LKML , "maintainer:X86 ARCHITECTURE (32-BIT AND 64-BIT)" , Al Viro , Linus Torvalds , Tony Luck , Alexei Starovoitov , Peter Ziljstra , Song Liu , Daniel Borkmann Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 8 Sept 2021 at 15:30, Thomas Gleixner wrote: > > Now that copy_fpregs_to_sigframe() returns boolean the individual return > codes in the related helper functions do not make sense anymore. Change > them to return boolean success/fail. > > Signed-off-by: Thomas Gleixner When I build and boot (qemu_x86_64) a defconfig kernel on from todays next tag next-20210921 I see the following segmentation fault 2021-09-21T10:11:45 <6>[ 1.622922] mount (89) used greatest stack depth: 14384 bytes left 2021-09-21T10:11:45 <6>[ 1.664760] EXT4-fs (sda): re-mounted. Opts: (null). Quota mode: none. 2021-09-21T10:11:45 <6>[ 1.691041] mkdir (92) used greatest stack depth: 14312 bytes left 2021-09-21T10:11:45 <6>[ 1.713201] mount (93) used greatest stack depth: 13720 bytes left 2021-09-21T10:11:46 Starting syslogd: /etc/init.d/rcS: line 12: 101 Segmentation fault $i start I did a bisection and found this as the faulty patch [1]. When I revert this patch I can't see the issue. We noticed that function 'save_xstate_epilog()' changes the polarity of its return code for one of the return statements, and for its only caller. but not for the other return statement. I tried this patch and I couldn't see the segmentation fault. diff --git a/arch/x86/kernel/fpu/signal.c b/arch/x86/kernel/fpu/signal.c index 445c57c9c539..61eeebc04427 100644 --- a/arch/x86/kernel/fpu/signal.c +++ b/arch/x86/kernel/fpu/signal.c @@ -104,7 +104,7 @@ static inline int save_xstate_epilog(void __user *buf, int ia32_frame) err = __copy_to_user(&x->i387.sw_reserved, sw_bytes, sizeof(*sw_bytes)); if (!use_xsave()) - return err; + return !err; err |= __put_user(FP_XSTATE_MAGIC2, (__u32 __user *)(buf + fpu_user_xstate_size)); Cheers, Anders [1] http://ix.io/3zxf > --- > arch/x86/kernel/fpu/signal.c | 17 +++++++++-------- > 1 file changed, 9 insertions(+), 8 deletions(-) > > --- a/arch/x86/kernel/fpu/signal.c > +++ b/arch/x86/kernel/fpu/signal.c > @@ -65,7 +65,7 @@ static inline int check_xstate_in_sigfra > /* > * Signal frame handlers. > */ > -static inline int save_fsave_header(struct task_struct *tsk, void __user *buf) > +static inline bool save_fsave_header(struct task_struct *tsk, void __user *buf) > { > if (use_fxsr()) { > struct xregs_state *xsave = &tsk->thread.fpu.state.xsave; > @@ -82,18 +82,19 @@ static inline int save_fsave_header(stru > if (__copy_to_user(buf, &env, sizeof(env)) || > __put_user(xsave->i387.swd, &fp->status) || > __put_user(X86_FXSR_MAGIC, &fp->magic)) > - return -1; > + return false; > } else { > struct fregs_state __user *fp = buf; > u32 swd; > + > if (__get_user(swd, &fp->swd) || __put_user(swd, &fp->status)) > - return -1; > + return false; > } > > - return 0; > + return true; > } > > -static inline int save_xstate_epilog(void __user *buf, int ia32_frame) > +static inline bool save_xstate_epilog(void __user *buf, int ia32_frame) > { > struct xregs_state __user *x = buf; > struct _fpx_sw_bytes *sw_bytes; > @@ -131,7 +132,7 @@ static inline int save_xstate_epilog(voi > > err |= __put_user(xfeatures, (__u32 __user *)&x->header.xfeatures); > > - return err; > + return !err; > } > > static inline int copy_fpregs_to_sigframe(struct xregs_state __user *buf) > @@ -219,10 +220,10 @@ bool copy_fpstate_to_sigframe(void __use > } > > /* Save the fsave header for the 32-bit frames. */ > - if ((ia32_fxstate || !use_fxsr()) && save_fsave_header(tsk, buf)) > + if ((ia32_fxstate || !use_fxsr()) && !save_fsave_header(tsk, buf)) > return false; > > - if (use_fxsr() && save_xstate_epilog(buf_fx, ia32_fxstate)) > + if (use_fxsr() && !save_xstate_epilog(buf_fx, ia32_fxstate)) > return false; > > return true; >