The Art, Science, and Engineering of Programming
Total Page:16
File Type:pdf, Size:1020Kb
Load more
										Recommended publications
									
								- 
												  CHERI Instruction-Set ArchitectureUCAM-CL-TR-876 Technical Report ISSN 1476-2986 Number 876 Computer Laboratory Capability Hardware Enhanced RISC Instructions: CHERI Instruction-Set Architecture Robert N. M. Watson, Peter G. Neumann, Jonathan Woodruff, Michael Roe, Jonathan Anderson, David Chisnall, Brooks Davis, Alexandre Joannou, Ben Laurie, Simon W. Moore, Steven J. Murdoch, Robert Norton, Stacey Son September 2015 15 JJ Thomson Avenue Cambridge CB3 0FD United Kingdom phone +44 1223 763500 http://www.cl.cam.ac.uk/ c 2015 Robert N. M. Watson, Peter G. Neumann, Jonathan Woodruff, Michael Roe, Jonathan Anderson, David Chisnall, Brooks Davis, Alexandre Joannou, Ben Laurie, Simon W. Moore, Steven J. Murdoch, Robert Norton, Stacey Son, SRI International Approved for public release; distribution is unlimited. Sponsored by the Defense Advanced Research Projects Agency (DARPA) and the Air Force Research Laboratory (AFRL), under contracts FA8750-10-C-0237 (“CTSRD”) and FA8750-11-C-0249 (“MRC2”) as part of the DARPA CRASH and DARPA MRC research programs. The views, opinions, and/or findings contained in this report are those of the authors and should not be interpreted as representing the official views or policies, either expressed or implied, of the Department of Defense or the U.S. Government. Additional support was received from St John’s College Cambridge, the SOAAP Google Focused Research Award, the RCUK’s Horizon Digital Economy Research Hub Grant (EP/G065802/1), the EPSRC REMS Programme Grant (EP/K008528/1), the Isaac Newton Trust, the UK Higher Education Innovation Fund (HEIF), and Thales E-Security. Technical reports published by the University of Cambridge Computer Laboratory are freely available via the Internet: http://www.cl.cam.ac.uk/techreports/ ISSN 1476-2986 Abstract This technical report describes CHERI ISAv4, the fourth version of the Capability Hardware Enhanced RISC Instructions (CHERI) Instruction-Set Architecture (ISA)1 being developed by SRI International and the University of Cambridge.
- 
												  A Capability-Based Module System for Authority Control∗†A Capability-Based Module System for Authority Control∗† Darya Melicher1, Yangqingwei Shi2, Alex Potanin3, and Jonathan Aldrich4 1 Carnegie Mellon University, Pittsburgh, PA, USA 2 Carnegie Mellon University, Pittsburgh, PA, USA 3 Victoria University of Wellington, Wellington, New Zealand 4 Carnegie Mellon University, Pittsburgh, PA, USA Abstract The principle of least authority states that each component of the system should be given author- ity to access only the information and resources that it needs for its operation. This principle is fundamental to the secure design of software systems, as it helps to limit an application’s attack surface and to isolate vulnerabilities and faults. Unfortunately, current programming languages do not provide adequate help in controlling the authority of application modules, an issue that is particularly acute in the case of untrusted third-party extensions. In this paper, we present a language design that facilitates controlling the authority granted to each application module. The key technical novelty of our approach is that modules are first- class, statically typed capabilities. First-class modules are essentially objects, and so we formalize our module system by translation into an object calculus and prove that the core calculus is type- safe and authority-safe. Unlike prior formalizations, our work defines authority non-transitively, allowing engineers to reason about software designs that use wrappers to provide an attenuated version of a more powerful capability. Our approach allows developers to determine a module’s authority by examining the capab- ilities passed as module arguments when the module is created, or delegated to the module later during execution.
- 
												  Capability Myths DemolishedCapability Myths Demolished Mark S. Miller Ka-Ping Yee Jonathan Shapiro Combex, Inc. University of California, Berkeley Johns Hopkins University [email protected] [email protected] [email protected] ABSTRACT The second and third myths state false limitations on We address three common misconceptions about what capability systems can do, and have been capability-based systems: the Equivalence Myth (access propagated by a series of research publications over the control list systems and capability systems are formally past 20 years (including [2, 3, 7, 24]). They have been equivalent), the Confinement Myth (capability systems cited as reasons to avoid adopting capability models cannot enforce confinement), and the Irrevocability and have even motivated some researchers to augment Myth (capability-based access cannot be revoked). The capability systems with extra access checks [7, 13] in Equivalence Myth obscures the benefits of capabilities attempts to fix problems that do not exist. The myths as compared to access control lists, while the Confine- about what capability systems cannot do continue to ment Myth and the Irrevocability Myth lead people to spread, despite formal results [22] and practical see problems with capabilities that do not actually exist. systems [1, 9, 18, 21] demonstrating that they can do these supposedly impossible things. The prevalence of these myths is due to differing inter- pretations of the capability security model. To clear up We believe these severe misunderstandings are rooted the confusion, we examine three different models that in the fact that the term capability has come to be have been used to describe capabilities, and define a set portrayed in terms of several very different security of seven security properties that capture the distinctions models.
- 
												  Embassies: Radically Refactoring the Web Jon Howell, Bryan Parno, John REmbassies: Radically Refactoring the Web Jon Howell, Bryan Parno, John R. Douceur, Microsoft Research Abstract of evolving complexity. On the Internet, application Web browsers ostensibly provide strong isolation for providers, or vendors, run server-side applications over the client-side components of web applications. Unfor- which they exercise total control, from the app down tunately, this isolation is weak in practice; as browsers to the network stack, firewall, and OS. Even when ven- add increasingly rich APIs to please developers, these dors are tenants of a shared datacenter, each tenant au- complex interfaces bloat the trusted computing base and tonomously controls its software stack down to the ma- erode cross-app isolation boundaries. chine code, and each tenant is accessible only via IP. We reenvision the web interface based on the notion The strong isolation among virtualized Infrastructure-as- of a pico-datacenter, the client-side version of a shared a-Service datacenter tenants derives not from physical server datacenter. Mutually untrusting vendors run their separation but from the execution interface’s simplicity. code on the user’s computer in low-level native code con- This paper extends the semantics of datacenter rela- tainers that communicate with the outside world only via tionships to the client’s web experience. Suspending dis- IP. Just as in the cloud datacenter, the simple semantics belief momentarily, suppose every client had ubiquitous makes isolation tractable, yet native code gives vendors high-performance Internet connectivity. In such a world, the freedom to run any software stack. Since the datacen- exploiting datacenter semantics is easy: The client is ter model is designed to be robust to malicious tenants, it merely a screencast (VNC) viewer; every app runs on is never dangerous for the user to click a link and invite its vendor’s servers and streams a video of its display to a possibly-hostile party onto the client.
- 
												  SHILL: a Secure Shell Scripting LanguageSHILL: A Secure Shell Scripting Language Scott Moore, Christos Dimoulas, Dan King, and Stephen Chong Harvard School of Engineering and Applied Sciences Abstract require significant changes to existing software, and are The Principle of Least Privilege suggests that software often not available to all users [16]. For both of these rea- should be executed with no more authority than it re- sons, users tend to execute software with more authority quires to accomplish its task. Current security tools make than is necessary. it difficult to apply this principle: they either require sig- For example, consider scripts to grade homework sub- nificant modifications to applications or do not facilitate missions in a computer science course. Students submit reasoning about combining untrustworthy components. source code, and a script grade.sh is run on each sub- We propose SHILL, a secure shell scripting language. mission to compile it and run it against a test suite. The SHILL scripts enable compositional reasoning about se- submission server must execute grade.sh with suffi- curity through contracts that limit the effects of script cient authority to accomplish its task, but should also execution, including the effects of programs invoked by restrict its authority to protect the server from student- the script. SHILL contracts are declarative security poli- submitted code and ensure the integrity of grading. At a cies that act as documentation for consumers of SHILL coarse grain, the server should allow grade.sh to ac- scripts, and are enforced through a combination of lan- cess files and directories necessary to compile, run, and guage design and sandboxing.
- 
												  INTRODUCING CAPSICUM: PRACTICAL CAPABILITIES for UNIX 9 PermittedAPPLICATIONS ARE INCREASINGLY ROBERT N.M. WATSON, turning to privilege separation, or JONATHAN ANDERSON, BEN LAURIE, AND KRIS KENNAWAY sandboxing, to protect themselves from malicious data, but these protections are built on the weak foundation of primitives introducing such as chroot and setuid. Capsicum is a Capsicum: practical scheme that augments the UNIX security model with fine-grained capabilities and capabilities for UNIX a sandboxed capability mode, allowing Robert N.M. Watson is a PhD candidate applications to dynamically impose at the University of Cambridge Computer capability discipline on themselves. Laboratory. His PhD research is in operating system security extensibility. Prior to joining This approach lets application authors the Computer Laboratory, he was a Senior Principal Scientist at McAfee Research, now express security policies in code, ensuring SPARTA ISSO, where he directed commercial that application-level concerns such and government research and development projects in computer security, including the as Web domains map well onto robust TrustedBSD MAC Framework now used for access control in FreeBSD, Juniper Junos, Mac OS primitives. In this article we explain OS X, and Apple iOS. His research interests how Capsicum functions, compare it to include operating system security, network stack performance, and the evolving other current sandboxing technologies in software-hardware interface. Mr. Watson is also a member of the board of directors Linux, Mac OS, and Windows, and provide for the FreeBSD Foundation, a 501(c)(3) non- examples of integrating Capsicum into profit supporting development of FreeBSD, a widely used open source operating system. existing applications, from tcpdump and [email protected] gzip to the Chromium Web browser.
- 
												  A Capability-Based Module System for Authority ControlA Capability-Based Module System for Authority Control Darya Melicher,˚ Yangqingwei Shi,˚ Alex Potanin,: and Jonathan Aldrich˚ June 2017 CMU-ISR-17-106R This is a technical report accompanying a paper that was published at ECOOP 2017 [21]. This is an updated version of CMU-ISR-17-106, May 2017. Institute for Software Research School of Computer Science Carnegie Mellon University Pittsburgh, PA 15213 ˚School of Computer Science, Carnegie Mellon University, Pittsburgh, PA, USA :School of Engineering and Computer Science, Victoria University of Wellington, Wellington, New Zealand This work was supported in part by NSA lablet contract #H98230-14-C-0140 and by Oracle Labs Australia. Keywords: Language-based security, capabilities, authority, modules Abstract The principle of least authority states that each component of the system should be given author- ity to access only the information and resources that it needs for its operation. This principle is fundamental to the secure design of software systems, as it helps to limit an application’s attack surface and to isolate vulnerabilities and faults. Unfortunately, current programming languages do not provide adequate help in controlling the authority of application modules, an issue that is particularly acute in the case of untrusted third-party extensions. In this paper, we present a language design that facilitates controlling the authority granted to each application module. The key technical novelty of our approach is that modules are first-class, statically typed capabilities. First-class modules are essentially objects, and so we formalize our module system by translation into an object calculus and prove that the core calculus is type-safe and authority-safe.
