《電子技術應用》
您所在的位置:首頁 > 通信與網(wǎng)絡 > 業(yè)界動態(tài) > 在IAR Embedded Workbench開發(fā)工具中如何實現(xiàn)堆棧保護來提高代碼的安全性

在IAR Embedded Workbench開發(fā)工具中如何實現(xiàn)堆棧保護來提高代碼的安全性

2022-05-29
來源:IAR Systems

  隨著越來越多的嵌入式產(chǎn)品連接到外部網(wǎng)絡,嵌入式產(chǎn)品的信息安全性(Security)越來越多地被人們關注。其中既包括直接連接到外部網(wǎng)絡,比如通過Wi-Fi連接;也包括間接連接到外部網(wǎng)絡,比如汽車中的ECU通過CAN總線與T-box相連,而T-box通過移動網(wǎng)絡可以連接到外部網(wǎng)絡。特別是對于一些高功能安全性(Safety)要求的產(chǎn)品,如工業(yè),汽車,醫(yī)療產(chǎn)品等,信息安全成為了功能安全的前提(There Is No Safety Without Security)。

  在C/C++中,堆棧緩存溢出(Stack Buffer Overflow)是一種常見的錯誤:當程序往堆棧緩存(Stack Buffer)寫數(shù)據(jù)時,由于堆棧緩存通常采用固定長度,如果需要寫的數(shù)據(jù)長度超過堆棧緩存的長度時,就會造成堆棧緩存溢出。堆棧緩存溢出會覆蓋堆棧緩存臨近的堆棧數(shù)據(jù),其中可能包含函數(shù)的返回地址,就會造成函數(shù)返回時異常。如果堆棧緩存溢出是攻擊者利用代碼的漏洞蓄意造成的,它就稱為堆棧粉碎(Stack Smashing)。堆棧粉碎是常用的一種攻擊手段。

  堆棧金絲雀(Stack Canaries), 因其類似于在煤礦中使用金絲雀來感測瓦斯等氣體而得名,它可以用于在函數(shù)返回之前檢測堆棧緩存溢出來實現(xiàn)堆棧保護(Stack Protection),從而提高代碼的安全性。

  相對于很多更加關注發(fā)揮器件性能的原廠開發(fā)工具,一些在行業(yè)中被廣泛使用的商用開發(fā)工具更加關注性能和安全性的平衡性和完整性。本文以過去數(shù)十年來在行業(yè)中被廣泛采用的商用工具鏈IAR Embedded Workbench為例,介紹如何在工具中實現(xiàn)堆棧保護,從而提高代碼的安全性。

  堆棧粉碎

  在C/C++中,堆棧(Stack)用于保存程序正常運行(比如函數(shù)調(diào)用或者中斷搶占)的臨時數(shù)據(jù),可能包含如下數(shù)據(jù):

  沒有存儲在寄存器中的函數(shù)參數(shù)和局部變量

  沒有存儲在寄存器中的函數(shù)返回值和函數(shù)返回地址

  CPU和寄存器狀態(tài)

  由于堆棧保存的是保證程序正常運行的臨時數(shù)據(jù),堆棧緩存溢出會覆蓋堆棧緩存臨近的堆棧數(shù)據(jù),這些數(shù)據(jù)可能包含函數(shù)的返回地址,如果發(fā)生時一般會造成程序運行異常。攻擊者經(jīng)常利用這一點來進行堆棧粉碎攻擊。

  下面通過一個簡單的例子來說明堆棧粉碎攻擊:

  void foo(char *bar)

  {

  char c[12];

  strcpy(c, bar);  // no bounds checking

  }

  foo()函數(shù)將函數(shù)參數(shù)輸入復制到本地堆棧變量c。如下圖B所示:當函數(shù)參數(shù)輸入小于12個字符時,foo()函數(shù)會正常工作。如下圖C所示:當函數(shù)參數(shù)輸入大于11個字符時,foo()函數(shù)會覆蓋本地堆棧的數(shù)據(jù),將函數(shù)返回地址覆蓋為0x80C03508,當foo()函數(shù)返回時,會執(zhí)行地址0x80C03508對應的代碼A,代碼A有可能包含攻擊者提供的shell代碼,從而使攻擊者獲得操作權限。

  

1.jpg

  圖:堆棧粉碎示例

  堆棧保護

  因其功能類似于在煤礦中用來發(fā)現(xiàn)瓦斯的金絲雀而得名的堆棧金絲雀(Stack Canaries),可以用于在函數(shù)返回執(zhí)行惡意代碼之前檢測堆棧緩存溢出。其檢測原理是:當調(diào)用函數(shù)時,將需要保存的臨時數(shù)據(jù)保存到堆棧,然后放置一個堆棧金絲雀,當函數(shù)返回時,檢查堆棧金絲雀的值是否發(fā)生改變;如果發(fā)生改變,說明堆棧已被篡改,否則說明堆棧沒有被篡改。

  下面介紹如何在IAR Embedded Workbench這種廣受歡迎的商用工具鏈中實現(xiàn)堆棧保護,從而提高代碼的安全性:

  在IAR Embedded Workbench中,會使用啟發(fā)模式(Heuristic)來決定函數(shù)是否需要堆棧保護: 如果函數(shù)局部變量包含數(shù)組類型或者結構體成員包含數(shù)組類型,或者局部變量的地址在該函數(shù)外被使用,該函數(shù)需要堆棧保護。

  IAR Embedded Workbench安裝目錄下面\src\lib\runtime包含stack_protection.c,里面包含了__stack_chk_guard變量和__stack_chk_fail函數(shù),可以作為模板使用:其中__stack_chk_guard變量就是堆棧金絲雀的值,在函數(shù)返回時,如果檢測到堆棧金絲雀的值被篡改,就會調(diào)用__stack_chk_fail函數(shù)。

  1.將IAR Embedded Workbench安裝目錄下面\src\lib\runtime文件夾的stack_protection.c拷貝并添加到工程。

  2.在IAR Embedded Workbench中啟用堆棧保護。

  2.png

  3.在代碼中聲明堆棧保護相關的__stack_chk_guard變量和__stack_chk_fail函數(shù)。

  extern uint32_t __stack_chk_guard;

  __interwork __nounwind __noreturn void __stack_chk_fail(void);

  4.編譯工程。編譯器會在需要堆棧保護的函數(shù)中添加如下操作:在函數(shù)入口處先入棧(Push),然后再額外保存堆棧金絲雀,具體的值用戶可以在stack_protection.c中更改__stack_chk_guard;在函數(shù)出口,會檢測堆棧金絲雀的值是否還是__stack_chk_guard,如果不是,說明堆棧被篡改,會調(diào)用__stack_chk_fail函數(shù)。

  調(diào)試

  將斷點打到需要堆棧保護的函數(shù)反匯編(Disassembly)入口,暫停后發(fā)現(xiàn)編譯器在函數(shù)入口處入棧操作之后額外將堆棧金絲雀保存:

  

3.png

4.png

  在函數(shù)出口處打斷點,然后運行程序,在函數(shù)返回時,會先檢測堆棧金絲雀的值是否還是__stack_chk_guard,如果不是,說明堆棧被篡改,會調(diào)用__stack_chk_fail函數(shù)。

  

5.png

  改變堆棧金絲雀的值使之與__stack_chk_guard不一致,然后運行程序,函數(shù)返回時將會調(diào)用__stack_chk_fail函數(shù):

 

6.png

  總結

  本文主要介紹了堆棧粉碎攻擊如何利用堆棧緩存溢出來影響代碼的安全性。通過在IAR Embedded Workbench中實現(xiàn)堆棧保護可以檢測堆棧的完整性,從而提高代碼的安全性。

  參考文獻:

  1.https://en.wikipedia.org/wiki/Stack_buffer_overflow

  2.https://cwe.mitre.org/data/definitions/121.html

  3.https://en.wikipedia.org/wiki/Buffer_overflow_protection

  4.https://www.iar.com/knowledge/learn/programming/stack-protection-in-iar-embedded-workbench/

  5.IAR C/C++ Development Guide (Stack protection)





圖片.jpg


本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認版權者。如涉及作品內(nèi)容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經(jīng)濟損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
欧美日本一区| 亚洲精品国产精品国自产观看浪潮| 欧美成人第一页| 欧美在线视频观看| 午夜在线精品偷拍| 午夜精品亚洲| 亚洲欧美日韩国产中文| 在线视频亚洲欧美| 一区二区三区视频观看| 99精品视频免费在线观看| 亚洲精品小视频在线观看| 亚洲国产片色| 亚洲精品国精品久久99热| 亚洲国产欧美精品| 亚洲精品国产精品国自产观看浪潮 | 亚洲伦理在线| 亚洲精品久久久久久下一站 | 免费久久99精品国产自| 麻豆成人av| 欧美国产精品va在线观看| 欧美成人一区二区三区| 欧美久久久久| 国产精品白丝av嫩草影院 | 国产欧美一级| 国产真实精品久久二三区| 一区在线视频| 亚洲精品资源| 亚洲天堂视频在线观看| 性欧美激情精品| 久久精品亚洲精品国产欧美kt∨| 亚洲国产欧美久久| av成人激情| 亚洲综合成人婷婷小说| 欧美在线观看一区二区| 久久久青草婷婷精品综合日韩| 麻豆成人综合网| 欧美日本一区二区高清播放视频| 国产精品v一区二区三区 | 国产一区二区三区免费观看| 亚洲第一在线综合网站| 亚洲精品视频一区二区三区| 亚洲午夜久久久| 久久狠狠亚洲综合| 亚洲精品一区二区三区福利| 亚洲视频1区2区| 久久99伊人| 欧美激情一二三区| 国产精品每日更新| 国产一区导航| 亚洲精品黄色| 亚洲欧美欧美一区二区三区| 亚洲激情二区| 亚洲专区欧美专区| 久久婷婷综合激情| 欧美日韩亚洲一区三区| 国产日韩欧美一区| 亚洲国产91色在线| 亚洲一二三区视频在线观看| 久久成人免费网| 亚洲图片欧美一区| 久久综合给合| 国产精品jizz在线观看美国| 国精产品99永久一区一区| 99精品视频免费全部在线| 午夜在线一区| 日韩午夜剧场| 久久精品免费播放| 欧美日韩亚洲一区三区| 狠狠色综合网站久久久久久久| 日韩一级网站| 亚洲国产精品久久| 西瓜成人精品人成网站| 欧美国产一区在线| 国产视频精品va久久久久久| 亚洲人午夜精品免费| 欧美一区二区播放| 亚洲一区二区三区免费观看 | 国产精品99久久久久久久久| 亚洲激情在线| 久久九九99视频| 欧美日韩中文另类| 亚洲国产小视频| 欧美一级电影久久| 亚洲一区二区在线看| 欧美成人蜜桃| 国产一区二区精品丝袜| 亚洲丝袜av一区| 99这里只有久久精品视频| 久热精品视频在线免费观看| 国产精品免费看| 亚洲精品在线观看免费| 亚洲国产精品va在线观看黑人| 小嫩嫩精品导航| 欧美日韩中文字幕在线| 亚洲国产精品一区二区www在线| 欧美在线网站| 香蕉国产精品偷在线观看不卡| 欧美视频在线观看一区| 亚洲国产成人久久综合一区| 欧美影院成年免费版| 午夜精品免费在线| 欧美色图天堂网| 亚洲美女毛片| 99视频在线精品国自产拍免费观看 | 美女主播精品视频一二三四| 国产亚洲一区二区在线观看| 亚洲免费网址| 先锋影音久久久| 国产精品日韩电影| 亚洲先锋成人| 亚洲免费视频中文字幕| 欧美色播在线播放| 一本色道久久综合亚洲精品小说| 一本色道久久加勒比精品| 欧美韩国日本综合| 亚洲精品久久嫩草网站秘色| 亚洲精品一级| 欧美激情一区二区三区不卡| 最近看过的日韩成人| 亚洲伦伦在线| 欧美精品久久久久a| 91久久在线播放| 夜色激情一区二区| 欧美调教视频| 正在播放亚洲| 午夜一区二区三区不卡视频| 国产精品一区2区| 欧美一级在线播放| 久久女同互慰一区二区三区| 一区二区视频在线观看| 亚洲欧洲在线看| 欧美绝品在线观看成人午夜影视| 亚洲啪啪91| 亚洲午夜日本在线观看| 国产精品卡一卡二卡三| 亚洲女ⅴideoshd黑人| 久久精品国产一区二区三区| 一区二区三区自拍| 亚洲靠逼com| 欧美四级剧情无删版影片| 中国日韩欧美久久久久久久久| 亚洲欧美日韩综合| 国产日韩精品在线| 亚洲国产精品成人| 欧美激情一区| 亚洲网址在线| 久久精品国产91精品亚洲| 伊人久久婷婷| 中国日韩欧美久久久久久久久| 国产精品久久久91| 欧美在线free| 欧美精品999| 亚洲在线黄色| 麻豆av福利av久久av| 日韩视频一区二区三区在线播放免费观看 | 久久免费国产精品1| 樱桃视频在线观看一区| 一本大道久久a久久精品综合 | 亚洲精品网址在线观看| 亚洲欧美一区二区精品久久久| 国产永久精品大片wwwapp| 亚洲精选中文字幕| 国产精品色网| 亚洲黄色成人| 国产精品ⅴa在线观看h| 欧美主播一区二区三区美女 久久精品人 | 亚洲精品乱码久久久久久黑人 | 国产视频精品va久久久久久| 亚洲精品一区二区三区四区高清| 国产精品扒开腿爽爽爽视频| 久久国产直播| 欧美午夜理伦三级在线观看| 欧美一区二区三区免费视| 欧美另类视频| 欧美专区在线观看| 欧美日韩在线一区二区三区| 久久成人精品一区二区三区| 欧美日韩在线免费| 亚洲国产福利在线| 国产精品久久久久久久久免费| 亚洲高清视频的网址| 欧美新色视频| 亚洲人成毛片在线播放| 国产精品视频自拍| 日韩午夜一区| 国外视频精品毛片| 亚洲伊人一本大道中文字幕| 伊人狠狠色丁香综合尤物| 亚洲综合另类| 1769国产精品| 欧美影院在线| 日韩天堂在线观看| 美女脱光内衣内裤视频久久网站| 亚洲一区中文字幕在线观看| 欧美巨乳在线| 亚洲国产日韩欧美综合久久| 国产日本欧美一区二区| 亚洲先锋成人| 亚洲国产黄色片| 久久乐国产精品|