Date: Tue, 22 Jan 2013 17:50:40 +0700 From: Alexey Dokuchaev <danfe@nsu.ru> To: questions@freebsd.org Subject: Re: TRIM support on SSD via ata(4) Message-ID: <20130122105039.GA11236@regency.nsu.ru> In-Reply-To: <20130122051346.GA53833@regency.nsu.ru> References: <20130122051346.GA53833@regency.nsu.ru>
next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, Jan 22, 2013 at 12:13:46PM +0700, Alexey Dokuchaev wrote:
> Unfortunately, I cannot use ahci(4) and limited to atacontrol(8), which
> does not have "identify" command like camcontrol(8). Shall I recompile the
> kernel with ATA_CAM option?
I've switched to ATA_CAM and removed atadisk from /boot/loader.conf. CAM
driver reported flags 0x896, which includes ADA_FLAG_CAN_TRIM (0x080). In
adaregister() of /sys/cam/ata/ata_da.c, this is enough to in turn enable
DISKFLAG_CANDELETE disk flag:
if ((softc->flags & ADA_FLAG_CAN_TRIM) ||
((softc->flags & ADA_FLAG_CAN_CFA) &&
!(softc->flags & ADA_FLAG_CAN_48BIT)))
softc->disk->d_flags |= DISKFLAG_CANDELETE;
In /sys/dev/ata/ata-disk.c, this check is different:
if ((atadev->param.support.command2 & ATA_SUPPORT_CFA) ||
atadev->param.config == ATA_PROTO_CFA)
adp->disk->d_flags |= DISKFLAG_CANDELETE;
Since this disk evidently does not support CFA, ata(4) was not raising
DISKFLAG_CANDELETE flag.
With CAM_ATA, I can now use camcontrol(8) to talk to my disks:
# camcontrol identify ada0 | egrep TRIM\|Feature
Feature Support Enabled Value Vendor
data set management (TRIM) yes
"TRIM on fs but drive does not have it" warning is gone. I wonder why
legacy ata(4) did not enable TRIM though.
./danfe
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20130122105039.GA11236>
