English

Dependently-Typed Data Plane Programming

Programming Languages 2022-06-08 v1

Abstract

Programming languages like P4 enable specifying the behavior of network data planes in software. However, with increasingly powerful and complex applications running in the network, the risk of faults also increases. Hence, there is growing recognition of the need for methods and tools to statically verify the correctness of P4 code, especially as the language lacks basic safety guarantees. Type systems are a lightweight and compositional way to establish program properties, but there is a significant gap between the kinds of properties that can be proved using simple type systems (e.g., SafeP4) and those that can be obtained using full-blown verification tools (e.g., p4v). In this paper, we close this gap by developing Π\Pi4, a dependently-typed version of P4 based on decidable refinements. We motivate the design of Π\Pi4, prove the soundness of its type system, develop an SMT-based implementation, and present case studies that illustrate its applicability to a variety of data plane programs.

Keywords

Cite

@article{arxiv.2206.03457,
  title  = {Dependently-Typed Data Plane Programming},
  author = {Matthias Eichholz and Eric Hayden Campbell and Matthias Krebs and Nate Foster and Mira Mezini},
  journal= {arXiv preprint arXiv:2206.03457},
  year   = {2022}
}

Comments

This version is the companion technical report for the submission to POPL'22

R2 v1 2026-06-24T11:42:28.714Z