Integration of a Security Type System into a Program Logic
Journal article, 2008

Type systems and program logics are often thought to be at opposing ends of the spectrum of formal software analyses. In this paper we show that a flow-sensitive type system ensuring non-interference in a simple while-language can be expressed through specialised rules of a program logic. In our framework, the structure of non-interference proofs resembles the corresponding derivations in a state-of-the-art security type system, meaning that the algorithmic version of the type system can be used as a proof procedure for the logic. We argue that this is important for obtaining uniform proof certificates in a proof-carrying code framework. We discuss in which cases the interleaving of approximative and precise reasoning allows us to deal with delimited information release. Finally, we present ideas on how our results can be extended to encompass features of realistic programming languages such as Java.

Formal verification

Dynamic logic

Security type system

Language-based security

Information-flow analysis

Author

Reiner Hähnle

Chalmers, Computer Science and Engineering (Chalmers), Computing Science (Chalmers)

Jing Pan

Eindhoven University of Technology

Philipp Rümmer

University of Gothenburg

Dennis Walter

Deutsches Forschungszentrum fur Kunstliche Intelligenz

Theoretical Computer Science

0304-3975 (ISSN)

Vol. 402 2-3 172-189

Subject Categories (SSIF 2011)

Computer Science

DOI

10.1016/j.tcs.2008.04.033

More information

Latest update

3/20/2018