Client-Server Computing on Shrimp

  • Authors:
  • Stefanos N. Damianakis;Angelos Bilas;Cezary Dubnicki;Edward W. Felten

  • Affiliations:
  • -;-;-;-

  • Venue:
  • IEEE Micro
  • Year:
  • 1997

Quantified Score

Hi-index 0.00

Visualization

Abstract

The SHRIMP project at Princeton University supports user-level communication between processes by mapping memory pages between virtual address spaces. This virtual memory-mapped network interface seems to have many advantages including flexible user-level communication, and very low overhead to initiate data transfers. In this work we examine two implementations of RPC and sockets for the SHRIMP multicomputer that deliver to user applications almost raw hardware performance. We achieve high performance by taking advantage of the features of the underlying SHRIMP architecture. SHRIMP provides low-latency, user-level communication, without imposing any buffer management semantics, and without requiring an interrupt for each message. This allows packages like our RPC and sockets libraries to customize their buffer management and control transfer strategies to optimize performance.