Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp985625ybx; Thu, 31 Oct 2019 04:06:26 -0700 (PDT) X-Google-Smtp-Source: APXvYqzKBUPpTydttUmPkB/cpnXXPLrQFeb+iBJs2+Vkq0QxdG1OZZYcQmqj0AdIWJk/BO5OuHjy X-Received: by 2002:a17:906:7e50:: with SMTP id z16mr3352899ejr.130.1572519986613; Thu, 31 Oct 2019 04:06:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572519986; cv=none; d=google.com; s=arc-20160816; b=FdgNTWAUbQXB1kGjf68KlbV7a93EvBQFwjSaQPRxJbFL5fTPVBZfPiKOPtTRBmQZjM Wls9ka5nagK0iJLjPWY01t4hej92FJ3t/r5PRAeaGnJeL2EdFUBfOJTmG3m8LfA8ExFS QPa7qPr0o780dSPL8+qtovzrTyN1RzUSXbSImCXYt95vU76u252oI1ssdiOH/PJiWKho Rwt1SznRriCRiFwKCNWr64QBQm8FSatoBlmoPURP3/k0ZqVIcYALemvZScrHuPYGCZZs S6vMPOx2fgRbsA1ixGOijJ/MMuZNV2oOUWqgbXUMWQMGyXcMiNQ7RC8vvcwvUe+WxXlq iRJg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=bB3RaByQ4n8ZNwM2TmPODUC5xV88xdL4nzVoyZOor/o=; b=h8FjOB/lnHUuPLc3ayaBsqr879NUZgTZ3tD44TtslHCOtUQSzPcZsQQ6PuAWsvmpTV nI8bPCnTu/+kKdZ/Pwtkmh6zUCyrRmzkqhCRdbhtXGqlcz6Vl7EbFDItaYm2LdUrXgqg Yn00e9ZsyImRukggBzJtkhvgvCSevlMSNVoHO7hQUcXaIii3eGGLgt+rPCZBU/o6Wa1R O0cIF9coyd60P71vv+EsFwgwlkuLVkkeOTxk0eI3KI2bjfi0K5MXIrbX5Px7jS3YEYMO lehGLH6LaEgsPvMDUq+ZP5ciICSHRrMBCmyArmErG1cfiU5t/iABVluNIY2u1SCBm7ob WTFA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=embPrBh4; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l12si4247206edk.60.2019.10.31.04.06.03; Thu, 31 Oct 2019 04:06:26 -0700 (PDT) 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; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=embPrBh4; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727279AbfJaLCd (ORCPT + 99 others); Thu, 31 Oct 2019 07:02:33 -0400 Received: from fllv0015.ext.ti.com ([198.47.19.141]:53114 "EHLO fllv0015.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726947AbfJaLCd (ORCPT ); Thu, 31 Oct 2019 07:02:33 -0400 Received: from lelv0266.itg.ti.com ([10.180.67.225]) by fllv0015.ext.ti.com (8.15.2/8.15.2) with ESMTP id x9VB2H6x063092; Thu, 31 Oct 2019 06:02:17 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1572519737; bh=bB3RaByQ4n8ZNwM2TmPODUC5xV88xdL4nzVoyZOor/o=; h=Subject:To:CC:References:From:Date:In-Reply-To; b=embPrBh4ZavJ2O2q/1lBVebnQCCkZUX9O1fQU+7IDoRcnkh4vJYFPIAKnJwBouOr4 ozXwj3YI+rly+EepF5Ua3zD6rYQTa3DPKxlsFuaMVDNvXoxdg3DK9R257fGCa3emN0 8Wts7GfopEjc7qe/BX4UeeeqlGnY2ZqlEASkCTn8= Received: from DLEE113.ent.ti.com (dlee113.ent.ti.com [157.170.170.24]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id x9VB2Hls079270 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Thu, 31 Oct 2019 06:02:17 -0500 Received: from DLEE111.ent.ti.com (157.170.170.22) by DLEE113.ent.ti.com (157.170.170.24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1713.5; Thu, 31 Oct 2019 06:02:04 -0500 Received: from fllv0040.itg.ti.com (10.64.41.20) by DLEE111.ent.ti.com (157.170.170.22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1713.5 via Frontend Transport; Thu, 31 Oct 2019 06:02:04 -0500 Received: from [192.168.2.14] (ileax41-snat.itg.ti.com [10.172.224.153]) by fllv0040.itg.ti.com (8.15.2/8.15.2) with ESMTP id x9VB2ECn023353; Thu, 31 Oct 2019 06:02:15 -0500 Subject: Re: [PATCH v2] usb: cdns3: gadget: Fix g_audio use case when connected to Super-Speed host To: Felipe Balbi , , CC: , , , , References: <20191029151514.28495-1-rogerq@ti.com> <20191030121607.21739-1-rogerq@ti.com> <87pnide1k7.fsf@gmail.com> <44b07e90-a9de-ea99-25c6-dc72cf39bbe1@ti.com> <875zk5dw0m.fsf@gmail.com> From: Roger Quadros Message-ID: <86a7fbc4-136f-78bb-4677-784199842c9f@ti.com> Date: Thu, 31 Oct 2019 13:02:14 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.9.0 MIME-Version: 1.0 In-Reply-To: <875zk5dw0m.fsf@gmail.com> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 31/10/2019 12:55, Felipe Balbi wrote: > > Hi, > > Roger Quadros writes: > >> Hi, >> >> On 31/10/2019 10:55, Felipe Balbi wrote: >>> >>> Hi, >>> >>> Roger Quadros writes: >>> >>>> Take into account gadget driver's speed limit when programming >>>> controller speed. >>>> >>>> Fixes: commit 7733f6c32e36 ("usb: cdns3: Add Cadence USB3 DRD Driver") >>>> Signed-off-by: Roger Quadros >>>> Acked-by: Peter Chen >>>> --- >>>> >>>> Changelog: >>>> v2 >>>> - Add Fixes line >>>> >>>> drivers/usb/cdns3/gadget.c | 31 ++++++++++++++++++++++++++----- >>>> 1 file changed, 26 insertions(+), 5 deletions(-) >>>> >>>> diff --git a/drivers/usb/cdns3/gadget.c b/drivers/usb/cdns3/gadget.c >>>> index 40dad4e8d0dc..1c724c20d468 100644 >>>> --- a/drivers/usb/cdns3/gadget.c >>>> +++ b/drivers/usb/cdns3/gadget.c >>>> @@ -2338,9 +2338,35 @@ static int cdns3_gadget_udc_start(struct usb_gadget *gadget, >>>> { >>>> struct cdns3_device *priv_dev = gadget_to_cdns3_device(gadget); >>>> unsigned long flags; >>>> + enum usb_device_speed max_speed = driver->max_speed; >>>> >>>> spin_lock_irqsave(&priv_dev->lock, flags); >>>> priv_dev->gadget_driver = driver; >>>> + >>>> + /* limit speed if necessary */ >>>> + max_speed = min(driver->max_speed, gadget->max_speed); >>>> + >>>> + switch (max_speed) { >>>> + case USB_SPEED_FULL: >>>> + writel(USB_CONF_SFORCE_FS, &priv_dev->regs->usb_conf); > > so this forces the controller to FS Right. > >>>> + writel(USB_CONF_USB3DIS, &priv_dev->regs->usb_conf); > > and this disconnects in superspeed? What is this supposed to do? > It says "Disconnect USB device in SuperSpeed". We were asked to set that bit to limit it to HS. >>>> + break; >>>> + case USB_SPEED_HIGH: >>>> + writel(USB_CONF_USB3DIS, &priv_dev->regs->usb_conf); >>>> + break; >>>> + case USB_SPEED_SUPER: >>>> + break; >>>> + default: >>>> + dev_err(priv_dev->dev, >>>> + "invalid maximum_speed parameter %d\n", >>>> + max_speed); >>>> + /* fall through */ >>>> + case USB_SPEED_UNKNOWN: >>>> + /* default to superspeed */ >>>> + max_speed = USB_SPEED_SUPER; >>>> + break; >>>> + } >>> >>> I had suggested some simplification for this case statement. >>> >> >> oops, looks like Greg picked this already. >> >> During more tests today I just observed that this patch causes >> the following regression. >> >> Connect EVM to Super-Speed host >> Load g_audio. (this enumerates as HS which is fine) >> unload g_audio >> load g_zero (this enumerates at HS instead of SS). >> >> This is because the speed limit that we set doesn't get cleared. >> >> Now the bits are write only and there is a way to undo USB_CONF_SFORCE_FS >> by writing USB_CONF_CFORCE_FS, however there is no corresponding bit >> to clear USB_CONF_USB3DIS. Only way seems to be USB_CFG_SWRST which >> is a bit harsh IMO. > > Isn't bit 0 enough? > > /* Reset USB device configuration. */ > #define USB_CONF_CFGRST BIT(0) Probably not, as explanation of USB3DIS bit says, "To connect disconnected device, CPU performs software reset (CFG.SWRST)." which is bit 7. "Device software reset. But I'll let Pawel comment on this. > > Also, now that I look at this more carefully, you should move that code > to udc_set_speed(). > Agreed. I'll revise the implementation to move it to udc_set_speed() once I know how to undo the USB3DIS. -- cheers, -roger Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki