Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp626509imw; Fri, 8 Jul 2022 08:52:19 -0700 (PDT) X-Google-Smtp-Source: AGRyM1tX6KdogB3GsubeXmncCyVXyCc12hDCyf1lXdE7I88XagTqPIXUWr93sHNo6ZRvsDqKuqte X-Received: by 2002:a17:90a:fe4:b0:1ef:8564:4f4 with SMTP id 91-20020a17090a0fe400b001ef856404f4mr561466pjz.118.1657295539217; Fri, 08 Jul 2022 08:52:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657295539; cv=none; d=google.com; s=arc-20160816; b=aHIIPPpk9nt9YdvrGFazrAQ/gIyCQRChgeWWCtGpuNtInuynZVGmQT3fzGZMqznQE3 Jo4SfJPCax2uW2h/OuD5Hvk/oxBwmUelManW7+gbZ2LdA0DWao3TtU6fMBCY2NG9QCa5 gqKbRiLCRysjHkL5hZpR7DrGdwN046/eW+6binCqKDN6KmL9LbNC6TwAEBluve4OjP8z 5/+cYVcb0jtzDZ6htZ6JbBx3gP2CMAK6jsweKqXQBiSFMlX76ruIdLk8R4gVi441x6Zl nxeOR6NWJ06SUlG9Ur76VPK/o7bnqB1pQOItlUHvsEnL++PybQQ4S3JOXkgClU6MZYKo j9fA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=D/8aDSiqLtITiKuj/XtjZLGeOLoe4PmW6gXkg4hBV70=; b=ZzAHwhl5y9mMHtXYLu+1zkHnwUAEmBO1kxY/5PRC4ObQij3kt8IKIDWckT3HyldE40 6hhY9ziNhlx4D1kZ1/UjNaFaZJmSBJ2S1OyAgraN2xZC6pAB+eqIYBU+6CHnBl8ft6IZ ux22dhrw2cimVPNYFxlS28pDhw5JDtgprxTqYwVPEwZji1r2V16/+GHmV+0g2W5G+GBZ RVGZd9TPXHJ6ajIFB3l85Mnx/kp2rtMeI6xkV5Biqt260zrTmVGB3YxjTSETh+QWgNVg mtTyLx2nGGu6CqnweKdM2cBp8cg1Kk922aUMc2xo+kso3k03Q1hdn3PU/XCEDxTg9L1W W6Ew== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g20-20020a056a000b9400b005107cf64e1dsi1144302pfj.212.2022.07.08.08.52.06; Fri, 08 Jul 2022 08:52:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S238156AbiGHOjL (ORCPT + 99 others); Fri, 8 Jul 2022 10:39:11 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58200 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237847AbiGHOjI (ORCPT ); Fri, 8 Jul 2022 10:39:08 -0400 Received: from netrider.rowland.org (netrider.rowland.org [192.131.102.5]) by lindbergh.monkeyblade.net (Postfix) with SMTP id 2D89E1B7AC for ; Fri, 8 Jul 2022 07:39:07 -0700 (PDT) Received: (qmail 7518 invoked by uid 1000); 8 Jul 2022 10:39:06 -0400 Date: Fri, 8 Jul 2022 10:39:06 -0400 From: Alan Stern To: Jozef Martiniak Cc: Felipe Balbi , Greg Kroah-Hartman , Jens Axboe , Hangyu Hua , "Darrick J. Wong" , Wei Ming Chen , Ingo Molnar , Randy Dunlap , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] gadgetfs: ep_io - wait until IRQ finishes Message-ID: References: <20220708070645.6130-1-jomajm@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20220708070645.6130-1-jomajm@gmail.com> X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jul 08, 2022 at 09:06:44AM +0200, Jozef Martiniak wrote: > after usb_ep_queue() if wait_for_completion_interruptible() is > interrupted we need to wait until IRQ gets finished. This should say "request" or "I/O request", not "IRQ". Not a big deal. > > Otherwise complete() from epio_complete() can corrupt stack. > > Signed-off-by: Jozef Martiniak > --- Acked-by: Alan Stern > drivers/usb/gadget/legacy/inode.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/drivers/usb/gadget/legacy/inode.c b/drivers/usb/gadget/legacy/inode.c > index 79990597c39f..01c3ead7d1b4 100644 > --- a/drivers/usb/gadget/legacy/inode.c > +++ b/drivers/usb/gadget/legacy/inode.c > @@ -362,6 +362,7 @@ ep_io (struct ep_data *epdata, void *buf, unsigned len) > spin_unlock_irq (&epdata->dev->lock); > > DBG (epdata->dev, "endpoint gone\n"); > + wait_for_completion(&done); > epdata->status = -ENODEV; > } > } > -- > 2.25.1 >