diff options
-rw-r--r-- | drivers/infiniband/Kconfig | 2 | ||||
-rw-r--r-- | drivers/infiniband/core/addr.c | 4 | ||||
-rw-r--r-- | drivers/infiniband/core/cm.c | 2 | ||||
-rw-r--r-- | drivers/infiniband/core/cma.c | 8 | ||||
-rw-r--r-- | drivers/infiniband/core/mad.c | 12 | ||||
-rw-r--r-- | drivers/infiniband/core/mad_rmpp.c | 2 | ||||
-rw-r--r-- | drivers/infiniband/core/sa_query.c | 2 | ||||
-rw-r--r-- | drivers/infiniband/core/sysfs.c | 2 | ||||
-rw-r--r-- | drivers/infiniband/core/ucm.c | 6 | ||||
-rw-r--r-- | drivers/infiniband/core/user_mad.c | 2 | ||||
-rw-r--r-- | drivers/infiniband/core/uverbs_cmd.c | 2 | ||||
-rw-r--r-- | drivers/infiniband/hw/ipath/ipath_driver.c | 6 | ||||
-rw-r--r-- | drivers/infiniband/hw/mthca/mthca_cq.c | 10 | ||||
-rw-r--r-- | drivers/infiniband/ulp/ipoib/ipoib_multicast.c | 2 | ||||
-rw-r--r-- | drivers/infiniband/ulp/srp/ib_srp.c | 2 |
15 files changed, 31 insertions, 33 deletions
diff --git a/drivers/infiniband/Kconfig b/drivers/infiniband/Kconfig index fd2d528daa3a..9a329b2c108c 100644 --- a/drivers/infiniband/Kconfig +++ b/drivers/infiniband/Kconfig | |||
@@ -14,7 +14,7 @@ config INFINIBAND_USER_MAD | |||
14 | ---help--- | 14 | ---help--- |
15 | Userspace InfiniBand Management Datagram (MAD) support. This | 15 | Userspace InfiniBand Management Datagram (MAD) support. This |
16 | is the kernel side of the userspace MAD support, which allows | 16 | is the kernel side of the userspace MAD support, which allows |
17 | userspace processes to send and receive MADs. You will also | 17 | userspace processes to send and receive MADs. You will also |
18 | need libibumad from <http://www.openib.org>. | 18 | need libibumad from <http://www.openib.org>. |
19 | 19 | ||
20 | config INFINIBAND_USER_ACCESS | 20 | config INFINIBAND_USER_ACCESS |
diff --git a/drivers/infiniband/core/addr.c b/drivers/infiniband/core/addr.c index 1205e8027829..d8e54e002ce3 100644 --- a/drivers/infiniband/core/addr.c +++ b/drivers/infiniband/core/addr.c | |||
@@ -327,10 +327,10 @@ void rdma_addr_cancel(struct rdma_dev_addr *addr) | |||
327 | } | 327 | } |
328 | EXPORT_SYMBOL(rdma_addr_cancel); | 328 | EXPORT_SYMBOL(rdma_addr_cancel); |
329 | 329 | ||
330 | static int netevent_callback(struct notifier_block *self, unsigned long event, | 330 | static int netevent_callback(struct notifier_block *self, unsigned long event, |
331 | void *ctx) | 331 | void *ctx) |
332 | { | 332 | { |
333 | if (event == NETEVENT_NEIGH_UPDATE) { | 333 | if (event == NETEVENT_NEIGH_UPDATE) { |
334 | struct neighbour *neigh = ctx; | 334 | struct neighbour *neigh = ctx; |
335 | 335 | ||
336 | if (neigh->dev->type == ARPHRD_INFINIBAND && | 336 | if (neigh->dev->type == ARPHRD_INFINIBAND && |
diff --git a/drivers/infiniband/core/cm.c b/drivers/infiniband/core/cm.c index c8982b02d9b6..1c145fe92a54 100644 --- a/drivers/infiniband/core/cm.c +++ b/drivers/infiniband/core/cm.c | |||
@@ -179,7 +179,7 @@ static int cm_alloc_msg(struct cm_id_private *cm_id_priv, | |||
179 | if (IS_ERR(ah)) | 179 | if (IS_ERR(ah)) |
180 | return PTR_ERR(ah); | 180 | return PTR_ERR(ah); |
181 | 181 | ||
182 | m = ib_create_send_mad(mad_agent, cm_id_priv->id.remote_cm_qpn, | 182 | m = ib_create_send_mad(mad_agent, cm_id_priv->id.remote_cm_qpn, |
183 | cm_id_priv->av.pkey_index, | 183 | cm_id_priv->av.pkey_index, |
184 | 0, IB_MGMT_MAD_HDR, IB_MGMT_MAD_DATA, | 184 | 0, IB_MGMT_MAD_HDR, IB_MGMT_MAD_DATA, |
185 | GFP_ATOMIC); | 185 | GFP_ATOMIC); |
diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c index 5d625a81193f..9d58bb59cd45 100644 --- a/drivers/infiniband/core/cma.c +++ b/drivers/infiniband/core/cma.c | |||
@@ -613,7 +613,7 @@ static void cma_destroy_listen(struct rdma_id_private *id_priv) | |||
613 | if (id_priv->cma_dev) { | 613 | if (id_priv->cma_dev) { |
614 | switch (id_priv->id.device->node_type) { | 614 | switch (id_priv->id.device->node_type) { |
615 | case IB_NODE_CA: | 615 | case IB_NODE_CA: |
616 | if (id_priv->cm_id.ib && !IS_ERR(id_priv->cm_id.ib)) | 616 | if (id_priv->cm_id.ib && !IS_ERR(id_priv->cm_id.ib)) |
617 | ib_destroy_cm_id(id_priv->cm_id.ib); | 617 | ib_destroy_cm_id(id_priv->cm_id.ib); |
618 | break; | 618 | break; |
619 | default: | 619 | default: |
@@ -692,13 +692,13 @@ void rdma_destroy_id(struct rdma_cm_id *id) | |||
692 | if (id_priv->cma_dev) { | 692 | if (id_priv->cma_dev) { |
693 | switch (id->device->node_type) { | 693 | switch (id->device->node_type) { |
694 | case IB_NODE_CA: | 694 | case IB_NODE_CA: |
695 | if (id_priv->cm_id.ib && !IS_ERR(id_priv->cm_id.ib)) | 695 | if (id_priv->cm_id.ib && !IS_ERR(id_priv->cm_id.ib)) |
696 | ib_destroy_cm_id(id_priv->cm_id.ib); | 696 | ib_destroy_cm_id(id_priv->cm_id.ib); |
697 | break; | 697 | break; |
698 | default: | 698 | default: |
699 | break; | 699 | break; |
700 | } | 700 | } |
701 | mutex_lock(&lock); | 701 | mutex_lock(&lock); |
702 | cma_detach_from_dev(id_priv); | 702 | cma_detach_from_dev(id_priv); |
703 | mutex_unlock(&lock); | 703 | mutex_unlock(&lock); |
704 | } | 704 | } |
@@ -1492,7 +1492,7 @@ static int cma_use_port(struct idr *ps, struct rdma_id_private *id_priv) | |||
1492 | hlist_for_each_entry(cur_id, node, &bind_list->owners, node) { | 1492 | hlist_for_each_entry(cur_id, node, &bind_list->owners, node) { |
1493 | if (cma_any_addr(&cur_id->id.route.addr.src_addr)) | 1493 | if (cma_any_addr(&cur_id->id.route.addr.src_addr)) |
1494 | return -EADDRNOTAVAIL; | 1494 | return -EADDRNOTAVAIL; |
1495 | 1495 | ||
1496 | cur_sin = (struct sockaddr_in *) &cur_id->id.route.addr.src_addr; | 1496 | cur_sin = (struct sockaddr_in *) &cur_id->id.route.addr.src_addr; |
1497 | if (sin->sin_addr.s_addr == cur_sin->sin_addr.s_addr) | 1497 | if (sin->sin_addr.s_addr == cur_sin->sin_addr.s_addr) |
1498 | return -EADDRINUSE; | 1498 | return -EADDRINUSE; |
diff --git a/drivers/infiniband/core/mad.c b/drivers/infiniband/core/mad.c index 1c3cfbbe6a97..32d3028b274b 100644 --- a/drivers/infiniband/core/mad.c +++ b/drivers/infiniband/core/mad.c | |||
@@ -1246,8 +1246,8 @@ static int find_vendor_oui(struct ib_mad_mgmt_vendor_class *vendor_class, | |||
1246 | int i; | 1246 | int i; |
1247 | 1247 | ||
1248 | for (i = 0; i < MAX_MGMT_OUI; i++) | 1248 | for (i = 0; i < MAX_MGMT_OUI; i++) |
1249 | /* Is there matching OUI for this vendor class ? */ | 1249 | /* Is there matching OUI for this vendor class ? */ |
1250 | if (!memcmp(vendor_class->oui[i], oui, 3)) | 1250 | if (!memcmp(vendor_class->oui[i], oui, 3)) |
1251 | return i; | 1251 | return i; |
1252 | 1252 | ||
1253 | return -1; | 1253 | return -1; |
@@ -2237,7 +2237,7 @@ static void cancel_mads(struct ib_mad_agent_private *mad_agent_priv) | |||
2237 | list_for_each_entry_safe(mad_send_wr, temp_mad_send_wr, | 2237 | list_for_each_entry_safe(mad_send_wr, temp_mad_send_wr, |
2238 | &mad_agent_priv->send_list, agent_list) { | 2238 | &mad_agent_priv->send_list, agent_list) { |
2239 | if (mad_send_wr->status == IB_WC_SUCCESS) { | 2239 | if (mad_send_wr->status == IB_WC_SUCCESS) { |
2240 | mad_send_wr->status = IB_WC_WR_FLUSH_ERR; | 2240 | mad_send_wr->status = IB_WC_WR_FLUSH_ERR; |
2241 | mad_send_wr->refcount -= (mad_send_wr->timeout > 0); | 2241 | mad_send_wr->refcount -= (mad_send_wr->timeout > 0); |
2242 | } | 2242 | } |
2243 | } | 2243 | } |
@@ -2528,10 +2528,10 @@ static int ib_mad_post_receive_mads(struct ib_mad_qp_info *qp_info, | |||
2528 | } | 2528 | } |
2529 | } | 2529 | } |
2530 | sg_list.addr = dma_map_single(qp_info->port_priv-> | 2530 | sg_list.addr = dma_map_single(qp_info->port_priv-> |
2531 | device->dma_device, | 2531 | device->dma_device, |
2532 | &mad_priv->grh, | 2532 | &mad_priv->grh, |
2533 | sizeof *mad_priv - | 2533 | sizeof *mad_priv - |
2534 | sizeof mad_priv->header, | 2534 | sizeof mad_priv->header, |
2535 | DMA_FROM_DEVICE); | 2535 | DMA_FROM_DEVICE); |
2536 | pci_unmap_addr_set(&mad_priv->header, mapping, sg_list.addr); | 2536 | pci_unmap_addr_set(&mad_priv->header, mapping, sg_list.addr); |
2537 | recv_wr.wr_id = (unsigned long)&mad_priv->header.mad_list; | 2537 | recv_wr.wr_id = (unsigned long)&mad_priv->header.mad_list; |
@@ -2606,7 +2606,7 @@ static int ib_mad_port_start(struct ib_mad_port_private *port_priv) | |||
2606 | struct ib_qp *qp; | 2606 | struct ib_qp *qp; |
2607 | 2607 | ||
2608 | attr = kmalloc(sizeof *attr, GFP_KERNEL); | 2608 | attr = kmalloc(sizeof *attr, GFP_KERNEL); |
2609 | if (!attr) { | 2609 | if (!attr) { |
2610 | printk(KERN_ERR PFX "Couldn't kmalloc ib_qp_attr\n"); | 2610 | printk(KERN_ERR PFX "Couldn't kmalloc ib_qp_attr\n"); |
2611 | return -ENOMEM; | 2611 | return -ENOMEM; |
2612 | } | 2612 | } |
diff --git a/drivers/infiniband/core/mad_rmpp.c b/drivers/infiniband/core/mad_rmpp.c index 3ace5f492dc4..1ef79d015a1e 100644 --- a/drivers/infiniband/core/mad_rmpp.c +++ b/drivers/infiniband/core/mad_rmpp.c | |||
@@ -391,7 +391,7 @@ static inline int window_size(struct ib_mad_agent_private *agent) | |||
391 | static struct ib_mad_recv_buf * find_seg_location(struct list_head *rmpp_list, | 391 | static struct ib_mad_recv_buf * find_seg_location(struct list_head *rmpp_list, |
392 | int seg_num) | 392 | int seg_num) |
393 | { | 393 | { |
394 | struct ib_mad_recv_buf *seg_buf; | 394 | struct ib_mad_recv_buf *seg_buf; |
395 | int cur_seg_num; | 395 | int cur_seg_num; |
396 | 396 | ||
397 | list_for_each_entry_reverse(seg_buf, rmpp_list, list) { | 397 | list_for_each_entry_reverse(seg_buf, rmpp_list, list) { |
diff --git a/drivers/infiniband/core/sa_query.c b/drivers/infiniband/core/sa_query.c index d6b84226bba7..df762ba4868f 100644 --- a/drivers/infiniband/core/sa_query.c +++ b/drivers/infiniband/core/sa_query.c | |||
@@ -887,7 +887,7 @@ static void send_handler(struct ib_mad_agent *agent, | |||
887 | idr_remove(&query_idr, query->id); | 887 | idr_remove(&query_idr, query->id); |
888 | spin_unlock_irqrestore(&idr_lock, flags); | 888 | spin_unlock_irqrestore(&idr_lock, flags); |
889 | 889 | ||
890 | ib_free_send_mad(mad_send_wc->send_buf); | 890 | ib_free_send_mad(mad_send_wc->send_buf); |
891 | kref_put(&query->sm_ah->ref, free_sm_ah); | 891 | kref_put(&query->sm_ah->ref, free_sm_ah); |
892 | query->release(query); | 892 | query->release(query); |
893 | } | 893 | } |
diff --git a/drivers/infiniband/core/sysfs.c b/drivers/infiniband/core/sysfs.c index 21f9282c1b25..fb6660564a30 100644 --- a/drivers/infiniband/core/sysfs.c +++ b/drivers/infiniband/core/sysfs.c | |||
@@ -68,7 +68,7 @@ struct port_table_attribute { | |||
68 | int index; | 68 | int index; |
69 | }; | 69 | }; |
70 | 70 | ||
71 | static inline int ibdev_is_alive(const struct ib_device *dev) | 71 | static inline int ibdev_is_alive(const struct ib_device *dev) |
72 | { | 72 | { |
73 | return dev->reg_state == IB_DEV_REGISTERED; | 73 | return dev->reg_state == IB_DEV_REGISTERED; |
74 | } | 74 | } |
diff --git a/drivers/infiniband/core/ucm.c b/drivers/infiniband/core/ucm.c index c1c6fda9452c..e74c964af7fa 100644 --- a/drivers/infiniband/core/ucm.c +++ b/drivers/infiniband/core/ucm.c | |||
@@ -309,9 +309,9 @@ static int ib_ucm_event_process(struct ib_cm_event *evt, | |||
309 | info = evt->param.apr_rcvd.apr_info; | 309 | info = evt->param.apr_rcvd.apr_info; |
310 | break; | 310 | break; |
311 | case IB_CM_SIDR_REQ_RECEIVED: | 311 | case IB_CM_SIDR_REQ_RECEIVED: |
312 | uvt->resp.u.sidr_req_resp.pkey = | 312 | uvt->resp.u.sidr_req_resp.pkey = |
313 | evt->param.sidr_req_rcvd.pkey; | 313 | evt->param.sidr_req_rcvd.pkey; |
314 | uvt->resp.u.sidr_req_resp.port = | 314 | uvt->resp.u.sidr_req_resp.port = |
315 | evt->param.sidr_req_rcvd.port; | 315 | evt->param.sidr_req_rcvd.port; |
316 | uvt->data_len = IB_CM_SIDR_REQ_PRIVATE_DATA_SIZE; | 316 | uvt->data_len = IB_CM_SIDR_REQ_PRIVATE_DATA_SIZE; |
317 | break; | 317 | break; |
@@ -1237,7 +1237,7 @@ static struct class ucm_class = { | |||
1237 | static ssize_t show_ibdev(struct class_device *class_dev, char *buf) | 1237 | static ssize_t show_ibdev(struct class_device *class_dev, char *buf) |
1238 | { | 1238 | { |
1239 | struct ib_ucm_device *dev; | 1239 | struct ib_ucm_device *dev; |
1240 | 1240 | ||
1241 | dev = container_of(class_dev, struct ib_ucm_device, class_dev); | 1241 | dev = container_of(class_dev, struct ib_ucm_device, class_dev); |
1242 | return sprintf(buf, "%s\n", dev->ib_dev->name); | 1242 | return sprintf(buf, "%s\n", dev->ib_dev->name); |
1243 | } | 1243 | } |
diff --git a/drivers/infiniband/core/user_mad.c b/drivers/infiniband/core/user_mad.c index 1273f8807e84..8a455aec758f 100644 --- a/drivers/infiniband/core/user_mad.c +++ b/drivers/infiniband/core/user_mad.c | |||
@@ -1,6 +1,6 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (c) 2004 Topspin Communications. All rights reserved. | 2 | * Copyright (c) 2004 Topspin Communications. All rights reserved. |
3 | * Copyright (c) 2005 Voltaire, Inc. All rights reserved. | 3 | * Copyright (c) 2005 Voltaire, Inc. All rights reserved. |
4 | * Copyright (c) 2005 Sun Microsystems, Inc. All rights reserved. | 4 | * Copyright (c) 2005 Sun Microsystems, Inc. All rights reserved. |
5 | * | 5 | * |
6 | * This software is available to you under a choice of one of two | 6 | * This software is available to you under a choice of one of two |
diff --git a/drivers/infiniband/core/uverbs_cmd.c b/drivers/infiniband/core/uverbs_cmd.c index 3fcb5d189a23..b72c7f69ca90 100644 --- a/drivers/infiniband/core/uverbs_cmd.c +++ b/drivers/infiniband/core/uverbs_cmd.c | |||
@@ -1676,7 +1676,6 @@ ssize_t ib_uverbs_post_recv(struct ib_uverbs_file *file, | |||
1676 | break; | 1676 | break; |
1677 | } | 1677 | } |
1678 | 1678 | ||
1679 | |||
1680 | if (copy_to_user((void __user *) (unsigned long) cmd.response, | 1679 | if (copy_to_user((void __user *) (unsigned long) cmd.response, |
1681 | &resp, sizeof resp)) | 1680 | &resp, sizeof resp)) |
1682 | ret = -EFAULT; | 1681 | ret = -EFAULT; |
@@ -1726,7 +1725,6 @@ ssize_t ib_uverbs_post_srq_recv(struct ib_uverbs_file *file, | |||
1726 | break; | 1725 | break; |
1727 | } | 1726 | } |
1728 | 1727 | ||
1729 | |||
1730 | if (copy_to_user((void __user *) (unsigned long) cmd.response, | 1728 | if (copy_to_user((void __user *) (unsigned long) cmd.response, |
1731 | &resp, sizeof resp)) | 1729 | &resp, sizeof resp)) |
1732 | ret = -EFAULT; | 1730 | ret = -EFAULT; |
diff --git a/drivers/infiniband/hw/ipath/ipath_driver.c b/drivers/infiniband/hw/ipath/ipath_driver.c index 47c9d15557c8..2108466c7e33 100644 --- a/drivers/infiniband/hw/ipath/ipath_driver.c +++ b/drivers/infiniband/hw/ipath/ipath_driver.c | |||
@@ -2126,9 +2126,9 @@ int ipath_set_rx_pol_inv(struct ipath_devdata *dd, u8 new_pol_inv) | |||
2126 | dd->ipath_rx_pol_inv = new_pol_inv; | 2126 | dd->ipath_rx_pol_inv = new_pol_inv; |
2127 | val = ipath_read_kreg64(dd, dd->ipath_kregs->kr_xgxsconfig); | 2127 | val = ipath_read_kreg64(dd, dd->ipath_kregs->kr_xgxsconfig); |
2128 | val &= ~(INFINIPATH_XGXS_RX_POL_MASK << | 2128 | val &= ~(INFINIPATH_XGXS_RX_POL_MASK << |
2129 | INFINIPATH_XGXS_RX_POL_SHIFT); | 2129 | INFINIPATH_XGXS_RX_POL_SHIFT); |
2130 | val |= ((u64)dd->ipath_rx_pol_inv) << | 2130 | val |= ((u64)dd->ipath_rx_pol_inv) << |
2131 | INFINIPATH_XGXS_RX_POL_SHIFT; | 2131 | INFINIPATH_XGXS_RX_POL_SHIFT; |
2132 | ipath_write_kreg(dd, dd->ipath_kregs->kr_xgxsconfig, val); | 2132 | ipath_write_kreg(dd, dd->ipath_kregs->kr_xgxsconfig, val); |
2133 | } | 2133 | } |
2134 | return 0; | 2134 | return 0; |
diff --git a/drivers/infiniband/hw/mthca/mthca_cq.c b/drivers/infiniband/hw/mthca/mthca_cq.c index 3e27a084257e..e393681ba7d4 100644 --- a/drivers/infiniband/hw/mthca/mthca_cq.c +++ b/drivers/infiniband/hw/mthca/mthca_cq.c | |||
@@ -544,11 +544,11 @@ static inline int mthca_poll_one(struct mthca_dev *dev, | |||
544 | wq = &(*cur_qp)->rq; | 544 | wq = &(*cur_qp)->rq; |
545 | wqe = be32_to_cpu(cqe->wqe); | 545 | wqe = be32_to_cpu(cqe->wqe); |
546 | wqe_index = wqe >> wq->wqe_shift; | 546 | wqe_index = wqe >> wq->wqe_shift; |
547 | /* | 547 | /* |
548 | * WQE addr == base - 1 might be reported in receive completion | 548 | * WQE addr == base - 1 might be reported in receive completion |
549 | * with error instead of (rq size - 1) by Sinai FW 1.0.800 and | 549 | * with error instead of (rq size - 1) by Sinai FW 1.0.800 and |
550 | * Arbel FW 5.1.400. This bug should be fixed in later FW revs. | 550 | * Arbel FW 5.1.400. This bug should be fixed in later FW revs. |
551 | */ | 551 | */ |
552 | if (unlikely(wqe_index < 0)) | 552 | if (unlikely(wqe_index < 0)) |
553 | wqe_index = wq->max - 1; | 553 | wqe_index = wq->max - 1; |
554 | entry->wr_id = (*cur_qp)->wrid[wqe_index]; | 554 | entry->wr_id = (*cur_qp)->wrid[wqe_index]; |
diff --git a/drivers/infiniband/ulp/ipoib/ipoib_multicast.c b/drivers/infiniband/ulp/ipoib/ipoib_multicast.c index ec356ce7cdcd..60b09f5cb347 100644 --- a/drivers/infiniband/ulp/ipoib/ipoib_multicast.c +++ b/drivers/infiniband/ulp/ipoib/ipoib_multicast.c | |||
@@ -795,7 +795,7 @@ void ipoib_mcast_dev_flush(struct net_device *dev) | |||
795 | } | 795 | } |
796 | 796 | ||
797 | if (priv->broadcast) { | 797 | if (priv->broadcast) { |
798 | rb_erase(&priv->broadcast->rb_node, &priv->multicast_tree); | 798 | rb_erase(&priv->broadcast->rb_node, &priv->multicast_tree); |
799 | list_add_tail(&priv->broadcast->list, &remove_list); | 799 | list_add_tail(&priv->broadcast->list, &remove_list); |
800 | priv->broadcast = NULL; | 800 | priv->broadcast = NULL; |
801 | } | 801 | } |
diff --git a/drivers/infiniband/ulp/srp/ib_srp.c b/drivers/infiniband/ulp/srp/ib_srp.c index 249a98c06aeb..61c13d1e0506 100644 --- a/drivers/infiniband/ulp/srp/ib_srp.c +++ b/drivers/infiniband/ulp/srp/ib_srp.c | |||
@@ -330,7 +330,7 @@ static int srp_send_req(struct srp_target_port *target) | |||
330 | req->priv.req_buf_fmt = cpu_to_be16(SRP_BUF_FORMAT_DIRECT | | 330 | req->priv.req_buf_fmt = cpu_to_be16(SRP_BUF_FORMAT_DIRECT | |
331 | SRP_BUF_FORMAT_INDIRECT); | 331 | SRP_BUF_FORMAT_INDIRECT); |
332 | /* | 332 | /* |
333 | * In the published SRP specification (draft rev. 16a), the | 333 | * In the published SRP specification (draft rev. 16a), the |
334 | * port identifier format is 8 bytes of ID extension followed | 334 | * port identifier format is 8 bytes of ID extension followed |
335 | * by 8 bytes of GUID. Older drafts put the two halves in the | 335 | * by 8 bytes of GUID. Older drafts put the two halves in the |
336 | * opposite order, so that the GUID comes first. | 336 | * opposite order, so that the GUID comes first. |