Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp3127223rwb; Mon, 15 Aug 2022 18:48:56 -0700 (PDT) X-Google-Smtp-Source: AA6agR4w1zN8/QLvybjn+iQrswUdIoMPzXRHlUTsjmAx4/tipF08S4i40ALbX2YArmMXWcqMgXeY X-Received: by 2002:a17:902:ef93:b0:170:c9d6:a06b with SMTP id iz19-20020a170902ef9300b00170c9d6a06bmr20252845plb.101.1660614535870; Mon, 15 Aug 2022 18:48:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660614535; cv=none; d=google.com; s=arc-20160816; b=zDrREMytCS/eS+bK8u/HJziJmB/yDRe6uz1prDWkaH8wV56EwK0LdS533Q3c4PntrZ ucuJ3cIGE7WECjPYtrr9MNRqeAnqE1cuWqV20HS7+MS1lyBFLYEzlVF8QERF2Aye3JWJ sJvO7uVPJq0zCYUPKzzZ3QwY5uqN1oJ4iI3WzNujZIfY9t01EizQELSBJIFdwDD4jfRm tF1pBXD3KvMT0l8g97rO0G/3DcE/mDS4bvvaNhAX0vo6fGrIJKwbBJZSIDzom4fPTe36 gxx0pRsXB3M7nLhp0trigXDYjrs6TUIB4GSXm7s/nf6VeC5h6m1rJWEv7HwOur9wIBS/ zQ/A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from :dkim-signature; bh=Uy2k3ckyXgUmymPO/N1a9F/NhIcpSmtIiPPQA6JgDPk=; b=u+scdS+t2/ZamOxfkoq5t5WpGRh6FJzAxPWSPL25pCgoq0Fh8eime6+0c3pQkbr+eR 9LaunQp12IT1U48zyhqK/0v/7ZFPA9WaSLwpPfDg5FE8VaRLucmTZBcbV98mnwVxXBad WY75ZI8WLfDYjFEFZHk3tgyhWqYfVASulWtQdxN5F+XLhRz8gi8KRca5YBmc4ELF4tfL s8pgbUsYXWuDWu6GDZyZip2Y/2UvN68ajCTuWzmbxtlGNZtRX+HcqmYKw58XGlK70Mbv GsJH5CZus4EZ5FJXjorAvjQGc6dw8nW1rYZvUyOZc3DV9DwH7tj8/hyXkaBTNjlYjBeF L1rA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=NHhm0lGx; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b3-20020a170903228300b001708e1bb3b8si13234874plh.335.2022.08.15.18.48.45; Mon, 15 Aug 2022 18:48:55 -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; dkim=pass header.i=@quicinc.com header.s=qcppdkim1 header.b=NHhm0lGx; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233941AbiHPBjT (ORCPT + 99 others); Mon, 15 Aug 2022 21:39:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38322 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230378AbiHPBil (ORCPT ); Mon, 15 Aug 2022 21:38:41 -0400 Received: from mx0a-0031df01.pphosted.com (mx0a-0031df01.pphosted.com [205.220.168.131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C3FBAEE4BB; Mon, 15 Aug 2022 14:31:57 -0700 (PDT) Received: from pps.filterd (m0279864.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 27FKICe8018959; Mon, 15 Aug 2022 21:31:53 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h=from : to : cc : subject : date : message-id : mime-version : content-type; s=qcppdkim1; bh=Uy2k3ckyXgUmymPO/N1a9F/NhIcpSmtIiPPQA6JgDPk=; b=NHhm0lGxdyPx63LhJ8DSqhZT8lcVyuFgOx4YaIertAfSdgooduRefJKdy0a517DnHr9G SJuf7Vx8OjCr7opB0zZTve48weBZsW3DQ0iM4UjQJZGcbg/O0pkCebM3BZ5ttwHMknfh TGTcCAKT89aiD6nx+rl/E84cSD3pIqfU6VdfeeLGRMv8+7RPuB0uY/ARVkynsNfkXnxB t2dGA9qUKCtSJYwV2YNTMAWwf8q4UVT3XmAvclk5Bq/faXWH9ZngEMH+MQM3mHo3vHm1 QLN3Sr7Bb50UZorq6xUi5cB7K8Ihtnw6un8Rmnrt981QhO51XcrbZrJgkAfWdhm/y4TN hg== Received: from nalasppmta04.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3hx54sxey7-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 15 Aug 2022 21:31:53 +0000 Received: from nalasex01b.na.qualcomm.com (nalasex01b.na.qualcomm.com [10.47.209.197]) by NALASPPMTA04.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 27FLVqUw021061 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 15 Aug 2022 21:31:52 GMT Received: from hu-wcheng-lv.qualcomm.com (10.49.16.6) by nalasex01b.na.qualcomm.com (10.47.209.197) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.986.22; Mon, 15 Aug 2022 14:31:52 -0700 From: Wesley Cheng To: , CC: , , , , Wesley Cheng Subject: [PATCH v3 0/8] Fix controller halt and endxfer timeout issues Date: Mon, 15 Aug 2022 14:31:26 -0700 Message-ID: <20220815213134.23783-1-quic_wcheng@quicinc.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.49.16.6] X-ClientProxiedBy: nalasex01b.na.qualcomm.com (10.47.209.197) To nalasex01b.na.qualcomm.com (10.47.209.197) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-GUID: lmKR0JvjRRvelcPW94kT13FHENcVF8gM X-Proofpoint-ORIG-GUID: lmKR0JvjRRvelcPW94kT13FHENcVF8gM X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.205,Aquarius:18.0.883,Hydra:6.0.517,FMLib:17.11.122.1 definitions=2022-08-15_08,2022-08-15_01,2022-06-22_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 phishscore=0 priorityscore=1501 impostorscore=0 mlxlogscore=598 spamscore=0 mlxscore=0 clxscore=1015 suspectscore=0 bulkscore=0 lowpriorityscore=0 adultscore=0 malwarescore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2207270000 definitions=main-2208150082 X-Spam-Status: No, score=-2.8 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_LOW,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham 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 Changes in v3: - Modified the msleep() duration to ~2s versus ~10s due to the minimum mdelay() value. - Removed patch to modify DEP flags during dwc3_stop_active_transfer(). This was not required after fixing the logic to allow EP xfercomplete events to be handled on EP0. - Added some changes to account for a cable disconnect scenario, where dwc3_gadget_pullup() would not be executed to stop active transfers. Needed to add some logic to the disconnect interrupt to ensure that we cleanup/restart any pending SETUP transaction, so that we can clear the EP0 delayed stop status. (if pending) - Added patch to ensure that we don't proceed with umapping buffers until the endxfer was actually sent. Changes in v2: - Moved msleep() to before reading status register for halted state - Fixed kernel bot errors - Clearing DEP flags in __dwc3_stop_active_transfers() - Added Suggested-by tags and link references to previous discussions This patch series addresses some issues seen while testing with the latest soft disconnect implementation where EP events are allowed to process while the controller halt is occurring. #1 Since routines can now interweave, we can see that the soft disconnect can occur while conndone is being serviced. This leads to a controller halt timeout, as the soft disconnect clears the DEP flags, for which conndone interrupt handler will issue a __dwc3_ep_enable(ep0), that leads to re-issuing the set ep config command for every endpoint. #2 Function drivers can ask for a delayed_status phase, while it processes the received SETUP packet. This can lead to large delays when handling the soft disconnect routine. To improve the timing, forcefully send the status phase, as we are going to disconnect from the host. #3 Ensure that local interrupts are left enabled, so that EP0 events can be processed while the soft disconnect/dequeue is happening. #4 Since EP0 events can occur during controller halt, it may increase the time needed for the controller to fully stop. #5 Account for cable disconnect scenarios where nothing may cause the endxfer retry if DWC3_EP_DELAY_STOP is set. #6 Avoid unmapping pending USB requests that were never stopped. This would lead to a potential SMMU fault. Wesley Cheng (8): usb: dwc3: Do not service EP0 and conndone events if soft disconnected usb: dwc3: gadget: Force sending delayed status during soft disconnect usb: dwc3: gadget: Synchronize IRQ between soft connect/disconnect usb: dwc3: gadget: Continue handling EP0 xfercomplete events usb: dwc3: Avoid unmapping USB requests if endxfer is not complete usb: dwc3: Increase DWC3 controller halt timeout usb: dwc3: gadget: Skip waiting for CMDACT cleared during endxfer usb: dwc3: gadget: Submit endxfer command if delayed during disconnect drivers/usb/dwc3/core.c | 4 ---- drivers/usb/dwc3/core.h | 3 +++ drivers/usb/dwc3/ep0.c | 11 ++++++--- drivers/usb/dwc3/gadget.c | 48 +++++++++++++++++++++++++++++++++------ 4 files changed, 52 insertions(+), 14 deletions(-)