File systems deserve verification too!

  • Authors:
  • Gabriele Keller;Toby Murray;Sidney Amani;Liam O'Connor;Zilin Chen;Leonid Ryzhyk;Gerwin Klein;Gernot Heiser

  • Affiliations:
  • NICTA, Sydney, Australia and University of New South Wales, Australia;NICTA, Sydney, Australia and University of New South Wales, Australia;NICTA, Sydney, Australia and University of New South Wales, Australia;NICTA, Sydney, Australia and University of New South Wales, Australia;NICTA, Sydney, Australia and University of New South Wales, Australia;NICTA, Sydney, Australia and University of New South Wales, Australia and University of Toronto, Canada;NICTA, Sydney, Australia and University of New South Wales, Australia;NICTA, Sydney, Australia and University of New South Wales, Australia

  • Venue:
  • Proceedings of the Seventh Workshop on Programming Languages and Operating Systems
  • Year:
  • 2013

Quantified Score

Hi-index 0.00

Visualization

Abstract

File systems are too important, and current ones are too buggy, to remain unverified. Yet the most successful verification methods for functional correctness remain too expensive for current file system implementations --- we need verified correctness but at reasonable cost. This paper presents our vision and ongoing work to achieve this goal for a new high-performance flash file system, called BilbyFs. BilbyFs is carefully designed to be highly modular, so it can be verified against a high-level functional specification one component at a time. This modular implementation is captured in a set of domain specific languages from which we produce the design-level specification, as well as its optimised C implementation. Importantly, we also automatically generate the proof linking these two artefacts. The combination of these features dramatically reduces verification effort. Verified file systems are now within reach for the first time.