Abstract
Operating systems provide various inter-process communication (IPC) mechanisms. Software applications typically use IPC for communication between front-end and back-end components, which run in different processes on the same computer. This paper studies the security of how the IPC mechanisms are used in PC, Mac and Linux software. We describe attacks where a nonprivileged process impersonates the IPC communication endpoints. The attacks are closely related to impersonation and man-in-the-middle attacks on computer networks but take place inside one computer. The vulnerable IPC methods are ones where a server process binds to a name or address and waits for client communication. Our results show that application developers are often unaware of the risks and secure practices in using IPC. We find attacks against several security-critical applications including password managers and hardware tokens, in which another user's process is able to steal and misuse sensitive data such as the victim's credentials. The vulnerabilities can be exploited in enterprise environments with centralized access control that gives multiple users remote or local login access to the same host. Computers with guest accounts and shared computers at home are similarly vulnerable.
Original language | English |
---|---|
Title of host publication | Proceedings of the 27th USENIX Security Symposium, August 15–17, 2018, Baltimore, MD, USA |
Place of Publication | Baltimore, MD |
Publisher | USENIX : THE ADVANCED COMPUTING SYSTEMS ASSOCIATION |
Pages | 1511-1525 |
Number of pages | 15 |
ISBN (Print) | 978-1-931971-46-1 |
Publication status | Published - 2018 |
MoE publication type | A4 Article in a conference publication |
Event | USENIX Security Symposium - Baltimore, United States Duration: 15 Aug 2018 → 17 Aug 2018 Conference number: 27 |
Conference
Conference | USENIX Security Symposium |
---|---|
Country | United States |
City | Baltimore |
Period | 15/08/2018 → 17/08/2018 |