From owner-freebsd-hackers@freebsd.org Thu Feb 11 02:17:39 2016 Return-Path: Delivered-To: freebsd-hackers@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id DE1D9AA1747 for ; Thu, 11 Feb 2016 02:17:38 +0000 (UTC) (envelope-from johannes@brilliantservice.co.jp) Received: from mail-qk0-x230.google.com (mail-qk0-x230.google.com [IPv6:2607:f8b0:400d:c09::230]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (Client CN "smtp.gmail.com", Issuer "Google Internet Authority G2" (verified OK)) by mx1.freebsd.org (Postfix) with ESMTPS id 9DDA9A93 for ; Thu, 11 Feb 2016 02:17:38 +0000 (UTC) (envelope-from johannes@brilliantservice.co.jp) Received: by mail-qk0-x230.google.com with SMTP id x1so14243215qkc.1 for ; Wed, 10 Feb 2016 18:17:38 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=brilliantservice-co-jp.20150623.gappssmtp.com; s=20150623; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc:content-type; bh=6xz2XCFYE+6bAQK0zamaWgJaLy41nfCOxflz9voOnRI=; b=L0L5zLcf2XjsGZ4bV3G3hv+Sb0tt3hWO9+17HFOBBXOtnmoov9MfP9Cjbp23e9ZGja BGP4Hx5Lg2eXdxSuUK3zfKZRGAbj6i3ciBRz+1r7qSGigrSbxqQd65KXoq/Tc1SqRooH dPtBJgAMhPooPg/kMHSwrRqDgsI7EIJNCtIeNRUqv8/fBCsKfx+iGSASCEvL4YcMcTG0 bdJ+qa2X16jPsSA68OhBJbPbdk7sRLioCw14xQt6+/Rfj+8Kc+32EG7JYA2QLLzyqlS0 eYy5F2DOitvjAEGsLlEIxtx0CMHWxXE8B4KP6QA+u+Na5liAa5PPT6/O0CH+6TT7DVO8 PbsA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc:content-type; bh=6xz2XCFYE+6bAQK0zamaWgJaLy41nfCOxflz9voOnRI=; b=Hl6CYQY2LUiKG++cXE9RAB7A0IXyK1FpPM9Hq6UpH2K9R3ES5gc2PYq5itWuYj+s5w 3eFgcg6FleAMDWOBB9kIa+aL5gD/KgDccLtDAocPpbvw5WwUXowAb5gi9vI7Mg8J3q4W mAxg5eYX0FP2ZhWSwmR77P3xugqNZnw06QU65i/jiofvxQgBiBXPae30HXMPZhV4DCw7 JNiDn77JD8vz9IWJsqEh1+6hbBtMA8n3NPlbQ7xNPG0c0nR4mJIEr8LlMlIxjDSgP6bA Xe9ErVvCALKQgFNGJgNyvfGZ78Gnv9A1+GFvGI3lcymOYqVeOteLGyql0hFsdcAZTyXV 2yIg== X-Gm-Message-State: AG10YOToxbrtPKQM0y89WL6aAb4cNiQCdOvPqWhAxXUwrEPWCrIHbNaEomwvGi5Sbrlj94cHvJFNkmjTIAiHa5t3yfmE8qtQ6GJmur/I80FdsEbvAtTr3HyLYPIK23R7gav4LEZaOAjtQUWkEmSWHl+bfxY= X-Received: by 10.55.41.160 with SMTP id p32mr47742065qkp.69.1455157056884; Wed, 10 Feb 2016 18:17:36 -0800 (PST) MIME-Version: 1.0 Received: by 10.55.45.71 with HTTP; Wed, 10 Feb 2016 18:17:22 -0800 (PST) In-Reply-To: <5688F015.4090002@bakulin.de> References: <20140216111153.GA74858@olymp.kibab.com> <5C2CF572-360D-4CA0-81C7-18A5C455AED5@bsdimp.com> <20140224142642.GA32538@olymp.kibab.com> <53120EE8.1080600@bakulin.de> <5688F015.4090002@bakulin.de> From: "Lundberg, Johannes" Date: Wed, 10 Feb 2016 18:17:22 -0800 Message-ID: Subject: Re: MMC/SDIO stack under CAM To: Ilya Bakulin Cc: "freebsd-hackers@freebsd.org" , Adrian Chadd , Alexander Motin , "freebsd-arm@freebsd.org" Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: quoted-printable X-Content-Filtered-By: Mailman/MimeDel 2.1.20 X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 11 Feb 2016 02:17:39 -0000 Hi Ilya This is great! I've got a Tronsmart ARA X5 and just purchased a few UP boards and it would be really nice if I could utilize the onboard eMMC. These are all Intel Cherrytrail platforms. Please let me know if there's anything (testing?) I can do to speed up the process. -- Name: Johannes Lundberg Position: Mirama project leader Phone: +1-408-636-2161 Skype: brilliantjohannes Online: LinkedIn Facebook Reddit Twitter GitHub GitLab Company: Mirama Brilliantservice US Brilliantservice JP On Sun, Jan 3, 2016 at 1:55 AM, Ilya Bakulin wrote: > So, more than one year has passed, and I'd like to resurrect this work > and move forward. > > I have uploaded a new diff and created a completely new revision to > track the development: https://reviews.freebsd.org/D4761 > > What it is able to do now: > > * Read/write on SD/SDHC/MMC cards! > * Detect SDIO cards and create devices that correspond to SDIO functions > > This all works only on BeagleBone currently, because some changes need > to be done in each SDHCI-compliant driver to make it interact with CAM. > I have purchased a Wandboard Quad that has an integrated SDIO WiFi chip, > so I hope to tweak its SDHCI driver as well. > > I haven't profiled the stack because: > * Now we have only SD/MMC cards that are slow anyway; > * I don't know how to do it in FreeBSD :-) > > Please review this diff and tell what you think! > > On 01/03/14 18:05, Adrian Chadd wrote: > > On 1 March 2014 08:46, Ilya Bakulin wrote: > >> Hi Adrian, > >> > >> On 24.02.14, 16:59, Adrian Chadd wrote: > >>> hi, > >>> > >>> Let me just reiterate some .. well, experience doing this stuff at QC= A. > >>> > >>> You really, absolutely don't want too much overhead in the MMC/SDIO > >>> path between whatever is issuing things and the network driver. > >>> > >>> There was significant performance work done at QCA on a local MMC/SDI= O > >>> driver and bus to get extremely low latency and CPU utilisation when > >>> pushing around small transactions. The current CAM locking model is > >>> not geared towards getting to high transaction rates. > >> So here you mean some work done on Linux MMC/SDIO stack by QCA > >> which made it far better than current Linux MMC stack in terms of > >> high SDIO I/O rates? > > Yup. The stock MMC stack/driver in Linux wasn't "fast" enough at small > > transactions to sustain the wifi speeds customers required. > > > >>> You may think this is a very architecturally pretty solution and it > >>> indeed may be. But if it doesn't perform as well as the existing loca= l > >>> hacks that vendors have done, no company deploying this hardware is > >>> going to want to use it. They'll end up realising there's this massiv= e > >>> CAM storage layer in between and either have to sit down to rip it up > >>> and replace it with something lightweight, or they'll say "screw it" > >>> and go back to the vendor supplied hacked up Linux solution. > >> I think that if the "architecturally pretty solution" behaves worse th= an > >> some ugly hacks, then it may be not so pretty or the architecture is > >> just broken > >> by design. > >> > >>> So I highly recommend you profile things - and profile things with > >>> lots of small transactions. If the CAM overhead is more than a tiny, > >>> tiny fraction of CPU at 25,000 pps, your solution won't scale. :-) > >> I don't really know what to compare with. For MMC/SD cards it is prett= y > >> obvious, but then these cards will be likely the bottleneck, not the > stack. > >> And the only goal would be to not make the stack slower than it is now= . > >> But, as ATA devices are much faster than MMC/SD, I don't think this wi= ll > >> be a problem. > >> > >> For SDIO things are different. But we don't have any drivers (yet), > except > >> mv_sdiowl that I'm writing, to test on. So I have to bring the SDIO > >> stack on CAM, > >> than bring mv_sdiowl to the state when it can actually transmit the > >> data, and then > >> compare performance with the vendor-supplied Linux driver. > >> We'll see then if there is a room for improvement... > > That sounds like a plan. > > > > Just note that although storage looks like it's doing much more > > throughput, the IO size also matters. As I said above, it's not > > uncommon to have > 1000 receive frames a second on 802.11n; and that > > can peak much higher than that. That's not the kind of IO rate you see > > on SD cards. :-) > > > > > > > > -a > > _______________________________________________ > > freebsd-hackers@freebsd.org mailing list > > http://lists.freebsd.org/mailman/listinfo/freebsd-hackers > > To unsubscribe, send any mail to " > freebsd-hackers-unsubscribe@freebsd.org" > > > > > -- > Regards, > Ilya Bakulin > > > --=20 =3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D= -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D- =E7=A7=98=E5=AF=86=E4=BF=9D=E6=8C=81=E3=81=AB=E3=81=A4=E3=81=84=E3=81=A6=EF= =BC=9A=E3=81=93=E3=81=AE=E9=9B=BB=E5=AD=90=E3=83=A1=E3=83=BC=E3=83=AB=E3=81= =AF=E3=80=81=E5=90=8D=E5=AE=9B=E4=BA=BA=E3=81=AB=E9=80=81=E4=BF=A1=E3=81=97= =E3=81=9F=E3=82=82=E3=81=AE=E3=81=A7=E3=81=82=E3=82=8A=E3=80=81=E7=A7=98=E5= =8C=BF=E7=89=B9=E6=A8=A9=E3=81=AE=E5=AF=BE=E8=B1=A1=E3=81=A8=E3=81=AA=E3=82= =8B=E6=83=85=E5=A0=B1=E3=82=92=E5=90=AB=E3=82=93=E3=81=A7=E3=81=84=E3=81=BE= =E3=81=99=E3=80=82 =E3=82=82=E3=81=97=E3=80=81=E5=90=8D=E5=AE=9B=E4=BA=BA=E4=BB=A5=E5=A4=96=E3= =81=AE=E6=96=B9=E3=81=8C=E5=8F=97=E4=BF=A1=E3=81=95=E3=82=8C=E3=81=9F=E5=A0= =B4=E5=90=88=E3=80=81=E3=81=93=E3=81=AE=E3=83=A1=E3=83=BC=E3=83=AB=E3=81=AE= =E7=A0=B4=E6=A3=84=E3=80=81=E3=81=8A=E3=82=88=E3=81=B3=E3=81=93=E3=81=AE=E3= =83=A1=E3=83=BC=E3=83=AB=E3=81=AB=E9=96=A2=E3=81=99=E3=82=8B=E4=B8=80=E5=88= =87=E3=81=AE=E9=96=8B=E7=A4=BA=E3=80=81 =E8=A4=87=E5=86=99=E3=80=81=E9=85=8D=E5=B8=83=E3=80=81=E3=81=9D=E3=81=AE=E4= =BB=96=E3=81=AE=E5=88=A9=E7=94=A8=E3=80=81=E3=81=BE=E3=81=9F=E3=81=AF=E8=A8= =98=E8=BC=89=E5=86=85=E5=AE=B9=E3=81=AB=E5=9F=BA=E3=81=A5=E3=81=8F=E3=81=84= =E3=81=8B=E3=81=AA=E3=82=8B=E8=A1=8C=E5=8B=95=E3=82=82=E3=81=95=E3=82=8C=E3= =81=AA=E3=81=84=E3=82=88=E3=81=86=E3=81=8A=E9=A1=98=E3=81=84=E7=94=B3=E3=81= =97=E4=B8=8A=E3=81=92=E3=81=BE=E3=81=99=E3=80=82 --- CONFIDENTIALITY NOTE: The information in this email is confidential and intended solely for the addressee. Disclosure, copying, distribution or any other action of use of this email by person other than intended recipient, is prohibited. If you are not the intended recipient and have received this email in error, please destroy the original message.