diff options
Diffstat (limited to 'drivers/infiniband/hw/ipath/ipath_driver.c')
-rw-r--r-- | drivers/infiniband/hw/ipath/ipath_driver.c | 18 |
1 files changed, 10 insertions, 8 deletions
diff --git a/drivers/infiniband/hw/ipath/ipath_driver.c b/drivers/infiniband/hw/ipath/ipath_driver.c index 5a5fbdf66ac..7c69090f6bd 100644 --- a/drivers/infiniband/hw/ipath/ipath_driver.c +++ b/drivers/infiniband/hw/ipath/ipath_driver.c | |||
@@ -1104,13 +1104,14 @@ static void ipath_rcv_hdrerr(struct ipath_devdata *dd, | |||
1104 | 1104 | ||
1105 | /* | 1105 | /* |
1106 | * ipath_kreceive - receive a packet | 1106 | * ipath_kreceive - receive a packet |
1107 | * @dd: the infinipath device | 1107 | * @pd: the infinipath port |
1108 | * | 1108 | * |
1109 | * called from interrupt handler for errors or receive interrupt | 1109 | * called from interrupt handler for errors or receive interrupt |
1110 | */ | 1110 | */ |
1111 | void ipath_kreceive(struct ipath_devdata *dd) | 1111 | void ipath_kreceive(struct ipath_portdata *pd) |
1112 | { | 1112 | { |
1113 | u64 *rc; | 1113 | u64 *rc; |
1114 | struct ipath_devdata *dd = pd->port_dd; | ||
1114 | void *ebuf; | 1115 | void *ebuf; |
1115 | const u32 rsize = dd->ipath_rcvhdrentsize; /* words */ | 1116 | const u32 rsize = dd->ipath_rcvhdrentsize; /* words */ |
1116 | const u32 maxcnt = dd->ipath_rcvhdrcnt * rsize; /* words */ | 1117 | const u32 maxcnt = dd->ipath_rcvhdrcnt * rsize; /* words */ |
@@ -1125,8 +1126,8 @@ void ipath_kreceive(struct ipath_devdata *dd) | |||
1125 | goto bail; | 1126 | goto bail; |
1126 | } | 1127 | } |
1127 | 1128 | ||
1128 | l = dd->ipath_port0head; | 1129 | l = pd->port_head; |
1129 | hdrqtail = (u32) le64_to_cpu(*dd->ipath_hdrqtailptr); | 1130 | hdrqtail = ipath_get_rcvhdrtail(pd); |
1130 | if (l == hdrqtail) | 1131 | if (l == hdrqtail) |
1131 | goto bail; | 1132 | goto bail; |
1132 | 1133 | ||
@@ -1135,7 +1136,7 @@ reloop: | |||
1135 | u32 qp; | 1136 | u32 qp; |
1136 | u8 *bthbytes; | 1137 | u8 *bthbytes; |
1137 | 1138 | ||
1138 | rc = (u64 *) (dd->ipath_pd[0]->port_rcvhdrq + (l << 2)); | 1139 | rc = (u64 *) (pd->port_rcvhdrq + (l << 2)); |
1139 | hdr = (struct ipath_message_header *)&rc[1]; | 1140 | hdr = (struct ipath_message_header *)&rc[1]; |
1140 | /* | 1141 | /* |
1141 | * could make a network order version of IPATH_KD_QP, and | 1142 | * could make a network order version of IPATH_KD_QP, and |
@@ -1245,7 +1246,7 @@ reloop: | |||
1245 | * earlier packets, we "almost" guarantee we have covered | 1246 | * earlier packets, we "almost" guarantee we have covered |
1246 | * that case. | 1247 | * that case. |
1247 | */ | 1248 | */ |
1248 | u32 hqtail = (u32)le64_to_cpu(*dd->ipath_hdrqtailptr); | 1249 | u32 hqtail = ipath_get_rcvhdrtail(pd); |
1249 | if (hqtail != hdrqtail) { | 1250 | if (hqtail != hdrqtail) { |
1250 | hdrqtail = hqtail; | 1251 | hdrqtail = hqtail; |
1251 | reloop = 1; /* loop 1 extra time at most */ | 1252 | reloop = 1; /* loop 1 extra time at most */ |
@@ -1255,7 +1256,7 @@ reloop: | |||
1255 | 1256 | ||
1256 | pkttot += i; | 1257 | pkttot += i; |
1257 | 1258 | ||
1258 | dd->ipath_port0head = l; | 1259 | pd->port_head = l; |
1259 | 1260 | ||
1260 | if (pkttot > ipath_stats.sps_maxpkts_call) | 1261 | if (pkttot > ipath_stats.sps_maxpkts_call) |
1261 | ipath_stats.sps_maxpkts_call = pkttot; | 1262 | ipath_stats.sps_maxpkts_call = pkttot; |
@@ -1605,7 +1606,8 @@ int ipath_create_rcvhdrq(struct ipath_devdata *dd, | |||
1605 | 1606 | ||
1606 | /* clear for security and sanity on each use */ | 1607 | /* clear for security and sanity on each use */ |
1607 | memset(pd->port_rcvhdrq, 0, pd->port_rcvhdrq_size); | 1608 | memset(pd->port_rcvhdrq, 0, pd->port_rcvhdrq_size); |
1608 | memset(pd->port_rcvhdrtail_kvaddr, 0, PAGE_SIZE); | 1609 | if (pd->port_rcvhdrtail_kvaddr) |
1610 | memset(pd->port_rcvhdrtail_kvaddr, 0, PAGE_SIZE); | ||
1609 | 1611 | ||
1610 | /* | 1612 | /* |
1611 | * tell chip each time we init it, even if we are re-using previous | 1613 | * tell chip each time we init it, even if we are re-using previous |