Safe functional systems through integrity types and verified assembly

作者: Michael Christensen , Joseph McMahan , Lawton Nichols , Jared Roesch , Timothy Sherwood

DOI: 10.1016/J.TCS.2020.09.039

关键词:

摘要: Abstract Building a trustworthy life-critical embedded system requires deep reasoning about the potential effects that sequences of machine instructions can have on full operation. Rather than trying to analyze complete binaries and countless ways their interact with one another — memory, side effects, control registers, implicit state, etc. we explore new approach. We propose an architecture controlled by thin computational layer designed tightly correspond lambda calculus, drawing principles functional programming bring assembly much closer myriad frameworks, such as Coq proof assistant. This approach allows assembly-level verified versions critical code operate safely in tandem arbitrary code, including imperative unverified components, without need for large supporting trusted computing bases. demonstrate this be built way simultaneously provide programmability compact, precise, semantics, while still using hardware resources comparable normal systems. To practicality approach, our FPGA-implemented prototype runs medical application which monitors treats life-threatening arrhythmias. Though integrates untrusted formal verification multiple properties end-to-end system. present correctness implementation core algorithm Coq, integrity data via non-interference proof, guarantee meets timing requirements.

参考文章(2)
Artur Oliveira Gomes, Marcel Vinícius Medeiros Oliveira, Formal Specification of a Cardiac Pacing System formal methods. ,vol. 5850, pp. 692- 707 ,(2009) , 10.1007/978-3-642-05089-3_44
Rahul Mangharam, Houssam Abbas, Madhur Behl, Kuk Jang, Miroslav Pajic, Zhihao Jiang, Three challenges in cyber-physical systems communication systems and networks. pp. 1- 8 ,(2016) , 10.1109/COMSNETS.2016.7440015