@inbook{ea3f7765f18e44d69011ab18d1655ee1,
title = "Types and effects for non-interfering program monitors",
abstract = "A run-time monitor is a program that runs in parallel with an untrusted application and examines actions from the application's instruction stream. If the sequence of program actions deviates from a specified security policy, the monitor transforms the sequence or terminates the program. We present the design and formal specification of a language for defining the policies enforced by program monitors. Our language provides a number of facilities for composing complex policies from simpler ones. We allow policies to be parameterized by values or other policies, and we define operators for forming the conjunction and disjunction of policies. Since the computations that implement these policies modify program behavior, naive composition of computations does not necessarily produce the conjunction (or disjunction) of the policies that the computations implement separately. We use a type and effect system to ensure that computations do not interfere with one another when they are composed.",
author = "Lujo Bauer and Jarred Ligatti and David Walker",
note = "Copyright: Copyright 2020 Elsevier B.V., All rights reserved.",
year = "2003",
doi = "10.1007/3-540-36532-x_10",
language = "English (US)",
isbn = "3540007083",
series = "Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics)",
publisher = "Springer Verlag",
pages = "154--171",
editor = "Mitsuhiro Okada and Pierce, {Benjamin C.} and Andre Scedrov and Hideyuki Tokuda and Akinori Yonezawa",
booktitle = "Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics)",
address = "Germany",
}