Linear temporal logic

Introduction

Runtime verification monitor is a verification technique which checks that the kernel follows a specification. It does so by using tracepoints to monitor the kernel’s execution trace, and verifying that the execution trace sastifies the specification.

Initially, the specification can only be written in the form of deterministic automaton (DA). However, while attempting to implement DA monitors for some complex specifications, deterministic automaton is found to be inappropriate as the specification language. The automaton is complicated, hard to understand, and error-prone.

Thus, RV monitors based on linear temporal logic (LTL) are introduced. This type of monitor uses LTL as specification instead of DA. For some cases, writing the specification as LTL is more concise and intuitive.

Many materials explain LTL in details. One book is:

Christel Baier and Joost-Pieter Katoen: Principles of Model Checking, The MIT
Press, 2008.

Grammar

Unlike some existing syntax, kernel’s implementation of LTL is more verbose. This is motivated by considering that the people who read the LTL specifications may not be well-versed in LTL.

Grammar:

ltl ::= opd | ( ltl ) | ltl binop ltl | unop ltl

Operands (opd):

true, false, user-defined names consisting of upper-case characters, digits, and underscore.

Unary Operators (unop):

always eventually not

Binary Operators (binop):

until and or imply equivalent

This grammar is ambiguous: operator precedence is not defined. Parentheses must be used.

Example linear temporal logic

RAIN imply (GO_OUTSIDE imply HAVE_UMBRELLA)

means: if it is raining, going outside means having an umbrella.

RAIN imply (WET until not RAIN)

means: if it is raining, it is going to be wet until the rain stops.

RAIN imply eventually not RAIN

means: if it is raining, rain will eventually stop.

The above examples are referring to the current time instance only. For kernel verification, the always operator is usually desirable, to specify that something is always true at the present and for all future. For example:

always (RAIN imply eventually not RAIN)

means: all rain eventually stops.

In the above examples, RAIN, GO_OUTSIDE, HAVE_UMBRELLA and WET are the “atomic propositions”.

Monitor synthesis

To synthesize an LTL into a kernel monitor, the rvgen tool can be used: tools/verification/rvgen. The specification needs to be provided as a file, and it must have a “RULE = LTL” assignment. For example:

RULE = always (ACQUIRE imply ((not KILLED and not CRASHED) until RELEASE))

which says: if ACQUIRE, then RELEASE must happen before KILLED or CRASHED.

The LTL can be broken down using sub-expressions. The above is equivalent to:

RULE = always (ACQUIRE imply (ALIVE until RELEASE))
ALIVE = not KILLED and not CRASHED

From this specification, rvgen generates the C implementation of a Buchi automaton - a non-deterministic state machine which checks the satisfiability of the LTL. See Runtime Verification Monitor Synthesis for details on using rvgen.

References

One book covering model checking and linear temporal logic is:

Christel Baier and Joost-Pieter Katoen: Principles of Model Checking, The MIT
Press, 2008.

For an example of using linear temporal logic in software testing, see:

Ruijie Meng, Zhen Dong, Jialin Li, Ivan Beschastnikh, and Abhik Roychoudhury.
2022. Linear-time temporal logic guided greybox fuzzing. In Proceedings of the
44th International Conference on Software Engineering (ICSE '22).  Association
for Computing Machinery, New York, NY, USA, 1343–1355.
https://doi.org/10.1145/3510003.3510082

The kernel’s LTL monitor implementation is based on:

Gerth, R., Peled, D., Vardi, M.Y., Wolper, P. (1996). Simple On-the-fly
Automatic Verification of Linear Temporal Logic. In: Dembiński, P., Średniawa,
M. (eds) Protocol Specification, Testing and Verification XV. PSTV 1995. IFIP
Advances in Information and Communication Technology. Springer, Boston, MA.
https://doi.org/10.1007/978-0-387-34892-6_1