public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Matthew Dharm <mdharm-kernel@one-eyed-alien.net>
To: Constantin Baranov <const@const.mimas.ru>
Cc: linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [PATCH 2.6.25-rc4] usb: add support for Motorola ROKR Z6 cellphone in mass storage mode
Date: Mon, 10 Mar 2008 23:30:19 -0700	[thread overview]
Message-ID: <20080311063019.GA1756@one-eyed-alien.net> (raw)
In-Reply-To: <47D59173.9000902@const.mimas.ru>

[-- Attachment #1: Type: text/plain, Size: 4756 bytes --]

One last question:

If it's a ROKR Z6, why does the string in unusual_devs.h say "MSnc."?

Matt

On Mon, Mar 10, 2008 at 11:52:19PM +0400, Constantin Baranov wrote:
> Yes. These three flags corresponds to three different bugs
> discussed in linux-usb-users@lists.sourceforge.net
> (http://www.mail-archive.com/linux-usb-users@lists.sourceforge.net/msg19167.html)
> 
> FIX_INQUIRY: Device always sends PQ=1 in inquiry data, so SCSI subsystem
> stops to create sd device.
> FIX_CAPACITY: Device tells wrong size of internal memory card
> (real size + 1). If one would try to read/write "phantom" sector then
> phone hang up and reboot.
> BULK_IGNORE_TAG: Sometimes device sends wrong tags causing computer to
> reset endpoint. This may corrupt phone's filesystem in particular.
> 
> Matthew Dharm wrote:
> > Are all 3 flags truly needed?
> > 
> > Matt
> > 
> > On Mon, Mar 10, 2008 at 10:39:06PM +0400, Constantin Baranov wrote:
> >> From: Constantin Baranov <const@tltsu.ru>
> >>
> >> Motorola ROKR Z6 cellphone has bugs in its USB, so it is impossible to use
> >> it as mass storage. Patch describes new "unusual" USB device for it with
> >> FIX_INQUIRY and FIX_CAPACITY flags and new BULK_IGNORE_TAG flag.
> >> Last flag relaxes check for equality of bcs->Tag and us->tag in
> >> usb_stor_Bulk_transport routine.
> >>
> >> Signed-off-by: Constantin Baranov <const@tltsu.ru>
> >> ---
> >>  drivers/usb/storage/transport.c    |    3 ++-
> >>  drivers/usb/storage/unusual_devs.h |   10 ++++++++++
> >>  include/linux/usb_usual.h          |    4 +++-
> >>  3 files changed, 15 insertions(+), 2 deletions(-)
> >>
> >> diff -upr linux-2.6.25-rc4/drivers/usb/storage/transport.c
> >> linux-2.6.25-rc4-motorokr_z6/drivers/usb/storage/transport.c
> >> --- linux-2.6.25-rc4/drivers/usb/storage/transport.c	2008-03-10
> >> 22:09:11.000000000 +0400
> >> +++ linux-2.6.25-rc4-motorokr_z6/drivers/usb/storage/transport.c
> >> 2008-03-10 22:11:24.000000000 +0400
> >> @@ -1009,7 +1009,8 @@ int usb_stor_Bulk_transport(struct scsi_
> >>  	US_DEBUGP("Bulk Status S 0x%x T 0x%x R %u Stat 0x%x\n",
> >>  			le32_to_cpu(bcs->Signature), bcs->Tag,
> >>  			residue, bcs->Status);
> >> -	if (bcs->Tag != us->tag || bcs->Status > US_BULK_STAT_PHASE) {
> >> +	if (!(bcs->Tag == us->tag || (us->flags & US_FL_BULK_IGNORE_TAG)) ||
> >> +		bcs->Status > US_BULK_STAT_PHASE) {
> >>  		US_DEBUGP("Bulk logical error\n");
> >>  		return USB_STOR_TRANSPORT_ERROR;
> >>  	}
> >> diff -upr linux-2.6.25-rc4/drivers/usb/storage/unusual_devs.h
> >> linux-2.6.25-rc4-motorokr_z6/drivers/usb/storage/unusual_devs.h
> >> --- linux-2.6.25-rc4/drivers/usb/storage/unusual_devs.h	2008-03-10
> >> 22:09:11.000000000 +0400
> >> +++ linux-2.6.25-rc4-motorokr_z6/drivers/usb/storage/unusual_devs.h
> >> 2008-03-10 22:10:40.000000000 +0400
> >> @@ -1589,6 +1589,16 @@ UNUSUAL_DEV(  0x22b8, 0x4810, 0x0001, 0x
> >>  		US_SC_DEVICE, US_PR_DEVICE, NULL,
> >>  		US_FL_FIX_CAPACITY),
> >>
> >> +/*
> >> + * Patch by Constantin Baranov <const@tltsu.ru>
> >> + * Report by Andreas Koenecke
> >> + */
> >> +UNUSUAL_DEV(  0x22b8, 0x6426, 0x0101, 0x0101,
> >> +		"Motorola",
> >> +		"MSnc.",
> >> +		US_SC_DEVICE, US_PR_DEVICE, NULL,
> >> +		US_FL_FIX_INQUIRY | US_FL_FIX_CAPACITY | US_FL_BULK_IGNORE_TAG),
> >> +
> >>  /* Reported by Radovan Garabik <garabik@kassiopeia.juls.savba.sk> */
> >>  UNUSUAL_DEV(  0x2735, 0x100b, 0x0000, 0x9999,
> >>  		"MPIO",
> >> diff -upr linux-2.6.25-rc4/include/linux/usb_usual.h
> >> linux-2.6.25-rc4-motorokr_z6/include/linux/usb_usual.h
> >> --- linux-2.6.25-rc4/include/linux/usb_usual.h	2008-03-10
> >> 22:09:12.000000000 +0400
> >> +++ linux-2.6.25-rc4-motorokr_z6/include/linux/usb_usual.h	2008-03-10
> >> 22:10:40.000000000 +0400
> >> @@ -50,7 +50,9 @@
> >>  	US_FLAG(CAPACITY_HEURISTICS,	0x00001000)		\
> >>  		/* sometimes sizes is too big */		\
> >>  	US_FLAG(MAX_SECTORS_MIN,0x00002000)			\
> >> -		/* Sets max_sectors to arch min */
> >> +		/* Sets max_sectors to arch min */		\
> >> +	US_FLAG(BULK_IGNORE_TAG,0x00004000)			\
> >> +		/* Ignore tag mismatch in bulk operations */
> >>
> >>
> >>  #define US_FLAG(name, value)	US_FL_##name = value ,
> >>
> >> --
> >> To unsubscribe from this list: send the line "unsubscribe linux-usb" in
> >> the body of a message to majordomo@vger.kernel.org
> >> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> > 

-- 
Matthew Dharm                              Home: mdharm-usb@one-eyed-alien.net 
Maintainer, Linux USB Mass Storage Driver

G:  Money isn't everything, A.J.
AJ: Who convinced you of that?
G:  The Chief, at my last salary review.
					-- Mike and Greg
User Friendly, 11/3/1998

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

  reply	other threads:[~2008-03-11  6:30 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-03-10 18:39 [PATCH 2.6.25-rc4] usb: add support for Motorola ROKR Z6 cellphone in mass storage mode Constantin Baranov
2008-03-10 19:01 ` Matthew Dharm
2008-03-10 19:52   ` Constantin Baranov
2008-03-11  6:30     ` Matthew Dharm [this message]
2008-03-11  7:02       ` Constantin Baranov
2008-03-11 15:00         ` Matthew Dharm
2008-03-11 18:27           ` Constantin Baranov
2008-03-11 18:29             ` Matthew Dharm

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20080311063019.GA1756@one-eyed-alien.net \
    --to=mdharm-kernel@one-eyed-alien.net \
    --cc=const@const.mimas.ru \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-usb@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox