aboutsummaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMatt Jacob <mjacob@FreeBSD.org>2001-12-11 21:58:04 +0000
committerMatt Jacob <mjacob@FreeBSD.org>2001-12-11 21:58:04 +0000
commitc748b5e6345ac8f4bee752fd87303efe0cf25cab (patch)
treeb5c3683fdd7992fcba5a7c35bc61c5cb1410ab2f /sys
parent41a35633ba69419d7312b5558b853d1894feb8d0 (diff)
downloadsrc-c748b5e6345ac8f4bee752fd87303efe0cf25cab.tar.gz
src-c748b5e6345ac8f4bee752fd87303efe0cf25cab.zip
Explicitly decode GetAllNext SNS Response back *as*
a GetAllNext response. Otherwise, we won't unswizzle it correctly. This was found on linux/PPC. This mandated creating another inline: isp_get_gan_response.
Notes
Notes: svn path=/head/; revision=87671
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/isp/isp.c8
-rw-r--r--sys/dev/isp/isp_inline.h55
2 files changed, 59 insertions, 4 deletions
diff --git a/sys/dev/isp/isp.c b/sys/dev/isp/isp.c
index 4049eb501fd2..79768856a5e7 100644
--- a/sys/dev/isp/isp.c
+++ b/sys/dev/isp/isp.c
@@ -2282,7 +2282,7 @@ isp_scan_fabric(struct ispsoftc *isp)
for (first_portid_seen = hicap = 0; hicap < 65535; hicap++) {
mbreg_t mbs;
sns_screq_t *rq;
- sns_scrsp_t *rs0, *rs1;
+ sns_ganrsp_t *rs0, *rs1;
u_int8_t sc[SNS_GAN_REQ_SIZE];
rq = (sns_screq_t *)sc;
@@ -2349,9 +2349,9 @@ isp_scan_fabric(struct ispsoftc *isp)
return (-1);
}
MEMORYBARRIER(isp, SYNC_SFORCPU, 0x100, SNS_GAN_RESP_SIZE);
- rs1 = (sns_scrsp_t *) fcp->isp_scratch;
- rs0 = (sns_scrsp_t *) ((u_int8_t *)fcp->isp_scratch + 0x100);
- isp_get_sns_response(isp, rs0, rs1, SNS_GAN_RESP_SIZE >> 1);
+ rs1 = (sns_ganrsp_t *) fcp->isp_scratch;
+ rs0 = (sns_ganrsp_t *) ((u_int8_t *)fcp->isp_scratch + 0x100);
+ isp_get_gan_response(isp, rs0, rs1);
portid = (((u_int32_t) rs1->snscb_port_id[0]) << 16) |
(((u_int32_t) rs1->snscb_port_id[1]) << 8) |
(((u_int32_t) rs1->snscb_port_id[2]));
diff --git a/sys/dev/isp/isp_inline.h b/sys/dev/isp/isp_inline.h
index 9dd9004f49ac..0bb42d96230c 100644
--- a/sys/dev/isp/isp_inline.h
+++ b/sys/dev/isp/isp_inline.h
@@ -276,6 +276,8 @@ static INLINE void
isp_put_sns_request(struct ispsoftc *, sns_screq_t *, sns_screq_t *);
static INLINE void
isp_get_sns_response(struct ispsoftc *, sns_scrsp_t *, sns_scrsp_t *, int);
+static INLINE void
+isp_get_gan_response(struct ispsoftc *, sns_ganrsp_t *, sns_ganrsp_t *);
#ifdef ISP_TARGET_MODE
#ifndef _ISP_TARGET_H
#include "isp_target.h"
@@ -690,6 +692,59 @@ isp_get_sns_response(struct ispsoftc *isp, sns_scrsp_t *src,
}
}
+static INLINE void
+isp_get_gan_response(struct ispsoftc *isp, sns_ganrsp_t *src, sns_ganrsp_t *dst)
+{
+ int i;
+ for (i = 0; i < 16; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_cthdr[i], dst->snscb_cthdr[i]);
+ }
+ ISP_IOXGET_8(isp, &src->snscb_port_type, dst->snscb_port_type);
+ for (i = 0; i < 3; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_port_id[i],
+ dst->snscb_port_id[i]);
+ }
+ for (i = 0; i < 8; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_portname[i],
+ dst->snscb_portname[i]);
+ }
+ ISP_IOXGET_8(isp, &src->snscb_pnlen, dst->snscb_pnlen);
+ for (i = 0; i < 255; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_pname[i], dst->snscb_pname[i]);
+ }
+ for (i = 0; i < 8; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_nodename[i],
+ dst->snscb_nodename[i]);
+ }
+ ISP_IOXGET_8(isp, &src->snscb_nnlen, dst->snscb_nnlen);
+ for (i = 0; i < 255; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_nname[i], dst->snscb_nname[i]);
+ }
+ for (i = 0; i < 8; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_ipassoc[i],
+ dst->snscb_ipassoc[i]);
+ }
+ for (i = 0; i < 16; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_ipaddr[i], dst->snscb_ipaddr[i]);
+ }
+ for (i = 0; i < 4; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_svc_class[i],
+ dst->snscb_svc_class[i]);
+ }
+ for (i = 0; i < 32; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_fc4_types[i],
+ dst->snscb_fc4_types[i]);
+ }
+ for (i = 0; i < 8; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_fpname[i], dst->snscb_fpname[i]);
+ }
+ ISP_IOXGET_8(isp, &src->snscb_reserved, dst->snscb_reserved);
+ for (i = 0; i < 3; i++) {
+ ISP_IOXGET_8(isp, &src->snscb_hardaddr[i],
+ dst->snscb_hardaddr[i]);
+ }
+}
+
#ifdef ISP_TARGET_MODE
static INLINE void
isp_put_atio(struct ispsoftc *isp, at_entry_t *atsrc, at_entry_t *atdst)