Novel Techniques in Recovering, Embedding, and Enforcing Policies for Control-Flow Integrity
暫譯: 控制流完整性政策的恢復、嵌入與強制執行的新技術

Lin, Yan

  • 出版商: Springer
  • 出版日期: 2021-05-01
  • 售價: $4,510
  • 貴賓價: 9.5$4,285
  • 語言: 英文
  • 頁數: 95
  • 裝訂: Quality Paper - also called trade paper
  • ISBN: 3030731405
  • ISBN-13: 9783030731403
  • 海外代購書籍(需單獨結帳)

相關主題

商品描述

There are three fundamental components in Control-Flow Integrity (CFI) enforcement. The first component is accurately recovering the policy (CFG). Usually, the more precise the policy is, the more security CFI improves, but precise CFG generation was considered hard without the support of source code. The second component is embedding the CFI policy securely. Current CFI enforcement usually inserts checks before indirect branches to consult a read-only table which stores the valid CFG information. However, this kind of read-only table can be overwritten by some kinds of attacks (e.g., the Rowhammer attack and data-oriented programming). The third component is to efficiently enforce the CFI policy. In current approaches CFI checks are always executed whenever there is an indirect control flow transfer. Therefore, it is critical to minimize the performance impact of CFI checks.
In this book, we propose novel solutions to handle these three fundamental components. To generate a precise CFI policy without the support of the source code, we systematically study two methods which recover CFI policy based on function signature matching at the binary level and propose our novel rule- and heuristic-based mechanism to more accurately recover function signature. To embed CFI policy securely, we design a novel platform which encodes the policy into the machine instructions directly without relying on consulting any read-only data structure, by making use of the idea of instruction-set randomization. Each basic block is encrypted with a key derived from the CFG. To efficiently enforce CFI policy, we make use of a mature dynamic code optimization platform called DynamoRIO to enforce the policy so that we are only required to do the CFI check when needed.

商品描述(中文翻譯)

控制流完整性(Control-Flow Integrity, CFI)執行有三個基本組成部分。第一個組成部分是準確地恢復政策(控制流圖,CFG)。通常,政策越精確,CFI 提升的安全性就越高,但在沒有源代碼支持的情況下,精確的 CFG 生成被認為是困難的。第二個組成部分是安全地嵌入 CFI 政策。目前的 CFI 執行通常在間接分支之前插入檢查,以查詢存儲有效 CFG 資訊的只讀表。然而,這種只讀表可能會被某些類型的攻擊(例如 Rowhammer 攻擊和數據導向編程)覆蓋。第三個組成部分是有效地執行 CFI 政策。在當前的方法中,CFI 檢查在每次間接控制流轉移時都會執行。因此,最小化 CFI 檢查的性能影響至關重要。

在本書中,我們提出了處理這三個基本組成部分的新解決方案。為了在沒有源代碼支持的情況下生成精確的 CFI 政策,我們系統地研究了兩種方法,這些方法基於二進制層級的函數簽名匹配來恢復 CFI 政策,並提出我們的新規則和啟發式機制,以更準確地恢復函數簽名。為了安全地嵌入 CFI 政策,我們設計了一個新平台,該平台直接將政策編碼為機器指令,而不依賴於查詢任何只讀數據結構,利用指令集隨機化的理念。每個基本區塊都使用從 CFG 派生的密鑰進行加密。為了有效地執行 CFI 政策,我們利用一個成熟的動態代碼優化平台 DynamoRIO 來執行該政策,這樣我們只需在需要時進行 CFI 檢查。

作者簡介

Yan Lin is at the School of Computing and Information Systems, Singapore Management University. Her extensive studies have focused on the area of cybersecurity, and her current researches focus on software security and system security.

作者簡介(中文翻譯)

閻琳目前在新加坡管理大學的計算與資訊系統學院任職。她的廣泛研究專注於網路安全領域,並且她目前的研究重點是軟體安全和系統安全。