Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
e8223ea5
Commit
e8223ea5
authored
Oct 12, 2004
by
Christoph Hellwig
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] tmscsim: remove remaining INQUIRY sniffing
Signed-off-by:
James Bottomley
<
James.Bottomley@SteelEye.com
>
parent
7c79fb7e
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
3 additions
and
92 deletions
+3
-92
drivers/scsi/scsiiom.c
drivers/scsi/scsiiom.c
+3
-32
drivers/scsi/tmscsim.c
drivers/scsi/tmscsim.c
+0
-1
drivers/scsi/tmscsim.h
drivers/scsi/tmscsim.h
+0
-59
No files found.
drivers/scsi/scsiiom.c
View file @
e8223ea5
...
@@ -18,6 +18,7 @@ dc390_freetag (struct dc390_dcb* pDCB, struct dc390_srb* pSRB)
...
@@ -18,6 +18,7 @@ dc390_freetag (struct dc390_dcb* pDCB, struct dc390_srb* pSRB)
static
int
static
int
dc390_StartSCSI
(
struct
dc390_acb
*
pACB
,
struct
dc390_dcb
*
pDCB
,
struct
dc390_srb
*
pSRB
)
dc390_StartSCSI
(
struct
dc390_acb
*
pACB
,
struct
dc390_dcb
*
pDCB
,
struct
dc390_srb
*
pSRB
)
{
{
struct
scsi_device
*
sdev
=
pSRB
->
pcmd
->
device
;
u8
cmd
;
u8
disc_allowed
,
try_sync_nego
;
u8
cmd
;
u8
disc_allowed
,
try_sync_nego
;
pSRB
->
ScsiPhase
=
SCSI_NOP0
;
pSRB
->
ScsiPhase
=
SCSI_NOP0
;
...
@@ -59,7 +60,7 @@ dc390_StartSCSI( struct dc390_acb* pACB, struct dc390_dcb* pDCB, struct dc390_sr
...
@@ -59,7 +60,7 @@ dc390_StartSCSI( struct dc390_acb* pACB, struct dc390_dcb* pDCB, struct dc390_sr
* (pSRB->pcmd->cmnd[0] == TEST_UNIT_READY)) && pACB->scan_devices)
* (pSRB->pcmd->cmnd[0] == TEST_UNIT_READY)) && pACB->scan_devices)
||*/
(
pSRB
->
SRBFlag
&
AUTO_REQSENSE
)
)
||*/
(
pSRB
->
SRBFlag
&
AUTO_REQSENSE
)
)
disc_allowed
=
0
;
disc_allowed
=
0
;
if
(
(
pDCB
->
SyncMode
&
SYNC_ENABLE
)
&&
(
pDCB
->
TargetLUN
==
0
)
&&
(
pDCB
->
Inquiry7
&
0x10
)
&&
if
(
(
pDCB
->
SyncMode
&
SYNC_ENABLE
)
&&
(
pDCB
->
TargetLUN
==
0
)
&&
sdev
->
sdtr
&&
(
(
(
(
pSRB
->
pcmd
->
cmnd
[
0
]
==
REQUEST_SENSE
)
||
(
pSRB
->
SRBFlag
&
AUTO_REQSENSE
)
)
(
(
(
(
pSRB
->
pcmd
->
cmnd
[
0
]
==
REQUEST_SENSE
)
||
(
pSRB
->
SRBFlag
&
AUTO_REQSENSE
)
)
&&
!
(
pDCB
->
SyncMode
&
SYNC_NEGO_DONE
)
)
||
(
pSRB
->
pcmd
->
cmnd
[
0
]
==
INQUIRY
)
)
)
&&
!
(
pDCB
->
SyncMode
&
SYNC_NEGO_DONE
)
)
||
(
pSRB
->
pcmd
->
cmnd
[
0
]
==
INQUIRY
)
)
)
try_sync_nego
=
1
;
try_sync_nego
=
1
;
...
@@ -1307,19 +1308,12 @@ dc390_SRBdone( struct dc390_acb* pACB, struct dc390_dcb* pDCB, struct dc390_srb*
...
@@ -1307,19 +1308,12 @@ dc390_SRBdone( struct dc390_acb* pACB, struct dc390_dcb* pDCB, struct dc390_srb*
{
{
u8
bval
,
status
;
u8
bval
,
status
;
struct
scsi_cmnd
*
pcmd
;
struct
scsi_cmnd
*
pcmd
;
PSCSI_INQDATA
ptr
;
struct
scatterlist
*
ptr2
;
pcmd
=
pSRB
->
pcmd
;
pcmd
=
pSRB
->
pcmd
;
/* KG: Moved pci_unmap here */
/* KG: Moved pci_unmap here */
dc390_pci_unmap
(
pSRB
);
dc390_pci_unmap
(
pSRB
);
status
=
pSRB
->
TargetStatus
;
status
=
pSRB
->
TargetStatus
;
if
(
pcmd
->
use_sg
)
{
ptr2
=
(
struct
scatterlist
*
)
(
pcmd
->
request_buffer
);
ptr
=
(
PSCSI_INQDATA
)
(
page_address
(
ptr2
->
page
)
+
ptr2
->
offset
);
}
else
ptr
=
(
PSCSI_INQDATA
)
(
pcmd
->
request_buffer
);
DEBUG0
(
printk
(
" SRBdone (%02x,%08x), SRB %p, pid %li
\n
"
,
status
,
pcmd
->
result
,
\
DEBUG0
(
printk
(
" SRBdone (%02x,%08x), SRB %p, pid %li
\n
"
,
status
,
pcmd
->
result
,
\
pSRB
,
pcmd
->
pid
));
pSRB
,
pcmd
->
pid
));
...
@@ -1355,22 +1349,6 @@ dc390_SRBdone( struct dc390_acb* pACB, struct dc390_dcb* pDCB, struct dc390_srb*
...
@@ -1355,22 +1349,6 @@ dc390_SRBdone( struct dc390_acb* pACB, struct dc390_dcb* pDCB, struct dc390_srb*
{
{
if
(
status_byte
(
status
)
==
CHECK_CONDITION
)
if
(
status_byte
(
status
)
==
CHECK_CONDITION
)
{
{
#ifdef DC390_REMOVABLEDEBUG
printk
(
KERN_INFO
"DC390: Check_Condition (Cmd %02x, Id %02x, LUN %02x)
\n
"
,
pcmd
->
cmnd
[
0
],
pDCB
->
TargetID
,
pDCB
->
TargetLUN
);
if
((
pSRB
->
SGIndex
<
pSRB
->
SGcount
)
&&
(
pSRB
->
SGcount
)
&&
(
pSRB
->
SGToBeXferLen
))
{
bval
=
pSRB
->
SGcount
;
swlval
=
0
;
ptr2
=
pSRB
->
pSegmentList
;
for
(
i
=
pSRB
->
SGIndex
;
i
<
bval
;
i
++
)
{
swlval
+=
sg_dma_len
(
ptr2
);
ptr2
++
;
}
printk
(
KERN_INFO
"XferredLen=%08x,NotXferLen=%08x
\n
"
,
(
u32
)
pSRB
->
TotalXferredLen
,
(
u32
)
swlval
);
}
#endif
if
(
dc390_RequestSense
(
pACB
,
pDCB
,
pSRB
))
{
if
(
dc390_RequestSense
(
pACB
,
pDCB
,
pSRB
))
{
SET_RES_DID
(
pcmd
->
result
,
DID_ERROR
);
SET_RES_DID
(
pcmd
->
result
,
DID_ERROR
);
goto
cmd_done
;
goto
cmd_done
;
...
@@ -1431,13 +1409,6 @@ dc390_SRBdone( struct dc390_acb* pACB, struct dc390_dcb* pDCB, struct dc390_srb*
...
@@ -1431,13 +1409,6 @@ dc390_SRBdone( struct dc390_acb* pACB, struct dc390_dcb* pDCB, struct dc390_srb*
SET_RES_DID
(
pcmd
->
result
,
DID_OK
);
SET_RES_DID
(
pcmd
->
result
,
DID_OK
);
}
}
}
}
if
((
pcmd
->
result
&
RES_DID
)
==
0
&&
pcmd
->
cmnd
[
0
]
==
INQUIRY
&&
pcmd
->
cmnd
[
2
]
==
0
&&
pcmd
->
request_bufflen
>=
8
&&
ptr
&&
(
ptr
->
Vers
&
0x07
)
>=
2
)
pDCB
->
Inquiry7
=
ptr
->
Flags
;
cmd_done:
cmd_done:
pcmd
->
resid
=
pcmd
->
request_bufflen
-
pSRB
->
TotalXferredLen
;
pcmd
->
resid
=
pcmd
->
request_bufflen
-
pSRB
->
TotalXferredLen
;
...
...
drivers/scsi/tmscsim.c
View file @
e8223ea5
...
@@ -710,7 +710,6 @@ static int dc390_slave_alloc(struct scsi_device *scsi_device)
...
@@ -710,7 +710,6 @@ static int dc390_slave_alloc(struct scsi_device *scsi_device)
pDCB
->
CtrlR3
=
pDCB2
->
CtrlR3
;
pDCB
->
CtrlR3
=
pDCB2
->
CtrlR3
;
pDCB
->
CtrlR4
=
pDCB2
->
CtrlR4
;
pDCB
->
CtrlR4
=
pDCB2
->
CtrlR4
;
pDCB
->
Inquiry7
=
pDCB2
->
Inquiry7
;
}
else
{
}
else
{
u8
index
=
pACB
->
AdapterIndex
;
u8
index
=
pACB
->
AdapterIndex
;
PEEprom
prom
=
(
PEEprom
)
&
dc390_eepromBuf
[
index
][
id
<<
2
];
PEEprom
prom
=
(
PEEprom
)
&
dc390_eepromBuf
[
index
][
id
<<
2
];
...
...
drivers/scsi/tmscsim.h
View file @
e8223ea5
...
@@ -103,7 +103,6 @@ u8 DCBFlag;
...
@@ -103,7 +103,6 @@ u8 DCBFlag;
u8
CtrlR1
;
u8
CtrlR1
;
u8
CtrlR3
;
u8
CtrlR3
;
u8
CtrlR4
;
u8
CtrlR4
;
u8
Inquiry7
;
u8
SyncMode
;
/*; 0:async mode */
u8
SyncMode
;
/*; 0:async mode */
u8
NegoPeriod
;
/*;for nego. */
u8
NegoPeriod
;
/*;for nego. */
...
@@ -324,64 +323,6 @@ typedef struct {
...
@@ -324,64 +323,6 @@ typedef struct {
dma_addr_t
saved_dma_handle
;
dma_addr_t
saved_dma_handle
;
}
dc390_cmd_scp_t
;
}
dc390_cmd_scp_t
;
/*
** Inquiry Data format
*/
typedef
struct
_SCSIInqData
{
/* INQUIRY */
u8
DevType
;
/* Periph Qualifier & Periph Dev Type*/
u8
RMB_TypeMod
;
/* rem media bit & Dev Type Modifier */
u8
Vers
;
/* ISO, ECMA, & ANSI versions */
u8
RDF
;
/* AEN, TRMIOP, & response data format*/
u8
AddLen
;
/* length of additional data */
u8
Res1
;
/* reserved */
u8
Res2
;
/* reserved */
u8
Flags
;
/* RelADr,Wbus32,Wbus16,Sync,etc. */
u8
VendorID
[
8
];
/* Vendor Identification */
u8
ProductID
[
16
];
/* Product Identification */
u8
ProductRev
[
4
];
/* Product Revision */
}
SCSI_INQDATA
,
*
PSCSI_INQDATA
;
/* Inquiry byte 0 masks */
#define SCSI_DEVTYPE 0x1F
/* Peripheral Device Type */
#define SCSI_PERIPHQUAL 0xE0
/* Peripheral Qualifier */
#define TYPE_NODEV SCSI_DEVTYPE
/* Unknown or no device type */
/* Inquiry byte 1 mask */
#define SCSI_REMOVABLE_MEDIA 0x80
/* Removable Media bit (1=removable) */
/* Peripheral Device Type definitions */
/* see include/scsi/scsi.h for the rest */
#ifndef TYPE_PRINTER
# define TYPE_PRINTER 0x02
/* Printer device */
#endif
#ifndef TYPE_COMM
# define TYPE_COMM 0x09
/* Communications device */
#endif
/*
** Inquiry flag definitions (Inq data byte 7)
*/
#define SCSI_INQ_RELADR 0x80
/* device supports relative addressing*/
#define SCSI_INQ_WBUS32 0x40
/* device supports 32 bit data xfers */
#define SCSI_INQ_WBUS16 0x20
/* device supports 16 bit data xfers */
#define SCSI_INQ_SYNC 0x10
/* device supports synchronous xfer */
#define SCSI_INQ_LINKED 0x08
/* device supports linked commands */
#define SCSI_INQ_CMDQUEUE 0x02
/* device supports command queueing */
#define SCSI_INQ_SFTRE 0x01
/* device supports soft resets */
/*
/*
;==========================================================
;==========================================================
; EEPROM byte offset
; EEPROM byte offset
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment