# Performance Evaluation of InfiniBand with PCI Express

Jiuxing Liu Amith Mamidala Abhinav Vishnu Dhabaleswar K Panda

Department of Computer and Science and Engineering The Ohio State University Columbus, OH 43210 {liuj, mamidala, vishnu, panda}@cse.ohio-state.edu

Abstract-In this paper, we present an initial performance evaluation of InfiniBand HCAs from Mellanox with PCI Express interfaces. We compare the performance with HCAs using PCI-X interfaces. Our results show that InfiniBand HCAs with PCI Express can achieve significant performance benefits. Compared with HCAs using 64 bit/133 MHz PCI-X interfaces, they can achieve 20%-30% lower latency for small messages. The small message latency achieved with PCI Express is around 3.8  $\mu$ s, compared with the 5.0  $\mu$ s with PCI-X. For large messages, HCAs with PCI Express using a single port can deliver unidirectional bandwidth up to 968 MB/s and bidirectional bandwidth up to 1916 MB/s, which are 1.24 and 2.02 times of the peak bandwidths achieved by HCAs with PCI-X, respectively. When both the ports of the HCAs are activated, HCAs with PCI Express can deliver a peak unidirectional bandwidth of 1486 MB/s and aggregate bidirectional bandwidth up to 2729 MB/s, which are 1.93 and 2.88 times of the peak bandwidths obtained using HCAs with PCI-X.

PCI Express also improves performance at the MPI level. A latency of 4.6  $\mu$ s with PCI Express is achieved for small messages. And for large messages, uni-directional bandwidth of 1497 MB/s and bi-directional bandwidth of 2724 MB/s are observed.

#### I. INTRODUCTION

InfiniBand Architecture [1] is an industry standard which offers low latency and high bandwidth as well as many advanced features such as Remote Direct Memory Access (RDMA), atomic operations, multicast and QoS. Currently, InfiniBand products in the market can achieve a latency of several microseconds for small messages and a bandwidth of up to 700-900 MB/s. (Note that the unit MB in this paper is an abbreviation for  $10^6$  bytes and GB is an abbreviation for  $10^9$  bytes.) As a result, it is becoming increasingly popular as a high speed interconnect technology for building high performance clusters.

PCI [2] has been the standard local I/O bus technology for the last ten years. However, currently more and more applications require lower latency and higher bandwidth than what a PCI bus can provide. As an extension to PCI, PCI-X offers higher performance and efficiency. However, it can still become a bottleneck for today's demanding applications, especially for those running over InfiniBand. For example, a 64 bit/133 MHz PCI-X bus can sustain around 1 GB/s aggregate bandwidth at most. However, current 4x InfiniBand HCAs have a peak bandwidth of 1 GB/s in each link direction, resulting in an aggregate bandwidth of 2 GB/s for each port. To make matters worse, some of these InfiniBand HCAs have two ports which can deliver up to 4 GB/s combined theoretical bandwidth. Even PCI-X with Double Data Rate (DDR) cannot fully take advantage of their performance potential. Another issue with PCI and PCI-X buses is that a bus can be shared with other I/O devices. Therefore, communication performance can be adversely impacted by I/O operations of other devices on the same bus.

Recently, PCI Express [3] has been introduced as the next generation local I/O interconnect. Unlike PCI, PCI Express uses a serial, point-to-point interface. Compared with PCI, PCI Express can achieve lower latency by allowing I/O devices to be connected directly to the memory controller. More importantly, it can deliver scalable bandwidth by using multiple lanes in each point-to-point link. For example, an 8x PCI Express link can achieve 2 GB/s bandwidth in each direction (4 GB/s total), which matches perfectly with the requirement of current InfiniBand HCAs.

In this work, we present an initial performance evaluation of the third generation InfiniBand HCAs from Mellanox, which support PCI Express interfaces. We compare the performance of these HCAs with HCAs using PCI-X interfaces. Our performance evaluation consists of a set of microbenchmarks at the interconnect level, including latency, bandwidth, and bidirectional bandwidth experiments. Performance results using both ports in the HCAs are presented. In addition, MPI level enhancement to use both ports and associated results are also presented.