- 
												  CHERI Instruction-Set ArchitectureUCAM-CL-TR-850 Technical Report ISSN 1476-2986 Number 850 Computer Laboratory Capability Hardware Enhanced RISC Instructions: CHERI Instruction-set architecture Robert N.M. Watson, Peter G. Neumann, Jonathan Woodruff, Jonathan Anderson, David Chisnall, Brooks Davis, Ben Laurie, Simon W. Moore, Steven J. Murdoch, Michael Roe April 2014 15 JJ Thomson Avenue Cambridge CB3 0FD United Kingdom phone +44 1223 763500 http://www.cl.cam.ac.uk/ c 2014 Robert N.M. Watson, Peter G. Neumann, Jonathan Woodruff, Jonathan Anderson, David Chisnall, Brooks Davis, Ben Laurie, Simon W. Moore, Steven J. Murdoch, Michael Roe SRI International is acknowledged as an additional copyright holder Technical reports published by the University of Cambridge Computer Laboratory are freely available via the Internet: http://www.cl.cam.ac.uk/techreports/ ISSN 1476-2986 Abstract This document describes the rapidly maturing design for the Capability Hardware Enhanced RISC Instructions (CHERI) Instruction-Set Architecture (ISA), which is being developed by SRI International and the University of Cambridge. The document is intended to capture our evolving architecture, as it is being refined, tested, and formally analyzed. We have now reached 70% of the time for our research and development cycle. CHERI is a hybrid capability-system architecture that combines new processor primitives with the commodity 64-bit RISC ISA enabling software to efficiently implement fine-grained memory protection and a hardware-software object-capability security model. These extensions support incrementally adoptable, high-performance, formally based, programmer-friendly un- derpinnings for fine-grained software decomposition and compartmentalization, motivated by and capable of enforcing the principle of least privilege.
- 
												  Capsicum: Practical Capabilities for UNIXCapsicum: Practical capabilities for UNIX Anna Kornfeld Simpson & Venkatesh Srinivas Capsicum: Practical capabilities for UNIX And a little bit about Confused Deputies too... Anna Kornfeld Simpson & Venkatesh Srinivas A Tale of Woe Evil Solitaire A Tale of Woe, pt.2 “I was just trying to share a photo!” Problem, pt. 1 UNIX (& friends) treat the user as a principal Any process of a user can do anything that user can do. Confused Deputy Tricking a compiler The Problem Abelson: “Name gives you Power over object” In UNIX & friends, a process can pronounce names that it might not have power over. The names convey no authority or reference The Problem The amount of Ambient Authority is …. (Orthogonal problem) ● We don’t trust other users on our machine ● Existing access control systems specify which other users can do what to each file (using techniques such as chmod() in Linux or ACLs in Windows, or sharing online) ● If the user has permission to access the file, any program run by that user can access What are capabilities? An unforgeable reference. The reference itself conveys authority. What are capabilities? “Protection”, Lampson 1971 Access Control Matrix Object 1 Object 2 P1 R,W,X - P2 R R What are capabilities? An elegant idea from a more civilized time What are capabilities? An elegant idea from a more civilized time But actually… “Programming Semantics for Multiprogrammed Computation”, Dennis, van Horn 1966. GNOSIS ‘Great New Operating System In the Sky’ (1979) KeyKOS (1985) EROS (1999) E language (2006) Cap’n Proto / Sandstorm (coming to an Internet near you any day now!) … many, many others.
- 
												  A Survey of Distributed Capability File Systems and Their Application to Cloud EnvironmentsCalhoun: The NPS Institutional Archive Theses and Dissertations Thesis Collection 2014-09 A survey of distributed capability file systems and their application to cloud environments Jatho, Edgar W., III Monterey, California: Naval Postgraduate School http://hdl.handle.net/10945/43930 NAVAL POSTGRADUATE SCHOOL MONTEREY, CALIFORNIA THESIS A SURVEY OF DISTRIBUTED CAPABILITY FILE SYSTEMS AND THEIR APPLICATION TO CLOUD ENVIRONMENTS by Edgar W. Jatho, III September 2014 Thesis Co-Advisors: Peter Denning Mark Gondree Approved for public release; distribution is unlimited THIS PAGE INTENTIONALLY LEFT BLANK REPORT DOCUMENTATION PAGE Form Approved OMB No. 0704{0188 Public reporting burden for this collection of information is estimated to average 1 hour per response, including the time for reviewing instruction, searching existing data sources, gathering and maintaining the data needed, and completing and reviewing the collection of information. Send comments regarding this burden estimate or any other aspect of this collection of information, including suggestions for reducing this burden to Washington headquarters Services, Directorate for Information Operations and Reports, 1215 Jefferson Davis Highway, Suite 1204, Arlington, VA 22202{4302, and to the Office of Management and Budget, Paperwork Reduction Project (0704-0188) Washington DC 20503. 1. AGENCY USE ONLY (Leave Blank) 2. REPORT DATE 3. REPORT TYPE AND DATES COVERED 09-26-2014 Master’s Thesis 09-01-2013 to 09-26-2014 4. TITLE AND SUBTITLE 5. FUNDING NUMBERS A SURVEY OF DISTRIBUTED CAPABILITY FILE SYSTEMS AND THEIR APPLI- CATION TO CLOUD ENVIRONMENTS 6. AUTHOR(S) Edgar W. Jatho, III 7. PERFORMING ORGANIZATION NAME(S) AND ADDRESS(ES) 8. PERFORMING ORGANIZATION REPORT NUMBER Naval Postgraduate School Monterey, CA 93943 9.
- 
												  Language and Framework Support for Reviewably-Secure Software SystemsLanguage and Framework Support for Reviewably-Secure Software Systems by Adrian Matthew Mettler A dissertation submitted in partial satisfaction of the requirements for the degree of Doctor of Philosophy in Computer Science in the Graduate Division of the University of California, Berkeley Committee in charge: Professor David Wagner, Chair Professor Deirdre Mulligan Professor Dawn Song Fall 2012 Language and Framework Support for Reviewably-Secure Software Systems Copyright 2012 by Adrian Matthew Mettler 1 Abstract Language and Framework Support for Reviewably-Secure Software Systems by Adrian Matthew Mettler Doctor of Philosophy in Computer Science University of California, Berkeley Professor David Wagner, Chair My thesis is that languages and frameworks can and should be designed to make it easier for programmers to write reviewably secure systems. A system is reviewably secure if its security is easy for an experienced programmer to verify, given access to the source code. A security reviewer should be able, with a reasonable amount of effort, to gain confidence that such a system meets its stated security goals. This dissertation includes work on on language subsetting and web application framework design. It presents Joe-E, a subset of the Java programming language designed to enforce object- capability security, simplifying the task of verifying a variety of security properties by en- abling sound, local reasoning. Joe-E also enforces determinism-by-default, which permits functionally-pure methods to be identified by their signature. Functional purity is a useful property that can greatly simplify the task of correctly implementing and reasoning about application code. A number of applications of the Joe-E language are presented and evalu- ated.
- 
												![Sel4 Whitepaper [Pdf]](https://docslib.b-cdn.net/cover/5235/sel4-whitepaper-pdf-8295235.webp)  Sel4 Whitepaper [Pdf]The seL4® Foundation https://sel4.systems/Foundation The seL4 Microkernel An Introduction Gernot Heiser [email protected] Revision 1.2 of 2020-06-10 Abstract This whitepaper provides an introduction to and overview of seL4. We explain what seL4 is (and is not) and explore its defining features. We explain what makes seL4 uniquely qualified as the operating-system kernel of choice for security- and safety- critical systems, and generally embedded and cyber-physical systems. In particular, we explain seL4’s assurance story, its security- and safety-relevant features, and its benchmark-setting performance. We also discuss typical usage scenarios, including incremental cyber retrofit of legacy systems. CCS Concepts • Software and its engineering ! Operating Systems • Security and privacy ! Systems security • Security and privacy ! Formal methods and theory of security • Computer systems organization ! Real-time systems ! Real-time operating systems • Computer systems organization ! Real-time systems ! Dependable and fault- tolerant systems and networks Keywords seL4, microkernel, performance Reference Format: Gernot Heiser. The seL4 Microkernel – An Introduction. White paper. The seL4 Foun- dation, Revision 1.2 of 2020-06-10. Copyright © 2020 seL4 Project a Series of LF Projects, LLC. Distributed under the Creative Commons Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) License. seL4 is a trademark of LF Projects, LLC. Chapter 1 What Is seL4? seL4 is an operating system microkernel An operating system (OS) is the low-level system software that controls a com- puter system’s resources and enforces security. Unlike application software, the OS has exclusive access to a more privileged execution mode of the processor (kernel mode) that gives it direct access to hardware.