From owner-freebsd-arm@FreeBSD.ORG Sun Jun 1 02:33:41 2014 Return-Path: Delivered-To: freebsd-arm@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [8.8.178.115]) (using TLSv1 with cipher ADH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id 29E50E92; Sun, 1 Jun 2014 02:33:41 +0000 (UTC) Received: from raven.bwct.de (raven.bwct.de [85.159.14.73]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client CN "raven.bwct.de", Issuer "BWCT" (not verified)) by mx1.freebsd.org (Postfix) with ESMTPS id A8B6323FF; Sun, 1 Jun 2014 02:33:40 +0000 (UTC) Received: from mail.cicely.de ([10.1.1.37]) by raven.bwct.de (8.13.4/8.13.4) with ESMTP id s512XVQ5023259 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=FAIL); Sun, 1 Jun 2014 04:33:31 +0200 (CEST) (envelope-from ticso@cicely7.cicely.de) Received: from cicely7.cicely.de (cicely7.cicely.de [10.1.1.9]) by mail.cicely.de (8.14.5/8.14.4) with ESMTP id s512XOVb072012 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Sun, 1 Jun 2014 04:33:24 +0200 (CEST) (envelope-from ticso@cicely7.cicely.de) Received: from cicely7.cicely.de (localhost [127.0.0.1]) by cicely7.cicely.de (8.14.2/8.14.2) with ESMTP id s512XOrF055942; Sun, 1 Jun 2014 04:33:24 +0200 (CEST) (envelope-from ticso@cicely7.cicely.de) Received: (from ticso@localhost) by cicely7.cicely.de (8.14.2/8.14.2/Submit) id s512XOtl055941; Sun, 1 Jun 2014 04:33:24 +0200 (CEST) (envelope-from ticso) Date: Sun, 1 Jun 2014 04:33:24 +0200 From: Bernd Walter To: Warner Losh Subject: Re: TRIM on SD cards Message-ID: <20140601023324.GD54731@cicely7.cicely.de> Reply-To: ticso@cicely.de References: <20140531004306.GI26883@cicely7.cicely.de> <1401505209.20883.34.camel@revolution.hippie.lan> <20140531102305.GK26883@cicely7.cicely.de> <05005B04-1BDA-4242-946B-28D0DA069A42@bsdimp.com> <0A74DD39-7C54-4F09-A4B9-623A9BD25E2A@bsdimp.com> <20140601004311.GB54731@cicely7.cicely.de> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20140601004311.GB54731@cicely7.cicely.de> X-Operating-System: FreeBSD cicely7.cicely.de 7.0-STABLE i386 User-Agent: Mutt/1.5.11 X-Spam-Status: No, score=-2.9 required=5.0 tests=ALL_TRUSTED=-1, BAYES_00=-1.9, T_RP_MATCHES_RCVD=-0.01 autolearn=ham version=3.3.0 X-Spam-Checker-Version: SpamAssassin 3.3.0 (2010-01-18) on spamd.cicely.de Cc: Bernd Walter , "freebsd-arm@freebsd.org" , ticso@cicely.de, Ian Lepore X-BeenThere: freebsd-arm@freebsd.org X-Mailman-Version: 2.1.18 Precedence: list List-Id: "Porting FreeBSD to ARM processors." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 01 Jun 2014 02:33:41 -0000 On Sun, Jun 01, 2014 at 02:43:11AM +0200, Bernd Walter wrote: > On Sat, May 31, 2014 at 12:51:42PM -0600, Warner Losh wrote: > > > > On May 31, 2014, at 12:44 PM, Warner Losh wrote: > > > > > > > > On May 31, 2014, at 12:06 PM, Adrian Chadd wrote: > > > > > >> On 31 May 2014 10:49, Warner Losh wrote: > > >>> > > >>> On May 31, 2014, at 11:31 AM, Adrian Chadd wrote: > > >>> > > >>>> On 31 May 2014 09:45, Warner Losh wrote: > > >>>> > > >>>>> One of the things that I did for images years ago was compressed tar files. There was so much variation between CF makers and at the time CF geometry was important to the BIOS, so we made our images as tar balls. We then had a makefile target that would create a partition on the card that was actually there, put boot blocks on it then extract the tarball? I never have liked DD for creating images, even when LBAs ruled the day because you?d always have to grow/shrink the FS afterwards. The only advantage it had was it was easy? Perhaps it is time to go back to that model? The alternative that wouldn?t suck too bad would be to create variable sized images based on how much data was actually present and ensure there are no holes (or minimal holes) in the filesystem. > > >>>>> > > >>>>> Hmmm, if we know WHAT filesystem we?re dealing with, then we could perhaps enhance fsck and/or growfs to BIO_DELETE all the blocks that it knows are free, which would be a useful, data-driven approach that could ensure we start out with a nicely trimmed FS. Given the vagaries of the different kinds of TRIMs and the various translation layers we have, that might be the most robust. > > >>>> > > >>>> Having makefs spit this out would be rather useful. > > >>> > > >>> I?m not sure it would be. Any writes to the FS after you create it would invalidate the list? Far easier to have fsck do it for you any time you need it... > > >> > > >> Sure, but it'd be part of a larger scale image creation and writing > > >> tool. That way you could ship images that had the sparseness bits in > > >> them and the tool + growfs can TRIM as appropriate on the installing > > >> media. > > > > > > Except why have an extra step when all that metadata is encoded in the filesystem itself? > > > > looks like fsck already has a -E flag: > > > > -E Clear unallocated blocks, notifying the underlying device that > > they are not used and that their contents may be discarded. This > > is useful for filesystems which have been mounted on systems > > without TRIM support, or with TRIM support disabled, as well as > > filesystems which have been copied from one device to another. > > > > So maybe the answer ?it is already there? might be a better reason :) > > > > Bernd, can you try this on your arm box to see what it does for your system? > > Oh damn - I should have looked into the fsck manpage. > This is great. > I've put it on my TODO list for next week. Seems to be a rather new feature. At least my 1 month old stable system don't have this feature. At least this explains why I didn't spot it - I thought to have looked into fsck manpage, but wasn't sure. -- B.Walter http://www.bwct.de Modbus/TCP Ethernet I/O Baugruppen, ARM basierte FreeBSD Rechner uvm.