Our performance evaluation shows that InfiniBand HCAs with PCI Express interfaces deliver excellent performance. Compared with HCAs using PCI-X, they can achieve 20%–30% lower latency for small messages. The smallest latency obtained is around 3.8  $\mu$ s. In contrast, HCAs with PCI-X can only achieve a latency of 5.0  $\mu$ s for small messages. By removing the PCI-X bottleneck, HCAs with PCI Express interfaces can deliver much higher bandwidth. In the bi-directional bandwidth tests, PCI Express can achieve a peak bandwidth of 1916 MB/s, which is almost twice the bandwidth delivered by PCI-X. In bandwidth tests that use both ports, HCAs with

PCI-X cannot achieve much performance gain due to local I/O bus being the performance bottleneck. However, PCI Express can achieve significant performance improvements. In one bi-directional bandwidth test, PCI Express HCAs have been shown to deliver a peak aggregate bandwidth of 2729 MB/s, which is 2.88 times the bandwidth achievable by PCI-X.

At the MPI level, PCI Express also shows excellent performance. For small messages, a latency of 4.6  $\mu$ s was observed. For large messages, uni-directional bandwidth of 1497 MB/s and bi-directional bandwidth of 2724 MB/s were observed.

The remaining part of the paper is organized as follows: In Section 2, we provide a brief overview of InfiniBand and PCI Express. In Section 3, we describe the architectures of InfiniBand HCAs. Performance evaluations and discussions are presented in Section 4. We present conclusions and discuss future work in in Section 5.

# II. BACKGROUND

In this section, we provide background information for our work. First, we provide a brief introduction of InfiniBand. Then, we introduce PCI Express architecture and compare it with existing PCI buses.

# A. InfiniBand

The InfiniBand Architecture (IBA) [1] defines a switched network fabric for interconnecting processing nodes and I/O nodes. It provides a communication and management infrastructure for inter-processor communication and I/O. In an InfiniBand network, processing nodes and I/O nodes are connected to the fabric by Channel Adapters (CA). The Host Channel Adapters (HCAs) sit on processing nodes.

The InfiniBand communication stack consists of different layers. The interface presented by Channel adapters to consumers belongs to the transport layer. A queue-based model is used in this interface. A Queue Pair in InfiniBand Architecture consists of two queues: a send queue and a receive queue. The send queue holds instructions to transmit data and the receive queue holds instructions that describe where received data is to be placed. Communication operations are described in Work Queue Requests (WQR), or descriptors, and submitted to the work queue. The completion of WQRs is reported through Completion Queues (CQs). Once a work queue element is finished, a completion queue entry is placed in the associated completion queue. Applications can check the completion queue to see if any work queue request has been finished. InfiniBand supports different classes of transport services. In this paper, we focus on the Reliable Connection (RC) service. InfiniBand Architecture supports both channel and memory semantics. In channel semantics, send/receive operations are used for communication. To receive a message, the programmer posts a receive descriptor which describes where the message should be put at the receiver side. At the sender side, the programmer initiates the send operation by posting a send descriptor. In memory semantics, InfiniBand supports Remote Direct Memory Access (RDMA) operations, including RDMA write and RDMA read. RDMA operations are one-sided and do not incur software overhead at the remote side. In these operations, the sender (initiator) starts RDMA by posting RDMA descriptors. At the sender side, the completion of an RDMA operation can be reported through CQs. The operation is transparent to the software layer at the receiver side. InfiniBand also supports atomic operations that can carry out certain read-modify-write operations to remote memory locations in an atomic manner.

# B. PCI Express

PCI [2] has been the standard local I/O bus technology for the last ten years. It uses a parallel bus at the physical layer and a load/store based software usage model. Since its introduction, both PCI bus frequency and bus width have been increased to satisfy the ever-increasing I/O demand of applications. Later, PCI-X [2] was introduced as an extension to PCI. PCI-X is backward compatible with PCI in terms of both hardware and software interfaces. It delivers higher I/O performance and efficiency compared with PCI.

Recently, PCI Express [3] technology was introduced as the next generation I/O interconnect. Unlike traditional I/O buses such as PCI, PCI Express uses a high performance, pointto-point, and serial interface. Although the physical layer is different, PCI Express maintains compatibility with PCI at the software layer and no changes are necessary for current operating systems and device drivers.

In PCI and PCI-X architectures, bus frequency and width are limited due to signal skews in the underlying parallel physical interface. Further, a bus is shared among all devices connected to it. Therefore, PCI and PCI-X have limited bandwidth scalability. To achieve scalability, PCI Express links can have multiple lanes, with each lane delivering 250 MB/s bandwidth in each direction. For example, an 8x (8 lanes in each link) PCI Express channel can achieve 2 GB/s bandwidth in each direction, resulting in an aggregate bandwidth of 4 GB/s. In comparison, a 64 bit/133 MHz PCI-X bus can only achieve around 1 GB/s bandwidth at most.

In PCI or PCI-X based systems, I/O devices are typically connected to the memory controller through an additional I/O bridge. In PCI Express based systems, I/O devices can be connected directly to the memory controller through PCI Express links. This can result in improved I/O performance. A comparison of these two approaches is shown in Figure 1.

# III. ARCHITECTURES OF INFINIBAND HCAS

In this work, we focus on performance studies of two kinds of InfiniBand HCAs from Mellanox Technologies: InfiniHost MT25208 HCAs [4] and InfiniHost MT23108 HCAs [5]. InfiniHost MT25208 HCAs are the third generation products from Mellanox which has 8x PCI Express host interfaces. InfiniHost MT23108 cards are the second generation Infini-Band HCAs from Mellanox. They have PCI-X 64 bit/133 MHz interfaces to connect to the host. Both MT25208 and MT23108 HCAs have two physical ports. Although the major difference between MT25208 and MT23108 HCAs is the host I/O interface, MT25208 HCAs also include other enhancements such



Fig. 1. Comparing PCI (PCI-X) with PCI Express

as improved internal caching and prefetching mechanisms and additional CPU offload capabilities [4]. In our experiments, firmware in MT25208 HCAs runs in a "compatibility mode" which essentially emulates the MT23108 HCAs and the new features are not activated.

We have used VAPI as the software interface for accessing InfiniHost HCAs. This interface is based on InfiniBand verbs layer. It supports both send/receive operations and remote direct memory access (RDMA) operations.

## **IV. PERFORMANCE**

In this section, we present performance evaluation of Mellanox InfiniHost MT25208 PCI Express HCAs. We compare their performance with MT23108 HCAs which use PCI-X 64 bit/133 MHz interfaces. Our evaluation consists of two parts. In the first part, we show performance results at the VAPI level. In the second part, we present MPI level performance.

#### A. Experimental Testbeds

Our experimental testbed is a four-node InfiniBand cluster. Each node of the cluster has a 3.4 GHz Intel Xeon processor and 512 MB main memory. The nodes support both 8x PCI Express and 64 bit/133 MHz interfaces and are equipped with both MT23108 and MT25208 HCAs. An InfiniScale switch is used to connect all the nodes. The operating system used were Linux with kernel 2.4.18.

## B. VAPI Level Performance

At the VAPI level, we first show latency results of Infini-Band send/receive, RDMA write, and RDMA read operations. We also measure the cost of InfiniBand atomic operations. Then we present bandwidth numbers for tests using a single HCA port. After that, we show the results of a set of experiments that use both HCA ports. GCC 3.2 were used to compile all the test programs.

1) Latency: In this subsection, we present latency results of various InfiniBand operations such as send/receive, RDMA write, RDMA read, and atomic operations between two processes on two different nodes. Experiments for send/receive and RDMA write were carried out in a ping-pong fashion. For send/receive operations, CQ is used to check incoming messages. For RDMA write, the receiver polls on the last byte of destination memory buffer to detect the completion of RDMA communication. In the RDMA read and atomic experiments, one process acts as the initiator and the other process acts as the target. The initiator process issues RDMA read and atomic operations to buffers in the address space of the target process and uses CQ to detect completion of these operations. In all the latency experiments, the test programs consists of multiple iterations. The first 1000 iterations are used for warm-up. The average times of the following 10,000 iterations are reported.

Figure 2 compares InfiniBand send/receive latency with PCI Express and PCI-X. (Note that in the x axis of the figures, unit K is an abbreviation for  $2^{10}$  and M is an abbreviation for  $2^{20}$ .) We can see that PCI Express has better performance. For small messages, PCI Express achieves a latency of 5.2  $\mu$ s while PCI-X achieves 7.1  $\mu$ s. Figure 3 shows the results for RDMA write operations. RDMA write has better performance than send/receive operations since they incur less overhead at the receiver side. We can see that with PCI Express, we can achieve a latency of 3.8  $\mu$ s. The smallest latency for PCI-X is 5.0  $\mu$ s. Figure 4 shows the latency performance for RDMA read operations. With PCI Express, a latency of 9.4  $\mu$ s is achieved for small messages. Latencies are around 12.3  $\mu$ s with PCI-X for small messages. Figure 5 compares latency performance of InfiniBand atomic operations (Fetch-and-Add and Compare-and-Swap). The results are similar to RDMA read for small messages. Overall, we can see that HCAs using PCI Express can improve latency performance by 20%–30% for small messages.

