* [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd
@ 2012-06-09 17:41 Namjae Jeon
2012-06-09 18:42 ` Sergei Shtylyov
0 siblings, 1 reply; 8+ messages in thread
From: Namjae Jeon @ 2012-06-09 17:41 UTC (permalink / raw)
To: James.Bottomley, gregkh, mdharm-usb, stern, sshtylyov, bvanassche
Cc: linux-usb, linux-scsi, linux-kernel, Namjae Jeon, Namjae Jeon,
Pankaj Kumar, Amit Sahrawat
Add support for write cache quirk on usb hdd. scsi driver will be set to wce
by detecting write cache quirk in quirk list when plugging usb hdd.
Signed-off-by: Namjae Jeon <namjae.jeon@samsung.com>
Signed-off-by: Pankaj Kumar <pankaj.km@samsung.com>
Signed-off-by: Amit Sahrawat <a.sahrawat@samsung.com>
---
drivers/usb/storage/scsiglue.c | 5 +++++
drivers/usb/storage/usb.c | 5 ++++-
include/linux/usb_usual.h | 4 +++-
3 files changed, 12 insertions(+), 2 deletions(-)
diff --git a/drivers/usb/storage/scsiglue.c b/drivers/usb/storage/scsiglue.c
index a324a5d..fe42547 100644
--- a/drivers/usb/storage/scsiglue.c
+++ b/drivers/usb/storage/scsiglue.c
@@ -230,6 +230,11 @@ static int slave_configure(struct scsi_device *sdev)
US_FL_SCM_MULT_TARG)) &&
us->protocol == USB_PR_BULK)
us->use_last_sector_hacks = 1;
+
+ /* Check if write cache default on flag is set or not */
+ if (us->fflags & US_FL_WRITE_CACHE)
+ sdev->wce_default_on = 1;
+
} else {
/* Non-disk-type devices don't need to blacklist any pages
diff --git a/drivers/usb/storage/usb.c b/drivers/usb/storage/usb.c
index e23c30a..d012fe4 100644
--- a/drivers/usb/storage/usb.c
+++ b/drivers/usb/storage/usb.c
@@ -473,7 +473,7 @@ static void adjust_quirks(struct us_data *us)
US_FL_CAPACITY_OK | US_FL_IGNORE_RESIDUE |
US_FL_SINGLE_LUN | US_FL_NO_WP_DETECT |
US_FL_NO_READ_DISC_INFO | US_FL_NO_READ_CAPACITY_16 |
- US_FL_INITIAL_READ10);
+ US_FL_INITIAL_READ10 | US_FL_WRITE_CACHE);
p = quirks;
while (*p) {
@@ -529,6 +529,9 @@ static void adjust_quirks(struct us_data *us)
case 'o':
f |= US_FL_CAPACITY_OK;
break;
+ case 'p':
+ f |= US_FL_WRITE_CACHE;
+ break;
case 'r':
f |= US_FL_IGNORE_RESIDUE;
break;
diff --git a/include/linux/usb_usual.h b/include/linux/usb_usual.h
index 17df360..96fc152 100644
--- a/include/linux/usb_usual.h
+++ b/include/linux/usb_usual.h
@@ -64,7 +64,9 @@
US_FLAG(NO_READ_CAPACITY_16, 0x00080000) \
/* cannot handle READ_CAPACITY_16 */ \
US_FLAG(INITIAL_READ10, 0x00100000) \
- /* Initial READ(10) (and others) must be retried */
+ /* Initial READ(10) (and others) must be retried */ \
+ US_FLAG(WRITE_CACHE, 0x00200000) \
+ /* Write Cache status is not available */
#define US_FLAG(name, value) US_FL_##name = value ,
enum { US_DO_ALL_FLAGS };
--
1.7.9.5
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd
2012-06-09 17:41 [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd Namjae Jeon
@ 2012-06-09 18:42 ` Sergei Shtylyov
2012-06-10 0:30 ` Namjae Jeon
0 siblings, 1 reply; 8+ messages in thread
From: Sergei Shtylyov @ 2012-06-09 18:42 UTC (permalink / raw)
To: Namjae Jeon
Cc: James.Bottomley, gregkh, mdharm-usb, stern, bvanassche, linux-usb,
linux-scsi, linux-kernel, Namjae Jeon, Pankaj Kumar,
Amit Sahrawat
Hello.
On 06/09/2012 09:41 PM, Namjae Jeon wrote:
> Add support for write cache quirk on usb hdd. scsi driver will be set to wce
> by detecting write cache quirk in quirk list when plugging usb hdd.
> Signed-off-by: Namjae Jeon<namjae.jeon@samsung.com>
> Signed-off-by: Pankaj Kumar<pankaj.km@samsung.com>
> Signed-off-by: Amit Sahrawat<a.sahrawat@samsung.com>
> ---
> drivers/usb/storage/scsiglue.c | 5 +++++
> drivers/usb/storage/usb.c | 5 ++++-
> include/linux/usb_usual.h | 4 +++-
> 3 files changed, 12 insertions(+), 2 deletions(-)
> diff --git a/drivers/usb/storage/scsiglue.c b/drivers/usb/storage/scsiglue.c
> index a324a5d..fe42547 100644
> --- a/drivers/usb/storage/scsiglue.c
> +++ b/drivers/usb/storage/scsiglue.c
[...]
> @@ -529,6 +529,9 @@ static void adjust_quirks(struct us_data *us)
> case 'o':
> f |= US_FL_CAPACITY_OK;
> break;
> + case 'p':
> + f |= US_FL_WRITE_CACHE;
> + break;
> case 'r':
> f |= US_FL_IGNORE_RESIDUE;
> break;
You probably should unite this chunk with the documentation update patch.
> diff --git a/include/linux/usb_usual.h b/include/linux/usb_usual.h
> index 17df360..96fc152 100644
> --- a/include/linux/usb_usual.h
> +++ b/include/linux/usb_usual.h
> @@ -64,7 +64,9 @@
> US_FLAG(NO_READ_CAPACITY_16, 0x00080000) \
> /* cannot handle READ_CAPACITY_16 */ \
> US_FLAG(INITIAL_READ10, 0x00100000) \
> - /* Initial READ(10) (and others) must be retried */
> + /* Initial READ(10) (and others) must be retried */ \
> + US_FLAG(WRITE_CACHE, 0x00200000) \
You've been already told to keep '\' at the same level with the above '\'
and you're continuing to ignore this.
> + /* Write Cache status is not available */
>
> #define US_FLAG(name, value) US_FL_##name = value ,
> enum { US_DO_ALL_FLAGS };
WBR, Sergei
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd
2012-06-09 18:42 ` Sergei Shtylyov
@ 2012-06-10 0:30 ` Namjae Jeon
2012-06-11 17:11 ` Sergei Shtylyov
0 siblings, 1 reply; 8+ messages in thread
From: Namjae Jeon @ 2012-06-10 0:30 UTC (permalink / raw)
To: Sergei Shtylyov
Cc: James.Bottomley, gregkh, mdharm-usb, stern, bvanassche, linux-usb,
linux-scsi, linux-kernel, Namjae Jeon, Pankaj Kumar,
Amit Sahrawat
2012/6/10, Sergei Shtylyov <sshtylyov@mvista.com>:
> Hello.
>
> On 06/09/2012 09:41 PM, Namjae Jeon wrote:
>
>> Add support for write cache quirk on usb hdd. scsi driver will be set to
>> wce
>> by detecting write cache quirk in quirk list when plugging usb hdd.
>
>> Signed-off-by: Namjae Jeon<namjae.jeon@samsung.com>
>> Signed-off-by: Pankaj Kumar<pankaj.km@samsung.com>
>> Signed-off-by: Amit Sahrawat<a.sahrawat@samsung.com>
>> ---
>> drivers/usb/storage/scsiglue.c | 5 +++++
>> drivers/usb/storage/usb.c | 5 ++++-
>> include/linux/usb_usual.h | 4 +++-
>> 3 files changed, 12 insertions(+), 2 deletions(-)
>
>> diff --git a/drivers/usb/storage/scsiglue.c
>> b/drivers/usb/storage/scsiglue.c
>> index a324a5d..fe42547 100644
>> --- a/drivers/usb/storage/scsiglue.c
>> +++ b/drivers/usb/storage/scsiglue.c
> [...]
>> @@ -529,6 +529,9 @@ static void adjust_quirks(struct us_data *us)
>> case 'o':
>> f |= US_FL_CAPACITY_OK;
>> break;
>> + case 'p':
>> + f |= US_FL_WRITE_CACHE;
>> + break;
>> case 'r':
>> f |= US_FL_IGNORE_RESIDUE;
>> break;
>
> You probably should unite this chunk with the documentation update
> patch.
Hi Sergei.
I tried to post documentation update patch(4/4) for this chunk.
Do I misunderstand ?
>
>> diff --git a/include/linux/usb_usual.h b/include/linux/usb_usual.h
>> index 17df360..96fc152 100644
>> --- a/include/linux/usb_usual.h
>> +++ b/include/linux/usb_usual.h
>> @@ -64,7 +64,9 @@
>> US_FLAG(NO_READ_CAPACITY_16, 0x00080000) \
>> /* cannot handle READ_CAPACITY_16 */ \
>> US_FLAG(INITIAL_READ10, 0x00100000) \
>> - /* Initial READ(10) (and others) must be retried */
>> + /* Initial READ(10) (and others) must be retried */ \
>> + US_FLAG(WRITE_CACHE, 0x00200000) \
>
> You've been already told to keep '\' at the same level with the above
> '\'
> and you're continuing to ignore this.
Ah,,, okay, I will change this code.
Thanks for your review.
>
>> + /* Write Cache status is not available */
>>
>> #define US_FLAG(name, value) US_FL_##name = value ,
>> enum { US_DO_ALL_FLAGS };
>
> WBR, Sergei
>
^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd
@ 2012-06-10 1:30 Namjae Jeon
2012-06-10 17:36 ` Alan Stern
0 siblings, 1 reply; 8+ messages in thread
From: Namjae Jeon @ 2012-06-10 1:30 UTC (permalink / raw)
To: James.Bottomley, gregkh, mdharm-usb, stern, sshtylyov, bvanassche
Cc: linux-usb, linux-scsi, linux-kernel, Namjae Jeon, Namjae Jeon,
Pankaj Kumar, Amit Sahrawat
Add support for write cache quirk on usb hdd. scsi driver will be set to wce
by detecting write cache quirk in quirk list when plugging usb hdd.
Signed-off-by: Namjae Jeon <namjae.jeon@samsung.com>
Signed-off-by: Pankaj Kumar <pankaj.km@samsung.com>
Signed-off-by: Amit Sahrawat <a.sahrawat@samsung.com>
---
drivers/usb/storage/scsiglue.c | 5 +++++
drivers/usb/storage/usb.c | 5 ++++-
include/linux/usb_usual.h | 4 +++-
3 files changed, 12 insertions(+), 2 deletions(-)
diff --git a/drivers/usb/storage/scsiglue.c b/drivers/usb/storage/scsiglue.c
index a324a5d..fe42547 100644
--- a/drivers/usb/storage/scsiglue.c
+++ b/drivers/usb/storage/scsiglue.c
@@ -230,6 +230,11 @@ static int slave_configure(struct scsi_device *sdev)
US_FL_SCM_MULT_TARG)) &&
us->protocol == USB_PR_BULK)
us->use_last_sector_hacks = 1;
+
+ /* Check if write cache default on flag is set or not */
+ if (us->fflags & US_FL_WRITE_CACHE)
+ sdev->wce_default_on = 1;
+
} else {
/* Non-disk-type devices don't need to blacklist any pages
diff --git a/drivers/usb/storage/usb.c b/drivers/usb/storage/usb.c
index e23c30a..d012fe4 100644
--- a/drivers/usb/storage/usb.c
+++ b/drivers/usb/storage/usb.c
@@ -473,7 +473,7 @@ static void adjust_quirks(struct us_data *us)
US_FL_CAPACITY_OK | US_FL_IGNORE_RESIDUE |
US_FL_SINGLE_LUN | US_FL_NO_WP_DETECT |
US_FL_NO_READ_DISC_INFO | US_FL_NO_READ_CAPACITY_16 |
- US_FL_INITIAL_READ10);
+ US_FL_INITIAL_READ10 | US_FL_WRITE_CACHE);
p = quirks;
while (*p) {
@@ -529,6 +529,9 @@ static void adjust_quirks(struct us_data *us)
case 'o':
f |= US_FL_CAPACITY_OK;
break;
+ case 'p':
+ f |= US_FL_WRITE_CACHE;
+ break;
case 'r':
f |= US_FL_IGNORE_RESIDUE;
break;
diff --git a/include/linux/usb_usual.h b/include/linux/usb_usual.h
index 17df360..96fc152 100644
--- a/include/linux/usb_usual.h
+++ b/include/linux/usb_usual.h
@@ -64,7 +64,9 @@
US_FLAG(NO_READ_CAPACITY_16, 0x00080000) \
/* cannot handle READ_CAPACITY_16 */ \
US_FLAG(INITIAL_READ10, 0x00100000) \
- /* Initial READ(10) (and others) must be retried */
+ /* Initial READ(10) (and others) must be retried */ \
+ US_FLAG(WRITE_CACHE, 0x00200000) \
+ /* Write Cache status is not available */
#define US_FLAG(name, value) US_FL_##name = value ,
enum { US_DO_ALL_FLAGS };
--
1.7.9.5
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd
2012-06-10 1:30 Namjae Jeon
@ 2012-06-10 17:36 ` Alan Stern
2012-06-10 23:30 ` Namjae Jeon
0 siblings, 1 reply; 8+ messages in thread
From: Alan Stern @ 2012-06-10 17:36 UTC (permalink / raw)
To: Namjae Jeon
Cc: James.Bottomley, gregkh, mdharm-usb, sshtylyov, bvanassche,
linux-usb, linux-scsi, linux-kernel, Namjae Jeon, Pankaj Kumar,
Amit Sahrawat
On Sat, 9 Jun 2012, Namjae Jeon wrote:
> Add support for write cache quirk on usb hdd. scsi driver will be set to wce
> by detecting write cache quirk in quirk list when plugging usb hdd.
> --- a/include/linux/usb_usual.h
> +++ b/include/linux/usb_usual.h
> @@ -64,7 +64,9 @@
> US_FLAG(NO_READ_CAPACITY_16, 0x00080000) \
> /* cannot handle READ_CAPACITY_16 */ \
> US_FLAG(INITIAL_READ10, 0x00100000) \
> - /* Initial READ(10) (and others) must be retried */
> + /* Initial READ(10) (and others) must be retried */ \
> + US_FLAG(WRITE_CACHE, 0x00200000) \
> + /* Write Cache status is not available */
The documentation for the new flag should be added in the same patch
along with the flag itself. There's no reason to have separate
patches.
Alan Stern
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd
2012-06-10 17:36 ` Alan Stern
@ 2012-06-10 23:30 ` Namjae Jeon
0 siblings, 0 replies; 8+ messages in thread
From: Namjae Jeon @ 2012-06-10 23:30 UTC (permalink / raw)
To: Alan Stern
Cc: James.Bottomley, gregkh, mdharm-usb, sshtylyov, bvanassche,
linux-usb, linux-scsi, linux-kernel, Namjae Jeon, Pankaj Kumar,
Amit Sahrawat
2012/6/11, Alan Stern <stern@rowland.harvard.edu>:
> On Sat, 9 Jun 2012, Namjae Jeon wrote:
>
>> Add support for write cache quirk on usb hdd. scsi driver will be set to
>> wce
>> by detecting write cache quirk in quirk list when plugging usb hdd.
>
>> --- a/include/linux/usb_usual.h
>> +++ b/include/linux/usb_usual.h
>> @@ -64,7 +64,9 @@
>> US_FLAG(NO_READ_CAPACITY_16, 0x00080000) \
>> /* cannot handle READ_CAPACITY_16 */ \
>> US_FLAG(INITIAL_READ10, 0x00100000) \
>> - /* Initial READ(10) (and others) must be retried */
>> + /* Initial READ(10) (and others) must be retried */ \
>> + US_FLAG(WRITE_CACHE, 0x00200000) \
>> + /* Write Cache status is not available */
>
> The documentation for the new flag should be added in the same patch
> along with the flag itself. There's no reason to have separate
> patches.
Hi. Alan.
Okay, I see. I will merge documentation patch with this patch.
Thank you.
>
> Alan Stern
>
>
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd
2012-06-10 0:30 ` Namjae Jeon
@ 2012-06-11 17:11 ` Sergei Shtylyov
2012-06-11 22:50 ` Namjae Jeon
0 siblings, 1 reply; 8+ messages in thread
From: Sergei Shtylyov @ 2012-06-11 17:11 UTC (permalink / raw)
To: Namjae Jeon
Cc: James.Bottomley, gregkh, mdharm-usb, stern, bvanassche, linux-usb,
linux-scsi, linux-kernel, Namjae Jeon, Pankaj Kumar,
Amit Sahrawat
Hello.
On 10-06-2012 4:30, Namjae Jeon wrote:
>>> Add support for write cache quirk on usb hdd. scsi driver will be set to
>>> wce
>>> by detecting write cache quirk in quirk list when plugging usb hdd.
>>> Signed-off-by: Namjae Jeon<namjae.jeon@samsung.com>
>>> Signed-off-by: Pankaj Kumar<pankaj.km@samsung.com>
>>> Signed-off-by: Amit Sahrawat<a.sahrawat@samsung.com>
>>> ---
>>> drivers/usb/storage/scsiglue.c | 5 +++++
>>> drivers/usb/storage/usb.c | 5 ++++-
>>> include/linux/usb_usual.h | 4 +++-
>>> 3 files changed, 12 insertions(+), 2 deletions(-)
>>> diff --git a/drivers/usb/storage/scsiglue.c
>>> b/drivers/usb/storage/scsiglue.c
>>> index a324a5d..fe42547 100644
>>> --- a/drivers/usb/storage/scsiglue.c
>>> +++ b/drivers/usb/storage/scsiglue.c
>> [...]
>>> @@ -529,6 +529,9 @@ static void adjust_quirks(struct us_data *us)
>>> case 'o':
>>> f |= US_FL_CAPACITY_OK;
>>> break;
>>> + case 'p':
>>> + f |= US_FL_WRITE_CACHE;
>>> + break;
>>> case 'r':
>>> f |= US_FL_IGNORE_RESIDUE;
>>> break;
>>
>> You probably should unite this chunk with the documentation update
>> patch.
> Hi Sergei.
> I tried to post documentation update patch(4/4) for this chunk.
> Do I misunderstand ?
I mean that the documenation should be updated in the same patch where you
add the new value.
WBR, Sergei
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd
2012-06-11 17:11 ` Sergei Shtylyov
@ 2012-06-11 22:50 ` Namjae Jeon
0 siblings, 0 replies; 8+ messages in thread
From: Namjae Jeon @ 2012-06-11 22:50 UTC (permalink / raw)
To: Sergei Shtylyov
Cc: James.Bottomley, gregkh, mdharm-usb, stern, bvanassche, linux-usb,
linux-scsi, linux-kernel, Namjae Jeon, Pankaj Kumar,
Amit Sahrawat
2012/6/12, Sergei Shtylyov <sshtylyov@mvista.com>:
> Hello.
>
> On 10-06-2012 4:30, Namjae Jeon wrote:
>
>>>> Add support for write cache quirk on usb hdd. scsi driver will be set
>>>> to
>>>> wce
>>>> by detecting write cache quirk in quirk list when plugging usb hdd.
>
>>>> Signed-off-by: Namjae Jeon<namjae.jeon@samsung.com>
>>>> Signed-off-by: Pankaj Kumar<pankaj.km@samsung.com>
>>>> Signed-off-by: Amit Sahrawat<a.sahrawat@samsung.com>
>>>> ---
>>>> drivers/usb/storage/scsiglue.c | 5 +++++
>>>> drivers/usb/storage/usb.c | 5 ++++-
>>>> include/linux/usb_usual.h | 4 +++-
>>>> 3 files changed, 12 insertions(+), 2 deletions(-)
>
>>>> diff --git a/drivers/usb/storage/scsiglue.c
>>>> b/drivers/usb/storage/scsiglue.c
>>>> index a324a5d..fe42547 100644
>>>> --- a/drivers/usb/storage/scsiglue.c
>>>> +++ b/drivers/usb/storage/scsiglue.c
>>> [...]
>>>> @@ -529,6 +529,9 @@ static void adjust_quirks(struct us_data *us)
>>>> case 'o':
>>>> f |= US_FL_CAPACITY_OK;
>>>> break;
>>>> + case 'p':
>>>> + f |= US_FL_WRITE_CACHE;
>>>> + break;
>>>> case 'r':
>>>> f |= US_FL_IGNORE_RESIDUE;
>>>> break;
>>>
>>> You probably should unite this chunk with the documentation update
>>> patch.
>
>> Hi Sergei.
>> I tried to post documentation update patch(4/4) for this chunk.
>> Do I misunderstand ?
>
> I mean that the documenation should be updated in the same patch where
> you
> add the new value.
Okay, I changed it on the latest patch also.
Sergei, Thanks a lot.
>
> WBR, Sergei
>
^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2012-06-11 22:50 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-06-09 17:41 [PATCH v3 2/4] usb: storage: add support for write cache quirk on usb hdd Namjae Jeon
2012-06-09 18:42 ` Sergei Shtylyov
2012-06-10 0:30 ` Namjae Jeon
2012-06-11 17:11 ` Sergei Shtylyov
2012-06-11 22:50 ` Namjae Jeon
-- strict thread matches above, loose matches on Subject: below --
2012-06-10 1:30 Namjae Jeon
2012-06-10 17:36 ` Alan Stern
2012-06-10 23:30 ` Namjae Jeon
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox