FPL 2017最佳論文:如何對FPGA云發動DoS攻擊?

第27屆現場可編程邏輯與應用國際會議(The International Conference on Field-Programmable Logic and Applications,FPL)九月份在比利時根特召開。在FPL 2017上,一篇來自德國卡爾斯魯厄理工學院(Karlsruhe Institute of Technology)的論文《Voltage Drop-based Fault Attacks on FPGAs
using Valid Bitstreams》獲得了最佳論文獎,同時也成為了所有與會者談論的焦點。

本文作者@小哲打豆豆為雷鋒網專欄作者,目前在多倫多大學電子工程系就讀博士,以下為作者對于本篇論文的介紹。

背景介紹

FPGA(Field Programmable Gate Array,現場可編程邏輯門陣列)因為其卓越的靈活性而越來越受到用戶青睞。不論是低端的IoT設備,還是高端的云計算中心,FPGA在這些最新的應用場景下都展示出高效的計算能力。加上過去就一直在應用FPGA的關鍵行業,例如軍工,航空航天等,諸多領域的發展都給FPGA的安全性帶來了新的挑戰。

之前對FPGA攻擊的研究都是基于本地的,例如,更改FPGA的電源或時鐘,或在管腳人為注入“特洛伊代碼”。隨著FPGA越來越多的在云計算中心中的應用,任何人都可以遠程在服務器的FPGA上占用一部分邏輯門,將這個區域設置為自己需要的任意電路,以實現運算加速等功能。而之前,FPGA只能通過受信任的IP提供者被設置。這意味著FPGA在云計算這類應用中將前所未有的暴露自身的安全漏洞。

這項研究的威脅模型基于以下假設:攻擊者可以重構部分或全部FPGA的邏輯門,目的是對系統發起DoS(Denial of Service)攻擊。作者對兩種FPGA分別進行了測試,一類是在云計算中心作為加速器的FPGA,另一類是有片上SoC的FPGA,這類FPGA多應用在IoT場景下。對兩種FPGA的研究都發現,發動的DoS攻擊可以使FPGA完全癱瘓直至手動復位電源。對于有片上SoC的FPGA來說,在其應用場景下可能并沒有電源復位的選項,唯一復位電源的的辦法只能是將電池取出再放回。

電路設計

針對FPGA的DoS攻擊的基本原理大致如下:通過編輯片上邏輯,使FPGA負載能在瞬間改變。由于電源瞬態響應緩慢,以及電源分配網絡(Power Delivery Network,PDN)的設計缺陷,導致FPGA電壓過低,進入欠壓保護而被鎖定,進而達到癱瘓設備的目的。

為了達到瞬間改變FPGA負載的效果,作者將一個邏輯單元的輸出經過一個非門連回到輸出端。如下圖所示,這樣的電路構成了一個正反饋的環形振蕩器(Ring Oscillator)。環形振蕩器里的CMOS開關管會以極快的速度翻轉,消耗大量電流。大量邏輯單元都被設置成這樣的環形振蕩器,并且通過一個使能信號控制所有振蕩器,就能瞬間改變FPGA的電流負載。通過控制使能信號的開關頻率fRO-t,可以模擬不同的負載變化來觀察其對FPGA的影響。

FPL 2017最佳論文:如何對FPGA云發動DoS攻擊?

實驗結果與討論

作者測試了三塊FPGA開發板,分別是:有40納米的Xilinx Virterx 6 FPGA的ML605開發板,28納米的Kintex 7 FPGA的KC705開發板,以及28納米的Zynq 7020 SoC-FPGA(雙ARM Cortex A9 + 片上FPGA)的Zedboard開發板。

測試中,三種開發板都在一定條件下發生了欠壓保護導致的系統崩潰。ML605和KC705在欠壓保護后均無法自動恢復。Zedboard則會隨機出現三種不同的系統故障:一是和前兩塊開發板一樣出現無法自動復位的欠壓保護;一種是芯片自動重置,片上所有的設置,包括兩個ARM核的狀態也被重置;第三種狀況類似重置,但是作者在試圖重新配置芯片時發生軟件故障,之后系統便進入第一種無法自動恢復的欠壓保護模式。可見,不論出現何種故障,都需要手動重置電源才能恢復系統。

以ML605開發板作為實例,作者在片上布設了18720個環形振蕩器,大約只占用了12%的片上資源。使能信號的頻率fRO-t從20kHz到2MHz。實驗發現,在高于1MHz時,片上電壓壓降不足以引起欠壓保護;在80kHz到1MHz的范圍內,系統崩潰會隨機的發生;而在頻率小于80kHz時,系統崩潰幾乎必然發生。FPL 2017最佳論文:如何對FPGA云發動DoS攻擊?

作者同時將兩塊開發板通過PCIe接口接入工作站,發現系統崩潰同樣發生了。崩潰后ML605可以通過板上的電源開關進行復位,而KC705甚至必須要將整個工作站重啟才能恢復。下表總結了三塊板在不同狀態下的能耗:

FPL 2017最佳論文:如何對FPGA云發動DoS攻擊?

以上實例展示了通過欠壓保護機制對FPGA發動DoS攻擊的方法。如此發動的DoS攻擊快速,且可以導致整塊FPGA不可逆的癱瘓,直至手動重置電源。

允許用戶自己設置FPGA實現運算加速的系統中,無疑暴露了巨大的安全隱患。這導致整臺服務器需要重新啟動。如果系統是通過不可替換的電池供電的話,FPGA將陷入永久的DoS狀態。

結論

FPGA在云計算和IoT中都有大量的應用,在這些新的應用中,傳統的比特流加密(bitstream encryption)等安全措施已經不足以應對新的挑戰。在這項研究中,作者揭示了一個新的安全漏洞,通過一類方法可以對FPGA發動DoS攻擊,并在兩代FPGA上進行了實測。結果發現,僅僅利用12%的片上資源,就可以使FPGA由于欠壓保護而完全癱瘓。



本文作者:小哲打豆豆
本文轉自雷鋒網禁止二次轉載,原文鏈接

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/257218.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/257218.shtml
英文地址,請注明出處:http://en.pswp.cn/news/257218.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

應用程序唯一性

程序啟動后,如果再次啟動程序,不會出現2個程序,或者實現如Notepad已打開一個文件,再打開另外一個文件,則追加在Notepad界面上。 使用codeproject上別人編寫的一個類,加在程序啟動時即可。 sinstance.h /* M…

php的GC機制

在php5.3版本之前, php變量的回收機制只是簡單的通過計數來處理(當refcount0時,會回收內存),但這樣會出現一個問題 $aarray("str"); $a[]&$a; unset($a); 執行unset之前,$a的refcount 為2,執行unset之后,$a的refcout為1,因為是1不等于0,不能被回收內存…

Spring 框架的JDBC模板技術

1. 概述 Spring 框架提供了很多持久層的模板類來簡化編程;Spring 框架提供的JDBC模板類: JdbcTemplate 類;Spring 框架提供的整合 Hibernate 框架的模板類: HibernateTemplate 類2. 環境搭建 2.1 創建數據庫表結構 CREATE TABLE t_account(id INT PRIMARY KEY AUTO_INCREMENT,…

BZOJ 1692: [Usaco2007 Dec]隊列變換( 貪心 )

數據 n < 30000 , 然后 O( n ) 的貪心也過了..... USACO 數據是有多弱啊 ( ps : BZOJ 1640 和此題一模一樣 , 雙倍經驗 ) --------------------------------------------------------------------------------------#include<cstdio>#include<cstring>#include…

數據說話,88000條數據繪制北京市地圖

偶獲得一批數據&#xff0c;本著好玩的態度繪制下來看看到底是什么鬼&#xff0c;繪制的結果如下&#xff1a; 呵呵&#xff0c;什么都不像。而且中間最重要的部分因數據量過大繪制的已經看不清楚了。于是乎&#xff0c;縮小繪制范圍&#xff0c;去除周圍沒有用的數據。重新繪制…

我的第一個python web開發框架(11)——工具函數包說明(二)

db_helper.py是數據庫操作包&#xff0c;主要有兩個函數&#xff0c;分別是read()數據庫讀操作函數和write()數據庫寫操作函數。這個包的代碼是從小戴同學分享的博文改造過來的。 1 #!/usr/bin/env python2 # codingutf-83 4 import psycopg25 from common import log_helper6 …

ASP.NET:在一般處理程序中通過 Session 保存驗證碼卻無法顯示圖片?

1 using System.Drawing;2 using System.Web;3 using System.Web.SessionState;4 5 /// <summary>6 /// CaptchaHandler 的摘要說明7 /// </summary>8 public class CaptchaHandler : IHttpHandler, IRequiresSessionState  //簡記&#xff1a;我需要Session9 { …

[LINK]用Python計算昨天、今天和明天的日期時間

用Python計算昨天、今天和明天的日期時間 轉載于:https://www.cnblogs.com/Athrun/p/5477651.html

Windows系統下oracle數據庫每天定時備份

第一步&#xff1a;建立備份腳本oraclebackup.bat 首先建立一個備份bat文件&#xff0c;在D盤下新建備份目錄oraclebackup&#xff0c;將oracle安裝目錄下的EXP.EXE復制到此目錄下&#xff0c;再新建一個文本文件oraclebackup.txt&#xff0c;內容如下&#xff1a; echo off ec…

面試題3:二維數組查找

1 bool Find(const int *matrix, int rows, int columns, int number)2 {3 int key;4 int indexRow;5 int indexCol;6 7 /*合法性檢查*/8 if((NULL matrix)||(rows < 0)||(columns <0))9 { 10 return false; 11 } 12 13 /*提升…

linux crontab 命令

#method 1 crontab -e crontab -u root -e #不同用戶自己的任務計劃 crontab -l#method 2 vim /etc/crontab# Example of job definition: # .---------------- minute (0 - 59) # | .------------- hour (0 - 23) # | | .---------- day of month (1 - 31) # | | | .--…

[譯] RNN 循環神經網絡系列 2:文本分類

原文地址&#xff1a;RECURRENT NEURAL NETWORKS (RNN) – PART 2: TEXT CLASSIFICATION原文作者&#xff1a;GokuMohandas譯文出自&#xff1a;掘金翻譯計劃本文永久鏈接&#xff1a;github.com/xitu/gold-m…譯者&#xff1a;Changkun Ou校對者&#xff1a;yanqiangmiffy, To…

[置頂] Android開發者官方網站文檔 - 國內踏得網鏡像

Mark 一下&#xff1a; 鏡像地址&#xff1a;http://wear.techbrood.com/index.html Android DevelopTools: http://www.androiddevtools.cn/ 轉載于:https://www.cnblogs.com/superle/p/4561856.html

Java實現選擇排序

選擇排序思想就是選出最小或最大的數與第一個數交換&#xff0c;然后在剩下的數列中重復完成該動作。 package Sort;import java.util.Arrays;public class SelectionSort {public static int selectMinKey(int[] list, int beginIdx) {int idx beginIdx;int temp list[begin…

ASP.NET MVC中ViewData、ViewBag和TempData

1.ViewData 1.1 ViewData繼承了IDictionary<string, object>,因此在設置ViewData屬性時,傳入key必須要字符串型別,value可以是任意類型。 1.2 ViewData它只會存在這次的HTTP要求而已,而不像Session可以將數據帶到下HTTP要求。 public class TestController : Controller{…

java 正則表達式驗證郵箱格式是否合規 以及 正則表達式元字符

package com.ykmimi.testtest; /*** 測試郵箱地址是否合規* author ukyor**/ public class EmailTest {public static void main(String[] args) {//定義要匹配的Email地址的正則表達式//其中\w代表可用作標識符的字符,不包括$. \w表示多個// \\.\\w表示點.后面有\w 括號{2,3}…

鏡頭選型

景深&#xff1a; 光圈越大&#xff0c;光圈值越小&#xff0c;景深越小 光圈越小&#xff0c;光圈值越大&#xff0c;景深越深 焦距越長&#xff0c;視角越小&#xff0c;主體像越大&#xff0c;景深越小 主體越近&#xff0c;景深越小

迅雷賬號

賬號 jiangchnangli:1 密碼 892812 網址 http://www.s8song.net/read-htm-tid-4906661.html漫晴xydcq7681轉載于:https://www.cnblogs.com/wlzhang/p/4563118.html

【Swift學習】Swift編程之旅---ARC(二十)

Swift使用自動引用計數(ARC)來跟蹤并管理應用使用的內存。大部分情況下&#xff0c;這意味著在Swift語言中&#xff0c;內存管理"仍然工作"&#xff0c;不需要自己去考慮內存管理的事情。當實例不再被使用時&#xff0c;ARC會自動釋放這些類的實例所占用的內存。然而…

像元大小及精度

說完了光學系統的分辨率之后我們來看看相機的圖像分辨率。圖像分辨率比較好理解&#xff0c;就是單位距離內的像用多少個像素來顯示。以我們的ORCA-Flash4.0為例&#xff0c;芯片的像元大小為 6.5 μm&#xff0c;在 40X物鏡的放大倍率下&#xff0c;1 μm的物經光學系統放大為…