Dependently-typed data plane programming

12Citations
Citations of this article
17Readers
Mendeley users who have this article in their library.

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 4, a dependently-typed version of P4 based on decidable refinements. We motivate the design of 4, 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.

Cite

CITATION STYLE

APA

Eichholz, M., Campbell, E. H., Krebs, M., Foster, N., & Mezini, M. (2022). Dependently-typed data plane programming. Proceedings of the ACM on Programming Languages, 6(POPL). https://doi.org/10.1145/3498701

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free