2) Single Port Bandwidth: In this subsection we focus on bandwidth performance of InfiniBand RDMA write operations. Only one port of each HCA is used in all the tests. Results of bandwidth experiments using both ports are included in the next subsection.

A pre-defined window size W is used in all the bandwidth tests. In each test, the sender will issue W back-to-back messages to the receiver. The receiver waits for all W messages and then sends back a small reply message. Multiple iterations of the above procedure are carried out in the experiments. We have used a window size of 64 in our tests. The first 10 iterations of the tests are used for warm-up and the average bandwidths of the following 100 iterations are reported.

Figure 6 shows uni-directional bandwidth performance results. We can see that PCI Express HCAs perform better than PCI-X for all messages sizes. For large messages, PCI Express delivers a bandwidth of 968 MB/s. Compared with PCI-X which has a bandwidth of 778 MB/s for large messages, PCI Express improves performance by around 24%.

Figure 7 shows the results of bi-directional bandwidth tests.

HCAs with PCI-X achieve a peak aggregate bandwidth of 946 MB/s, which is only slightly higher (21%) than the unidirectional bandwidth (778 MB/s). This is mostly due to the limitation of PCI-X bus. In contract, PCI Express achieves a peak bi-directional bandwidth of 1916 MB/s, which almost doubles its uni-directional bandwidth.



Fig. 4. RDMA Read Latency

3) Multiple Ports Bandwidth: Current Mellanox InfiniBand HCAs have two physical ports. Each port can (in theory) offer 2 GB/s bi-directional bandwidth. However, the PCI-X bus can only achieve around 1 GB/s peak bandwidth. As a result, PCI-X becomes the performance bottleneck if both ports are used. However, 8x PCI Express offers 4 GB/s theoretical bidirectional bandwidth. Therefore, both ports can be used to achieve higher performance.



We have designed a set of microbenchmarks that use both ports of the HCAs and study their benefits. We have considered two cases to take advantage of multiple HCA ports: striping and binding. In the striping mode, each message is divided into even pieces and transferred simultaneously using multiple ports. A striping threshold of 8192 bytes is used which means that messages smaller than or equal to 8192 bytes are not striped. In the binding mode, messages are not striped. However, communication channels (send channel and receive channel) of different processes in a node will use different ports of the HCA. In the striping mode, the communication is not finished until all stripes arrive at the receiver side. To notify the receiver, we send extra control messages using send/receiver operations through all the ports after sending each stripe. The receiver then polls the CQ to detect the completion of communication.

Figure 8 shows uni-directional bandwidth performance results using both HCA ports. Only striping mode is used in this test. We can see that PCI Express performs significantly better than PCI-X. HCAs with PCI Express can deliver a peak bandwidth of 1486 MB/s. With PCI-X, we can only achieve around 768 MB/s because of the PCI-X bottleneck. This number is even lower than the peak bandwidth without striping, due to the overhead of dividing and reassembling messages.

In Figure 9, we show the performance of bi-directional bandwidth tests using both ports. In the striping mode, each messages (larger than 8192 bytes) are striped and transferred using both ports. In the binding mode, the process on the first node uses port 1 to send data and uses port 2 to receive data from the process on the second node. Still we can see that PCI Express performs much better than PCI-X. We also notice that striping mode performs better than binding mode in this test for large messages. With striping, PCI Express can achieve a peak bandwidth of 2370 MB/s. The peak performs better than binding is 1936 MB/s. The reason why striping performs better than binding in the bi-directional bandwidth test is that striping can utilize both ports in both directions while binding only uses one direction in each port.

In another set of tests, we have used two processes on each node with each process doing inter-node communication with another process on the other node. Both striping and binding tests have been carried out. In the binding mode, each process on the same node uses different ports for sending and receiving.

Figure 10 shows the aggregate bandwidth of two processes in the uni-directional bandwidth tests. We can see that with PCI Express, both striping and binding modes can achieve a peak bandwidth of around 1500 MB/s. The binding mode performs better than the striping mode, especially for messages smaller than 8 KB. There are two reasons for this. First, the binding mode has less overhead because it does not divide messages. Second, for small messages (less than 8 KB), both ports can be used, while the striping mode only uses one port. With PCI-X, only 772 MB/s can be achieved due to PCI-X bandwidth being the bottleneck.

In Figure 11, we show similar results for the bi-directional cases. With PCI-X, peak bandwidth is limited to around 946 MB/s. PCI Express can achieve much higher aggregate bandwidth. In the binding mode, peak bandwidth is 2729 MB/s, which is 2.88 times the bandwidth achieved by PCI-X. Due to its higher overhead, the striping mode performs a little worse than the binding mode. But it can still deliver a peak bandwidth of 2338 MB/s.



Fig. 7. Bi-Directional Bandwidth

## C. MPI Level Performance

In this section we present latency and bandwidth results using our enhanced MPI implementation over InfiniBand (MVAPICH) [6], [7]. Our original MVAPICH software only uses one port of each HCA. To improve its performance for PCI Express systems, we have developed an MPI implementation which can stripe large messages across both ports. In



Fig. 8. Uni-Directional Bandwidth (Two Ports)



Fig. 9. Bi-Directional Bandwidth (Two Ports)



Fig. 10. Uni-Directional Bandwidth (Two Processes)



Fig. 11. Bi-Directional Bandwidth (Two Processes)

this implementation, message striping and reassembling are handled completely in the MPI layer and transparent to user applications. Details of this implementation can be found in [8].

Our MPI level evaluation consists of a set of microbenchmarks. For compiling tests, we have used GCC 3.2 compiler.

Figure 12 shows MPI latency results for small messages. We can observe that HCAs with PCI Express can improve performance by over 20%. With PCI Express, we can achieve a latency of around 4.6  $\mu$ s for small messages. In comparison, PCI-X delivers a latency of 5.9  $\mu$ s for small messages. Since small messages are not striped in our new implementation, it performs comparable to the old implementation for PCI Express.



Figure 13 shows the performance results for the unidirectional bandwidth tests at the MPI level. Our original MPI implementation can achieve a peak bandwidth of 969 MB/s for PCI Express. It delivers around 800 MB/s peak bandwidth for PCI-X. With our new MPI implementation that stripes data across both ports, we can achieve a peak bandwidth of 1497 MB/s, which is 75% better than the one port implementation with PCI-X and 55% better than the one port implementation with PCI Express The performance drop at around 8 KB in the figures is because of both protocol switch in MPI and our striping threshold.

Figure 14 shows MPI bi-directional bandwidth performance results. We can see that PCI-X can only achieve a peak bandwidth of 943 MB/s. With PCI Express, we can achieve a bandwidth of 1911 MB/s for large messages. By using both ports of PCI Express HCAs, we are able to get 2724 MB/s, which is around 2.8 times the bandwidth we can achieve with PCI-X.

We have noticed that in some cases, MPI level bandwidth is higher than the VAPI level bandwidth. One reason for this could be that in the VAPI tests, we have used send/receive operations to send control and synchronization messages while our MPI implementation is based on RDMA operations, which have higher performance. We are currently investigating this issue.



# V. RELATED WORK

Studies on the performance of high performance interconnects including InfiniBand, Myrinet, Quadrics, and 10 gigabit ethernet have been carried out in the literature [9], [10], [11], [12]. Our previous work [13], [14] proposed test suites to compare performance of different VIA [15] and Infini-Band implementations. We have also conducted performance evaluation of different high speed interconnects at the MPI level [16]. In this paper, we focus on the interaction between InfiniBand Architecture and local I/O bus technologies. Our objective is to study how PCI Express can help us achieve better communication performance in an InfiniBand cluster.

## VI. CONCLUSIONS AND FUTURE WORK

In this work, we have conducted a performance study of Mellanox InfiniBand HCAs with PCI Express interfaces. We have used microbenchmarks at the interconnect level and the MPI level for our performance evaluation. Our results show that PCI Express can greatly improve the communication performance of InfiniBand. Compared with HCAs with PCI-X 64 bit/133 MHz interfaces, HCAs with PCI Express can improve small message latency by 20%–30%. For large messages, HCAs with PCI Express can achieve up to 2.88 times the bandwidth compared with PCI-X.

