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
nexedi
linux
Commits
be388a51
Commit
be388a51
authored
Dec 23, 2002
by
James Bottomley
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[SCSI 53c700] update to new generic device dma_ API
parent
b7ccbd3e
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
65 additions
and
110 deletions
+65
-110
drivers/scsi/53c700.c
drivers/scsi/53c700.c
+59
-77
drivers/scsi/53c700.h
drivers/scsi/53c700.h
+5
-28
drivers/scsi/Kconfig
drivers/scsi/Kconfig
+0
-5
drivers/scsi/NCR_D700.c
drivers/scsi/NCR_D700.c
+1
-0
No files found.
drivers/scsi/53c700.c
View file @
be388a51
...
@@ -238,39 +238,30 @@ struct Scsi_Host *
...
@@ -238,39 +238,30 @@ struct Scsi_Host *
NCR_700_detect
(
Scsi_Host_Template
*
tpnt
,
NCR_700_detect
(
Scsi_Host_Template
*
tpnt
,
struct
NCR_700_Host_Parameters
*
hostdata
)
struct
NCR_700_Host_Parameters
*
hostdata
)
{
{
dma_addr_t
pScript
,
p
Memory
,
p
Slots
;
dma_addr_t
pScript
,
pSlots
;
__u8
*
memory
;
__u8
*
memory
;
__u32
*
script
;
__u32
*
script
;
struct
Scsi_Host
*
host
;
struct
Scsi_Host
*
host
;
static
int
banner
=
0
;
static
int
banner
=
0
;
int
j
;
int
j
;
#ifdef CONFIG_53C700_USE_CONSISTENT
memory
=
dma_alloc_noncoherent
(
hostdata
->
dev
,
TOTAL_MEM_SIZE
,
memory
=
pci_alloc_consistent
(
hostdata
->
pci_dev
,
TOTAL_MEM_SIZE
,
&
pScript
);
&
pMemory
);
hostdata
->
consistent
=
1
;
if
(
memory
==
NULL
)
{
printk
(
KERN_WARNING
"53c700: consistent memory allocation failed
\n
"
);
#endif
memory
=
kmalloc
(
TOTAL_MEM_SIZE
,
GFP_KERNEL
);
if
(
memory
==
NULL
)
{
if
(
memory
==
NULL
)
{
printk
(
KERN_ERR
"53c700: Failed to allocate memory for driver, detatching
\n
"
);
printk
(
KERN_ERR
"53c700: Failed to allocate memory for driver, detatching
\n
"
);
return
NULL
;
return
NULL
;
}
}
pMemory
=
pci_map_single
(
hostdata
->
pci_dev
,
memory
,
TOTAL_MEM_SIZE
,
PCI_DMA_BIDIRECTIONAL
);
#ifdef CONFIG_53C700_USE_CONSISTENT
hostdata
->
consistent
=
0
;
}
#endif
script
=
(
__u32
*
)
memory
;
script
=
(
__u32
*
)
memory
;
pScript
=
pMemory
;
hostdata
->
msgin
=
memory
+
MSGIN_OFFSET
;
hostdata
->
msgin
=
memory
+
MSGIN_OFFSET
;
hostdata
->
msgout
=
memory
+
MSGOUT_OFFSET
;
hostdata
->
msgout
=
memory
+
MSGOUT_OFFSET
;
hostdata
->
status
=
memory
+
STATUS_OFFSET
;
hostdata
->
status
=
memory
+
STATUS_OFFSET
;
/* all of these offsets are L1_CACHE_BYTES separated. It is fatal
* if this isn't sufficient separation to avoid dma flushing issues */
BUG_ON
(
!
dma_is_consistent
(
pScript
)
&&
L1_CACHE_BYTES
<
dma_get_cache_alignment
());
hostdata
->
slots
=
(
struct
NCR_700_command_slot
*
)(
memory
+
SLOTS_OFFSET
);
hostdata
->
slots
=
(
struct
NCR_700_command_slot
*
)(
memory
+
SLOTS_OFFSET
);
pSlots
=
p
Memory
+
SLOTS_OFFSET
;
pSlots
=
p
Script
+
SLOTS_OFFSET
;
/* Fill in the missing routines from the host template */
/* Fill in the missing routines from the host template */
tpnt
->
queuecommand
=
NCR_700_queuecommand
;
tpnt
->
queuecommand
=
NCR_700_queuecommand
;
...
@@ -327,7 +318,7 @@ NCR_700_detect(Scsi_Host_Template *tpnt,
...
@@ -327,7 +318,7 @@ NCR_700_detect(Scsi_Host_Template *tpnt,
hostdata
->
script
=
script
;
hostdata
->
script
=
script
;
hostdata
->
pScript
=
pScript
;
hostdata
->
pScript
=
pScript
;
NCR_700_dma_cache_wback
((
unsigned
long
)
script
,
sizeof
(
SCRIPT
)
);
dma_sync_single
(
hostdata
->
dev
,
pScript
,
sizeof
(
SCRIPT
),
DMA_TO_DEVICE
);
hostdata
->
state
=
NCR_700_HOST_FREE
;
hostdata
->
state
=
NCR_700_HOST_FREE
;
hostdata
->
cmd
=
NULL
;
hostdata
->
cmd
=
NULL
;
host
->
max_id
=
7
;
host
->
max_id
=
7
;
...
@@ -363,18 +354,8 @@ NCR_700_release(struct Scsi_Host *host)
...
@@ -363,18 +354,8 @@ NCR_700_release(struct Scsi_Host *host)
struct
NCR_700_Host_Parameters
*
hostdata
=
struct
NCR_700_Host_Parameters
*
hostdata
=
(
struct
NCR_700_Host_Parameters
*
)
host
->
hostdata
[
0
];
(
struct
NCR_700_Host_Parameters
*
)
host
->
hostdata
[
0
];
#ifdef CONFIG_53C700_USE_CONSISTENT
dma_free_noncoherent
(
hostdata
->
dev
,
TOTAL_MEM_SIZE
,
if
(
hostdata
->
consistent
)
{
pci_free_consistent
(
hostdata
->
pci_dev
,
TOTAL_MEM_SIZE
,
hostdata
->
script
,
hostdata
->
pScript
);
hostdata
->
script
,
hostdata
->
pScript
);
}
else
{
#endif
pci_unmap_single
(
hostdata
->
pci_dev
,
hostdata
->
pScript
,
TOTAL_MEM_SIZE
,
PCI_DMA_BIDIRECTIONAL
);
kfree
(
hostdata
->
script
);
#ifdef CONFIG_53C700_USE_CONSISTENT
}
#endif
return
1
;
return
1
;
}
}
...
@@ -575,15 +556,16 @@ NCR_700_unmap(struct NCR_700_Host_Parameters *hostdata, Scsi_Cmnd *SCp,
...
@@ -575,15 +556,16 @@ NCR_700_unmap(struct NCR_700_Host_Parameters *hostdata, Scsi_Cmnd *SCp,
{
{
if
(
SCp
->
sc_data_direction
!=
SCSI_DATA_NONE
&&
if
(
SCp
->
sc_data_direction
!=
SCSI_DATA_NONE
&&
SCp
->
sc_data_direction
!=
SCSI_DATA_UNKNOWN
)
{
SCp
->
sc_data_direction
!=
SCSI_DATA_UNKNOWN
)
{
int
pci_direction
=
scsi_to_pci_dma_dir
(
SCp
->
sc_data_direction
);
enum
dma_data_direction
direction
=
(
enum
dma_data_direction
)
scsi_to_pci_dma_dir
(
SCp
->
sc_data_direction
);
if
(
SCp
->
use_sg
)
{
if
(
SCp
->
use_sg
)
{
pci_unmap_sg
(
hostdata
->
pci_
dev
,
SCp
->
buffer
,
dma_unmap_sg
(
hostdata
->
dev
,
SCp
->
buffer
,
SCp
->
use_sg
,
pci_
direction
);
SCp
->
use_sg
,
direction
);
}
else
{
}
else
{
pci_unmap_single
(
hostdata
->
pci_
dev
,
dma_unmap_single
(
hostdata
->
dev
,
slot
->
dma_handle
,
slot
->
dma_handle
,
SCp
->
request_bufflen
,
SCp
->
request_bufflen
,
pci_
direction
);
direction
);
}
}
}
}
}
}
...
@@ -600,8 +582,8 @@ NCR_700_scsi_done(struct NCR_700_Host_Parameters *hostdata,
...
@@ -600,8 +582,8 @@ NCR_700_scsi_done(struct NCR_700_Host_Parameters *hostdata,
(
struct
NCR_700_command_slot
*
)
SCp
->
host_scribble
;
(
struct
NCR_700_command_slot
*
)
SCp
->
host_scribble
;
NCR_700_unmap
(
hostdata
,
SCp
,
slot
);
NCR_700_unmap
(
hostdata
,
SCp
,
slot
);
pci_unmap_single
(
hostdata
->
pci_
dev
,
slot
->
pCmd
,
dma_unmap_single
(
hostdata
->
dev
,
slot
->
pCmd
,
sizeof
(
SCp
->
cmnd
),
PCI_DMA_TO
DEVICE
);
sizeof
(
SCp
->
cmnd
),
DMA_TO_
DEVICE
);
if
(
SCp
->
cmnd
[
0
]
==
REQUEST_SENSE
&&
SCp
->
cmnd
[
6
]
==
NCR_700_INTERNAL_SENSE_MAGIC
)
{
if
(
SCp
->
cmnd
[
0
]
==
REQUEST_SENSE
&&
SCp
->
cmnd
[
6
]
==
NCR_700_INTERNAL_SENSE_MAGIC
)
{
#ifdef NCR_700_DEBUG
#ifdef NCR_700_DEBUG
printk
(
" ORIGINAL CMD %p RETURNED %d, new return is %d sense is
\n
"
,
printk
(
" ORIGINAL CMD %p RETURNED %d, new return is %d sense is
\n
"
,
...
@@ -819,7 +801,7 @@ process_extended_message(struct Scsi_Host *host,
...
@@ -819,7 +801,7 @@ process_extended_message(struct Scsi_Host *host,
printk
(
KERN_WARNING
"scsi%d Unexpected SDTR msg
\n
"
,
printk
(
KERN_WARNING
"scsi%d Unexpected SDTR msg
\n
"
,
host
->
host_no
);
host
->
host_no
);
hostdata
->
msgout
[
0
]
=
A_REJECT_MSG
;
hostdata
->
msgout
[
0
]
=
A_REJECT_MSG
;
NCR_700_dma_cache_wback
((
unsigned
long
)
hostdata
->
msgout
,
1
);
dma_cache_sync
(
hostdata
->
msgout
,
1
,
DMA_TO_DEVICE
);
script_patch_16
(
hostdata
->
script
,
MessageCount
,
1
);
script_patch_16
(
hostdata
->
script
,
MessageCount
,
1
);
/* SendMsgOut returns, so set up the return
/* SendMsgOut returns, so set up the return
* address */
* address */
...
@@ -831,7 +813,7 @@ process_extended_message(struct Scsi_Host *host,
...
@@ -831,7 +813,7 @@ process_extended_message(struct Scsi_Host *host,
printk
(
KERN_INFO
"scsi%d: (%d:%d), Unsolicited WDTR after CMD, Rejecting
\n
"
,
printk
(
KERN_INFO
"scsi%d: (%d:%d), Unsolicited WDTR after CMD, Rejecting
\n
"
,
host
->
host_no
,
pun
,
lun
);
host
->
host_no
,
pun
,
lun
);
hostdata
->
msgout
[
0
]
=
A_REJECT_MSG
;
hostdata
->
msgout
[
0
]
=
A_REJECT_MSG
;
NCR_700_dma_cache_wback
((
unsigned
long
)
hostdata
->
msgout
,
1
);
dma_cache_sync
(
hostdata
->
msgout
,
1
,
DMA_TO_DEVICE
);
script_patch_16
(
hostdata
->
script
,
MessageCount
,
1
);
script_patch_16
(
hostdata
->
script
,
MessageCount
,
1
);
resume_offset
=
hostdata
->
pScript
+
Ent_SendMessageWithATN
;
resume_offset
=
hostdata
->
pScript
+
Ent_SendMessageWithATN
;
...
@@ -845,7 +827,7 @@ process_extended_message(struct Scsi_Host *host,
...
@@ -845,7 +827,7 @@ process_extended_message(struct Scsi_Host *host,
printk
(
"
\n
"
);
printk
(
"
\n
"
);
/* just reject it */
/* just reject it */
hostdata
->
msgout
[
0
]
=
A_REJECT_MSG
;
hostdata
->
msgout
[
0
]
=
A_REJECT_MSG
;
NCR_700_dma_cache_wback
((
unsigned
long
)
hostdata
->
msgout
,
1
);
dma_cache_sync
(
hostdata
->
msgout
,
1
,
DMA_TO_DEVICE
);
script_patch_16
(
hostdata
->
script
,
MessageCount
,
1
);
script_patch_16
(
hostdata
->
script
,
MessageCount
,
1
);
/* SendMsgOut returns, so set up the return
/* SendMsgOut returns, so set up the return
* address */
* address */
...
@@ -923,7 +905,7 @@ process_message(struct Scsi_Host *host, struct NCR_700_Host_Parameters *hostdata
...
@@ -923,7 +905,7 @@ process_message(struct Scsi_Host *host, struct NCR_700_Host_Parameters *hostdata
printk
(
"
\n
"
);
printk
(
"
\n
"
);
/* just reject it */
/* just reject it */
hostdata
->
msgout
[
0
]
=
A_REJECT_MSG
;
hostdata
->
msgout
[
0
]
=
A_REJECT_MSG
;
NCR_700_dma_cache_wback
((
unsigned
long
)
hostdata
->
msgout
,
1
);
dma_cache_sync
(
hostdata
->
msgout
,
1
,
DMA_TO_DEVICE
);
script_patch_16
(
hostdata
->
script
,
MessageCount
,
1
);
script_patch_16
(
hostdata
->
script
,
MessageCount
,
1
);
/* SendMsgOut returns, so set up the return
/* SendMsgOut returns, so set up the return
* address */
* address */
...
@@ -933,7 +915,7 @@ process_message(struct Scsi_Host *host, struct NCR_700_Host_Parameters *hostdata
...
@@ -933,7 +915,7 @@ process_message(struct Scsi_Host *host, struct NCR_700_Host_Parameters *hostdata
}
}
NCR_700_writel
(
temp
,
host
,
TEMP_REG
);
NCR_700_writel
(
temp
,
host
,
TEMP_REG
);
/* set us up to receive another message */
/* set us up to receive another message */
NCR_700_dma_cache_inv
((
unsigned
long
)
hostdata
->
msgin
,
MSG_ARRAY_SIZ
E
);
dma_cache_sync
(
hostdata
->
msgin
,
MSG_ARRAY_SIZE
,
DMA_FROM_DEVIC
E
);
return
resume_offset
;
return
resume_offset
;
}
}
...
@@ -997,19 +979,17 @@ process_script_interrupt(__u32 dsps, __u32 dsp, Scsi_Cmnd *SCp,
...
@@ -997,19 +979,17 @@ process_script_interrupt(__u32 dsps, __u32 dsp, Scsi_Cmnd *SCp,
SCp
->
cmnd
[
7
]
=
hostdata
->
status
[
0
];
SCp
->
cmnd
[
7
]
=
hostdata
->
status
[
0
];
SCp
->
use_sg
=
0
;
SCp
->
use_sg
=
0
;
SCp
->
sc_data_direction
=
SCSI_DATA_READ
;
SCp
->
sc_data_direction
=
SCSI_DATA_READ
;
pci_dma_sync_single
(
hostdata
->
pci_dev
,
dma_sync_single
(
hostdata
->
dev
,
slot
->
pCmd
,
slot
->
pCmd
,
SCp
->
cmd_len
,
DMA_TO_DEVICE
);
SCp
->
cmd_len
,
PCI_DMA_TODEVICE
);
SCp
->
request_bufflen
=
sizeof
(
SCp
->
sense_buffer
);
SCp
->
request_bufflen
=
sizeof
(
SCp
->
sense_buffer
);
slot
->
dma_handle
=
pci_map_single
(
hostdata
->
pci_dev
,
SCp
->
sense_buffer
,
sizeof
(
SCp
->
sense_buffer
),
PCI_DMA_FROM
DEVICE
);
slot
->
dma_handle
=
dma_map_single
(
hostdata
->
dev
,
SCp
->
sense_buffer
,
sizeof
(
SCp
->
sense_buffer
),
DMA_FROM_
DEVICE
);
slot
->
SG
[
0
].
ins
=
bS_to_host
(
SCRIPT_MOVE_DATA_IN
|
sizeof
(
SCp
->
sense_buffer
));
slot
->
SG
[
0
].
ins
=
bS_to_host
(
SCRIPT_MOVE_DATA_IN
|
sizeof
(
SCp
->
sense_buffer
));
slot
->
SG
[
0
].
pAddr
=
bS_to_host
(
slot
->
dma_handle
);
slot
->
SG
[
0
].
pAddr
=
bS_to_host
(
slot
->
dma_handle
);
slot
->
SG
[
1
].
ins
=
bS_to_host
(
SCRIPT_RETURN
);
slot
->
SG
[
1
].
ins
=
bS_to_host
(
SCRIPT_RETURN
);
slot
->
SG
[
1
].
pAddr
=
0
;
slot
->
SG
[
1
].
pAddr
=
0
;
slot
->
resume_offset
=
hostdata
->
pScript
;
slot
->
resume_offset
=
hostdata
->
pScript
;
NCR_700_dma_cache_wback
((
unsigned
long
)
slot
->
SG
,
sizeof
(
slot
->
SG
[
0
])
*
2
);
dma_cache_sync
(
slot
->
SG
,
sizeof
(
slot
->
SG
[
0
])
*
2
,
DMA_TO_DEVICE
);
NCR_700_dma_cache_inv
((
unsigned
long
)
SCp
->
sense_buffer
,
sizeof
(
SCp
->
sense_buffer
)
);
dma_cache_sync
(
SCp
->
sense_buffer
,
sizeof
(
SCp
->
sense_buffer
),
DMA_FROM_DEVICE
);
/* queue the command for reissue */
/* queue the command for reissue */
slot
->
state
=
NCR_700_SLOT_QUEUED
;
slot
->
state
=
NCR_700_SLOT_QUEUED
;
...
@@ -1024,10 +1004,10 @@ process_script_interrupt(__u32 dsps, __u32 dsp, Scsi_Cmnd *SCp,
...
@@ -1024,10 +1004,10 @@ process_script_interrupt(__u32 dsps, __u32 dsp, Scsi_Cmnd *SCp,
// SCp->cmnd[0] == INQUIRY && SCp->use_sg == 0) {
// SCp->cmnd[0] == INQUIRY && SCp->use_sg == 0) {
// /* Piggy back the tag queueing support
// /* Piggy back the tag queueing support
// * on this command */
// * on this command */
//
pci_dma_sync_single(hostdata->pci_
dev,
//
dma_sync_single(hostdata->
dev,
// slot->dma_handle,
// slot->dma_handle,
// SCp->request_bufflen,
// SCp->request_bufflen,
//
PCI_DMA_FROM
DEVICE);
//
DMA_FROM_
DEVICE);
// if(((char *)SCp->request_buffer)[7] & 0x02) {
// if(((char *)SCp->request_buffer)[7] & 0x02) {
// printk(KERN_INFO "scsi%d: (%d:%d) Enabling Tag Command Queuing\n", host->host_no, pun, lun);
// printk(KERN_INFO "scsi%d: (%d:%d) Enabling Tag Command Queuing\n", host->host_no, pun, lun);
// hostdata->tag_negotiated |= (1<<SCp->target);
// hostdata->tag_negotiated |= (1<<SCp->target);
...
@@ -1137,14 +1117,14 @@ process_script_interrupt(__u32 dsps, __u32 dsp, Scsi_Cmnd *SCp,
...
@@ -1137,14 +1117,14 @@ process_script_interrupt(__u32 dsps, __u32 dsp, Scsi_Cmnd *SCp,
* should therefore always clear ACK */
* should therefore always clear ACK */
NCR_700_writeb
(
NCR_700_get_SXFER
(
hostdata
->
cmd
->
device
),
NCR_700_writeb
(
NCR_700_get_SXFER
(
hostdata
->
cmd
->
device
),
host
,
SXFER_REG
);
host
,
SXFER_REG
);
NCR_700_dma_cache_inv
((
unsigned
long
)
hostdata
->
msgin
,
dma_cache_sync
(
hostdata
->
msgin
,
MSG_ARRAY_SIZ
E
);
MSG_ARRAY_SIZE
,
DMA_FROM_DEVIC
E
);
NCR_700_dma_cache_wback
((
unsigned
long
)
hostdata
->
msgout
,
dma_cache_sync
(
hostdata
->
msgout
,
MSG_ARRAY_SIZ
E
);
MSG_ARRAY_SIZE
,
DMA_TO_DEVIC
E
);
/* I'm just being paranoid here, the command should
/* I'm just being paranoid here, the command should
* already have been flushed from the cache */
* already have been flushed from the cache */
NCR_700_dma_cache_wback
((
unsigned
long
)
slot
->
cmnd
->
cmnd
,
dma_cache_sync
(
slot
->
cmnd
->
cmnd
,
slot
->
cmnd
->
cmd_len
);
slot
->
cmnd
->
cmd_len
,
DMA_TO_DEVICE
);
...
@@ -1207,8 +1187,8 @@ process_script_interrupt(__u32 dsps, __u32 dsp, Scsi_Cmnd *SCp,
...
@@ -1207,8 +1187,8 @@ process_script_interrupt(__u32 dsps, __u32 dsp, Scsi_Cmnd *SCp,
hostdata
->
reselection_id
=
reselection_id
;
hostdata
->
reselection_id
=
reselection_id
;
/* just in case we have a stale simple tag message, clear it */
/* just in case we have a stale simple tag message, clear it */
hostdata
->
msgin
[
1
]
=
0
;
hostdata
->
msgin
[
1
]
=
0
;
NCR_700_dma_cache_wback_inv
((
unsigned
long
)
hostdata
->
msgin
,
dma_cache_sync
(
hostdata
->
msgin
,
MSG_ARRAY_SIZE
);
MSG_ARRAY_SIZE
,
DMA_BIDIRECTIONAL
);
if
(
hostdata
->
tag_negotiated
&
(
1
<<
reselection_id
))
{
if
(
hostdata
->
tag_negotiated
&
(
1
<<
reselection_id
))
{
resume_offset
=
hostdata
->
pScript
+
Ent_GetReselectionWithTag
;
resume_offset
=
hostdata
->
pScript
+
Ent_GetReselectionWithTag
;
}
else
{
}
else
{
...
@@ -1323,7 +1303,8 @@ process_selection(struct Scsi_Host *host, __u32 dsp)
...
@@ -1323,7 +1303,8 @@ process_selection(struct Scsi_Host *host, __u32 dsp)
hostdata
->
cmd
=
NULL
;
hostdata
->
cmd
=
NULL
;
/* clear any stale simple tag message */
/* clear any stale simple tag message */
hostdata
->
msgin
[
1
]
=
0
;
hostdata
->
msgin
[
1
]
=
0
;
NCR_700_dma_cache_wback_inv
((
unsigned
long
)
hostdata
->
msgin
,
MSG_ARRAY_SIZE
);
dma_cache_sync
(
hostdata
->
msgin
,
MSG_ARRAY_SIZE
,
DMA_BIDIRECTIONAL
);
if
(
id
==
0xff
)
{
if
(
id
==
0xff
)
{
/* Selected as target, Ignore */
/* Selected as target, Ignore */
...
@@ -1434,10 +1415,11 @@ NCR_700_start_command(Scsi_Cmnd *SCp)
...
@@ -1434,10 +1415,11 @@ NCR_700_start_command(Scsi_Cmnd *SCp)
if
(
slot
->
resume_offset
==
0
)
if
(
slot
->
resume_offset
==
0
)
slot
->
resume_offset
=
hostdata
->
pScript
;
slot
->
resume_offset
=
hostdata
->
pScript
;
/* now perform all the writebacks and invalidates */
/* now perform all the writebacks and invalidates */
NCR_700_dma_cache_wback
((
unsigned
long
)
hostdata
->
msgout
,
count
);
dma_cache_sync
(
hostdata
->
msgout
,
count
,
DMA_TO_DEVICE
);
NCR_700_dma_cache_inv
((
unsigned
long
)
hostdata
->
msgin
,
MSG_ARRAY_SIZE
);
dma_cache_sync
(
hostdata
->
msgin
,
MSG_ARRAY_SIZE
,
NCR_700_dma_cache_wback
((
unsigned
long
)
SCp
->
cmnd
,
SCp
->
cmd_len
);
DMA_FROM_DEVICE
);
NCR_700_dma_cache_inv
((
unsigned
long
)
hostdata
->
status
,
1
);
dma_cache_sync
(
SCp
->
cmnd
,
SCp
->
cmd_len
,
DMA_TO_DEVICE
);
dma_cache_sync
(
hostdata
->
status
,
1
,
DMA_FROM_DEVICE
);
/* set the synchronous period/offset */
/* set the synchronous period/offset */
NCR_700_writeb
(
NCR_700_get_SXFER
(
SCp
->
device
),
NCR_700_writeb
(
NCR_700_get_SXFER
(
SCp
->
device
),
...
@@ -1606,7 +1588,7 @@ NCR_700_intr(int irq, void *dev_id, struct pt_regs *regs)
...
@@ -1606,7 +1588,7 @@ NCR_700_intr(int irq, void *dev_id, struct pt_regs *regs)
slot
->
SG
[
i
].
ins
=
bS_to_host
(
SCRIPT_NOP
);
slot
->
SG
[
i
].
ins
=
bS_to_host
(
SCRIPT_NOP
);
slot
->
SG
[
i
].
pAddr
=
0
;
slot
->
SG
[
i
].
pAddr
=
0
;
}
}
NCR_700_dma_cache_wback
((
unsigned
long
)
slot
->
SG
,
sizeof
(
slot
->
SG
)
);
dma_cache_sync
(
slot
->
SG
,
sizeof
(
slot
->
SG
),
DMA_TO_DEVICE
);
/* and pretend we disconnected after
/* and pretend we disconnected after
* the command phase */
* the command phase */
resume_offset
=
hostdata
->
pScript
+
Ent_MsgInDuringData
;
resume_offset
=
hostdata
->
pScript
+
Ent_MsgInDuringData
;
...
@@ -1755,7 +1737,7 @@ NCR_700_queuecommand(Scsi_Cmnd *SCp, void (*done)(Scsi_Cmnd *))
...
@@ -1755,7 +1737,7 @@ NCR_700_queuecommand(Scsi_Cmnd *SCp, void (*done)(Scsi_Cmnd *))
struct
NCR_700_Host_Parameters
*
hostdata
=
struct
NCR_700_Host_Parameters
*
hostdata
=
(
struct
NCR_700_Host_Parameters
*
)
SCp
->
host
->
hostdata
[
0
];
(
struct
NCR_700_Host_Parameters
*
)
SCp
->
host
->
hostdata
[
0
];
__u32
move_ins
;
__u32
move_ins
;
int
pci_
direction
;
enum
dma_data_direction
direction
;
struct
NCR_700_command_slot
*
slot
;
struct
NCR_700_command_slot
*
slot
;
if
(
hostdata
->
command_slot_count
>=
NCR_700_COMMAND_SLOTS_PER_HOST
)
{
if
(
hostdata
->
command_slot_count
>=
NCR_700_COMMAND_SLOTS_PER_HOST
)
{
...
@@ -1883,7 +1865,7 @@ NCR_700_queuecommand(Scsi_Cmnd *SCp, void (*done)(Scsi_Cmnd *))
...
@@ -1883,7 +1865,7 @@ NCR_700_queuecommand(Scsi_Cmnd *SCp, void (*done)(Scsi_Cmnd *))
}
}
/* now build the scatter gather list */
/* now build the scatter gather list */
pci_direction
=
scsi_to_pci_dma_dir
(
SCp
->
sc_data_direction
);
direction
=
(
enum
dma_data_direction
)
scsi_to_pci_dma_dir
(
SCp
->
sc_data_direction
);
if
(
move_ins
!=
0
)
{
if
(
move_ins
!=
0
)
{
int
i
;
int
i
;
int
sg_count
;
int
sg_count
;
...
@@ -1891,13 +1873,13 @@ NCR_700_queuecommand(Scsi_Cmnd *SCp, void (*done)(Scsi_Cmnd *))
...
@@ -1891,13 +1873,13 @@ NCR_700_queuecommand(Scsi_Cmnd *SCp, void (*done)(Scsi_Cmnd *))
__u32
count
=
0
;
__u32
count
=
0
;
if
(
SCp
->
use_sg
)
{
if
(
SCp
->
use_sg
)
{
sg_count
=
pci_map_sg
(
hostdata
->
pci_
dev
,
SCp
->
buffer
,
sg_count
=
dma_map_sg
(
hostdata
->
dev
,
SCp
->
buffer
,
SCp
->
use_sg
,
pci_
direction
);
SCp
->
use_sg
,
direction
);
}
else
{
}
else
{
vPtr
=
pci_map_single
(
hostdata
->
pci_
dev
,
vPtr
=
dma_map_single
(
hostdata
->
dev
,
SCp
->
request_buffer
,
SCp
->
request_buffer
,
SCp
->
request_bufflen
,
SCp
->
request_bufflen
,
pci_
direction
);
direction
);
count
=
SCp
->
request_bufflen
;
count
=
SCp
->
request_bufflen
;
slot
->
dma_handle
=
vPtr
;
slot
->
dma_handle
=
vPtr
;
sg_count
=
1
;
sg_count
=
1
;
...
@@ -1920,14 +1902,14 @@ NCR_700_queuecommand(Scsi_Cmnd *SCp, void (*done)(Scsi_Cmnd *))
...
@@ -1920,14 +1902,14 @@ NCR_700_queuecommand(Scsi_Cmnd *SCp, void (*done)(Scsi_Cmnd *))
}
}
slot
->
SG
[
i
].
ins
=
bS_to_host
(
SCRIPT_RETURN
);
slot
->
SG
[
i
].
ins
=
bS_to_host
(
SCRIPT_RETURN
);
slot
->
SG
[
i
].
pAddr
=
0
;
slot
->
SG
[
i
].
pAddr
=
0
;
NCR_700_dma_cache_wback
((
unsigned
long
)
slot
->
SG
,
sizeof
(
slot
->
SG
)
);
dma_cache_sync
(
slot
->
SG
,
sizeof
(
slot
->
SG
),
DMA_TO_DEVICE
);
DEBUG
((
" SETTING %08lx to %x
\n
"
,
DEBUG
((
" SETTING %08lx to %x
\n
"
,
(
&
slot
->
pSG
[
i
].
ins
),
(
&
slot
->
pSG
[
i
].
ins
),
slot
->
SG
[
i
].
ins
));
slot
->
SG
[
i
].
ins
));
}
}
slot
->
resume_offset
=
0
;
slot
->
resume_offset
=
0
;
slot
->
pCmd
=
pci_map_single
(
hostdata
->
pci_
dev
,
SCp
->
cmnd
,
slot
->
pCmd
=
dma_map_single
(
hostdata
->
dev
,
SCp
->
cmnd
,
sizeof
(
SCp
->
cmnd
),
PCI_DMA_TO
DEVICE
);
sizeof
(
SCp
->
cmnd
),
DMA_TO_
DEVICE
);
NCR_700_start_command
(
SCp
);
NCR_700_start_command
(
SCp
);
return
0
;
return
0
;
}
}
...
...
drivers/scsi/53c700.h
View file @
be388a51
...
@@ -45,25 +45,6 @@
...
@@ -45,25 +45,6 @@
#error "Config.in must define either CONFIG_53C700_IO_MAPPED or CONFIG_53C700_MEM_MAPPED to use this scsi core."
#error "Config.in must define either CONFIG_53C700_IO_MAPPED or CONFIG_53C700_MEM_MAPPED to use this scsi core."
#endif
#endif
/* macros for consistent memory allocation */
#ifdef CONFIG_53C700_USE_CONSISTENT
#define NCR_700_dma_cache_wback(mem, size) \
if(!hostdata->consistent) \
dma_cache_wback(mem, size)
#define NCR_700_dma_cache_inv(mem, size) \
if(!hostdata->consistent) \
dma_cache_inv(mem, size)
#define NCR_700_dma_cache_wback_inv(mem, size) \
if(!hostdata->consistent) \
dma_cache_wback_inv(mem, size)
#else
#define NCR_700_dma_cache_wback(mem, size) dma_cache_wback(mem,size)
#define NCR_700_dma_cache_inv(mem, size) dma_cache_inv(mem,size)
#define NCR_700_dma_cache_wback_inv(mem, size) dma_cache_wback_inv(mem,size)
#endif
struct
NCR_700_Host_Parameters
;
struct
NCR_700_Host_Parameters
;
/* These are the externally used routines */
/* These are the externally used routines */
...
@@ -215,7 +196,7 @@ struct NCR_700_Host_Parameters {
...
@@ -215,7 +196,7 @@ struct NCR_700_Host_Parameters {
/* These must be filled in by the calling driver */
/* These must be filled in by the calling driver */
int
clock
;
/* board clock speed in MHz */
int
clock
;
/* board clock speed in MHz */
unsigned
long
base
;
/* the base for the port (copied to host) */
unsigned
long
base
;
/* the base for the port (copied to host) */
struct
pci_dev
*
pci_
dev
;
struct
device
*
dev
;
__u32
dmode_extra
;
/* adjustable bus settings */
__u32
dmode_extra
;
/* adjustable bus settings */
__u32
differential
:
1
;
/* if we are differential */
__u32
differential
:
1
;
/* if we are differential */
#ifdef CONFIG_53C700_LE_ON_BE
#ifdef CONFIG_53C700_LE_ON_BE
...
@@ -229,10 +210,6 @@ struct NCR_700_Host_Parameters {
...
@@ -229,10 +210,6 @@ struct NCR_700_Host_Parameters {
/* NOTHING BELOW HERE NEEDS ALTERING */
/* NOTHING BELOW HERE NEEDS ALTERING */
__u32
fast
:
1
;
/* if we can alter the SCSI bus clock
__u32
fast
:
1
;
/* if we can alter the SCSI bus clock
speed (so can negiotiate sync) */
speed (so can negiotiate sync) */
#ifdef CONFIG_53C700_USE_CONSISTENT
__u32
consistent
:
1
;
#endif
int
sync_clock
;
/* The speed of the SYNC core */
int
sync_clock
;
/* The speed of the SYNC core */
__u32
*
script
;
/* pointer to script location */
__u32
*
script
;
/* pointer to script location */
...
@@ -442,7 +419,7 @@ struct NCR_700_Host_Parameters {
...
@@ -442,7 +419,7 @@ struct NCR_700_Host_Parameters {
for(i=0; i< (sizeof(A_##symbol##_used) / sizeof(__u32)); i++) { \
for(i=0; i< (sizeof(A_##symbol##_used) / sizeof(__u32)); i++) { \
__u32 val = bS_to_cpu((script)[A_##symbol##_used[i]]) + value; \
__u32 val = bS_to_cpu((script)[A_##symbol##_used[i]]) + value; \
(script)[A_##symbol##_used[i]] = bS_to_host(val); \
(script)[A_##symbol##_used[i]] = bS_to_host(val); \
dma_cache_
wback((unsigned long)&(script)[A_##symbol##_used[i]], 4
); \
dma_cache_
sync(&(script)[A_##symbol##_used[i]], 4, DMA_TO_DEVICE
); \
DEBUG((" script, patching %s at %d to 0x%lx\n", \
DEBUG((" script, patching %s at %d to 0x%lx\n", \
#symbol, A_##symbol##_used[i], (value))); \
#symbol, A_##symbol##_used[i], (value))); \
} \
} \
...
@@ -453,7 +430,7 @@ struct NCR_700_Host_Parameters {
...
@@ -453,7 +430,7 @@ struct NCR_700_Host_Parameters {
int i; \
int i; \
for(i=0; i< (sizeof(A_##symbol##_used) / sizeof(__u32)); i++) { \
for(i=0; i< (sizeof(A_##symbol##_used) / sizeof(__u32)); i++) { \
(script)[A_##symbol##_used[i]] = bS_to_host(value); \
(script)[A_##symbol##_used[i]] = bS_to_host(value); \
dma_cache_
wback((unsigned long)&(script)[A_##symbol##_used[i]], 4
); \
dma_cache_
sync(&(script)[A_##symbol##_used[i]], 4, DMA_TO_DEVICE
); \
DEBUG((" script, patching %s at %d to 0x%lx\n", \
DEBUG((" script, patching %s at %d to 0x%lx\n", \
#symbol, A_##symbol##_used[i], (value))); \
#symbol, A_##symbol##_used[i], (value))); \
} \
} \
...
@@ -468,7 +445,7 @@ struct NCR_700_Host_Parameters {
...
@@ -468,7 +445,7 @@ struct NCR_700_Host_Parameters {
val &= 0xff00ffff; \
val &= 0xff00ffff; \
val |= ((value) & 0xff) << 16; \
val |= ((value) & 0xff) << 16; \
(script)[A_##symbol##_used[i]] = bS_to_host(val); \
(script)[A_##symbol##_used[i]] = bS_to_host(val); \
dma_cache_
wback((unsigned long)&(script)[A_##symbol##_used[i]], 4
); \
dma_cache_
sync(&(script)[A_##symbol##_used[i]], 4, DMA_TO_DEVICE
); \
DEBUG((" script, patching ID field %s at %d to 0x%x\n", \
DEBUG((" script, patching ID field %s at %d to 0x%x\n", \
#symbol, A_##symbol##_used[i], val)); \
#symbol, A_##symbol##_used[i], val)); \
} \
} \
...
@@ -482,7 +459,7 @@ struct NCR_700_Host_Parameters {
...
@@ -482,7 +459,7 @@ struct NCR_700_Host_Parameters {
val &= 0xffff0000; \
val &= 0xffff0000; \
val |= ((value) & 0xffff); \
val |= ((value) & 0xffff); \
(script)[A_##symbol##_used[i]] = bS_to_host(val); \
(script)[A_##symbol##_used[i]] = bS_to_host(val); \
dma_cache_
wback((unsigned long)&(script)[A_##symbol##_used[i]], 4
); \
dma_cache_
sync(&(script)[A_##symbol##_used[i]], 4, DMA_TO_DEVICE
); \
DEBUG((" script, patching short field %s at %d to 0x%x\n", \
DEBUG((" script, patching short field %s at %d to 0x%x\n", \
#symbol, A_##symbol##_used[i], val)); \
#symbol, A_##symbol##_used[i], val)); \
} \
} \
...
...
drivers/scsi/Kconfig
View file @
be388a51
...
@@ -900,11 +900,6 @@ config 53C700_LE_ON_BE
...
@@ -900,11 +900,6 @@ config 53C700_LE_ON_BE
depends
on
SCSI_LASI700
depends
on
SCSI_LASI700
default
y
default
y
config
53
C700_USE_CONSISTENT
bool
depends
on
SCSI_LASI700
default
y
config
SCSI_NCR53C7xx
config
SCSI_NCR53C7xx
tristate
"NCR53c7,8xx SCSI support"
tristate
"NCR53c7,8xx SCSI support"
depends
on
SCSI
&&
PCI
depends
on
SCSI
&&
PCI
...
...
drivers/scsi/NCR_D700.c
View file @
be388a51
...
@@ -307,6 +307,7 @@ NCR_D700_probe(struct device *dev)
...
@@ -307,6 +307,7 @@ NCR_D700_probe(struct device *dev)
continue
;
continue
;
}
}
scsi_set_device
(
host
,
dev
);
scsi_set_device
(
host
,
dev
);
hostdata
->
dev
=
dev
;
found
++
;
found
++
;
}
}
info
->
found
+=
found
;
info
->
found
+=
found
;
...
...
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