From owner-freebsd-arm@freebsd.org Sun Jan 22 04:29:37 2017 Return-Path: Delivered-To: freebsd-arm@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 59D20CBA885 for ; Sun, 22 Jan 2017 04:29:37 +0000 (UTC) (envelope-from karl@denninger.net) Received: from mail.denninger.net (denninger.net [70.169.168.7]) by mx1.freebsd.org (Postfix) with ESMTP id F299F98B for ; Sun, 22 Jan 2017 04:29:36 +0000 (UTC) (envelope-from karl@denninger.net) Received: from [192.168.1.40] (Karl-Desktop.Denninger.net [192.168.1.40]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.denninger.net (Postfix) with ESMTPSA id E192213381 for ; Sat, 21 Jan 2017 22:29:35 -0600 (CST) Subject: Re: how to measure microsd wear References: <20170122002432.B16E8406061@ip-64-139-1-69.sjc.megapath.net> To: freebsd-arm@freebsd.org From: Karl Denninger Message-ID: Date: Sat, 21 Jan 2017 22:29:32 -0600 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:45.0) Gecko/20100101 Thunderbird/45.6.0 MIME-Version: 1.0 In-Reply-To: <20170122002432.B16E8406061@ip-64-139-1-69.sjc.megapath.net> Content-Type: multipart/signed; protocol="application/pkcs7-signature"; micalg=sha-512; boundary="------------ms070404060709020904080902" X-Content-Filtered-By: Mailman/MimeDel 2.1.23 X-BeenThere: freebsd-arm@freebsd.org X-Mailman-Version: 2.1.23 Precedence: list List-Id: "Porting FreeBSD to ARM processors." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 22 Jan 2017 04:29:37 -0000 This is a cryptographically signed message in MIME format. --------------ms070404060709020904080902 Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: quoted-printable On 1/21/2017 18:24, Hal Murray wrote: > karl@denninger.net said: >> and this one is not a low-hour failure either, nor is it an off-brand = -- >> it's a Sandisk Ultra 32Gb and the machine has roughly a year of 24x7x3= 65 >> uptime on it. > Any idea how many writes it did? Offhand, no. I did not expect this particular device to have a problem given its workload, but it did. It could have been a completely random even (e.g. cosmic ray hits the "wrong" place in the controller's mapping tables, damages the data in it a critical way, and the controller throws up its hands and says "screw you, it's over.") There's no real way to know - the card is effectively junk as the controller has write-locked it, so all I can do (and did) is get the config files and application it runs under the OS off it and put them on the new one. The other failures were less-surprising; in particular the box on my desk, given that I compile on it frequently and that produces a lot of small write I/O activity, didn't shock me all that much when it failed. One of the big problems with NAND flash (in any form) is that it can only be written to "zeros." That is, a blank page is all "1s" at a bit level, and a write actually just writes the zeros. This leads to what is called "write amplification" because changing one byte in a page requires reading the page in and writing an entire new page out, then (usually later) erasing the former page; you cannot update in-place. If a page is 4k in size then writing a single byte results in an actual write of 4k bytes, or ~4,000 times as much as you think you wrote. This is also one of the reasons that random small-block write performance is much slower than big writes; if you write an even multiple of an on-card block the controller can simply lay down the new data onto pre-erased space, where if you write small pieces of data it cannot do that and winds up doing a lot of read/write cycling. It gets worse (by a lot) if there's file metadata to update with each write as well because that metadata almost-certainly winds up carrying a (large) amount of write amplification irrespective of the file data itself. All of this is a big part of why write I/O performance to these cards for actual filesystem use is stinky in the general case compared against pretty-much anything else. The controller's internal logic has much voodoo in it from a user's perspective; the manufacturers consider exactly how they do what they do to be proprietary and simply present to you an opaque block-level interface. There are rumors that some controllers "know" about certain filesystems (specifically exFAT) and are optimized for it, which implies they may behave less-well if you're using something else. How true this actually might be is unknown but a couple of years ago I had a card that appeared dead -- until it was reformatted with exFAT, at which point it started working again. I didn't trust it, needless to say. SSDs typically have a published endurance rating and a reasonable interface to get a handle on how much "wear" they have experienced.=20 I've never seen either in any meaningful form for SD cards of any sort.=20 In addition SSDs can (and do) "cheat" in that they all have RAM in them and thus can collate writes together before physically committing them in some instances, plus they typically will report that a write is "complete" when it is in RAM (and not actually in NAND!) Needless to say if there's no proper power protection sufficient to flush that RAM if the power fails unexpectedly very bad things will happen to your data, and very few SSDs have said proper power protection (Intel 7xx and 3xxx series are two that are known to do this correctly; I have a bunch of the 7xx series drives in service and have never had a problem with any of them even under intentional cord-yank scenarios intended to test their power-loss protection.) I'm unaware of SD cards that do any of this and I suspect their small size precludes it, never mind that they were not designed for a workload where this would be terribly useful.=20 The use envisioned for most SD cards, and their intent when designed, is the sequential writing of anywhere from large to huge files (video or still pictures) and the later sequential reading back of same, all under some form of a FAT filesystem (exFAT for the larger cards now available.)= IMHO the best you can do with these cards in this application is to minimize writes to the extent you can, especially small and frequent writes of little actual value (e.g. mount with noatime!) and make sure you can reasonably recover from failures in a rational fashion. --=20 Karl Denninger karl@denninger.net /The Market Ticker/ /[S/MIME encrypted email preferred]/ --------------ms070404060709020904080902 Content-Type: application/pkcs7-signature; name="smime.p7s" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="smime.p7s" Content-Description: S/MIME Cryptographic Signature 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 FqeE/DBbs+PZcqY/q6dlRWwAAAAAAAA= --------------ms070404060709020904080902--