Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp2748745pxb; Tue, 24 Aug 2021 06:46:38 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyqZ++GLY3h4Lshrpf/j6h9YNNJc77CKq2nesU6HtXhXIoQTtoh58TECkeFLh8UQX4DzQGA X-Received: by 2002:a17:906:7153:: with SMTP id z19mr40883068ejj.343.1629812797795; Tue, 24 Aug 2021 06:46:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629812797; cv=none; d=google.com; s=arc-20160816; b=tEuJUXDsl8WEZ7ipJTzBXau6GJkv7PQVuPjh38MIX4odYRU406rRd2gyfIdt3MLQI+ GfZh+x44eWdfOK/HjqaBuwQwzOBRJJavhi9NoTmdl2X2R+Ix5toXR1xv5VDxU5Avd/0F kZRJojAWqu4Gr5A1o5Aw+r7cqSNslIWtyTPIx1g3870r9uEusoLjZA4YJFVSGj1wyoNc TNdst79gZUTvcz9yGG/Zwlfe1jQIAdEKYSZ2rp+hmlJ6VZmLkIz+WrZg7811d5rNyKnw upY2m3QFGFvaXTA5AgF2y5pyrl7qibR3R8oI6wKE2gi2Xtup/ukb023dJyWwe3U/AYPM sqNg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:references:cc :to:subject:from; bh=pb/i9DDjFZOd8Fl0raa2bZjIdeYUUAYNIwKRaQtDWn8=; b=CCuY9hIqPmOqPFbx7+jdG/6vxKVUYACr/d4lJgBN/DvYyq6hfdsWyc/vQXnt45j6sD tVJzHw8d8GXCuBQMzZdZlwLeSr9XfUpopMkQLdqK5NOmhwrcztKkr9XzBuBBDzecg+GK 0xMeCX5dhm41bcvMGDQJkPVsMvj54VwWDymiP0lFYWXaJXu+fFqOmE/ozw6Gj9CzQ2pL wn5uGYrEDMOA07H0Wmi3qQ+jhWzk0ADINP3VZvBB6ZftQZ3W0B57PZfy0z+23K4rUwsR /InqEgnj6rL5tfjcA8oI2KK98UG8yil9sE6MuiSMF1gHOLUCRtx0ype7FDSYqhGqdbD2 AIOg== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z5si18389988edb.511.2021.08.24.06.46.14; Tue, 24 Aug 2021 06:46:37 -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; 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=fail (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237614AbhHXNp2 (ORCPT + 99 others); Tue, 24 Aug 2021 09:45:28 -0400 Received: from smtp.radex.nl ([178.250.146.7]:34079 "EHLO radex-web.radex.nl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229517AbhHXNp1 (ORCPT ); Tue, 24 Aug 2021 09:45:27 -0400 Received: from [192.168.1.35] (cust-178-250-146-69.breedbanddelft.nl [178.250.146.69]) by radex-web.radex.nl (Postfix) with ESMTPS id 650112406A; Tue, 24 Aug 2021 15:44:41 +0200 (CEST) From: Ferry Toth Subject: Re: [PATCH v10 0/6] Re-introduce TX FIFO resize for larger EP bursting To: Pavel Hofman , Thinh Nguyen , Andy Shevchenko Cc: 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> Message-ID: <84236328-750e-700a-855b-19b362362d25@gmail.com> Date: Tue, 24 Aug 2021 15:44:40 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.11.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Op 24-08-2021 om 07:39 schreef Pavel Hofman: > > > 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. > Edison-Arduino kit 2nd hand with display on ebay ~$100 :-) > Best regards, > > Pavel.