University of Wollongong

Research Online
Faculty of Informatics - Papers (Archive)

Faculty of Engineering and Information
Sciences

2002

An architecture for carrier grade programmable networks
T. V. Nguyen
University of Wollongong

P. Boustead
University of Wollongong, boustead@uow.edu.au

Farzad Safaei
University of Wollongong, farzad@uow.edu.au

Follow this and additional works at: https://ro.uow.edu.au/infopapers
Part of the Physical Sciences and Mathematics Commons

Recommended Citation
Nguyen, T. V.; Boustead, P.; and Safaei, Farzad: An architecture for carrier grade programmable networks
2002.
https://ro.uow.edu.au/infopapers/187

Research Online is the open access institutional repository for the University of Wollongong. For further information
contact the UOW Library: research-pubs@uow.edu.au

An architecture for carrier grade programmable networks
Abstract
Active and programmable networks allow innovative new services to be deployed rapidly. However, in a
carrier grade network, it is imperative to maintain a scalable fast path mechanism so that the delay and
throughput requirements are met. This is particularly important since, in many cases, network-level
processing is only needed for a subset of packets and the remainder of traffic must be forwarded on the
fast path. It is a challenge to design a cost effective node architecture that can satisfy this requirement.
Current models are often 'revolutionary' and may not scale to the required performance levels of a carrier
grade network. We develop an evolutionary architecture that uses MPLS label stacks to enable efficient
and scalable extraction of active packets from the fast path without penalising the rest of the traffic. Our
model can be used to extend the reach of programmable networks over a legacy infrastructure and
provide a migratory path for existing carriers towards a programmable infrastructure.

Disciplines
Physical Sciences and Mathematics

Publication Details
This article was originally published as: Nguyen, TV, Boustead P & Safaei, F, An architecture for carrier
grade programmable networks, GLOBECOM '02 IEEE Global Telecommunications Conference, 17-21
November 2002, vol 2, 2016-2020. Copyright IEEE 2002.

This conference paper is available at Research Online: https://ro.uow.edu.au/infopapers/187

An Architecture for Carrier Grade Programmable Networks
Thanh Vinh Nguyen, Paul Boustead, Farzad Safaei
Telecommunications and Information Technology Research lnrtnfute
Univcmity of Wollongong. Aurhdia
email: {vinh,paui)@titruowedu.au: f-d@uw.sdu.au

Absamr-Active and programmable network allow innovative new se,vices tm bo deployed rapidly. However, in a carrier grade network, il is imperative to maintain a sealable fast path mechanism 30 Ihat the delay and
throughput requimmcntl arc mrt. This is p m t i d s r l y important since in
many c a m ~itwork-IweIpmrrrsing is only needed for P subset of packets
and the remainder of trilItic must he forwarded on the fast path. It is I
challenge to design I e011 effective nodr archilectum that can ralirty this
reqniremcnl. Currenl models are often ‘malutionary’ and may no1 scnlc
to the required performance IeveIs of P carrier grade network In this paper we develop an evolutionary architecture that uses MPLS label stack lo
enable efficient and ncalablr extraction Of active packets from the fast path
without penaliring tho rest of the traffic. Our model can he u r d to extend the reach of programmable network Over legacy infrastructure and
provide a migratoly path for existing carriers towards a programmable
1nfnsfr”eture.

1. INTRODUCTION

:

Programmable, or active[, networking has been widely promoted as a future solution for fast and easy deployment of new
innovative services over the Internet. The vision is that by offering programmability at network nodes customised code can be
injected into the network to enable service provisioning without going through any standardisation process. Since research
in this area was initiated a few years ago, there bas been much
research effort, resulting in a large amount of published literature ([I], [2], [3], [4] and references therein). However, we
believe that even with the current state of the art, introducing programmability in carrier networks without significantly
changing existing high-speed packet forwarding mechanisms is
still a challenge that has not been totally addressed.
The challenge in carrier-grade programmable networking is to
achieve scalability while having enough flexibility to support
a wide range of services. In this environment, there is little
processing time available for each packet, which places a constraint on the amount of processing that can be performed. The
bottle neck is expected to persist in the foreseeable future, since
currently transmission speed is growing at 200% per year,outpacing the growth of processing power, which still keeps up
with the Moore’s law [SI. This is the reason why ‘revolutionary’ software-based active router models such as ANTS [I],
which requires processing for every packet, are not suitable [6].
There have been more practical approaches, such as the Tempest [7], which aims at a less flexible architecture by introducing programmability only in the node’s control plane. Tempest,
therefore, only supports applications that does not require data
plane programmability. Section V will briefly review existing
related architectures.
In this paper we propose an architecture that we believe is practical and suitahle for the carrier grade environment. This architecture is designed for Multi-Protocol Label Switching (MPLS)
‘In this papcr.w c u x t h s t c m ‘prog”ab1c’

0-7803-7632-3/02/517.00 02002 IEEE

and ‘active’ interchangeably

2016

networks - an increasingly popular carrier-grade networking
platform. Utilising MPLS traffic engineering capabilities, we
have developed an architecture that is scalable, flexible enough
to support a wide spectrum of applications and is ‘evolutionary’, i.e. allowing carrier-grade programmable networking in
the nearfilure using legacy equipment.
The rest of the paper is organised as follows: Section I1 will
specify the requirements of a carrier-grade programmable network architecture, Section 111 will describe the proposed architecture and the advantages ensued, Section IV will describe the
current development and implementation status of the architecture, and illustrate the architecture’s feasibility through an example application scenario. Related literature will be discussed
in Section V and we will conclude in Section VI
11. PROGRAMMABLENETWORKING
IN A CARRIER-GRADE

ENVIRONMENT
A key characteristic of the carrier network environment is extremely high transmission speed, typically in the order of tens
of gigabits per second. Coupled with a mismatch in growth
of transmission speed and processing power, such environment
does not allow a practical architecture to afford active processing for every packet.
Fortunately, our observation is that in practice there is a large
class of applications that require network-based processing for
only a subset of packets, for example fault detection and recovery, performance monitoring or customised routing. In such
applications the active packets are used for control purpose,
while the remaining are data packets. Though there are applications that require processing for 100% of packets, such as encryption or content adaptation, they can only comprise a small
pomon of traffic since the predominant function of networks
is transport. We therefore believe it is practical and desirable
to develop an architecture that exploits this trait to maintain a
fast data path and support selective processing for a portion of
traffic. Processing intensive applications can also be supported
but to a lesser degree, e.g. not at every network node but at
special-purpose processor farms (nodes with very high processing power) deployed inside the network.
Having relaxed the processing requirements to a subset of packets, it is imperative to have an efficient and robust mechanism
for identifying and extracting active packets from the data path.
The challenge lies in the fact that such process may impose extra overhead on other non-active packets. Furthermore, a packet
may even be active at some nodes and follow the fast path at
others. Current approaches, e.g. those described in [SI and [9],
are usually based on filtering to extract active packets. Active
packets are generally selected according to (a combination 00
header information, such as IP addresses and TCPKJDP port

Active Rossrsai

.

Fig. 1. Active node architecture

1

numbers. A drawback is filtering may affect every packet.
The data path, while having high performance, needs to be flexible enough so that it can be affected by (the processing 00active packets. The ability to accommodate active packets in a
portion of traffic will only be useful if active packets are able to
affect what happens in the fast path. This is required to allow
applications with customised routing and forwarding mechanisms to be deployed with only a few active packets per flow.
Finally, to make camer-grade programmable networking possible in the near future, an evolutionary approach with a clear
migration path from current networks is vital. In particular, it is
important to ensure that the architecture will be able to integrate
with legacy non-active networks and non active packet flows.
In summary, the following is desired
1. Flexiblefast path: Non-active packets must be forwarded
on a fast path, which has minimal extra overhead and can be
influenced by active applications.
2. Robust activepacket idenhficntion and exIradon: An active
packet should only be processed where necessary. Othenvise it
should be forwarded on the fast path and not incur any additional penalty.
3. Processing intensive application support: To support these
applications with processor farms a mechanism to divert traffic
there seamlessly when necessary is needed.
4. A clear migration path.

:

.

. .........
'-.,*""~"~P"

... ....

:.:

.

Fig. 2. Active and non-aclive label switched paths

behaviour, e.g. updating the MPLS switch's label mappings.
The active processor has an MPLS abstraction layer that acts as
a middleware between the MPLS fast path and the processor's
execution environments (EE). This layer provides fast path information to the EEs andior polices their actions on the switch.
This node architecture allows programmable nodes to be constructed from legacy equipment by adding adjunct processors
to high-speed MPLS switches.

E . Using MPLS Label Stack for Packet Forwarding

The architecture defines two m e s of LSPs: active and nonactive. An active LSP starts andlor ends at active processors,
but may go through the fast path of intermediate nodes. Note
that active LSPs terminate at active processors to enable delivery of active packets to the processors and do not necessarily
mean active packets will stop there. In fact, packets can be
recycled back to the switch through the input port for further
transmission. A non-active LSP carries only non-active packets
(i.e. it goes through the fast path of the nodes it traverses).
Figure 2 shows an example ofthree active nodes connecting by
LSPs A, B, COto CS, D, S and Z. By our definitions, LSPs CO
Ill. AN MPLS-BASEDCARRIER-GRADE
PROGRAMMABLE to C3, B and D are active. It is important to note that packets
NETWORK ARCHITECTURE
on LSP D are "active" in node 1 and node 3 and "non-active"
in node 2. LSP S is a path for diverting traffic from node 1 to a
A. Node Architechwe
processor farm, and LSP Z represents an alternative path from
In our architecture, each programmable node has two main node 1 to node 3. LSP A is non-active; it is a multipoint-tocomponents - a fast path and an active processor. The fast path point LSP since packets from immediate active processors are
is an MPLS switch. An active processor is connected to an out- able to join the flow, which aims to reduce the total number of
put port and an input port of the switch (Figure I), or may be LSPs required.
integrated in future generation switches, to provide processing We will now describe the architecture's capabilities and underpower. If a packet is to be processed at a node, it will be placed lying mechanisms using examples based on this network. The
on a label switched path (LSP) that goes to the active proces- letters (A, B, CO...) are used to represent labels on these LSPs,
sor at that node. Otherwise it is forwarded directly through the but the actual label values will be different on each link due to
switching fabric on a separate LSP."Therefore, at each node, MPLS label swapping.
Active packet seleetive delivery: By using the appropriate
each packet will require only one label look-up, regardless of it
being active or non-active and the fast path does not experience label stack to forward an active packet along a suitable LSP,
any extra overhead due to the presence of active packets.
a packet can be delivered to active processors only at selected
The active processor is also connected to the switch manage- nodes, while bypassing processing at others.
ment port, A flexible fast path is achieved by allowing the ac- As an example, consider Packet 1 in Figure 2.11 arrives at
tive processor control the switch through this interface. Active Node 1 with label Co and is delivered to the active processor.
applications residing in the processor thus can alter fast path The active application in Node 1 then may swap the current la-

.

2017

bel for C1 to enable further processing in Node 2, D to enable
processing at Node 3 but not Node 2, or A to forward the packet
on along the fast path.
It is also possible for the ingress to manipulate label stacks
and decide where packets should be processed. An example is
Packet 2 in the same figure. This packet arrives at Node 1 with
labels COand A. After processing in Node 1’s active processor,
the top label (CO)is popped and the packets is forwarded using
the second label (A). It now follows the fast path for the rest of
the route. Packet 3, on the other hand, needs processing at both
Node I and 2, and is thus labelled with CO,C1 and A. The top
two labels will cause the packet to be processed at both Nodes 1
and 2 as required. After that it will also follow the fast path.
The selection of processing locations depends on two factors
- specific application requirements and available processing
power at nodes. The ability to perform active processing at pinpoint selective locations is important in making the architecture
scalable, since it allows efficient use of this limited resource.
Influencing the fast path: The following example demonstrates why active processors are required to be able to affect
fast path behaviours. Consider a packet flow in LSP “A” (e.g.
Packet 4). normally such packets are forwarded along fast path
LSP A from Node I to Node 3. Suppose that a monitoring application in Node I decides that the flow needs to be diverted
to the alternative path (e.g. due to a link failure or congestion), it can request the active processor to modify the switch’s
MPLS table so that an incoming packet with label A has its label swapped with the correct label for this LSP at the end of
the alternative path and Z is then pushed onto the stack. Such
packets are now transmitted to Node 3 via the alternative route.
LSP Z can either be pre-setup or created on demand.
Such flexibility is achieved by allowing the active processor to
access the switch management port and alter switch setings(
e.g. MPLS mapping table or QoS settings). This enables support for applications that have some active packets controlling
the forwarding of the remaining traffic, such as applicationspecific routing or failure recovery.
Incorporating processor farms: The range of applications
supported by the architechlre can be broadened to include those
requiring intensive processing by deploying processor farms inside the network. Utilising the traffic diversion ability described
above, processor-intensive traffic can be seamlessly diverted to
processor farms and back.
As an example, imagine the flaw in LSP CO in the network
above belongs to such application, e.g. encryption or multimedia transcoding. If a processor farm is needed to meet processing requirement for this application, an LSP (LSP S) is created
to connect Node I to that processor farm, and then the fast path
label mappings are modified so that label S is pushed onto all
the packets in the flow. The flow will now get diverted to the
processor farm for processing, then come back for further forwarding.
Packet labelling options: The use of LSPs and label stacks
in the mechanisms described above makes an important assumptions on the edge (of the carrier network) node’s capability
-it must be able to classify incoming packets and add the ap-

2018

propriate labels so that packets are placed on the suitable LSPs.
Our solution is to use either an active node at the edge or a
content switch that is capable of filtering packets based on a
combination of Layer 2 to 1 headers. In effect, instead of classifying packets at each node such as in [8], we have pushed the
requirement to the network edge. The reason i s the traffic load
at such locations are expected to be less than in the core.
Creating LSPs: We may need to develop new methods to
create active and non-active LSPs requried for an application.
A solution i s for the first active packet in the stream to negotiate which active processors to be used on the route and create
the LSPs “on the fly” between them. This packet would follow
pre-setup LSPs between the processors - CO, CI, C2, and Cs
in the above example. It examines capabilities of each node,
determines what operation i s to be performed in that node and
configures LSPs for the remaining packets. The result will be
creation of LSPs that bypass active processing in some nodes
and obtain active processing in others. LSPs may also be created on demand by an active application, such as LSP S in the
previous example. The ability of active applications to modify
the MPLS switch settings would facilitate such operations.

Iv.

DEVELOPMENT AND IMPLEMENTATION

A . Development direction
Our aim is to continue developing this architecture as a platform for integrating multiple services using the programmable
virtual network (PVN) concept. A PVN is an overlay topology
of virtual nodes and links created over a physical programmable
network infrastructure. It is envisioned to be commonly offered as generic service by a network provider to customers
that might be service providers themselves. Service providers
(or PVN owners) will lease a virtual network topology from the
network provider (or PVN provider) that includes both transmission and processing resources. The aim is to provide a customer with a virtual network which is also programmable and
can be adapted to its business and operational requirements. For
example, each service provider may instantiate its own routing protocol, billing, accounting, management, and custom services independently and securely.
We see this as a desirable development due to number of reasons. Firstly, it will be an efficient and convenient means of hiring and managing network resources (bandwidth, label space,
storage and computation power) between network owners and
service providers, which is particularly desirable in a carrier
network environment. Secondly, the PVN is well suited to
our programmable architectye since it is an application for
which there is only a small percentage of active packets (service
provider’s traffic) and the majoriv of packets (end users’ traffic) follow the fast path. Furthermore, the use of MPLS LSPs
in OUT architecture will provide a convenient means of isolating
and managing traffic in different PVNs.
Although similar concepts have been discussed in the literature ([7], [IO] and [ I l l ) , our goal is a complete architecture
that can support a large range of applications and fully address
research issues including scalability, migratory path, multiple
network spanning (PVN peering), quick PVN provisioning.

network content switches are not required since the edge nodes
in C and D are programmable and can place packets onto the
appropriate LSPs.
For processing intensive work that can not be supported by the
active processors, processor farms may be needed. We assume
that the router in network “A“ wishes to multicast multimedia
packets to nodes in “c” and “D.Thesepackets are extracted
by the content switch in node 1 and placed on an LSP destined
for node 2. At node 2 they are forwarded by a custom multicast protocol to networks “ D and “c”. Suppose the virtual
router in node 2 determines that the multicast branch destined
for network “ Drequires a high level of processing (e.g. addition of localised advertising). If there is insufficient processing
power in node 2, the label for a LSP linking a nearby processor
farm (PF) is pushed onto the stack for all packets in this media
stream to divert them to that node. The processing intensive
work is performed in.the processor fann and then packets are
returned to the node 2 to be forwarded on to the destination.

Fig. 3. Application scsnano

B. A n Applicalion Scenario

This section will demonstrate how the architecture will enable deployment of useful services in a network consisting of
legacy equipment though an example application.
In this example a fictitious Singapore company “Singvideo” is
providing a video chat room service in Singapore that scales to a
large number of members cost-effectively.As sume that the service implements a multimedia multicast mechanism and supports features like transcoding and addition of local or targeted
advertising. The service is being extended to Australia using an
Australian carrier. Requirements include network reach to cnstomer bases in several Australia metropolitan areas, the ability
to deploy proprietary multicasting and billing protocols, multimedia processing capabilities.
Figure 3 summarizes the scenario. Network “A” in Singapore
is designed and implemented (using specialised hardware) to
support Singvideo’s proprietary service. The new Australian
customer bases are networks “c” and “ D . Service from an
Australian carrier (network “B”) is used to enable Singvideo
to extend their network to the new customers without installing
their own hardware.
In order to support the service over the Australian camer grade
network, active processors are connected to several legacy
MPLS switches: the one peering the Singapore network, and
some located in networks C and D.Suppose that for efficient
multicast, a processor is also added to a switch within the core
of the carrier network to support an intermediate node between
Sydney and Perth. A virtual topology (a PVN) is created over
these nodes to provide the necessary network reach. Resources
at these nodes (computation, storage, label space) are allocated
to Singvideo in the form of “virtual nodes’’. LSPs similar to
example in Figure 2 are created to Connect these nodes. Customised protocols are deployed in the processors to process protocol messages forwarded using active LSPs.
Since “A”is a proprietary network a content switch is placed at
the edge ronter of the Australian carrier grade network. It uses
filters to extract packets belonging to the “Singvideo” PVN and
push the appropriate MPLS labels onto the stack to forward
them on suitable LSPs. In the remainder of the camer grade

2019

C. Tesl Bed

We have implemented a testbed over which we demonstrated
the feasibility of our camer-grade programmable network architecture and the PVN concept. In our testbed each active node
is constructed from an emulated MPLS switch, based on the
Cambridge University NetX‘ MPLS implementation on Linux
kemel, connected to an active processor. We created a management interface for the MPLS switch which is similar to a basic
Cisco 10s management interface and is accessible to the active
processor. The testbed currently has 5 active nodes and is being extended to contain a commercial grade Cisco 7200 MPLS
switch.
We have demonstrated the key mechanisms including active
packet identification and extraction, using active packets to create label switched paths (LSPs) or change existing label mappings. We have also successfully created multiple PVNs running different routing protocols. We achieved this by maintaining separate routing databases and tables for each PVN in the
active processor. However, since fonvarding in the data path
uses the MPLS switch’s table, these per-PVN tables are merged
into the common routing table via the management interface.
v. RELATEDWORK
A . Software-based Architectures

A number of prominent pioneering activene twork architectllres are ANTS [I] developed at Massachusetts lnstitute
of Technology, Switchware [3] developed at the University
of Pennsylvania, Genesis kernel [I21 and Netscript [2] at
Columbia University.
These early works share a common characteristic: they are
all software based models that consider the network as a distributed computer and active nodes as general purpose processors, and which require active processing for every packets. Although such design allows maximum flexibility, the resulting
overhead adversely affects their performance and scalability. In
2htm://wwwcl.cam.ac.~~kiRcsearch/SRGincfos~

comparison, our approach of using MPLS label stacking has
removed the overhead required for active packet extraction.

B. Scoloble Active Node Architectures
The Active Network Node (ANN) 1131, and similarly work
in 1141, proposed architectures that have multiple extensible
processing engines plugged into a high speed backbone to provide processing power. Issues dealt with were mainly at node
level and focused on computation resource management.
Works in 1151, [I61 and [8] introduced active networking
into Nortel Networks' commercial-grade multi-gigabit Passport routers using Openet technology. In these devices the forwarding plane is implemented using ASlCs while the control
plane is CPU-based and contains an embedded Java virtual machine (JVM). Services are deployed in the programmable control plane in form of applets running inside the JVM. Incoming
packets are classified using combinations of hardware filters to
identify flows or to distinguish active and non-active packets.
Although the approach has the advantage of having high performance, the use of customised hardware filters are essential.

advantages:
I . Scalability: achieved through a fast data path, an efficient
means of active packet identification and delivery and moving
packet classification to network edge.
2. Flexibility: although most applications are expected to have
a few active packets, those requiring heavy processing can still
be supported by incorporating processor farms, without compromising scalability.
3. Migratory path: gradual deployment of processing capability and expansion of active network applications over a
legacy infrastructure is possible.
VII. AKNOWLEDGEMENT
The support of the Cooperative Research Centre for Smart
Intemet Technology (http:liwww.smartintemet.com.au>for this
work is hereby acknowledged.

C. Progrommoble Artuol Network

REFERENCES
[I] D. Wetherall, J. Gunag. and D. Tennenhourc. A m network services

D. Alaander, W. Arbaigh, M. Hicks, P. Kakkar,A. Kmmyiis. 1. Moore,
C. Gander, S.Nsnles. and J. Smit. The switchactive network architCcNre. IEEE N e w w k . MaviJunc 1998.
[4] David L. Tennenhoure,'Jo&han M. Smith, W. David Sincorkie, David 1.
Wsthsmll, and Gary 1. Minden. A survey of active network research.
IEEE Communications Mogonne, 3S( 1):8&86, 1997.
[5] Wcmcr Bux, Wolfgang Denrcl, Tan Engbersen, and Ronald Luijtsn.
Technologies and building block for fast packet forwarding. IEEE Commuaicariom Magazine, 39(1):7&77, January 2001.
~ a capsule[6] David W. Active network virion and reality: l e ~ s i o nform
bared system. In Symposrum on Operating Systems Principles, pages
64-79.1999.
(71 S. Roonw. J. E. van der M m c . S. A. Crasbv. and 1. M. Leslie. The
tcmpen. a fnmovnrk far wfc. ~ C I O Y ~ aimed.
~ C
p r u p " x h l c ncrworki

[3l

The Virtual Active Network (VAN) concept [IO] is very similar to the PVN. The main contribution of this work is a framework that splits resposibilities between network providers and
service providers. The authors envisoned an active network
shared by multiple customers, each allowed to install, run and
manage services independently using VANS. However, in this
work an underlying active network architecture is not yet defined and the issues related to the camer environment, especiallv scalabilitv oroblems. have not been considered.
Tempest 171 provider a framework in which v w " 1 pnvare nelworks tVPN)
dynmlcalb
and asslped
dedlcaled
sets of network ~ C P O U ~ C Cin
S the form of swituhletr. It has a
programmable control plane where users can inject customised
control architecture. The Tempest approach has limited flexibility because active packets are not allowed. The architecture
also excludes processor intensive applications. Our aim, on the
other hand, is to support a wider range of applications, including some processor intensive applications, without penalty on
performance or scalability.
Work in [I I ] addressed a resource optimisation problem seen
by the network provider in provisioning multiple PVNs with
different topology and resource requirements over a physical
network. This work is compatible and complementary to ours.

,.

~

~~~

VI. CONCLUSION AND FUTUREWORK
The migration of carriers' IP networks to MPLS is well undenvay. The widespread deployment of programmable networks in the near-term would be more realistic if it is consistent
with this e n d . In this paper we have pmposed an evolutionary
approach to programmable camer-grade networking based on
MPLS traffic management capabilities that offers the following

2020

..

IEEE C'ommunica(ionr .Mog~2mr.3t112-13. O c l o k r 1998
T Lavianand P Wang ACWLnclrarkingan a p m g m m " l c networking
olilform In OPLNARCII2001 2001 I E E E f i m n h C,,n&rrnrr on.oaec$
..
98- 107. March 2001.
[9] G. Hjalmtysson. Flexible toolkit for programming networks using a cammodiry operating ~ y ~ e m
1" .OPENARCHZODDIEEE nird conference
on, pages 98-107, March 2M)O.
[IO] T. Bmnncr and R. Sfadler. Service management in multiparty active networks. IEEE CommunicofionrMagazine, 38(3):14&151,2000.
[Ill F Safaei, 1. Ouvcysi, M. Zukcman, and R. Patfic. C-er-scale programmable networks: wholesaler platform and resome optimilatian.
Selected Areas in Communications. IEEE Journol on, l9(3):566573,
March 2001.
(121 A. Campbell, M. Kounavia. D. Villsla, 1. Viscnls, H. De Me-, K. Miki,
and K. Kalaichclva. Spawning networks. IEEENemark JulyIAugurt:1 6

[81

I

29, 1999.
[I31 Pamlku G. Choi S.DeHm 1. Wolf T. Deeasper, D.and 8. Plaltncr A
scalable high-psrformanccactive nctwork node. IEEENemork 13(1):%
19, Januqffsbmary 1999.
[I41 T.W olfand J. Tumer. Design issues for high-psrformanccactive mutm.
IEEE Journol on Selected &ear in Communicolionr, 19(3):404409,
March 2M) I.
[IS] T. Lavian, P.Wang, F. Travostino, S. Subrammian, V. Sethaput D. Hoang,
and D. Culler. Enahling active flow manipulation in silicon-bared network forwarding engine. IEEE Journal of Communicaliom and Networks, pages 78 87, March 2001.
116, T,
p,
F, Tmvoslino, S.
D. Hoang, and
V. Sethaput. Intelligent network services h u g h active flow manipu' lation. In InreKwf N 0 M . d Workshop,pages 73 - 82.2WI.

-

