[<prev] [next>] [day] [month] [year] [list]
Message-Id: <1339263606-3967-1-git-send-email-linkinjeon@gmail.com>
Date: Sat, 9 Jun 2012 13:40:06 -0400
From: Namjae Jeon <linkinjeon@...il.com>
To: James.Bottomley@...senPartnership.com, gregkh@...uxfoundation.org,
mdharm-usb@...-eyed-alien.net, stern@...land.harvard.edu,
sshtylyov@...sta.com, bvanassche@....org
Cc: linux-usb@...r.kernel.org, linux-scsi@...r.kernel.org,
linux-kernel@...r.kernel.org, Namjae Jeon <linkinjeon@...il.com>
Subject: [PATCH v3 0/3] scsi: fix internal write cache issue on usb hdd.
The numbers of USB HDDs(All USB HDD I checked) does not respond
correctly to scsi mode sense command for retrieving the write cache
page status. Even though write cache is enabled by default, due to
scsi driver assume that cache is not enabled which in turn might lead
to loss of data since data still will be in cache.
This result that all filesystems is not stable on USB HDD when the
device is unplugged abruptly, even though these are having journaling
feature. Our first trying is that scsi driver send ATA command
(ATA Pass through, #58) to USB HDD after failure from normal routine to
know write cache enable.
We have known it is dangerous after testing several USB HDD. some of
HDD is stalled by this command(A-DATA HDD). So we tried to make the
patch James's suggestion(usb quirk) on version 2 that add product ID
and verdor ID of USB HDD to USB quirk list after checking write cache.
All filesystem will be stable on USB HDD registered in quirk list.
And it will be updated continuously.
scsi: set to WCE if usb cache quirk is present.
usb: storage: add support write cache quirk on usb hdd.
usb: core: update usb devices for write cache quirk in quirk.
drivers/scsi/sd.c | 9 +++++++--
include/scsi/scsi_device.h | 1 +
drivers/usb/storage/scsiglue.c | 5 +++++
drivers/usb/storage/usb.c | 5 ++++-
include/linux/usb_usual.h | 4 +++-
drivers/usb/storage/unusual_devs.h | 24 ++++++++++++++++++++++++
Documentation/kernel-parameters.txt | 2 ++
7 files changed, 46 insertions(+), 4 deletions(-)
--
1.7.9.5
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists