diff options
Diffstat (limited to 'drivers/infiniband/ulp/ipoib')
-rw-r--r-- | drivers/infiniband/ulp/ipoib/ipoib.h | 152 | ||||
-rw-r--r-- | drivers/infiniband/ulp/ipoib/ipoib_cm.c | 48 | ||||
-rw-r--r-- | drivers/infiniband/ulp/ipoib/ipoib_ib.c | 8 | ||||
-rw-r--r-- | drivers/infiniband/ulp/ipoib/ipoib_main.c | 38 | ||||
-rw-r--r-- | drivers/infiniband/ulp/ipoib/ipoib_multicast.c | 4 | ||||
-rw-r--r-- | drivers/infiniband/ulp/ipoib/ipoib_verbs.c | 10 |
6 files changed, 130 insertions, 130 deletions
diff --git a/drivers/infiniband/ulp/ipoib/ipoib.h b/drivers/infiniband/ulp/ipoib/ipoib.h index eb7edab0e836..a376fb6ffa0e 100644 --- a/drivers/infiniband/ulp/ipoib/ipoib.h +++ b/drivers/infiniband/ulp/ipoib/ipoib.h | |||
@@ -56,42 +56,42 @@ | |||
56 | /* constants */ | 56 | /* constants */ |
57 | 57 | ||
58 | enum { | 58 | enum { |
59 | IPOIB_PACKET_SIZE = 2048, | 59 | IPOIB_PACKET_SIZE = 2048, |
60 | IPOIB_BUF_SIZE = IPOIB_PACKET_SIZE + IB_GRH_BYTES, | 60 | IPOIB_BUF_SIZE = IPOIB_PACKET_SIZE + IB_GRH_BYTES, |
61 | 61 | ||
62 | IPOIB_ENCAP_LEN = 4, | 62 | IPOIB_ENCAP_LEN = 4, |
63 | 63 | ||
64 | IPOIB_CM_MTU = 0x10000 - 0x10, /* padding to align header to 16 */ | 64 | IPOIB_CM_MTU = 0x10000 - 0x10, /* padding to align header to 16 */ |
65 | IPOIB_CM_BUF_SIZE = IPOIB_CM_MTU + IPOIB_ENCAP_LEN, | 65 | IPOIB_CM_BUF_SIZE = IPOIB_CM_MTU + IPOIB_ENCAP_LEN, |
66 | IPOIB_CM_HEAD_SIZE = IPOIB_CM_BUF_SIZE % PAGE_SIZE, | 66 | IPOIB_CM_HEAD_SIZE = IPOIB_CM_BUF_SIZE % PAGE_SIZE, |
67 | IPOIB_CM_RX_SG = ALIGN(IPOIB_CM_BUF_SIZE, PAGE_SIZE) / PAGE_SIZE, | 67 | IPOIB_CM_RX_SG = ALIGN(IPOIB_CM_BUF_SIZE, PAGE_SIZE) / PAGE_SIZE, |
68 | IPOIB_RX_RING_SIZE = 128, | 68 | IPOIB_RX_RING_SIZE = 128, |
69 | IPOIB_TX_RING_SIZE = 64, | 69 | IPOIB_TX_RING_SIZE = 64, |
70 | IPOIB_MAX_QUEUE_SIZE = 8192, | 70 | IPOIB_MAX_QUEUE_SIZE = 8192, |
71 | IPOIB_MIN_QUEUE_SIZE = 2, | 71 | IPOIB_MIN_QUEUE_SIZE = 2, |
72 | 72 | ||
73 | IPOIB_NUM_WC = 4, | 73 | IPOIB_NUM_WC = 4, |
74 | 74 | ||
75 | IPOIB_MAX_PATH_REC_QUEUE = 3, | 75 | IPOIB_MAX_PATH_REC_QUEUE = 3, |
76 | IPOIB_MAX_MCAST_QUEUE = 3, | 76 | IPOIB_MAX_MCAST_QUEUE = 3, |
77 | 77 | ||
78 | IPOIB_FLAG_OPER_UP = 0, | 78 | IPOIB_FLAG_OPER_UP = 0, |
79 | IPOIB_FLAG_INITIALIZED = 1, | 79 | IPOIB_FLAG_INITIALIZED = 1, |
80 | IPOIB_FLAG_ADMIN_UP = 2, | 80 | IPOIB_FLAG_ADMIN_UP = 2, |
81 | IPOIB_PKEY_ASSIGNED = 3, | 81 | IPOIB_PKEY_ASSIGNED = 3, |
82 | IPOIB_PKEY_STOP = 4, | 82 | IPOIB_PKEY_STOP = 4, |
83 | IPOIB_FLAG_SUBINTERFACE = 5, | 83 | IPOIB_FLAG_SUBINTERFACE = 5, |
84 | IPOIB_MCAST_RUN = 6, | 84 | IPOIB_MCAST_RUN = 6, |
85 | IPOIB_STOP_REAPER = 7, | 85 | IPOIB_STOP_REAPER = 7, |
86 | IPOIB_MCAST_STARTED = 8, | 86 | IPOIB_MCAST_STARTED = 8, |
87 | IPOIB_FLAG_ADMIN_CM = 9, | 87 | IPOIB_FLAG_ADMIN_CM = 9, |
88 | IPOIB_FLAG_UMCAST = 10, | 88 | IPOIB_FLAG_UMCAST = 10, |
89 | 89 | ||
90 | IPOIB_MAX_BACKOFF_SECONDS = 16, | 90 | IPOIB_MAX_BACKOFF_SECONDS = 16, |
91 | 91 | ||
92 | IPOIB_MCAST_FLAG_FOUND = 0, /* used in set_multicast_list */ | 92 | IPOIB_MCAST_FLAG_FOUND = 0, /* used in set_multicast_list */ |
93 | IPOIB_MCAST_FLAG_SENDONLY = 1, | 93 | IPOIB_MCAST_FLAG_SENDONLY = 1, |
94 | IPOIB_MCAST_FLAG_BUSY = 2, /* joining or already joined */ | 94 | IPOIB_MCAST_FLAG_BUSY = 2, /* joining or already joined */ |
95 | IPOIB_MCAST_FLAG_ATTACHED = 3, | 95 | IPOIB_MCAST_FLAG_ATTACHED = 3, |
96 | }; | 96 | }; |
97 | 97 | ||
@@ -117,7 +117,7 @@ struct ipoib_pseudoheader { | |||
117 | struct ipoib_mcast { | 117 | struct ipoib_mcast { |
118 | struct ib_sa_mcmember_rec mcmember; | 118 | struct ib_sa_mcmember_rec mcmember; |
119 | struct ib_sa_multicast *mc; | 119 | struct ib_sa_multicast *mc; |
120 | struct ipoib_ah *ah; | 120 | struct ipoib_ah *ah; |
121 | 121 | ||
122 | struct rb_node rb_node; | 122 | struct rb_node rb_node; |
123 | struct list_head list; | 123 | struct list_head list; |
@@ -186,27 +186,27 @@ enum ipoib_cm_state { | |||
186 | }; | 186 | }; |
187 | 187 | ||
188 | struct ipoib_cm_rx { | 188 | struct ipoib_cm_rx { |
189 | struct ib_cm_id *id; | 189 | struct ib_cm_id *id; |
190 | struct ib_qp *qp; | 190 | struct ib_qp *qp; |
191 | struct list_head list; | 191 | struct list_head list; |
192 | struct net_device *dev; | 192 | struct net_device *dev; |
193 | unsigned long jiffies; | 193 | unsigned long jiffies; |
194 | enum ipoib_cm_state state; | 194 | enum ipoib_cm_state state; |
195 | }; | 195 | }; |
196 | 196 | ||
197 | struct ipoib_cm_tx { | 197 | struct ipoib_cm_tx { |
198 | struct ib_cm_id *id; | 198 | struct ib_cm_id *id; |
199 | struct ib_qp *qp; | 199 | struct ib_qp *qp; |
200 | struct list_head list; | 200 | struct list_head list; |
201 | struct net_device *dev; | 201 | struct net_device *dev; |
202 | struct ipoib_neigh *neigh; | 202 | struct ipoib_neigh *neigh; |
203 | struct ipoib_path *path; | 203 | struct ipoib_path *path; |
204 | struct ipoib_tx_buf *tx_ring; | 204 | struct ipoib_tx_buf *tx_ring; |
205 | unsigned tx_head; | 205 | unsigned tx_head; |
206 | unsigned tx_tail; | 206 | unsigned tx_tail; |
207 | unsigned long flags; | 207 | unsigned long flags; |
208 | u32 mtu; | 208 | u32 mtu; |
209 | struct ib_wc ibwc[IPOIB_NUM_WC]; | 209 | struct ib_wc ibwc[IPOIB_NUM_WC]; |
210 | }; | 210 | }; |
211 | 211 | ||
212 | struct ipoib_cm_rx_buf { | 212 | struct ipoib_cm_rx_buf { |
@@ -215,24 +215,24 @@ struct ipoib_cm_rx_buf { | |||
215 | }; | 215 | }; |
216 | 216 | ||
217 | struct ipoib_cm_dev_priv { | 217 | struct ipoib_cm_dev_priv { |
218 | struct ib_srq *srq; | 218 | struct ib_srq *srq; |
219 | struct ipoib_cm_rx_buf *srq_ring; | 219 | struct ipoib_cm_rx_buf *srq_ring; |
220 | struct ib_cm_id *id; | 220 | struct ib_cm_id *id; |
221 | struct list_head passive_ids; /* state: LIVE */ | 221 | struct list_head passive_ids; /* state: LIVE */ |
222 | struct list_head rx_error_list; /* state: ERROR */ | 222 | struct list_head rx_error_list; /* state: ERROR */ |
223 | struct list_head rx_flush_list; /* state: FLUSH, drain not started */ | 223 | struct list_head rx_flush_list; /* state: FLUSH, drain not started */ |
224 | struct list_head rx_drain_list; /* state: FLUSH, drain started */ | 224 | struct list_head rx_drain_list; /* state: FLUSH, drain started */ |
225 | struct list_head rx_reap_list; /* state: FLUSH, drain done */ | 225 | struct list_head rx_reap_list; /* state: FLUSH, drain done */ |
226 | struct work_struct start_task; | 226 | struct work_struct start_task; |
227 | struct work_struct reap_task; | 227 | struct work_struct reap_task; |
228 | struct work_struct skb_task; | 228 | struct work_struct skb_task; |
229 | struct work_struct rx_reap_task; | 229 | struct work_struct rx_reap_task; |
230 | struct delayed_work stale_task; | 230 | struct delayed_work stale_task; |
231 | struct sk_buff_head skb_queue; | 231 | struct sk_buff_head skb_queue; |
232 | struct list_head start_list; | 232 | struct list_head start_list; |
233 | struct list_head reap_list; | 233 | struct list_head reap_list; |
234 | struct ib_wc ibwc[IPOIB_NUM_WC]; | 234 | struct ib_wc ibwc[IPOIB_NUM_WC]; |
235 | struct ib_sge rx_sge[IPOIB_CM_RX_SG]; | 235 | struct ib_sge rx_sge[IPOIB_CM_RX_SG]; |
236 | struct ib_recv_wr rx_wr; | 236 | struct ib_recv_wr rx_wr; |
237 | }; | 237 | }; |
238 | 238 | ||
@@ -269,30 +269,30 @@ struct ipoib_dev_priv { | |||
269 | struct work_struct pkey_event_task; | 269 | struct work_struct pkey_event_task; |
270 | 270 | ||
271 | struct ib_device *ca; | 271 | struct ib_device *ca; |
272 | u8 port; | 272 | u8 port; |
273 | u16 pkey; | 273 | u16 pkey; |
274 | u16 pkey_index; | 274 | u16 pkey_index; |
275 | struct ib_pd *pd; | 275 | struct ib_pd *pd; |
276 | struct ib_mr *mr; | 276 | struct ib_mr *mr; |
277 | struct ib_cq *cq; | 277 | struct ib_cq *cq; |
278 | struct ib_qp *qp; | 278 | struct ib_qp *qp; |
279 | u32 qkey; | 279 | u32 qkey; |
280 | 280 | ||
281 | union ib_gid local_gid; | 281 | union ib_gid local_gid; |
282 | u16 local_lid; | 282 | u16 local_lid; |
283 | 283 | ||
284 | unsigned int admin_mtu; | 284 | unsigned int admin_mtu; |
285 | unsigned int mcast_mtu; | 285 | unsigned int mcast_mtu; |
286 | 286 | ||
287 | struct ipoib_rx_buf *rx_ring; | 287 | struct ipoib_rx_buf *rx_ring; |
288 | 288 | ||
289 | spinlock_t tx_lock; | 289 | spinlock_t tx_lock; |
290 | struct ipoib_tx_buf *tx_ring; | 290 | struct ipoib_tx_buf *tx_ring; |
291 | unsigned tx_head; | 291 | unsigned tx_head; |
292 | unsigned tx_tail; | 292 | unsigned tx_tail; |
293 | struct ib_sge tx_sge; | 293 | struct ib_sge tx_sge; |
294 | struct ib_send_wr tx_wr; | 294 | struct ib_send_wr tx_wr; |
295 | unsigned tx_outstanding; | 295 | unsigned tx_outstanding; |
296 | 296 | ||
297 | struct ib_wc ibwc[IPOIB_NUM_WC]; | 297 | struct ib_wc ibwc[IPOIB_NUM_WC]; |
298 | 298 | ||
@@ -317,10 +317,10 @@ struct ipoib_dev_priv { | |||
317 | 317 | ||
318 | struct ipoib_ah { | 318 | struct ipoib_ah { |
319 | struct net_device *dev; | 319 | struct net_device *dev; |
320 | struct ib_ah *ah; | 320 | struct ib_ah *ah; |
321 | struct list_head list; | 321 | struct list_head list; |
322 | struct kref ref; | 322 | struct kref ref; |
323 | unsigned last_send; | 323 | unsigned last_send; |
324 | }; | 324 | }; |
325 | 325 | ||
326 | struct ipoib_path { | 326 | struct ipoib_path { |
@@ -331,11 +331,11 @@ struct ipoib_path { | |||
331 | 331 | ||
332 | struct list_head neigh_list; | 332 | struct list_head neigh_list; |
333 | 333 | ||
334 | int query_id; | 334 | int query_id; |
335 | struct ib_sa_query *query; | 335 | struct ib_sa_query *query; |
336 | struct completion done; | 336 | struct completion done; |
337 | 337 | ||
338 | struct rb_node rb_node; | 338 | struct rb_node rb_node; |
339 | struct list_head list; | 339 | struct list_head list; |
340 | }; | 340 | }; |
341 | 341 | ||
@@ -344,7 +344,7 @@ struct ipoib_neigh { | |||
344 | #ifdef CONFIG_INFINIBAND_IPOIB_CM | 344 | #ifdef CONFIG_INFINIBAND_IPOIB_CM |
345 | struct ipoib_cm_tx *cm; | 345 | struct ipoib_cm_tx *cm; |
346 | #endif | 346 | #endif |
347 | union ib_gid dgid; | 347 | union ib_gid dgid; |
348 | struct sk_buff_head queue; | 348 | struct sk_buff_head queue; |
349 | 349 | ||
350 | struct neighbour *neighbour; | 350 | struct neighbour *neighbour; |
@@ -455,8 +455,8 @@ void ipoib_drain_cq(struct net_device *dev); | |||
455 | 455 | ||
456 | #ifdef CONFIG_INFINIBAND_IPOIB_CM | 456 | #ifdef CONFIG_INFINIBAND_IPOIB_CM |
457 | 457 | ||
458 | #define IPOIB_FLAGS_RC 0x80 | 458 | #define IPOIB_FLAGS_RC 0x80 |
459 | #define IPOIB_FLAGS_UC 0x40 | 459 | #define IPOIB_FLAGS_UC 0x40 |
460 | 460 | ||
461 | /* We don't support UC connections at the moment */ | 461 | /* We don't support UC connections at the moment */ |
462 | #define IPOIB_CM_SUPPORTED(ha) (ha[0] & (IPOIB_FLAGS_RC)) | 462 | #define IPOIB_CM_SUPPORTED(ha) (ha[0] & (IPOIB_FLAGS_RC)) |
@@ -500,7 +500,7 @@ void ipoib_cm_dev_cleanup(struct net_device *dev); | |||
500 | struct ipoib_cm_tx *ipoib_cm_create_tx(struct net_device *dev, struct ipoib_path *path, | 500 | struct ipoib_cm_tx *ipoib_cm_create_tx(struct net_device *dev, struct ipoib_path *path, |
501 | struct ipoib_neigh *neigh); | 501 | struct ipoib_neigh *neigh); |
502 | void ipoib_cm_destroy_tx(struct ipoib_cm_tx *tx); | 502 | void ipoib_cm_destroy_tx(struct ipoib_cm_tx *tx); |
503 | void ipoib_cm_skb_too_long(struct net_device* dev, struct sk_buff *skb, | 503 | void ipoib_cm_skb_too_long(struct net_device *dev, struct sk_buff *skb, |
504 | unsigned int mtu); | 504 | unsigned int mtu); |
505 | void ipoib_cm_handle_rx_wc(struct net_device *dev, struct ib_wc *wc); | 505 | void ipoib_cm_handle_rx_wc(struct net_device *dev, struct ib_wc *wc); |
506 | void ipoib_cm_handle_tx_wc(struct net_device *dev, struct ib_wc *wc); | 506 | void ipoib_cm_handle_tx_wc(struct net_device *dev, struct ib_wc *wc); |
@@ -582,7 +582,7 @@ int ipoib_cm_add_mode_attr(struct net_device *dev) | |||
582 | return 0; | 582 | return 0; |
583 | } | 583 | } |
584 | 584 | ||
585 | static inline void ipoib_cm_skb_too_long(struct net_device* dev, struct sk_buff *skb, | 585 | static inline void ipoib_cm_skb_too_long(struct net_device *dev, struct sk_buff *skb, |
586 | unsigned int mtu) | 586 | unsigned int mtu) |
587 | { | 587 | { |
588 | dev_kfree_skb_any(skb); | 588 | dev_kfree_skb_any(skb); |
@@ -624,12 +624,12 @@ extern struct ib_sa_client ipoib_sa_client; | |||
624 | extern int ipoib_debug_level; | 624 | extern int ipoib_debug_level; |
625 | 625 | ||
626 | #define ipoib_dbg(priv, format, arg...) \ | 626 | #define ipoib_dbg(priv, format, arg...) \ |
627 | do { \ | 627 | do { \ |
628 | if (ipoib_debug_level > 0) \ | 628 | if (ipoib_debug_level > 0) \ |
629 | ipoib_printk(KERN_DEBUG, priv, format , ## arg); \ | 629 | ipoib_printk(KERN_DEBUG, priv, format , ## arg); \ |
630 | } while (0) | 630 | } while (0) |
631 | #define ipoib_dbg_mcast(priv, format, arg...) \ | 631 | #define ipoib_dbg_mcast(priv, format, arg...) \ |
632 | do { \ | 632 | do { \ |
633 | if (mcast_debug_level > 0) \ | 633 | if (mcast_debug_level > 0) \ |
634 | ipoib_printk(KERN_DEBUG, priv, format , ## arg); \ | 634 | ipoib_printk(KERN_DEBUG, priv, format , ## arg); \ |
635 | } while (0) | 635 | } while (0) |
@@ -642,7 +642,7 @@ extern int ipoib_debug_level; | |||
642 | 642 | ||
643 | #ifdef CONFIG_INFINIBAND_IPOIB_DEBUG_DATA | 643 | #ifdef CONFIG_INFINIBAND_IPOIB_DEBUG_DATA |
644 | #define ipoib_dbg_data(priv, format, arg...) \ | 644 | #define ipoib_dbg_data(priv, format, arg...) \ |
645 | do { \ | 645 | do { \ |
646 | if (data_debug_level > 0) \ | 646 | if (data_debug_level > 0) \ |
647 | ipoib_printk(KERN_DEBUG, priv, format , ## arg); \ | 647 | ipoib_printk(KERN_DEBUG, priv, format , ## arg); \ |
648 | } while (0) | 648 | } while (0) |
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_cm.c b/drivers/infiniband/ulp/ipoib/ipoib_cm.c index 059cf92b60a5..5d2da1676928 100644 --- a/drivers/infiniband/ulp/ipoib/ipoib_cm.c +++ b/drivers/infiniband/ulp/ipoib/ipoib_cm.c | |||
@@ -155,7 +155,7 @@ partial_error: | |||
155 | return NULL; | 155 | return NULL; |
156 | } | 156 | } |
157 | 157 | ||
158 | static void ipoib_cm_start_rx_drain(struct ipoib_dev_priv* priv) | 158 | static void ipoib_cm_start_rx_drain(struct ipoib_dev_priv *priv) |
159 | { | 159 | { |
160 | struct ib_send_wr *bad_wr; | 160 | struct ib_send_wr *bad_wr; |
161 | struct ipoib_cm_rx *p; | 161 | struct ipoib_cm_rx *p; |
@@ -495,10 +495,10 @@ static inline int post_send(struct ipoib_dev_priv *priv, | |||
495 | { | 495 | { |
496 | struct ib_send_wr *bad_wr; | 496 | struct ib_send_wr *bad_wr; |
497 | 497 | ||
498 | priv->tx_sge.addr = addr; | 498 | priv->tx_sge.addr = addr; |
499 | priv->tx_sge.length = len; | 499 | priv->tx_sge.length = len; |
500 | 500 | ||
501 | priv->tx_wr.wr_id = wr_id | IPOIB_OP_CM; | 501 | priv->tx_wr.wr_id = wr_id | IPOIB_OP_CM; |
502 | 502 | ||
503 | return ib_post_send(tx->qp, &priv->tx_wr, &bad_wr); | 503 | return ib_post_send(tx->qp, &priv->tx_wr, &bad_wr); |
504 | } | 504 | } |
@@ -540,7 +540,7 @@ void ipoib_cm_send(struct net_device *dev, struct sk_buff *skb, struct ipoib_cm_ | |||
540 | tx_req->mapping = addr; | 540 | tx_req->mapping = addr; |
541 | 541 | ||
542 | if (unlikely(post_send(priv, tx, tx->tx_head & (ipoib_sendq_size - 1), | 542 | if (unlikely(post_send(priv, tx, tx->tx_head & (ipoib_sendq_size - 1), |
543 | addr, skb->len))) { | 543 | addr, skb->len))) { |
544 | ipoib_warn(priv, "post_send failed\n"); | 544 | ipoib_warn(priv, "post_send failed\n"); |
545 | ++dev->stats.tx_errors; | 545 | ++dev->stats.tx_errors; |
546 | ib_dma_unmap_single(priv->ca, addr, skb->len, DMA_TO_DEVICE); | 546 | ib_dma_unmap_single(priv->ca, addr, skb->len, DMA_TO_DEVICE); |
@@ -799,7 +799,7 @@ static struct ib_qp *ipoib_cm_create_tx_qp(struct net_device *dev, struct ipoib_ | |||
799 | .sq_sig_type = IB_SIGNAL_ALL_WR, | 799 | .sq_sig_type = IB_SIGNAL_ALL_WR, |
800 | .qp_type = IB_QPT_RC, | 800 | .qp_type = IB_QPT_RC, |
801 | .qp_context = tx | 801 | .qp_context = tx |
802 | }; | 802 | }; |
803 | 803 | ||
804 | return ib_create_qp(priv->pd, &attr); | 804 | return ib_create_qp(priv->pd, &attr); |
805 | } | 805 | } |
@@ -816,28 +816,28 @@ static int ipoib_cm_send_req(struct net_device *dev, | |||
816 | data.qpn = cpu_to_be32(priv->qp->qp_num); | 816 | data.qpn = cpu_to_be32(priv->qp->qp_num); |
817 | data.mtu = cpu_to_be32(IPOIB_CM_BUF_SIZE); | 817 | data.mtu = cpu_to_be32(IPOIB_CM_BUF_SIZE); |
818 | 818 | ||
819 | req.primary_path = pathrec; | 819 | req.primary_path = pathrec; |
820 | req.alternate_path = NULL; | 820 | req.alternate_path = NULL; |
821 | req.service_id = cpu_to_be64(IPOIB_CM_IETF_ID | qpn); | 821 | req.service_id = cpu_to_be64(IPOIB_CM_IETF_ID | qpn); |
822 | req.qp_num = qp->qp_num; | 822 | req.qp_num = qp->qp_num; |
823 | req.qp_type = qp->qp_type; | 823 | req.qp_type = qp->qp_type; |
824 | req.private_data = &data; | 824 | req.private_data = &data; |
825 | req.private_data_len = sizeof data; | 825 | req.private_data_len = sizeof data; |
826 | req.flow_control = 0; | 826 | req.flow_control = 0; |
827 | 827 | ||
828 | req.starting_psn = 0; /* FIXME */ | 828 | req.starting_psn = 0; /* FIXME */ |
829 | 829 | ||
830 | /* | 830 | /* |
831 | * Pick some arbitrary defaults here; we could make these | 831 | * Pick some arbitrary defaults here; we could make these |
832 | * module parameters if anyone cared about setting them. | 832 | * module parameters if anyone cared about setting them. |
833 | */ | 833 | */ |
834 | req.responder_resources = 4; | 834 | req.responder_resources = 4; |
835 | req.remote_cm_response_timeout = 20; | 835 | req.remote_cm_response_timeout = 20; |
836 | req.local_cm_response_timeout = 20; | 836 | req.local_cm_response_timeout = 20; |
837 | req.retry_count = 0; /* RFC draft warns against retries */ | 837 | req.retry_count = 0; /* RFC draft warns against retries */ |
838 | req.rnr_retry_count = 0; /* RFC draft warns against retries */ | 838 | req.rnr_retry_count = 0; /* RFC draft warns against retries */ |
839 | req.max_cm_retries = 15; | 839 | req.max_cm_retries = 15; |
840 | req.srq = 1; | 840 | req.srq = 1; |
841 | return ib_send_cm_req(id, &req); | 841 | return ib_send_cm_req(id, &req); |
842 | } | 842 | } |
843 | 843 | ||
@@ -1150,7 +1150,7 @@ static void ipoib_cm_skb_reap(struct work_struct *work) | |||
1150 | spin_unlock_irq(&priv->tx_lock); | 1150 | spin_unlock_irq(&priv->tx_lock); |
1151 | } | 1151 | } |
1152 | 1152 | ||
1153 | void ipoib_cm_skb_too_long(struct net_device* dev, struct sk_buff *skb, | 1153 | void ipoib_cm_skb_too_long(struct net_device *dev, struct sk_buff *skb, |
1154 | unsigned int mtu) | 1154 | unsigned int mtu) |
1155 | { | 1155 | { |
1156 | struct ipoib_dev_priv *priv = netdev_priv(dev); | 1156 | struct ipoib_dev_priv *priv = netdev_priv(dev); |
@@ -1212,7 +1212,7 @@ static void ipoib_cm_stale_task(struct work_struct *work) | |||
1212 | } | 1212 | } |
1213 | 1213 | ||
1214 | 1214 | ||
1215 | static ssize_t show_mode(struct device *d, struct device_attribute *attr, | 1215 | static ssize_t show_mode(struct device *d, struct device_attribute *attr, |
1216 | char *buf) | 1216 | char *buf) |
1217 | { | 1217 | { |
1218 | struct ipoib_dev_priv *priv = netdev_priv(to_net_dev(d)); | 1218 | struct ipoib_dev_priv *priv = netdev_priv(to_net_dev(d)); |
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_ib.c b/drivers/infiniband/ulp/ipoib/ipoib_ib.c index 5063dd509ad2..52bc2bd5799a 100644 --- a/drivers/infiniband/ulp/ipoib/ipoib_ib.c +++ b/drivers/infiniband/ulp/ipoib/ipoib_ib.c | |||
@@ -345,12 +345,12 @@ static inline int post_send(struct ipoib_dev_priv *priv, | |||
345 | { | 345 | { |
346 | struct ib_send_wr *bad_wr; | 346 | struct ib_send_wr *bad_wr; |
347 | 347 | ||
348 | priv->tx_sge.addr = addr; | 348 | priv->tx_sge.addr = addr; |
349 | priv->tx_sge.length = len; | 349 | priv->tx_sge.length = len; |
350 | 350 | ||
351 | priv->tx_wr.wr_id = wr_id; | 351 | priv->tx_wr.wr_id = wr_id; |
352 | priv->tx_wr.wr.ud.remote_qpn = qpn; | 352 | priv->tx_wr.wr.ud.remote_qpn = qpn; |
353 | priv->tx_wr.wr.ud.ah = address; | 353 | priv->tx_wr.wr.ud.ah = address; |
354 | 354 | ||
355 | return ib_post_send(priv->qp, &priv->tx_wr, &bad_wr); | 355 | return ib_post_send(priv->qp, &priv->tx_wr, &bad_wr); |
356 | } | 356 | } |
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_main.c b/drivers/infiniband/ulp/ipoib/ipoib_main.c index c9f6077b615e..5a9c3b5a39ef 100644 --- a/drivers/infiniband/ulp/ipoib/ipoib_main.c +++ b/drivers/infiniband/ulp/ipoib/ipoib_main.c | |||
@@ -474,8 +474,8 @@ static struct ipoib_path *path_rec_create(struct net_device *dev, void *gid) | |||
474 | INIT_LIST_HEAD(&path->neigh_list); | 474 | INIT_LIST_HEAD(&path->neigh_list); |
475 | 475 | ||
476 | memcpy(path->pathrec.dgid.raw, gid, sizeof (union ib_gid)); | 476 | memcpy(path->pathrec.dgid.raw, gid, sizeof (union ib_gid)); |
477 | path->pathrec.sgid = priv->local_gid; | 477 | path->pathrec.sgid = priv->local_gid; |
478 | path->pathrec.pkey = cpu_to_be16(priv->pkey); | 478 | path->pathrec.pkey = cpu_to_be16(priv->pkey); |
479 | path->pathrec.numb_path = 1; | 479 | path->pathrec.numb_path = 1; |
480 | path->pathrec.traffic_class = priv->broadcast->mcmember.traffic_class; | 480 | path->pathrec.traffic_class = priv->broadcast->mcmember.traffic_class; |
481 | 481 | ||
@@ -950,34 +950,34 @@ static void ipoib_setup(struct net_device *dev) | |||
950 | { | 950 | { |
951 | struct ipoib_dev_priv *priv = netdev_priv(dev); | 951 | struct ipoib_dev_priv *priv = netdev_priv(dev); |
952 | 952 | ||
953 | dev->open = ipoib_open; | 953 | dev->open = ipoib_open; |
954 | dev->stop = ipoib_stop; | 954 | dev->stop = ipoib_stop; |
955 | dev->change_mtu = ipoib_change_mtu; | 955 | dev->change_mtu = ipoib_change_mtu; |
956 | dev->hard_start_xmit = ipoib_start_xmit; | 956 | dev->hard_start_xmit = ipoib_start_xmit; |
957 | dev->tx_timeout = ipoib_timeout; | 957 | dev->tx_timeout = ipoib_timeout; |
958 | dev->header_ops = &ipoib_header_ops; | 958 | dev->header_ops = &ipoib_header_ops; |
959 | dev->set_multicast_list = ipoib_set_mcast_list; | 959 | dev->set_multicast_list = ipoib_set_mcast_list; |
960 | dev->neigh_setup = ipoib_neigh_setup_dev; | 960 | dev->neigh_setup = ipoib_neigh_setup_dev; |
961 | 961 | ||
962 | netif_napi_add(dev, &priv->napi, ipoib_poll, 100); | 962 | netif_napi_add(dev, &priv->napi, ipoib_poll, 100); |
963 | 963 | ||
964 | dev->watchdog_timeo = HZ; | 964 | dev->watchdog_timeo = HZ; |
965 | 965 | ||
966 | dev->flags |= IFF_BROADCAST | IFF_MULTICAST; | 966 | dev->flags |= IFF_BROADCAST | IFF_MULTICAST; |
967 | 967 | ||
968 | /* | 968 | /* |
969 | * We add in INFINIBAND_ALEN to allow for the destination | 969 | * We add in INFINIBAND_ALEN to allow for the destination |
970 | * address "pseudoheader" for skbs without neighbour struct. | 970 | * address "pseudoheader" for skbs without neighbour struct. |
971 | */ | 971 | */ |
972 | dev->hard_header_len = IPOIB_ENCAP_LEN + INFINIBAND_ALEN; | 972 | dev->hard_header_len = IPOIB_ENCAP_LEN + INFINIBAND_ALEN; |
973 | dev->addr_len = INFINIBAND_ALEN; | 973 | dev->addr_len = INFINIBAND_ALEN; |
974 | dev->type = ARPHRD_INFINIBAND; | 974 | dev->type = ARPHRD_INFINIBAND; |
975 | dev->tx_queue_len = ipoib_sendq_size * 2; | 975 | dev->tx_queue_len = ipoib_sendq_size * 2; |
976 | dev->features = NETIF_F_VLAN_CHALLENGED | NETIF_F_LLTX; | 976 | dev->features = NETIF_F_VLAN_CHALLENGED | NETIF_F_LLTX; |
977 | 977 | ||
978 | /* MTU will be reset when mcast join happens */ | 978 | /* MTU will be reset when mcast join happens */ |
979 | dev->mtu = IPOIB_PACKET_SIZE - IPOIB_ENCAP_LEN; | 979 | dev->mtu = IPOIB_PACKET_SIZE - IPOIB_ENCAP_LEN; |
980 | priv->mcast_mtu = priv->admin_mtu = dev->mtu; | 980 | priv->mcast_mtu = priv->admin_mtu = dev->mtu; |
981 | 981 | ||
982 | memcpy(dev->broadcast, ipv4_bcast_addr, INFINIBAND_ALEN); | 982 | memcpy(dev->broadcast, ipv4_bcast_addr, INFINIBAND_ALEN); |
983 | 983 | ||
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_multicast.c b/drivers/infiniband/ulp/ipoib/ipoib_multicast.c index 9bcfc7ad6aa6..858ada17f980 100644 --- a/drivers/infiniband/ulp/ipoib/ipoib_multicast.c +++ b/drivers/infiniband/ulp/ipoib/ipoib_multicast.c | |||
@@ -702,7 +702,7 @@ void ipoib_mcast_send(struct net_device *dev, void *mgid, struct sk_buff *skb) | |||
702 | 702 | ||
703 | out: | 703 | out: |
704 | if (mcast && mcast->ah) { | 704 | if (mcast && mcast->ah) { |
705 | if (skb->dst && | 705 | if (skb->dst && |
706 | skb->dst->neighbour && | 706 | skb->dst->neighbour && |
707 | !*to_ipoib_neigh(skb->dst->neighbour)) { | 707 | !*to_ipoib_neigh(skb->dst->neighbour)) { |
708 | struct ipoib_neigh *neigh = ipoib_neigh_alloc(skb->dst->neighbour, | 708 | struct ipoib_neigh *neigh = ipoib_neigh_alloc(skb->dst->neighbour, |
@@ -710,7 +710,7 @@ out: | |||
710 | 710 | ||
711 | if (neigh) { | 711 | if (neigh) { |
712 | kref_get(&mcast->ah->ref); | 712 | kref_get(&mcast->ah->ref); |
713 | neigh->ah = mcast->ah; | 713 | neigh->ah = mcast->ah; |
714 | list_add_tail(&neigh->list, &mcast->neigh_list); | 714 | list_add_tail(&neigh->list, &mcast->neigh_list); |
715 | } | 715 | } |
716 | } | 716 | } |
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_verbs.c b/drivers/infiniband/ulp/ipoib/ipoib_verbs.c index 3c6e45db0ab5..b6848a8d35db 100644 --- a/drivers/infiniband/ulp/ipoib/ipoib_verbs.c +++ b/drivers/infiniband/ulp/ipoib/ipoib_verbs.c | |||
@@ -197,12 +197,12 @@ int ipoib_transport_dev_init(struct net_device *dev, struct ib_device *ca) | |||
197 | priv->dev->dev_addr[2] = (priv->qp->qp_num >> 8) & 0xff; | 197 | priv->dev->dev_addr[2] = (priv->qp->qp_num >> 8) & 0xff; |
198 | priv->dev->dev_addr[3] = (priv->qp->qp_num ) & 0xff; | 198 | priv->dev->dev_addr[3] = (priv->qp->qp_num ) & 0xff; |
199 | 199 | ||
200 | priv->tx_sge.lkey = priv->mr->lkey; | 200 | priv->tx_sge.lkey = priv->mr->lkey; |
201 | 201 | ||
202 | priv->tx_wr.opcode = IB_WR_SEND; | 202 | priv->tx_wr.opcode = IB_WR_SEND; |
203 | priv->tx_wr.sg_list = &priv->tx_sge; | 203 | priv->tx_wr.sg_list = &priv->tx_sge; |
204 | priv->tx_wr.num_sge = 1; | 204 | priv->tx_wr.num_sge = 1; |
205 | priv->tx_wr.send_flags = IB_SEND_SIGNALED; | 205 | priv->tx_wr.send_flags = IB_SEND_SIGNALED; |
206 | 206 | ||
207 | return 0; | 207 | return 0; |
208 | 208 | ||