CRMay 30, 2018

Lord of the x86 Rings: A Portable User Mode Privilege Separation Architecture on x86

arXiv:1805.11912v130 citations
Originality Incremental advance
AI Analysis

This provides a portable solution for developers to enhance security in applications by protecting sensitive data without relying on vendor-specific hardware features, though it is incremental in leveraging existing x86 privilege levels.

The paper tackles the lack of portable privilege separation in user space on x86 architectures by proposing LOTRx86, which creates a more privileged execution layer called PrivUser to protect sensitive application secrets, and demonstrates its effectiveness in mitigating vulnerabilities like HeartBleed with limited performance overhead on Intel and AMD systems.

Modern applications are increasingly advanced and complex, and inevitably contain exploitable software bugs despite the ongoing efforts. The applications today often involve processing of sensitive information. However, the lack of privilege separation within the user space leaves sensitive application secret such as cryptographic keys just as unprotected as a "hello world" string. Cutting-edge hardware-supported security features are being introduced. However, the features are often vendor-specific or lack compatibility with older generations of the processors. The situation leaves developers with no portable solution to incorporate protection for the sensitive application component. We propose LOTRx86, a fundamental and portable approach for user space privilege separation. Our approach creates a more privileged user execution layer called PrivUser through harnessing the underused intermediate privilege levels on the x86 architecture. The PrivUser memory space, a set of pages within process address space that are inaccessible to user mode, is a safe place for application secrets and routines that access them. We implement the LOTRx86 ABI that exports the privilege-based, accessing the protected application secret only requires a change in the privilege, eliminating the need for costly remote procedure calls or change in address space. We evaluated our platform by developing a proof-of-concept LOTRx86-enabled web server that employs our architecture to securely access its private key during SSL connection and thereby mitigating the HeartBleed vulnerability by design. We conducted a set of experiments including a performance measurement on the PoC on both Intel and AMD PCs, and confirmed that LOTRx86 incurs only a limited performance overhead.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes