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
a80bc2d3
Commit
a80bc2d3
authored
Mar 26, 2003
by
James Bottomley
Browse files
Options
Browse Files
Download
Plain Diff
Merge raven.il.steeleye.com:/home/jejb/BK/scsi-qlogicfc-2.5
into raven.il.steeleye.com:/home/jejb/BK/scsi-misc-2.5
parents
c27a298f
4158d9ce
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
31 additions
and
41 deletions
+31
-41
drivers/scsi/qlogicfc.c
drivers/scsi/qlogicfc.c
+31
-41
No files found.
drivers/scsi/qlogicfc.c
View file @
a80bc2d3
...
@@ -643,6 +643,7 @@ struct isp2x00_hostdata {
...
@@ -643,6 +643,7 @@ struct isp2x00_hostdata {
u_char
queued
;
u_char
queued
;
u_char
host_id
;
u_char
host_id
;
struct
timer_list
explore_timer
;
struct
timer_list
explore_timer
;
struct
id_name_map
tempmap
[
QLOGICFC_MAX_ID
+
1
];
};
};
...
@@ -836,22 +837,13 @@ static int isp2x00_make_portdb(struct Scsi_Host *host)
...
@@ -836,22 +837,13 @@ static int isp2x00_make_portdb(struct Scsi_Host *host)
short
param
[
8
];
short
param
[
8
];
int
i
,
j
;
int
i
,
j
;
struct
id_name_map
*
map
;
/* base of array [QLOGICFC_MAX_ID + 1] */
struct
id_name_map
*
mapx
;
/* array entry pointer */
struct
isp2x00_hostdata
*
hostdata
;
struct
isp2x00_hostdata
*
hostdata
;
hostdata
=
(
struct
isp2x00_hostdata
*
)
host
->
hostdata
;
map
=
kmalloc
((
QLOGICFC_MAX_ID
+
1
)
*
sizeof
(
struct
id_name_map
),
GFP_ATOMIC
);
if
(
!
map
)
{
printk
(
"qlogicfc%d : error getting memory -- cannot make port database.
\n
"
,
hostdata
->
host_id
);
goto
fini
;
}
memset
(
map
,
0
,
(
QLOGICFC_MAX_ID
+
1
)
*
sizeof
(
struct
id_name_map
));
isp2x00_disable_irqs
(
host
);
isp2x00_disable_irqs
(
host
);
hostdata
=
(
struct
isp2x00_hostdata
*
)
host
->
hostdata
;
memset
(
hostdata
->
tempmap
,
0
,
sizeof
(
hostdata
->
tempmap
));
#if ISP2x00_FABRIC
#if ISP2x00_FABRIC
for
(
i
=
0x81
;
i
<
QLOGICFC_MAX_ID
;
i
++
)
{
for
(
i
=
0x81
;
i
<
QLOGICFC_MAX_ID
;
i
++
)
{
param
[
0
]
=
MBOX_PORT_LOGOUT
;
param
[
0
]
=
MBOX_PORT_LOGOUT
;
...
@@ -876,74 +868,72 @@ static int isp2x00_make_portdb(struct Scsi_Host *host)
...
@@ -876,74 +868,72 @@ static int isp2x00_make_portdb(struct Scsi_Host *host)
if
(
param
[
0
]
==
MBOX_COMMAND_COMPLETE
)
{
if
(
param
[
0
]
==
MBOX_COMMAND_COMPLETE
)
{
hostdata
->
port_id
=
((
u_int
)
param
[
3
])
<<
16
;
hostdata
->
port_id
=
((
u_int
)
param
[
3
])
<<
16
;
hostdata
->
port_id
|=
param
[
2
];
hostdata
->
port_id
|=
param
[
2
];
map
->
loop_id
=
param
[
1
];
hostdata
->
tempmap
[
0
].
loop_id
=
param
[
1
];
map
->
wwn
=
hostdata
->
wwn
;
hostdata
->
tempmap
[
0
].
wwn
=
hostdata
->
wwn
;
}
}
else
{
else
{
printk
(
"qlogicfc%d : error getting scsi id.
\n
"
,
hostdata
->
host_id
);
printk
(
"qlogicfc%d : error getting scsi id.
\n
"
,
hostdata
->
host_id
);
}
}
for
(
i
=
0
,
mapx
=
map
;
i
<=
QLOGICFC_MAX_ID
;
i
++
,
mapx
++
)
for
(
i
=
0
;
i
<=
QLOGICFC_MAX_ID
;
i
++
)
mapx
->
loop_id
=
map
->
loop_id
;
hostdata
->
tempmap
[
i
].
loop_id
=
hostdata
->
tempmap
[
0
].
loop_id
;
for
(
i
=
0
,
j
=
1
,
mapx
=
map
+
1
;
i
<=
QLOGICFC_MAX_LOOP_ID
;
i
++
)
{
for
(
i
=
0
,
j
=
1
;
i
<=
QLOGICFC_MAX_LOOP_ID
;
i
++
)
{
param
[
0
]
=
MBOX_GET_PORT_NAME
;
param
[
0
]
=
MBOX_GET_PORT_NAME
;
param
[
1
]
=
(
i
<<
8
)
&
0xff00
;
param
[
1
]
=
(
i
<<
8
)
&
0xff00
;
isp2x00_mbox_command
(
host
,
param
);
isp2x00_mbox_command
(
host
,
param
);
if
(
param
[
0
]
==
MBOX_COMMAND_COMPLETE
)
{
if
(
param
[
0
]
==
MBOX_COMMAND_COMPLETE
)
{
mapx
->
loop_id
=
i
;
hostdata
->
tempmap
[
j
].
loop_id
=
i
;
mapx
->
wwn
=
((
u64
)
(
param
[
2
]
&
0xff
))
<<
56
;
hostdata
->
tempmap
[
j
].
wwn
=
((
u64
)
(
param
[
2
]
&
0xff
))
<<
56
;
mapx
->
wwn
|=
((
u64
)
((
param
[
2
]
>>
8
)
&
0xff
))
<<
48
;
hostdata
->
tempmap
[
j
].
wwn
|=
((
u64
)
((
param
[
2
]
>>
8
)
&
0xff
))
<<
48
;
mapx
->
wwn
|=
((
u64
)
(
param
[
3
]
&
0xff
))
<<
40
;
hostdata
->
tempmap
[
j
].
wwn
|=
((
u64
)
(
param
[
3
]
&
0xff
))
<<
40
;
mapx
->
wwn
|=
((
u64
)
((
param
[
3
]
>>
8
)
&
0xff
))
<<
32
;
hostdata
->
tempmap
[
j
].
wwn
|=
((
u64
)
((
param
[
3
]
>>
8
)
&
0xff
))
<<
32
;
mapx
->
wwn
|=
((
u64
)
(
param
[
6
]
&
0xff
))
<<
24
;
hostdata
->
tempmap
[
j
].
wwn
|=
((
u64
)
(
param
[
6
]
&
0xff
))
<<
24
;
mapx
->
wwn
|=
((
u64
)
((
param
[
6
]
>>
8
)
&
0xff
))
<<
16
;
hostdata
->
tempmap
[
j
].
wwn
|=
((
u64
)
((
param
[
6
]
>>
8
)
&
0xff
))
<<
16
;
mapx
->
wwn
|=
((
u64
)
(
param
[
7
]
&
0xff
))
<<
8
;
hostdata
->
tempmap
[
j
].
wwn
|=
((
u64
)
(
param
[
7
]
&
0xff
))
<<
8
;
mapx
->
wwn
|=
((
u64
)
((
param
[
7
]
>>
8
)
&
0xff
));
hostdata
->
tempmap
[
j
].
wwn
|=
((
u64
)
((
param
[
7
]
>>
8
)
&
0xff
));
j
++
;
j
++
;
mapx
++
;
}
}
}
}
#if ISP2x00_FABRIC
#if ISP2x00_FABRIC
isp2x00_init_fabric
(
host
,
map
,
j
);
isp2x00_init_fabric
(
host
,
hostdata
->
temp
map
,
j
);
#endif
#endif
for
(
i
=
0
,
mapx
=
map
;
i
<=
QLOGICFC_MAX_ID
;
i
++
,
mapx
++
)
{
for
(
i
=
0
;
i
<=
QLOGICFC_MAX_ID
;
i
++
)
{
struct
id_name_map
*
tmap
;
/* second array entry pointer */
if
(
hostdata
->
tempmap
[
i
].
wwn
!=
hostdata
->
port_db
[
i
].
wwn
)
{
if
(
mapx
->
wwn
!=
hostdata
->
port_db
[
i
].
wwn
)
{
for
(
j
=
0
;
j
<=
QLOGICFC_MAX_ID
;
j
++
)
{
for
(
j
=
0
,
tmap
=
map
;
j
<=
QLOGICFC_MAX_ID
;
j
++
,
tmap
++
)
{
if
(
hostdata
->
tempmap
[
j
].
wwn
==
hostdata
->
port_db
[
i
].
wwn
)
{
if
(
tmap
->
wwn
==
hostdata
->
port_db
[
i
].
wwn
)
{
hostdata
->
port_db
[
i
].
loop_id
=
hostdata
->
tempmap
[
j
].
loop_id
;
hostdata
->
port_db
[
i
].
loop_id
=
tmap
->
loop_id
;
break
;
break
;
}
}
}
}
if
(
j
==
QLOGICFC_MAX_ID
+
1
)
if
(
j
==
QLOGICFC_MAX_ID
+
1
)
hostdata
->
port_db
[
i
].
loop_id
=
map
->
loop_id
;
hostdata
->
port_db
[
i
].
loop_id
=
hostdata
->
tempmap
[
0
].
loop_id
;
for
(
j
=
0
;
j
<=
QLOGICFC_MAX_ID
;
j
++
)
{
for
(
j
=
0
;
j
<=
QLOGICFC_MAX_ID
;
j
++
)
{
if
(
hostdata
->
port_db
[
j
].
wwn
==
mapx
->
wwn
||
!
hostdata
->
port_db
[
j
].
wwn
)
{
if
(
hostdata
->
port_db
[
j
].
wwn
==
hostdata
->
tempmap
[
i
].
wwn
||
!
hostdata
->
port_db
[
j
].
wwn
)
{
break
;
break
;
}
}
}
}
if
(
j
==
QLOGICFC_MAX_ID
+
1
)
if
(
j
==
QLOGICFC_MAX_ID
+
1
)
printk
(
"qlogicfc%d : Too many scsi devices, no more room in port map.
\n
"
,
hostdata
->
host_id
);
printk
(
"qlogicfc%d : Too many scsi devices, no more room in port map.
\n
"
,
hostdata
->
host_id
);
if
(
!
hostdata
->
port_db
[
j
].
wwn
)
{
if
(
!
hostdata
->
port_db
[
j
].
wwn
)
{
hostdata
->
port_db
[
j
].
loop_id
=
mapx
->
loop_id
;
hostdata
->
port_db
[
j
].
loop_id
=
hostdata
->
tempmap
[
i
].
loop_id
;
hostdata
->
port_db
[
j
].
wwn
=
mapx
->
wwn
;
hostdata
->
port_db
[
j
].
wwn
=
hostdata
->
tempmap
[
i
].
wwn
;
}
}
}
else
}
else
hostdata
->
port_db
[
i
].
loop_id
=
mapx
->
loop_id
;
hostdata
->
port_db
[
i
].
loop_id
=
hostdata
->
tempmap
[
i
].
loop_id
;
}
}
isp2x00_enable_irqs
(
host
);
isp2x00_enable_irqs
(
host
);
kfree
(
map
);
fini:
return
0
;
return
0
;
}
}
...
...
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