skip to main content
10.1145/2660267.2660331acmconferencesArticle/Chapter ViewAbstractPublication PagesccsConference Proceedingsconference-collections
research-article

A Tale of Two Kernels: Towards Ending Kernel Hardening Wars with Split Kernel

Published: 03 November 2014 Publication History

Abstract

Software security practitioners are often torn between choosing performance or security. In particular, OS kernels are sensitive to the smallest performance regressions. This makes it difficult to develop innovative kernel hardening mechanisms: they may inevitably incur some run-time performance overhead. Here, we propose building each kernel function with and without hardening, within a single split kernel. In particular, this allows trusted processes to be run under unmodified kernel code, while system calls of untrusted processes are directed to the hardened kernel code. We show such trusted processes run with no overhead when compared to an unmodified kernel. This allows deferring the decision of making use of hardening to the run-time. This means kernel distributors, system administrators and users can selectively enable hardening according to their needs: we give examples of such cases. Although this approach cannot be directly applied to arbitrary kernel hardening mechanisms, we show cases where it can. Finally, our implementation in the Linux kernel requires few changes to the kernel sources and no application source changes. Thus, it is both maintainable and easy to use.

References

[1]
Martín Abadi, Mihai Budiu, Úlfar Erlingsson, and Jay Ligatti. "Control-flow Integrity Principles, Implementations, and Applications". In: ACM Trans. Inf. Syst. Secur. 13.1 (2009), 4:1--4:40. ISSN: 1094--9224.
[2]
James P Anderson. Computer Security Technology Planning Study. Volume 2. Technical report. DTIC Document, 1972.
[3]
Jeff Arnold and M. Frans Kaashoek. "Ksplice: Automatic Rebootless Kernel Updates". In: Proceedings of the 4th ACM European Conference on Computer Systems. EuroSys '09. 2009, pages 187--198. ISBN: 978--1--60558--482--9.
[4]
Andrew Ayers, Richard Schooler, and Robert Gottlieb. "Aggressive Inlining". In: Proceedings of the ACM SIGPLAN 1997 Conference on Programming Language Design and Implementation. PLDI'97. 1997, pages 134--145. ISBN: 0-89791-907-6.
[5]
Brian N. Bershad, Craig Chambers, Susan J. Eggers, Chris Maeda, Dylan McNamee, Przemyslaw Pardyak, Stefan Savage, and Emin Gun Sirer. "SPIN-An Extensible Microkernel for Application-specific Operating System Services". In: ACM SIGOPS European Workshop. 1994, pages 68--71.
[6]
Phil Blundell. Econet: fix CVE-2010--3848. http://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/commit/?id=a27e13d370415add34879.
[7]
Haogang Chen, Yandong Mao, Xi Wang, Dong Zhou, Nickolai Zeldovich, and M. Frans Kaashoek. "Linux Kernel Vulnerabilities: State-of-the-art Defenses and Open Problems". In: Proceedings of the Second Asia-Pacific Workshop on Systems. APSys'11. 2011, 5:1--5:5. ISBN: 978--1--4503--1179--3.
[8]
Kees Cook. Kernel exploitation via uninitialized stack. DefCon 19https://www.defcon.org/images/defcon-19/dc-19-presentations/Cook/DEFCON-19-Cook-Kernel- Exploitation.pdf.
[9]
Keith D Cooper, Mary W Hall, and Ken Kennedy. "A Methodology for Procedure Cloning". In: Comput. Lang. 19.2 (1993), pages 105--117. ISSN: 0096-0551.
[10]
Intel Corp. Intel Architecture Instruction Set Extensions Programming Reference. http://software.intel.com/sites/default/files/319433-014.pdf. 2012.
[11]
John Criswell, Andrew Lenharth, Dinakar Dhurjati, and Vikram Adve. "Secure Virtual Architecture: A Safe Execution Environment for Commodity Operating Systems". In: Proceedings of the 21st ACM Symposium on Operating Systems Principles (SOSP'07). (Stevenson, WA, USA). 2007, pages 351--366. ISBN:978-1-59593-591-5.
[12]
Nelson Elhage. Econet local privilege escalation. http://www.exploit-db.com/exploits/15704/.
[13]
Dawson R. Engler, M. Frans Kaashoek, and James O'Toole. "Exokernel: An Operating System Architecture for Application-Level Resource Management". In: Proceedings of the 15th ACM Symposium on Operating Systems Principles (SOSP'95). ACM SIGOPS Operating Systems Review. 1995, pages 251--266.
[14]
Úlfar Erlingsson, Martín Abadi, Michael Vrable, Mihai Budiu, and George C. Necula. "XFI: Software Guards for System Address Spaces". In: 7th Symposium on Operating System Design andImplementation (OSDI'06). (Seattle, WA, USA). 2006, pages 75--88.ISBN: 1-931971-47-1.
[15]
Chris Evans. Pwnium 3 and Pwn2Own Results. http://blog.chromium.org/2013/03/pwnium-3-and-pwn2own-results.html. 2012.
[16]
Stephen Fischer. Supervisor Mode Execution Protection. NSA Trusted Computing Conference and Exposition. https://www.ncsi.com/nsatc11/presentations/wednesday/emerging_technologies/fischer.pdf. 2011.
[17]
Grigori Fursin, Cupertino Miranda, Sebastian Pop, Albert Cohen, and Olivier Temam. "Practical Run-time Adaptation with Procedure Cloning to Enable Continuous Collective Compilation". In: GCC Developers' Summit. 2007, page 39.
[18]
Cristiano Giuffrida, Anton Kuijsten, and Andrew S. Tanenbaum. "Enhanced Operating System Security Through Efficient and Fine-grained Address Space Randomization". In: Proceedings of the 21st USENIX Conference on Security Symposium. Security'12. 2012, pages 40--40.
[19]
Google. AddressSanitizer for the Linux kernel. http://bit.ly/TdRoab. 2014.
[20]
A. Gutierrez, R.G. Dreslinski, T.F. Wenisch, T. Mudge, A. Saidi, C. Emmons, and N. Paver. "Full-System Analysis and Characterization of Interactive Smartphone Applications". In: the proceedings of the 2011 IEEE International Symposium on Workload Characterization (IISWC). 2011, pages 81--90.
[21]
Jorrit N. Herder, Herbert Bos, Ben Gras, Philip Homburg, and Andrew S. Tanenbaum. "MINIX 3: a highly reliable, self-repairing operating system". In: SIGOPS Oper. Syst. Rev. 40.3 (2006), pages 80--89. ISSN: 0163--5980.
[22]
Vasileios P. Kemerlis, Georgios Portokalidis, and Angelos D. Keromytis. "kGuard: Lightweight Kernel Protection Against Return-to-user Attacks". In: Proceedings of the 21st USENIX Conference on Security Symposium. Security'12. 2012, pages 39--39.
[23]
Anil Kurmus, Sergej Dechand, and Rüdiger Kapitza. "Quantifiable Run-Time Kernel Attack Surface Reduction". In: Proceedings of the 11th DIMVA Conference. 2014, pages 212--234.
[24]
Jinku Li, Zhi Wang, Xuxian Jiang, Michael Grace, and Sina Bahram. "Defeating Return-oriented Rootkits with "Return-Less" Kernels". In: Proceedings of the 5th European Conference on Computer Systems. EuroSys'10. 2010, pages 195--208. ISBN: 978--1--60558--577--2.
[25]
Siarhei Liakh, Michael Grace, and Xuxian Jiang. "Analyzing and Improving Linux Kernel Memory Protection: A Model Checking Approach". In: Proceedings of the 26th Annual Computer Security Applications Conference. ACSAC '10. 2010, pages 271--280. ISBN: 978--1--4503-0133--6.
[26]
Jochen Liedtke. "On m-Kernel Construction". In: Proceedings of the 15th ACM Symposium on Operating Systems Principles (SOSP '95). ACM SIGOPS Operating Systems Review. 1995.
[27]
LTP -- Linux Test Project. https://linux-test-project.github.io/.
[28]
Kristis Makris and Kyung Dong Ryu. "Dynamic and Adaptive Updates of Non-quiescent Subsystems in Commodity Operating System Kernels". In: Proceedings of the 2Nd ACM SIGOPS/EuroSys European Conference on Computer Systems 2007. EuroSys'07. 2007, pages 327--340. ISBN: 978-1-59593-636-3.
[29]
MITRE. CWE-457: Use of Uninitialized Variable. https://cwe.mitre.org/data/definitions/457.html.
[30]
Vegard Nossum. Documentation of the Linux kernel kmemcheck configuration option. https://www.kernel.org/doc/ Documentation/kmemcheck.txt.
[31]
Niels Provos, Markus Friedl, and Peter Honeyman. "Preventing Privilege Escalation". In: Proceedings of the 12th Conference on USENIX Security Symposium - Volume 12. 2003, pages 16--16.
[32]
Ryan Roemer, Erik Buchanan, Hovav Shacham, and Stefan Savage. "Return-Oriented Programming: Systems, Languages, and Applications". In: ACM Trans. Inf. Syst. Secur. 15.1 (2012), 2:1--2:34. ISSN: 1094--9224.
[33]
Konstantin Serebryany, Derek Bruening, Alexander Potapenko, and Dmitry Vyukov. "AddressSanitizer: A Fast Address Sanity Checker". In: Proceedings of the 2012 USENIX Conference on Annual Technical Conference. USENIX ATC'12. 2012, pages 28--28.
[34]
Stephen Smalley, Chris Vance, and Wayne Salamon. Implementing SELinux as a Linux security module. Technical report. NAI Labs Report, 2001.
[35]
Brad Spengler and PaX team. grsecurity kernel patches. www.grsecurity.net.
[36]
Richard Ta-Min, Lionel Litty, and David Lie. "Splitting Interfaces: Making Trust Between Applications and Operating Systems Configurable". In: Proceedings of the 7th Symposium on Operating Systems Design and Implementation. OSDI'06. 2006, pages 279--292. ISBN: 1--931971--47--1.
[37]
PaX team. Future direction of PaX. pax.grsecurity.net/docs/pax-future.txt.
[38]
Victor van der Veen, Nitish dutt Sharma, Lorenzo Cavallaro, and Herbert Bos. "Memory Errors: The Past, the Present, and the Future". In: Proceedings of the 15th International Conference on Research in Attacks, Intrusions, and Defenses. RAID'12. 2012, pages 86--106. ISBN: 978-3-642-33337-8.
[39]
Chris Wright, Crispin Cowan, James Morris, Stephen Smalley, and Greg Kroah-Hartman. "Linux security module framework". In: Ottawa Linux Symposium. Volume 8032. 2002.

Cited By

View all

Index Terms

  1. A Tale of Two Kernels: Towards Ending Kernel Hardening Wars with Split Kernel

    Recommendations

    Comments

    Information & Contributors

    Information

    Published In

    cover image ACM Conferences
    CCS '14: Proceedings of the 2014 ACM SIGSAC Conference on Computer and Communications Security
    November 2014
    1592 pages
    ISBN:9781450329576
    DOI:10.1145/2660267
    Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than the author(s) must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected].

    Sponsors

    Publisher

    Association for Computing Machinery

    New York, NY, United States

    Publication History

    Published: 03 November 2014

    Permissions

    Request permissions for this article.

    Check for updates

    Author Tags

    1. build system
    2. kernel hardening
    3. os security
    4. performance

    Qualifiers

    • Research-article

    Conference

    CCS'14
    Sponsor:

    Acceptance Rates

    CCS '14 Paper Acceptance Rate 114 of 585 submissions, 19%;
    Overall Acceptance Rate 1,261 of 6,999 submissions, 18%

    Upcoming Conference

    CCS '25

    Contributors

    Other Metrics

    Bibliometrics & Citations

    Bibliometrics

    Article Metrics

    • Downloads (Last 12 months)31
    • Downloads (Last 6 weeks)2
    Reflects downloads up to 06 Jan 2025

    Other Metrics

    Citations

    Cited By

    View all

    View Options

    Login options

    View options

    PDF

    View or Download as a PDF file.

    PDF

    eReader

    View online with eReader.

    eReader

    Media

    Figures

    Other

    Tables

    Share

    Share

    Share this Publication link

    Share on social media