Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp1807163imu; Fri, 14 Dec 2018 00:31:00 -0800 (PST) X-Google-Smtp-Source: AFSGD/X3folG2c+uscl5tdVE9JJp+6WwQuBCyhoFIqNqcO27BnCCBGVcCWFsNIDJI7YQNaM37LiG X-Received: by 2002:a17:902:aa0a:: with SMTP id be10mr2003879plb.266.1544776260696; Fri, 14 Dec 2018 00:31:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544776260; cv=none; d=google.com; s=arc-20160816; b=vHh6AJOZzWl9/3T+isNk3evTpTI64x972hoVqjGy800b2v79eAiED1DitL1rifMSSB ov6i44j9dTmIJIQ6zf59OA1S8ZHXkLjRLV0B7QJM7yoq02I1kz/x4GVdLQDQ+U8ILaQ9 mFT5alLlOvdgjQ9agt/wV0jraMM46dPxZN/5+HN+qbV2rW7XrvfMFAem24/rj5H0SkQx cfgxO+oT2o/3s5u7XygDI93csKPnehFDA5E7mV6KRPmB5g10zJvP7vy4z5Qo+ZQThZZE XIUz7wAOzm/iayqoRDELy4/eb1dhqGMAxubECpOiR4toV5UQ7XFsU1Tjni8RDX5JZl06 myLw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from; bh=6veDL45R1P5HXnVXPjyMMJJBBDNDDSG3QUX9H+JFNrc=; b=O/6DZMGjCnn3Ev9JzlRMt4OyjEkSe8cUpk2nJE9Roo4VmX05CpSjjkuOO66s8oPRbe 4mJFTZz36pXnreCf7PgVrVVR15HkOM3sZYRlBQa5V308DPpNcmJxKbRwD1K5v+q7RARF /3tR9KgMaJOYe7J+ewn5TAvOLXbFPNzITV70JDmcSfyFjLFcBpwE/Zs2O4iuYrrw3Ak0 zuxsjxBqXN3zzPrf4qLxeAq0JByeh0kQbWe4uSV6q0HpXxnZQcXYl91VETkMwWc6U/Lc LMYAN7uuLUnI6nB1vJdMvS2oxhSFBXfPDqq5zB2cs/hg9Q0K801NFRZwwOSSsH3NGjxK TXjQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p26si3846426pfj.244.2018.12.14.00.30.46; Fri, 14 Dec 2018 00:31:00 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727579AbeLNI36 (ORCPT + 99 others); Fri, 14 Dec 2018 03:29:58 -0500 Received: from szxga05-in.huawei.com ([45.249.212.191]:16126 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726494AbeLNI36 (ORCPT ); Fri, 14 Dec 2018 03:29:58 -0500 Received: from DGGEMS402-HUB.china.huawei.com (unknown [172.30.72.59]) by Forcepoint Email with ESMTP id 7F973D1C09A30; Fri, 14 Dec 2018 16:29:54 +0800 (CST) Received: from dessert.huawei.com (10.69.192.158) by DGGEMS402-HUB.china.huawei.com (10.3.19.202) with Microsoft SMTP Server id 14.3.408.0; Fri, 14 Dec 2018 16:29:47 +0800 From: Zeng Tao To: CC: , Zeng Tao , "Greg Kroah-Hartman" , , Subject: [PATCH] usb: dwc3: gadget: fix miss isoc issue introduced by IRQ latency Date: Sat, 15 Dec 2018 00:32:58 +0800 Message-ID: <1544805179-2248-1-git-send-email-prime.zeng@hisilicon.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.69.192.158] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If it's a busy system, some times when we start an isoc transfer, the framenumber get from the event buffer may be already elasped, in this case, we will get all the packets dropped due to miss isoc. And we turn into transfer nothing, to fix this issue, we need to fix the framenumber to make sure that it's not out of date. Signed-off-by: Liang Shengjun Signed-off-by: Zeng Tao --- drivers/usb/dwc3/core.h | 3 +++ drivers/usb/dwc3/gadget.c | 12 ++++++++++++ 2 files changed, 15 insertions(+) diff --git a/drivers/usb/dwc3/core.h b/drivers/usb/dwc3/core.h index 5bfb625..8742d96 100644 --- a/drivers/usb/dwc3/core.h +++ b/drivers/usb/dwc3/core.h @@ -452,6 +452,9 @@ #define DWC3_DSTS_RXFIFOEMPTY BIT(17) +#define DWC3_EVENT_PRAM_MAX_SOFFN 0x3fff +#define DWC3_EVENT_PRAM_SOFFN_MASK 0x3fff + #define DWC3_DSTS_SOFFN_MASK (0x3fff << 3) #define DWC3_DSTS_SOFFN(n) (((n) & DWC3_DSTS_SOFFN_MASK) >> 3) diff --git a/drivers/usb/dwc3/gadget.c b/drivers/usb/dwc3/gadget.c index 9f92ee0..b63bd72 100644 --- a/drivers/usb/dwc3/gadget.c +++ b/drivers/usb/dwc3/gadget.c @@ -1263,6 +1263,15 @@ static int __dwc3_gadget_get_frame(struct dwc3 *dwc) return DWC3_DSTS_SOFFN(reg); } +static bool __dwc3_gadget_target_frame_elapsed(struct dwc3_ep *dep) +{ + u16 cframe = __dwc3_gadget_get_frame(dep->dwc); + u16 eframe = dep->frame_number & DWC3_EVENT_PRAM_SOFFN_MASK; + + return (((eframe - cframe) & DWC3_EVENT_PRAM_SOFFN_MASK) + > DWC3_EVENT_PRAM_MAX_SOFFN / 2); +} + static void __dwc3_gadget_start_isoc(struct dwc3_ep *dep) { if (list_empty(&dep->pending_list)) { @@ -1272,6 +1281,9 @@ static void __dwc3_gadget_start_isoc(struct dwc3_ep *dep) return; } + while (__dwc3_gadget_target_frame_elapsed(dep)) + dep->frame_number = DWC3_ALIGN_FRAME(dep); + dep->frame_number = DWC3_ALIGN_FRAME(dep); __dwc3_gadget_kick_transfer(dep); } -- 2.7.4