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
eb56b153
Commit
eb56b153
authored
Oct 31, 2002
by
Adam Radford
Committed by
Linus Torvalds
Oct 31, 2002
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[PATCH] 3ware driver update for 2.5.46, sync cache, 64-bit, etc.
parent
caeff901
Changes
2
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
425 additions
and
238 deletions
+425
-238
drivers/scsi/3w-xxxx.c
drivers/scsi/3w-xxxx.c
+403
-222
drivers/scsi/3w-xxxx.h
drivers/scsi/3w-xxxx.h
+22
-16
No files found.
drivers/scsi/3w-xxxx.c
View file @
eb56b153
This diff is collapsed.
Click to expand it.
drivers/scsi/3w-xxxx.h
View file @
eb56b153
...
@@ -164,7 +164,7 @@ static unsigned char tw_sense_table[][4] =
...
@@ -164,7 +164,7 @@ static unsigned char tw_sense_table[][4] =
#define TW_RESPONSE_ID_MASK 0x00000FF0
#define TW_RESPONSE_ID_MASK 0x00000FF0
/* PCI related defines */
/* PCI related defines */
#define TW_IO_ADDRESS_RANGE 0x
D
#define TW_IO_ADDRESS_RANGE 0x
10
#define TW_DEVICE_NAME "3ware Storage Controller"
#define TW_DEVICE_NAME "3ware Storage Controller"
#define TW_VENDOR_ID (0x13C1)
/* 3ware */
#define TW_VENDOR_ID (0x13C1)
/* 3ware */
#define TW_DEVICE_ID (0x1000)
/* Storage Controller */
#define TW_DEVICE_ID (0x1000)
/* Storage Controller */
...
@@ -183,6 +183,7 @@ static unsigned char tw_sense_table[][4] =
...
@@ -183,6 +183,7 @@ static unsigned char tw_sense_table[][4] =
#define TW_OP_SET_PARAM 0x13
#define TW_OP_SET_PARAM 0x13
#define TW_OP_SECTOR_INFO 0x1a
#define TW_OP_SECTOR_INFO 0x1a
#define TW_OP_AEN_LISTEN 0x1c
#define TW_OP_AEN_LISTEN 0x1c
#define TW_OP_FLUSH_CACHE 0x0e
#define TW_CMD_PACKET 0x1d
#define TW_CMD_PACKET 0x1d
#define TW_ATA_PASSTHRU 0x1e
#define TW_ATA_PASSTHRU 0x1e
#define TW_CMD_PACKET_WITH_DATA 0x1f
#define TW_CMD_PACKET_WITH_DATA 0x1f
...
@@ -221,7 +222,6 @@ static unsigned char tw_sense_table[][4] =
...
@@ -221,7 +222,6 @@ static unsigned char tw_sense_table[][4] =
#define TW_MAX_CMDS_PER_LUN 255
#define TW_MAX_CMDS_PER_LUN 255
#define TW_BLOCK_SIZE 0x200
/* 512-byte blocks */
#define TW_BLOCK_SIZE 0x200
/* 512-byte blocks */
#define TW_IOCTL 0x80
#define TW_IOCTL 0x80
#define TW_MAX_AEN_TRIES 100
#define TW_UNIT_ONLINE 1
#define TW_UNIT_ONLINE 1
#define TW_IN_INTR 1
#define TW_IN_INTR 1
#define TW_IN_IOCTL 2
#define TW_IN_IOCTL 2
...
@@ -248,8 +248,8 @@ static unsigned char tw_sense_table[][4] =
...
@@ -248,8 +248,8 @@ static unsigned char tw_sense_table[][4] =
/* Scatter Gather List Entry */
/* Scatter Gather List Entry */
typedef
struct
TAG_TW_SG_Entry
{
typedef
struct
TAG_TW_SG_Entry
{
u
nsigned
long
address
;
u
32
address
;
u
nsigned
long
length
;
u
32
length
;
}
TW_SG_Entry
;
}
TW_SG_Entry
;
typedef
unsigned
char
TW_Sector
[
512
];
typedef
unsigned
char
TW_Sector
[
512
];
...
@@ -277,17 +277,17 @@ typedef struct TW_Command {
...
@@ -277,17 +277,17 @@ typedef struct TW_Command {
}
byte6
;
}
byte6
;
union
{
union
{
struct
{
struct
{
u
nsigned
long
lba
;
u
32
lba
;
TW_SG_Entry
sgl
[
TW_MAX_SGL_LENGTH
];
TW_SG_Entry
sgl
[
TW_MAX_SGL_LENGTH
];
u
nsigned
long
padding
;
/* pad to 512 bytes */
u
32
padding
;
/* pad to 512 bytes */
}
io
;
}
io
;
struct
{
struct
{
TW_SG_Entry
sgl
[
TW_MAX_SGL_LENGTH
];
TW_SG_Entry
sgl
[
TW_MAX_SGL_LENGTH
];
u
nsigned
long
padding
[
2
];
u
32
padding
[
2
];
}
param
;
}
param
;
struct
{
struct
{
u
nsigned
long
response_queue_pointer
;
u
32
response_queue_pointer
;
u
nsigned
long
padding
[
125
];
u
32
padding
[
125
];
}
init_connection
;
}
init_connection
;
struct
{
struct
{
char
version
[
504
];
char
version
[
504
];
...
@@ -376,12 +376,12 @@ typedef struct TAG_TW_Passthru
...
@@ -376,12 +376,12 @@ typedef struct TAG_TW_Passthru
typedef
struct
TAG_TW_Device_Extension
{
typedef
struct
TAG_TW_Device_Extension
{
TW_Registers
registers
;
TW_Registers
registers
;
u
32
*
alignment_virtual_address
[
TW_Q_LENGTH
];
u
nsigned
long
*
alignment_virtual_address
[
TW_Q_LENGTH
];
u
32
alignment_physical_address
[
TW_Q_LENGTH
];
u
nsigned
long
alignment_physical_address
[
TW_Q_LENGTH
];
int
is_unit_present
[
TW_MAX_UNITS
];
int
is_unit_present
[
TW_MAX_UNITS
];
int
num_units
;
int
num_units
;
u
32
*
command_packet_virtual_address
[
TW_Q_LENGTH
];
u
nsigned
long
*
command_packet_virtual_address
[
TW_Q_LENGTH
];
u
32
command_packet_physical_address
[
TW_Q_LENGTH
];
u
nsigned
long
command_packet_physical_address
[
TW_Q_LENGTH
];
struct
pci_dev
*
tw_pci_dev
;
struct
pci_dev
*
tw_pci_dev
;
Scsi_Cmnd
*
srb
[
TW_Q_LENGTH
];
Scsi_Cmnd
*
srb
[
TW_Q_LENGTH
];
unsigned
char
free_queue
[
TW_Q_LENGTH
];
unsigned
char
free_queue
[
TW_Q_LENGTH
];
...
@@ -411,8 +411,9 @@ typedef struct TAG_TW_Device_Extension {
...
@@ -411,8 +411,9 @@ typedef struct TAG_TW_Device_Extension {
unsigned
char
aen_head
;
unsigned
char
aen_head
;
unsigned
char
aen_tail
;
unsigned
char
aen_tail
;
volatile
long
flags
;
/* long req'd for set_bit --RR */
volatile
long
flags
;
/* long req'd for set_bit --RR */
char
*
ioctl_data
[
TW_Q_LENGTH
];
unsigned
long
*
ioctl_data
[
TW_Q_LENGTH
];
int
reset_print
;
int
reset_print
;
char
online
;
}
TW_Device_Extension
;
}
TW_Device_Extension
;
/* Function prototypes */
/* Function prototypes */
...
@@ -440,10 +441,11 @@ int tw_ioctl(TW_Device_Extension *tw_dev, int request_id);
...
@@ -440,10 +441,11 @@ int tw_ioctl(TW_Device_Extension *tw_dev, int request_id);
int
tw_ioctl_complete
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_ioctl_complete
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
void
tw_mask_command_interrupt
(
TW_Device_Extension
*
tw_dev
);
void
tw_mask_command_interrupt
(
TW_Device_Extension
*
tw_dev
);
int
tw_poll_status
(
TW_Device_Extension
*
tw_dev
,
u32
flag
,
int
seconds
);
int
tw_poll_status
(
TW_Device_Extension
*
tw_dev
,
u32
flag
,
int
seconds
);
int
tw_poll_status_gone
(
TW_Device_Extension
*
tw_dev
,
u32
flag
,
int
seconds
);
int
tw_post_command_packet
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_post_command_packet
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_reset_device_extension
(
TW_Device_Extension
*
tw_dev
);
int
tw_reset_device_extension
(
TW_Device_Extension
*
tw_dev
);
int
tw_reset_sequence
(
TW_Device_Extension
*
tw_dev
);
int
tw_reset_sequence
(
TW_Device_Extension
*
tw_dev
);
int
tw_scsi_biosparam
(
struct
scsi_device
*
sdev
,
struct
block_device
*
bev
,
int
tw_scsi_biosparam
(
struct
scsi_device
*
sdev
,
struct
block_device
*
b
d
ev
,
sector_t
capacity
,
int
geom
[]);
sector_t
capacity
,
int
geom
[]);
int
tw_scsi_detect
(
Scsi_Host_Template
*
tw_host
);
int
tw_scsi_detect
(
Scsi_Host_Template
*
tw_host
);
int
tw_scsi_eh_abort
(
Scsi_Cmnd
*
SCpnt
);
int
tw_scsi_eh_abort
(
Scsi_Cmnd
*
SCpnt
);
...
@@ -453,10 +455,13 @@ int tw_scsi_queue(Scsi_Cmnd *cmd, void (*done) (Scsi_Cmnd *));
...
@@ -453,10 +455,13 @@ int tw_scsi_queue(Scsi_Cmnd *cmd, void (*done) (Scsi_Cmnd *));
int
tw_scsi_release
(
struct
Scsi_Host
*
tw_host
);
int
tw_scsi_release
(
struct
Scsi_Host
*
tw_host
);
int
tw_scsiop_inquiry
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_inquiry
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_inquiry_complete
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_inquiry_complete
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_mode_sense
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_mode_sense_complete
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_read_capacity
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_read_capacity
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_read_capacity_complete
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_read_capacity_complete
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_read_write
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_read_write
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_request_sense
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_request_sense
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_synchronize_cache
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_test_unit_ready
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_scsiop_test_unit_ready
(
TW_Device_Extension
*
tw_dev
,
int
request_id
);
int
tw_setfeature
(
TW_Device_Extension
*
tw_dev
,
int
parm
,
int
param_size
,
int
tw_setfeature
(
TW_Device_Extension
*
tw_dev
,
int
parm
,
int
param_size
,
unsigned
char
*
val
);
unsigned
char
*
val
);
...
@@ -485,6 +490,7 @@ void tw_unmask_command_interrupt(TW_Device_Extension *tw_dev);
...
@@ -485,6 +490,7 @@ void tw_unmask_command_interrupt(TW_Device_Extension *tw_dev);
present : 0, \
present : 0, \
unchecked_isa_dma : 0, \
unchecked_isa_dma : 0, \
use_clustering : ENABLE_CLUSTERING, \
use_clustering : ENABLE_CLUSTERING, \
emulated : 1 \
emulated : 1, \
highmem_io : 1 \
}
}
#endif
/* _3W_XXXX_H */
#endif
/* _3W_XXXX_H */
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