Date: Thu, 11 Aug 2011 12:51:43 +0300 From: Dmitry Zamaruyev <dmitry.zamaruyev@zoral.com.ua> To: Dmitry Zamaruyev <dmitry.zamaruyev@zoral.com.ua> Cc: freebsd-geom@freebsd.org Subject: Re: SSD and gmirror Message-ID: <20110811125143.6a70fb4a@ghost.kharkov.zoral.com.ua> In-Reply-To: <20110804130014.0df63364@ghost.kharkov.zoral.com.ua> References: <20110804130014.0df63364@ghost.kharkov.zoral.com.ua>
next in thread | previous in thread | raw e-mail | index | archive | help
Having troubles using gmirror device with TRIM. Two SSDs on 8.2-STABLE, supports TRIM on device: # camcontrol identify ada1 pass1: <OCZ-VERTEX2 1.33> ATA-8 SATA 2.x device pass1: 300.000MB/s transfers (SATA 2.x, UDMA6, PIO 8192bytes) protocol ATA/ATAPI-8 SATA 2.x device model OCZ-VERTEX2 ... data set management (TRIM) yes And if I create UFS directly on SSD with TRIM enabled all goes OK (-E uses trim to erase SSD): # newfs -U -E -t /dev/ada1 /dev/ada1: 57241.9MB (117231408 sectors) block size 16384, fragment size 2048 using 312 cylinder groups of 183.72MB, 11758 blks, 23552 inodes. with soft updates Erasing sectors [128...117231407] super-block backups (for fsck -b #) at: 160, 376416, ..... # mount -t ufs /dev/ada1 /mnt But if I add device to gmirror, situation is different. Newfs passed ok (so TRIM call propagated to devices?), but mount complaints: # newfs -U -E -t /dev/mirror/gm0s1a=20 /dev/mirror/gm0s1a: 57239.9MB (117227312 sectors) block size 16384, fragment size 2048 using 312 cylinder groups of 183.72MB, 11758 blks, 23552 inodes. with soft updates Erasing sectors [128...117227311] super-block backups (for fsck -b #) at: 160, 376416, ........ # mount -t ufs /dev/mirror/gm0s1a /mnt WARNING: /mnt: TRIM flag on fs but cannot get whether disk supports TRIM If we look at UFS source, after such warning received - TRIM got disabled at FS level: ufs/ffs/ffs_vfsops.c: 996 if ((fs->fs_flags & FS_TRIM) !=3D 0) { 997 size =3D sizeof(int); 998 if (g_io_getattr("GEOM::candelete", cp, &size, 999 &ump->um_candelete) =3D=3D 0) { 1000 if (!ump->um_candelete) 1001 printf( 1002 "WARNING: %s: TRIM flag on fs but disk does not support TRIM\n", 1003 mp->mnt_stat.f_mntonname); 1004 } else { 1005 printf( 1006 "WARNING: %s: TRIM flag on fs but cannot get whether disk supports TR= IM\n", 1007 mp->mnt_stat.f_mntonname); 1008 ump->um_candelete =3D 0;=20 1009 } 1010 } How I could achieve that call g_io_getattr("GEOM::candelete"...) will retur= n without errors and stating that underlying disks support TRIM ? =D0=92 Thu, 4 Aug 2011 13:00:14 +0300 Dmitry Zamaruyev <dmitry.zamaruyev@zoral.com.ua> =D0=BF=D0=B8=D1=88=D0=B5= =D1=82: > Hello list, >=20 > I'm looking for clarification regarding gmirror/geom behavior in > current 8-STABLE. > I want to use couple of SSD drives in mirror RAID configuration with > UFS on top. I know that UFS now supports TRIM (BIO_DELETE) on plain > disks. > But will gmirror propagate BIO_DELETE event to lower driver, so both > SSDs will get trimmed when UFS issue this command? >=20 --=20 Best regards, Dmitry Zamaruyev, System administrator.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20110811125143.6a70fb4a>