In future, we plan to continue our evaluation of PCI Express technology by using more application level benchmarks and large scale systems. In this paper, we have shown that we can achieve much higher bandwidth at the MPI level by utilizing both ports of the HCAs. We are currently working on enhancing our MPI implementation to efficiently support different ways of transferring messages through multiple HCA ports as well as multiple HCAs for both point-to-point and collective communication.

## Acknowledgments

This research is supported in part by Department of Energy's Grant #DE-FC02-01ER25506 and National Science Foundation's grants #CNS-0204429 and #CCR-0311542.

#### REFERENCES

- Infi niBand Trade Association, "Infi niBand Architecture Specifi cation, Release 1.1," http://www.infi nibandta.org, November 2002.
- [2] PCI-SIG, "PCI and PCI-X," http://www.pcisig.com.
- [3] PCI-SIG, "PCI Express Architecture," http://www.pcisig.com.
- [4] Mellanox Technologies, "Mellanox InfiniBand InfiniHost III Ex MT25208 Adapters," http://www.mellanox.com, February 2004.
- [5] Mellanox Technologies, "Mellanox Infi niBand Infi niHost MT23108 Adapters," http://www.mellanox.com, July 2002.
- [6] Network-Based Computing Laboratory, "MVAPICH: MPI for Infi ni-Band on VAPI Layer," http://nowlab.cis.ohio-state.edu/projects/mpiiba/index.html, January 2003.
- [7] J. Liu, J. Wu, S. P. Kini, P. Wyckoff, and D. K. Panda, "High Performance RDMA-Based MPI Implementation over Infi niBand," in *17th Annual ACM International Conference on Supercomputing (ICS* '03), June 2003.
- [8] J. Liu, A. Vishnu, and D. K. Panda, "Building Multirail InfiniBand Clusters: MPI-Level Design and Performance Evaluation," in *SuperComputing 2004 (SC '04)*, November 2004, to be presented.

- [9] C. Bell, D. Bonachea, Y. Cote, J. Duell, P. Hargrove, P. Husbands, C. Iancu, M. Welcome, and K. Yelick, "An evaluation of current high-performance networks," in *International Parallel and Distributed Processing Symposium (IPDPS'03)*, April 2003.
- [10] F. Petrini, W. Feng, A. Hoisie, S. Coll, and E. Frachtenberg, "The Quadrics Network: High-Performance Clustering Technology," *IEEE Micro*, vol. 22, no. 1, pp. 46–57, 2002.
- [11] J. Liu, B. Chandrasekaran, W. Yu, J. Wu, D. Buntinas, S. P. Kinis, P. Wyckoff, and D. K. Pand, "Micro-Benchmark Level Performance Comparison of High-Speed Cluster Interconnects," *IEEE Micro*, vol. 24, no. 1, pp. 42–51, January-February 2004.
- [12] J. Hurwitz and W. Feng, "End-to-End Performance of 10-Gigabit Ethernet on Commodity Systems," *IEEE Micro*, vol. 24, no. 1, pp. 10– 22, 2004.
- [13] M. Banikazemi, J. Liu, S. Kutlug, A. Ramakrishna, P. Sadayappan, H. Shah, and D. K. Panda, "VIBe: A Micro-benchmark Suite for Evaluating Virtual Interface Architecture (VIA) Implementations," in *Int'l Parallel and Distributed Processing Symposium (IPDPS '01)*, April 2001.
- [14] B. Chandrasekaran, P. Wyckoff, and D. K. Panda, "A micro-benchmark suite for evaluating InfiniBand architecture implementations," in *Performance TOOLS 2003 (part of the 2003 Illinois International Multiconference on Measurement, Modeling, and Evaluation of Computer-Communication Systems)*, Sept. 2003.
- [15] D. Dunning, G. Regnier, G. McAlpine, D. Cameron, B. Shubert, F. Berry, A. Merritt, E. Gronke, and C. Dodd, "The Virtual Interface Architecture," *IEEE Micro*, pp. 66–76, March/April 1998.
- [16] J. Liu, B. Chandrasekaran, J. Wu, W. Jiang, S. Kini, W. Yu, D. Buntinas, P. Wyckoff, and D. K. Panda, "Performance Comparison of MPI Implementations over Infi niBand, Myrinet and Quadrics," in *SuperComputing* 2003 (SC '03), November 2003.