

















|                                                                                                                                                                                                                                                                                                                                | Static routing                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                | Statically routed switch — all cells in a VC follow same path                                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                                                                                                                                                                | • IPP inserts path specification into the cell headers                                                                                                                                                                                                                                                                                                     |
| <ul> <li>internal links need not be much faster than line speed</li> <li>Requires a resequencing buffer, since cells can arrive along</li> </ul>                                                                                                                                                                               | <ul> <li>can perform static routing with many interconnection<br/>topologies, including Benes network</li> </ul>                                                                                                                                                                                                                                           |
| different paths                                                                                                                                                                                                                                                                                                                | 3-stage Clos network similar to Benes network, except that                                                                                                                                                                                                                                                                                                 |
| <ul> <li>1000 ports — resequencing buffer of size 50–100 cells<br/>statistically acceptable</li> </ul>                                                                                                                                                                                                                         | switch elements in stage 1 are $d\times r,$ stage 2 are $d\times d,$ and stage 3 are $r\times d$                                                                                                                                                                                                                                                           |
|                                                                                                                                                                                                                                                                                                                                | <ul> <li>when new VC added, control processor must find some<br/>path with enough unused bandwidth on each link</li> </ul>                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                | - checks $r$ pairs of links                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                            |
| Communication Systems Switching 39 of 53                                                                                                                                                                                                                                                                                       | VLSI Communication Systems Switching 40 c                                                                                                                                                                                                                                                                                                                  |
| <ul> <li>a Communication Systems Switching 39 of 53</li> <li>Banyan network</li> <li>Dynamically routed multistage fabric built from 2×2 switches</li> <li>Banyan on 2<sup>n</sup> outputs: n stages each with 2<sup>n-1</sup> elements</li> <li>element in <i>i</i>-th stage examines <i>i</i>-th bit of output-id</li> </ul> | Benes networks<br>$B_{n,d} - n$ is number of input/output ports, $d$ is number of<br>inputs and outputs of constituent switch elements<br>• recursive construction $n = d$ , single $d \times d$ switch element<br>• $n = d^2$ consists of 3 stages with $d$ elements in each<br>stage<br>- first stage distributes incoming cells across all              |
| <ul> <li>Banyan network</li> <li>Dynamically routed multistage fabric built from 2×2 switches</li> <li>Banyan on 2<sup>n</sup> outputs: n stages each with 2<sup>n-1</sup> elements</li> <li>element in <i>i</i>-th stage examines <i>i</i>-th bit of output-id</li> </ul>                                                     | Benes networks $B_{n,d}$ — $n$ is number of input/output ports, $d$ is number ofinputs and outputs of constituent switch elements• recursive construction $n = d$ , single $d \times d$ switch element• $n = d^2$ consists of 3 stages with $d$ elements in eachstage- first stage distributes incoming cells across allswitches in middle to balance load |
| <ul> <li>Banyan network</li> <li>Dynamically routed multistage fabric built from 2×2 switches</li> <li>Banyan on 2<sup>n</sup> outputs: n stages each with 2<sup>n-1</sup> elements</li> </ul>                                                                                                                                 | Benes networks<br>$B_{n,d} - n$ is number of input/output ports, $d$ is number of<br>inputs and outputs of constituent switch elements<br>• recursive construction $n = d$ , single $d \times d$ switch element<br>• $n = d^2$ consists of 3 stages with $d$ elements in each<br>stage<br>- first stage distributes incoming cells across all              |



| Computational complexity<br>First implementation of firewalls: linear scan, with some<br>tricks<br>• works fine for 3 Mb Ethernet, 10 rules in rule-set<br>Innate complexity: performing classification is akin to<br>searching geometrical structures<br>• recall from IP forwarding: prefix corresponds to interval<br>of $[0, 2^{32} - 1]$ | <ul> <li>Given set of N disjoint ranges {[l<sub>1</sub>, u<sub>1</sub>],, [l<sub>N</sub>, u<sub>N</sub>]}<br/>partitioning [0, 2<sup>32</sup> - 1] range lookup problem is to find range<br/>corresponding to point P</li> <li>assumption: lots of lookups, can spend time<br/>preprocessing set</li> <li>various solutions: binary search on endpoints, prefix<br/>matching (convert range to set of prefixes)</li> <li>[4,7] — 01**; Interval [3,8] — 0011, 01**, 1000;<br/>Interval [1,14] — 0001, 001*, 01**, 10**, 110*, 1100</li> <li>worst case: range on W-dimensions becomes 2W - 2<br/>prefixes</li> </ul> |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Communication Systems Switching 47 of 53                                                                                                                                                                                                                                                                                                      | VLSI Communication Systems Switching 48 c                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Syntax and semantics of rules<br>Will study classification based on header fields                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



Search for  $(v_1, v_2, \ldots, v_d)$  by finding longest matching prefix of  $v_1$ , follow its next trie pointer, recurse

• guaranteed every matching rule encountered

Complexity:

- time  $\Theta(W \cdot d)$  (no backtrack!)
- space  $\Theta(N^d \cdot d \cdot W)$

53 of 53