osdi20-panic.pdf
Background
Design of PANIC

- RMT pipeline parses packet header and matches them to chain of offloads
- also generates a PANIC descriptor for multi-tenant scenario and for priority scheduling
- packet is injected to switching fabric (crowbar method)
- if does not need to be processed by offload, can just go to output port
- if need, send to central scheduler
- if no load, packets are chained with a source route that takes them from offload to offload without stopping at packet scheduler
- push scheduling is used where scheduler push work to the offloads directly
- When load is high, loaded unit detours a packet that was pushed to it off to the buffer in the central scheduler
- pulling scheduling is used where service units pull work once their pulled work is complete
RMT Pipeline:

- Service Chain: a list of services to send the packet to along with per-service metadata from the RMT
- enables scheduler to perform dynamic load balancing across multiple computation units implementing the same service in parallel
High Performance Interconnect
- PANIC utilizes non-blocking, low latency, and high throughput crossbar interconnect network
- crossbar interconnects do not scale well with more cores
- could use flattened butterfly topology
Centralized Scheduler