Show simple item record

dc.contributor.authorKohler, Eddieen_US
dc.contributor.authorChen, Benjieen_US
dc.contributor.authorKaashoek, M. Fransen_US
dc.contributor.authorMorris, Robert T.en_US
dc.contributor.authorPoletto, Massimilianoen_US
dc.date.accessioned2023-03-29T15:33:47Z
dc.date.available2023-03-29T15:33:47Z
dc.date.issued2000-08
dc.identifier.urihttps://hdl.handle.net/1721.1/149915
dc.description.abstractThis paper applies programming language techniques to a high-level system description, both to optimize the system and to prove useful properties about it. The system in question is Click, a modular software router framework. Click routers are built from components called elements. Elements are written in C++, but the user creates a configuration using a simple, declarative data flow language. This language is amenable to data flow analysis and other conventional programming language techniques. Applied to a router configuration, these techniques have high-level results---for example, optimizing the router or verifying its high-level properties. This paper describes several programming language techniques that have been useful in practice, including optimization tools that remove virtual function calls from router definitions and remove redundant parts of adjacent routers. We also present performance results for an extensively optimized standards-compliant IP router. On conventional PC hardware, this router can forward up to 456,000 64-byte packets per second.en_US
dc.relation.ispartofseriesMIT-LCS-TR-812
dc.titleProgramming Language Techniques for Modular Router Configurationsen_US


Files in this item

Thumbnail

This item appears in the following Collection(s)

Show simple item record