Translation validation for synchronous languages
Translation validations an alternative to the verification of translators (compilers, code generators). Rather than proving in advance that, the compiler always produces a target code which correctly implements the source code (compiler verification), each individual translation (i.e. a run of the compiler) is followed by a validation phase which verifies that the target code producted on this run correctly implements the submitted source program. In order to be a practical alternative to compiler verification, a key feature of this validation is its full automation.
Since the validation process attempts to “unravel” the transformation effected by the translators, its task becomes increasingly more difficult (and necessary) with the increase of sophistication and variety of the optimizations methods employed by the translator. In this paper we address the feasibility of translation validation for highly optimizing, industrial code generators from DC+, a widely used intermediate format for synchronous languages, to C.
KeywordsOrder Logic Proof Obligation Refinement Mapping Proof Rule Abstract Variable
Unable to display preview. Download preview PDF.
- M. Abadi and L. Lamport. The existence of refinement mappings. Theoretical Computer Science, 82(2), 1991.Google Scholar
- A. Benviniste, P. Le Guernic, ami C. Jacquemot. Synchronous programming with events and relations: the SIGNAL language. Science of Computer Programming, 16, 1991.Google Scholar
- G. Berry and G. Gonthier. The esterel synchronous programming language: Design, semantics, implementation. Science of Computer Programming, 19(2), 1992.Google Scholar
- E. Börger, E. Grädel, and Y. Gurevich. The Classical Decision Problem.Springer, 1996.Google Scholar
- P. Caspi, N. Halbwachs, P. Raymond, and D. Pilaud. The synchronous dataflow programming language lustre. Proceedings of the IEEE, 79(9),1991.Google Scholar
- A. Cimatti, F. Giunchiglia, and P. Pecchiari et al. A provably correct embedded verifier for the certification of safety critical software. In CAV, number 1254 in LNCS. Springer, 1997.Google Scholar
- The declarative code DC+. ESPRIT Project: SACRES, Project Report, 1997. Version 1.3.Google Scholar
- Another look at real-time programming, volume 79 of Special Issue in Proc. of the IEEE, September 1991.Google Scholar
- F. Maraninchi. Operational and compositional semantics of synchronous automata compositions. In Proceedings CONCUR, volume 630 of LNCS.Springer, 1992.Google Scholar
- A. Pnueli, M. Siegel, and E. Singermann. Translation validation. In TACAS 98: Tools and Algorithms for the Construction and Analysis of Systems, LNCS. Springer-Verlag, 1998.Google Scholar
- private communications with TNI (BREST), Siemens (Munich) and Inria (Rennes).Google Scholar