Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp273562pxf; Thu, 8 Apr 2021 02:49:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwb7cJAoxTCUEgoWEdJNKfJTNdzy8K9WE5+zoiF3y/y5cjeMx44LtjEUN/lHd+BQgv9QKKz X-Received: by 2002:a17:906:6a94:: with SMTP id p20mr9265897ejr.68.1617875385723; Thu, 08 Apr 2021 02:49:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617875385; cv=none; d=google.com; s=arc-20160816; b=P2zFSR42Gs9WDuJt/GrMrJuEG70ePsWRKO1hagUWDA65lQnujrH4ABIMcXocQPuvaI KxeT8LFSOMmZkMX8MfrBPnte6hGVg/Ydal2jcE4p7Xilo1foI2i+sYNm/XQmeTGxQU5X zuD8dErwtsq01Hyfymba7F7dngFYxrRJ72KldalVvxhi3DPvlXBc68kYOG1MrN3VKDp/ H3MydoCNsgUs3VBA7UKXOQyijK8w+3JDSswtRKC/qJ9Ngud42ECDMA8zC6xBvI6H9ZPM BMDv6JT7Ta9Jy+BaZe/ixfZ2MtJr4zSvZR+mih1emIi7NFfkDCZbGyISFzYcA2ulbKBj bEjg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:cc:to:subject:from:references :in-reply-to:date:dkim-signature; bh=sE6sbUPyNdxtXAJeXiOEoiXsovh9MLrnCAj9qUDsC3E=; b=REz1z/Zoqjm8jz749ljhsOuP2Qkhi/MBN7hzHKhyutQ9DFJYUyNUh11mQ+7g4rstcc afJBZ5z49LgNO7v52ZRAV4mr68HmrAckp1gfAIJP/5gSvL5EFLJdTEms5lvi8dlVnJWe ssxMIYjkDMJLRPew4jl/723tG9g68m8z4hPo4ljkBvMytqYm1BgklKa4Xj3ZRGdgjfgg olZi2htsDnkuEDZJSj+2tjha6wyS2JFoN82fLx0Cb/Z6UhA5aO/R5KnrN66BTzmtcF+L B/C297STOGrwqept6rj+t8URbUlHK3yfXD1FrGGBuTkvip0uM/yGd44fO30Y5hxgAL0c h5zg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@synopsys.com header.s=mail header.b=ZwB5fZoQ; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=synopsys.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f16si15859446ejc.601.2021.04.08.02.49.22; Thu, 08 Apr 2021 02:49:45 -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=@synopsys.com header.s=mail header.b=ZwB5fZoQ; 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=synopsys.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231493AbhDHJp5 (ORCPT + 99 others); Thu, 8 Apr 2021 05:45:57 -0400 Received: from smtprelay-out1.synopsys.com ([149.117.73.133]:37622 "EHLO smtprelay-out1.synopsys.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231478AbhDHJp4 (ORCPT ); Thu, 8 Apr 2021 05:45:56 -0400 Received: from mailhost.synopsys.com (mdc-mailhost2.synopsys.com [10.225.0.210]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) (No client certificate requested) by smtprelay-out1.synopsys.com (Postfix) with ESMTPS id 4202F4051F; Thu, 8 Apr 2021 09:45:45 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=synopsys.com; s=mail; t=1617875145; bh=ftbyk00YEvJSEIL+T7rY2QGF6NNFxPT9bL5QU6rM9KI=; h=Date:In-Reply-To:References:From:Subject:To:Cc:From; b=ZwB5fZoQXN6MqbC41fLhmdMBGryeaK+0k4qwYxWJMrVGe44bRPRveVjBBkSo+Aj2T USDLD6ZSK+3Ngh5XXQMXSdCl2MpMLK3Fdirnl78zaU2ZbjOMShTApQOQvXR6cX14CJ FQBeWrs3Xg6GflteSmvDqKcJbBYSdXNVIMrhDJ46MG8f7DK4XCkt2c1atN8GXNzTUB u+3nmIH3CJUocPxnlLll4pWQn+foYjisyyDugLVNv+CSxE3LoaVZi7xH87ApAxfa9r sg7tAzZUgNk2icqdrKpSMhiFqXgaCxBdDRkHww/rLkrwlGIKeh/7IDjwajYMWHxab/ 3DsXVB9EvBZKg== Received: from razpc-HP (razpc-hp.internal.synopsys.com [10.116.126.207]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) (No client certificate requested) by mailhost.synopsys.com (Postfix) with ESMTPSA id 685BAA0094; Thu, 8 Apr 2021 09:45:42 +0000 (UTC) Received: by razpc-HP (sSMTP sendmail emulation); Thu, 08 Apr 2021 13:45:41 +0400 Date: Thu, 08 Apr 2021 13:45:41 +0400 In-Reply-To: References: X-SNPS-Relay: synopsys.com From: Artur Petrosyan Subject: [PATCH v3 10/14] usb: dwc2: Allow exit partial power down in urb enqueue To: Felipe Balbi , Greg Kroah-Hartman , Minas Harutyunyan , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org Cc: John Youn , Artur Petrosyan Message-Id: <20210408094542.685BAA0094@mailhost.synopsys.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org When core is in partial power down state and an external hub is connected, upper layer sends URB enqueue request, which results in port reset issue. Added exit from partial power down state to avoid port reset issue and process upper layer request correctly. Signed-off-by: Artur Petrosyan --- Changes in v3: - None Changes in v2: - None drivers/usb/dwc2/hcd.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/drivers/usb/dwc2/hcd.c b/drivers/usb/dwc2/hcd.c index 9529e9839961..cb52bc41bfb8 100644 --- a/drivers/usb/dwc2/hcd.c +++ b/drivers/usb/dwc2/hcd.c @@ -4633,6 +4633,13 @@ static int _dwc2_hcd_urb_enqueue(struct usb_hcd *hcd, struct urb *urb, dwc2_dump_urb_info(hcd, urb, "urb_enqueue"); } + if (hsotg->in_ppd) { + retval = dwc2_exit_partial_power_down(hsotg, 0, true); + if (retval) + dev_err(hsotg->dev, + "exit partial_power_down failed\n"); + } + if (!ep) return -EINVAL; -- 2.25.1