Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp2452746pxb; Mon, 23 Aug 2021 22:41:42 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy8bu6goZac3wbOlwmdh9D7OayaYxb1sNf3x5qYvFSyGYzZ81C9LSu1SPyHmNH7jBONia/f X-Received: by 2002:a05:6402:445:: with SMTP id p5mr41822773edw.208.1629783702471; Mon, 23 Aug 2021 22:41:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629783702; cv=none; d=google.com; s=arc-20160816; b=UQ9AdgHlFoDF/PvbFhPWpEW34taBevRSEpMxVK4R+9vIHe/dzF1A7d2mmSffcJXtJC IpSVGXDYRRUtmu9hTe4lyvUb6QAPPunEMR5dGEbFNEMT/ivdNk0PaqGJKpg1WuvRzVgT EJk703ceqNh4xtz22lkTXFmayQRyl9z4uHqSKMmwICjEIwf1lnfSGcAmHJf1WkoUKcT/ xJ/UK+QUM7UNc/pgf/rqoscPPsGNGpUZJEf9Q3amxCc4yWfGUDTrw3AXmLS6RFpEm7I/ d+s9x5rpiNlL2Uhi4+Qfay68GD8wZhJhuXuGn/eyM99hOt+hY7/9q/oaC4Y0BIZrd4TQ sSoQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature:dkim-signature; bh=6FJYl4dTAM/9fGzO0Y+MXinAlJCLYdmUY2yXUOUhaBs=; b=a7A1WAqJOg7RAoxiHvD37X5v7JoQmvF89euxdBMQWBulU6Uqyz0DmkjCf8BgH9CtuP vDPCeiBI7tjqHtB5rfkNwYo7C5XCqSSO76aV1uMKxryLey19ZcVUQk7rq62JhR9PP3W6 BjrulZox6u+Qe4xTgqznRilPHZvs0KUqoVcIQQoAw3Sf1vHcGCdvl19hPtNY6LSe19Fy sakcF4TWenuXD0mG59RCDYqqvKFFJRhzHzF0dteDLtAiT92/wEHAOutkUKrdqO82N+Cp h7hyW96sjeu/4K3+5wFHBpmPjnZBKcrTCD/59BytnaMlTthDhWQsl+iCiQPBeX/axGXL UmgQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@ivitera.com header.s=mail header.b=T3QrPPiz; dkim=fail header.i=@ivitera.com header.s=mail header.b=XR7TDdna; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id nc34si1023710ejc.702.2021.08.23.22.41.19; Mon, 23 Aug 2021 22:41:42 -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=fail header.i=@ivitera.com header.s=mail header.b=T3QrPPiz; dkim=fail header.i=@ivitera.com header.s=mail header.b=XR7TDdna; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234127AbhHXFk1 (ORCPT + 99 others); Tue, 24 Aug 2021 01:40:27 -0400 Received: from cable.insite.cz ([84.242.75.189]:39532 "EHLO cable.insite.cz" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229885AbhHXFkZ (ORCPT ); Tue, 24 Aug 2021 01:40:25 -0400 Received: from localhost (localhost [127.0.0.1]) by cable.insite.cz (Postfix) with ESMTP id 5E706A1A3D403; Tue, 24 Aug 2021 07:39:39 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=ivitera.com; s=mail; t=1629783579; bh=ZqNx3U1aIGV13rkQp+VB34ijO0GCIA3x/Xr3oxij54E=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=T3QrPPizSJV93tNQuENTmj76a4cfsGiraooDWOABTtFlyIMRB7SYb8SLDxYfY99jh LSdLf4VZeQDzZURQG698TfaY0PySYx3k/Usv9dFFaHfrZvKprYu10YTiBOtq7jaAhd MWKNW3DYtDAS4ru0Z0ehXulBRpapb8wnPjwrRymg= Received: from cable.insite.cz ([84.242.75.189]) by localhost (server.insite.cz [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id 5CU-FVQD_vhl; Tue, 24 Aug 2021 07:39:33 +0200 (CEST) Received: from [192.168.105.119] (ip28.insite.cz [81.0.237.28]) (Authenticated sender: pavel) by cable.insite.cz (Postfix) with ESMTPSA id CCFCFA1A3D400; Tue, 24 Aug 2021 07:39:32 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=ivitera.com; s=mail; t=1629783573; bh=ZqNx3U1aIGV13rkQp+VB34ijO0GCIA3x/Xr3oxij54E=; h=Subject:To:Cc:References:From:Date:In-Reply-To:From; b=XR7TDdnacdv9dUIcWo4SaaQ6kGJ1btfBdZG1FWiktVtRB13IC3VmJziZUucfKKn1N hdmfqcBkNpf9iyGK7ys7o7e1ZG3aMh38nJu4/eOYaAd0WffM+E5fpR0HOE8Sr5d8jX a1nN64hG24MoAjGDtWtTRpL9cXlTCiXBTQH5nM70= Subject: Re: [PATCH v10 0/6] Re-introduce TX FIFO resize for larger EP bursting To: Thinh Nguyen , Andy Shevchenko Cc: Ferry Toth , Felipe Balbi , Wesley Cheng , "gregkh@linuxfoundation.org" , "robh+dt@kernel.org" , "agross@kernel.org" , "bjorn.andersson@linaro.org" , "frowand.list@gmail.com" , "linux-usb@vger.kernel.org" , "linux-kernel@vger.kernel.org" , "devicetree@vger.kernel.org" , "linux-arm-msm@vger.kernel.org" , "jackp@codeaurora.org" , "heikki.krogerus@linux.intel.com" , Ruslan Bilovol References: <1623923899-16759-1-git-send-email-wcheng@codeaurora.org> <87pmv9l1dv.fsf@kernel.org> <9dc6cd83-17b9-7075-0934-6b9d41b6875d@gmail.com> <87a6mbudvc.fsf@kernel.org> <6e8bb4ad-fe68-ad36-7416-2b8e10b6ae96@gmail.com> <877dhev68a.fsf@kernel.org> <874kchvcq0.fsf@kernel.org> <8735raj766.fsf@kernel.org> <1fb52c92-9319-c035-722f-695ab34723dd@gmail.com> <702c72cd-40e4-e641-797a-764e7e611afb@ivitera.com> <7ad8b755-1fa0-3be4-3f2e-a4d95858e450@synopsys.com> From: Pavel Hofman Message-ID: Date: Tue, 24 Aug 2021 07:39:32 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.2.1 MIME-Version: 1.0 In-Reply-To: <7ad8b755-1fa0-3be4-3f2e-a4d95858e450@synopsys.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Dne 24. 08. 21 v 0:50 Thinh Nguyen napsal(a): > Pavel Hofman wrote: >> >> >> Dne 23. 08. 21 v 17:21 Andy Shevchenko napsal(a): >>> On Mon, Aug 23, 2021 at 5:59 PM Pavel Hofman >>> wrote: >>>> Dne 22. 08. 21 v 21:43 Ferry Toth napsal(a): >>>>> Op 19-08-2021 om 23:04 schreef Pavel Hofman: >>>>>> Dne 19. 08. 21 v 22:10 Ferry Toth napsal(a): >>>>>>> Op 19-08-2021 om 09:51 schreef Pavel Hofman: >>>>>>>> Dne 18. 08. 21 v 21:07 Ferry Toth napsal(a): >>>>>>>>> Op 18-08-2021 om 00:00 schreef Ferry Toth: >>> >>> ... >>> >>>>>>>>> So, where do we go from here? >>>>>>>> >>>>>>>> I know the patches have been tested on dwc2 (by me and others).  I >>>>>>>> do not know if Ruslan or Jerome tested them on dwc3 but probably >>>>>>>> not. Ruslan has talked about RPi (my case too) and BeagleboneBlack, >>>>>>>> both with dwc2. Perhaps the dwc2 behaves a bit differently than >>>>>>>> dwc3? >>>>>>>> >>>>>>>> The patches add a new EP-IN for async feedback. I am sorry I have >>>>>>>> not followed your long thread (it started as unrelated to uac). Does >>>>>>>> the problem appear with f_uac1 or f_uac2? Please how have you >>>>>>>> reached the above problem? >>>>>>> >>>>>>> I'm sorry too. I first believed the issue was related to the patch >>>>>>> mentioned in the subject line. >>>>>>> >>>>>>> The problem appaers with f_uac2. I bost Edison_Arduino board in host >>>>>>> mode (there is a switch allowing to select host/device mode). When >>>>>>> flipping the switch to device mode udev run a script: >>>>>>> But as I am using configfs (excerpt follows) and just disabling the >>>>>>> last 2 line resolves the issue, I'm guessing uac2 is the issue. Or >>>>>>> exceeding the available resources. >>>>>>> >>>>>>> # Create directory structure >>>>>>> mkdir "${GADGET_BASE_DIR}" >>>>>>> cd "${GADGET_BASE_DIR}" >>>>>>> mkdir -p configs/c.1/strings/0x409 >>>>>>> mkdir -p strings/0x409 >>>>>>> >>>>>>> # Serial device >>>>>>> mkdir functions/gser.usb0 >>>>>>> ln -s functions/gser.usb0 configs/c.1/ >>>>>>> ### >>>>>>> >>>>>>> # Ethernet device >>>>>>> mkdir functions/eem.usb0 >>>>>>> echo "${DEV_ETH_ADDR}" > functions/eem.usb0/dev_addr >>>>>>> echo "${HOST_ETH_ADDR}" > functions/eem.usb0/host_addr >>>>>>> ln -s functions/eem.usb0 configs/c.1/ >>>>>>> >>>>>>> # Mass Storage device >>>>>>> mkdir functions/mass_storage.usb0 >>>>>>> echo 1 > functions/mass_storage.usb0/stall >>>>>>> echo 0 > functions/mass_storage.usb0/lun.0/cdrom >>>>>>> echo 0 > functions/mass_storage.usb0/lun.0/ro >>>>>>> echo 0 > functions/mass_storage.usb0/lun.0/nofua >>>>>>> echo "${USBDISK}" > functions/mass_storage.usb0/lun.0/file >>>>>>> ln -s functions/mass_storage.usb0 configs/c.1/ >>>>>>> >>>>>>> # UAC2 device >>>>>>> mkdir functions/uac2.usb0 >>>>>>> ln -s functions/uac2.usb0 configs/c.1 >>>>>>> .... >>>>>> >>>>>> As you say, could perhaps the reason be that the extra EP-IN added in >>>>>> those patches (previously 1, now 2 with the default config you use) >>>>>> exceeds your EP-IN max count or available fifos somehow?  You have a >>>>>> number of functions initialized. If you change the load order of the >>>>>> functions, do you get the error later with a different function? Just >>>>>> guessing... >>>>>> >>>>>> You should be able to switch the default async EP-OUT (which >>>>>> configures the new feedback EP-IN ) to adaptive EP-OUT (which requires >>>>>> no feedback EP) with c_sync=8 parameter of f_uac2. >>>>>> >>>>>> https://urldefense.com/v3/__https://elixir.bootlin.com/linux/v5.14-rc6/source/drivers/usb/gadget/function/f_uac2.c*L47__;Iw!!A4F2R9G_pg!LBySrM_zgMGV0x-zZ7nSrs54yJw1GlnpUVUVxdQE8PeszSMZ6OkFX8lSoigwRbWQzLcU$ >>>>>> >>>>>> https://urldefense.com/v3/__https://elixir.bootlin.com/linux/v5.14-rc6/source/drivers/usb/gadget/function/f_uac2.c*L830__;Iw!!A4F2R9G_pg!LBySrM_zgMGV0x-zZ7nSrs54yJw1GlnpUVUVxdQE8PeszSMZ6OkFX8lSoigwRfP5TdZC$ >>>>>> >>>>>> https://urldefense.com/v3/__https://elixir.bootlin.com/linux/v5.14-rc6/source/include/uapi/linux/usb/ch9.h*L453__;Iw!!A4F2R9G_pg!LBySrM_zgMGV0x-zZ7nSrs54yJw1GlnpUVUVxdQE8PeszSMZ6OkFX8lSoigwRejzMbWO$ >>>>>> >>>>>> Does that fix the problem? >>>>> >>>>> Not sure how to do that. Do you mean the module should have a parameter >>>>> called c_sync? `modinfo` list no parameters for usb_f_uac2. >>>> >>>> Those are configfs params, not available in modinfo. >>>> >>>> I checked and the value is "adaptive" >>>> https://urldefense.com/v3/__https://elixir.bootlin.com/linux/v5.14-rc7/source/drivers/usb/gadget/function/f_uac2.c*L1312__;Iw!!A4F2R9G_pg!LBySrM_zgMGV0x-zZ7nSrs54yJw1GlnpUVUVxdQE8PeszSMZ6OkFX8lSoigwRTETcbsN$ >>> >>> >>>> In your configfs script: >>> >>> Kernel shouldn't crash with any available set of configuration >>> parameters, right? So, even if the parameter would fix the crash the >>> series is buggy and has to be reverted in my opinion. >> >> Sure, no problem with reverting. I am just trying to start up some >> troubleshooting. A resource exhaustion was mentioned here, that's why I >> suggested a way to test the patch with the original number of endpoints >> allocated. I do not get any crashes on my setup which uses fewer gadget >> functions. That's why I asked what happens if the functions load order >> is changed. I am afraid this thread is so complex that the actual >> problem has been burried in the history. >> > > As I pointed out previously, the crash is probably because of f_uac2 > prematurely freeing feedback request before its completion. > usb_ep_dequeue() is asynchronous. dwc2() may treat it as a synchronous > call so you didn't get a crash. Thanks for your hint, it greatly helps. >> > > I'm not sure how easy it is for you to obtain/test a device with dwc3, > but it would be great to also have it as part of your testing suite. :) Can you recommend a reasonably priced device with viable kernel updates for the testing? Optionally with SS which you mentioned last time? Thanks. Best regards, Pavel.