Received: by 10.223.176.5 with SMTP id f5csp376257wra; Fri, 9 Feb 2018 00:06:53 -0800 (PST) X-Google-Smtp-Source: AH8x224NpEgfh9Ir0P8v92ug8dfwydz+aLnMbKCQo9YQl1z73Cn+LA4HUVu+eMJ26FyL/K+LL6cV X-Received: by 10.98.65.220 with SMTP id g89mr1985864pfd.124.1518163613716; Fri, 09 Feb 2018 00:06:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518163613; cv=none; d=google.com; s=arc-20160816; b=jU7OXspsIVaXxhNTb4gg3wA1kW5B+zMVwME5Ph6X8vje6PDmJcR9+Oqel2qTH5Gmhp chifJBoFVHwxGOS/rujtZXed9Tnvog3DXM49bgDpAgsw3h2jIoPV2IPS7L7+jD6J+Hev uLLNivWW9ITYsPS7w+Qjj4ykhzekXuAJdnLMKBd/PsA+Cao8ClWGuQLK3XMKN+s7QvW1 6ZjIMEo4ai75eITT393Mv/5vUgTE62G6Y9TxVL9TC4STe+cqtco3TDx9bftmdz8/rAGE X3EsJzxI37ngkhNXspHeyO5ViJSnNprKAI9TXZa1Br4yjtIrz+7Soc1I0ewFlssBNj3f Atnw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:arc-authentication-results; bh=n/Cq5RmZcO2r5c7OFlTbvV+d22hleAfVXE6eJnwqIBQ=; b=A+EWUFFkwdVVzDNKYJPLGS2gIUWOInTKJczhAxipC/O1f6pEsglO3fKkX4vjDxJyJ2 9KnFWkh8mY3k8gf1h0KYRMv7TPV2H6hag03v5tJDYoRJwjE3GHIImk/WSiun3BszRWlE tXXi9bBEpZW47D+7pi49mOM0gVt/XI1E6B2Q6ANbXKG9SY6gcwCYzLfRdLyV6YXx0Dga oL2vBUKHdBCuq7YfpOD0wKSmoxva/dUbreUDlkCekKHyOwDA8fWJwSjuWI1v9lUktIOh 76H9RoOqxyj+FCnWakzEOA7yyTYu9JcbyOQNXbKu7LNbA3KE/S/sBaTmeyzz6Hb/FspW K0zQ== 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 u8si1077725pgp.78.2018.02.09.00.06.39; Fri, 09 Feb 2018 00:06:53 -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 S1750993AbeBIIF6 (ORCPT + 99 others); Fri, 9 Feb 2018 03:05:58 -0500 Received: from mail.free-electrons.com ([62.4.15.54]:60075 "EHLO mail.free-electrons.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750789AbeBIIF4 (ORCPT ); Fri, 9 Feb 2018 03:05:56 -0500 Received: by mail.free-electrons.com (Postfix, from userid 110) id EC8DC203B5; Fri, 9 Feb 2018 09:05:53 +0100 (CET) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on mail.free-electrons.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT shortcircuit=ham autolearn=disabled version=3.4.0 Received: from qschulz (LStLambert-657-1-97-87.w90-63.abo.wanadoo.fr [90.63.216.87]) by mail.free-electrons.com (Postfix) with ESMTPSA id 7B8C32036C; Fri, 9 Feb 2018 09:05:43 +0100 (CET) Date: Fri, 9 Feb 2018 09:05:41 +0100 From: Quentin Schulz To: Ulf Hansson Cc: Hans de Goede , Quentin Schulz , Greg Kroah-Hartman , Linus Walleij , Shawn Lin , Adrian Hunter , Baolin Wang , Maxime Ripard , Thomas Petazzoni , "linux-kernel@vger.kernel.org" , "linux-mmc@vger.kernel.org" , driverdevel , Icenowy Zheng , Chen-Yu Tsai Subject: Re: [PATCH 2/2] mmc: Add mmc_force_detect_change_begin / _end functions Message-ID: <20180209080541.edgjbhjo542vq3h6@qschulz> References: <20170721143502.1991-1-quentin.schulz@free-electrons.com> <20170721143502.1991-3-quentin.schulz@free-electrons.com> <4015f7df-36ca-c762-5b9a-94a270f65475@redhat.com> <20180208145952.qlq4sxohqd3s7m7o@qschulz> MIME-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha256; protocol="application/pgp-signature"; boundary="xuf3jspe2anqcsl3" Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20170609 (1.8.3) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org --xuf3jspe2anqcsl3 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable Hi Ulf, On Thu, Feb 08, 2018 at 10:31:39PM +0100, Ulf Hansson wrote: > On 8 February 2018 at 15:59, Quentin Schulz = wrote: > > Hi Ulf, > > > > On Wed, Aug 30, 2017 at 03:43:49PM +0200, Ulf Hansson wrote: > >> On 30 August 2017 at 14:44, Hans de Goede wrote: > >> > Hi, > >> > > >> > > >> > On 21-07-17 16:35, Quentin Schulz wrote: > >> >> > >> >> From: Hans de Goede > >> >> > >> >> Some sdio devices have a multiple stage bring-up process. Specifica= lly > >> >> the esp8089 (for which an out of tree driver is available) loads fi= rmware > >> >> on the first call to its sdio-drivers' probe function and then rese= ts > >> >> the device causing it to reboot from its RAM with the new firmware. > >> >> > >> >> When this sdio device reboots it comes back up in 1 bit 400 KHz mode > >> >> again, and we need to walk through the whole ios negatiation and sd= io > >> >> setup > >> >> again. > >> >> > >> >> There are 2 problems with this: > >> >> > >> >> 1) Typically these devices are soldered onto some (ARM) tablet / SBC > >> >> PCB and as such are described in devicetree as "non-removable", whi= ch > >> >> causes the mmc-core to scan them only once and not poll for the dev= ice > >> >> dropping of the bus. Normally this is the right thing todo but in t= he > >> >> eso8089 example we need the mmc-core to notice the module has disco= nnected > >> >> (since it is now in 1 bit mode again it will not talk to the host i= n 4 bit > >> >> mode). This can be worked around by using "broken-cd" in devicetree > >> >> instead of "non-removable", but that is not a proper fix since the = device > >> >> really is non-removable. > >> >> > >> >> 2) When the mmc-core detects the device has disconnected it will po= weroff > >> >> the device, causing the RAM loaded firmware to be lost. This can be= worked > >> >> around in devicetree by using regulator-always-on (and avoiding the= use of > >> >> mmc-pwrseq), but again that is more of a hack then a proper fix. > >> >> > >> >> This commmit fixes 1) by adding a mmc_force_detect_change function = which > >> >> will cause scanning for device removal / insertion until a new devi= ce is > >> >> detected. 2) Is fixed by a keep_power flag to the mmc_force_detect_= change > >> >> function which when set causes the mmc-core to keep the power to the > >> >> device > >> >> on during the rescan. > >> >> > >> >> Cc: Icenowy Zheng > >> >> Cc: Maxime Ripard > >> >> Cc: Chen-Yu Tsai > >> >> Signed-off-by: Hans de Goede > >> > > >> > > >> > So when I posted this patch quite a while back, there was some discu= ssion > >> > about this and a consensus that this is not the right solution. > >> > > >> > So first of all lets describe the problem: > >> > > >> > The esp8089 sdio wifi chip is really an ARM core with a wifi phy > >> > connected to it (as many wifi chipsets are). > >> > > >> > But this one comes up in some really generic sdio capable boot-loader > >> > mode and we need to feed it firmware and then reboot it into the > >> > new firmware. > >> > > >> > The reboot is where the problems happens. It seems to fallback > >> > from the negotiated 4 wire sdio mode to single wire spi mode then. > >> > > >> > The out of tree version of the driver deals with this by not setting > >> > the non-removable flag as well as setting the broken_cd flag so that > >> > the mmc core polls the device, after the reboot the poll fails > >> > because the mmc-controller and the esp8089 are using a different > >> > amount of wires so the mmc-cmd the poll uses times out. > >> > > >> > After which the esp8089 drivers remove function gets called, and > >> > the mmc stack re-discovers the esp8089 by restarting the whole > >> > number of wires (and speed) used negotiation. After which the > >> > esp8089 driver's probe function gets called (again) and on > >> > firmware loading is has set a global flag, so now it actually > >> > acts as a wifi driver rather then trying to load the firmware > >> > a second time. > >> > > >> > Since I did not want to rely on broken_cd polling I came up > >> > with the hack which is this patch. > >> > > >> > So when this patch was first discussed we came to the conclusion > >> > that what we really need is some sort of mmc_reprobe_device > >> > function which the driver can call from probe which will > >> > redo the number of wires (and speed) used negotiation, > >> > while keeping the sdio_function device as is so that probe can > >> > simply continue after this and we also don't need the ugly > >> > global flag. > >> > > >> > The idea would be for this function to be some wrapper > >> > around mmc_init_card() which resets the ios settings as is > >> > normally done on remove and then call mmc_init_card() > >> > passing in the existing card the same way as is done > >> > one resume, so that the existing card / sdio_function > >> > devices get reused. > >> > > >> > IIRC Ulf would look into writing this mmc_reprobe_device > >> > function and then I would test it with the esp8089, but > >> > Ulf never got around to writing the function and I ended > >> > up working on other things too. > >> > >> Thanks for summary! > >> > >> Just to let you know, I haven't forgot about this problem. I am > >> planning for a major update of the SDIO for power management support, > >> within a not too far future. > >> The issue described above, is then also one of the things I also plan > >> to look into. > >> > > > > I'd like to know if any progress has been made on that problem (I may > > have missed patches). > > Had you had the time to look at the issue? >=20 > I have looked at the issue, but not manage to cook some patches for it. >=20 > However, it's on my top of my TODO list for mmc. No promises, but > perhaps and hopefully I manage to get something posted during the > coming release cycle. >=20 Cool! If you ever need some testing, I'd be glad to test your patches (even if they are in a draft/RFC state). Also, when you send patches, I'd appreciate being Cc'ed so that I can put my Tested-by :) Thanks! Best regards, Quentin --xuf3jspe2anqcsl3 Content-Type: application/pgp-signature; name="signature.asc" -----BEGIN PGP SIGNATURE----- iQIcBAABCAAGBQJafVZSAAoJEIS4mnU+4PGjVqEP/jA52IMS4EaSxvEuy7OCT/eY MUzeeQ34ZCgNNxpNkkFq7v5W2dpmxd6cNDUrW7UgDOazZWiH84fUWJ1ZCLSX8/cM AIm1tKqwEHWmRCi7Uz/h9VPYKUBJkX6YOsrm+CUAlXDKUSKufOoXuLT66EUQESdH 2q4IlSOYqKyJ09vvkBGwRA2+nkcxM1TLY0EysjwFUy8vh16NHs4EPgoaDtr3+dd2 cSvk6fXq6DmLgK6QuzAwZZDgY3/xREg8S+t56ZMqozk66/xISNi6RSw5ZAMCVLXq xY20c4pxHbldWjNMspo1W/xypqxeKh+Mphk98cXgSNz2hBxHVHRvz6s4Kf2CeqKs rS61IceBXXTL+Iuf4Rq3VbhYbL12udL+3m3iGUlRfHJRlAytebeox8h6jtlgwA4Y iR/s3xAupuz3uKafuSRcvbrvAloLdO4LV3Lj+wu2hZWxw/PDw5sOhyKkbR7vltvZ v6jzprLXk7seVyoqQapq17zO/w12+/WdfZbxvj9ocu8qMt2Na9Anbd4TMIpUdLnc CeseM313IjKVzWZKyOGDvydVeu/OsAOXdCnaOB2nvtam7kh2GLOILRCFC8XjA+hr 3UWPVUwXfUmUZf8Vti8jStb2AyNWFWApILzSAZooKlHIw3leP97G5kC5T8c/6zkE dSEu21t/nYmA10rawjfO =7BeV -----END PGP SIGNATURE----- --xuf3jspe2anqcsl3--