《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 解決方案 > 如何利用現(xiàn)代嵌入式開發(fā)工具中的堆棧保護(hù)功能

如何利用現(xiàn)代嵌入式開發(fā)工具中的堆棧保護(hù)功能

2022-02-16
來源:IAR Systems

在開發(fā)以MCU為核心的嵌入式系統(tǒng)時(shí),當(dāng)軟件程序向預(yù)設(shè)的數(shù)據(jù)結(jié)構(gòu)(通常是一個(gè)固定長度的緩沖區(qū))之外的程序調(diào)用堆棧的內(nèi)存地址范圍寫入數(shù)據(jù)時(shí),就會(huì)發(fā)生堆棧緩沖區(qū)溢出。這幾乎必然會(huì)損壞附近的數(shù)據(jù),甚至?xí)淖兎祷睾瘮?shù)。如果是有意為之,則這就是我們熟知的堆棧粉碎。防范堆棧緩沖區(qū)溢出的一種方法是使用堆棧canary,因其類似于在煤礦中使用金絲雀偵測毒氣而得名。目前,在以IAR Embedded Workbench為代表的領(lǐng)先開發(fā)工具的所有最新版本中,均已支持堆棧保護(hù)功能。

堆棧保護(hù)功能已經(jīng)成為最新嵌入式開發(fā)工具中必要的功能,但要在諸如IAR Embedded Workbench for Arm這樣的行業(yè)標(biāo)桿工具中實(shí)現(xiàn)堆棧保護(hù),就要使用一種啟發(fā)式算法來確認(rèn)一個(gè)函數(shù)是否需要堆棧保護(hù)。如果任何函數(shù)內(nèi)定義的局部變量為數(shù)組類型或包含數(shù)組類型成員的結(jié)構(gòu)類型,則該函數(shù)就需要堆棧保護(hù)。此外,如果任何局部變量的地址被傳播到函數(shù)之外,則該函數(shù)也需要堆棧保護(hù)。

如果一個(gè)函數(shù)需要堆棧保護(hù),那么該函數(shù)的局部變量將被按序排放,將數(shù)組類型的變量在函數(shù)堆棧中被放置在盡可能高的地址。在這些變量之后,會(huì)放置一個(gè)canary元素。在函數(shù)入口處,canary被初始化。初始化值取自全局變量 __stack_chk_guard。在函數(shù)退出時(shí),代碼會(huì)驗(yàn)證canary元素是否仍然包含初始化值。如果該數(shù)值被改變,函數(shù) __stack_chk_fail就會(huì)被調(diào)用。

以被廣泛使用的IAR Embedded Workbench for Arm嵌入式開發(fā)工具為例,使用Project>Options>C/C++ Compiler>Code>Stack protection選項(xiàng),即可針對被認(rèn)定為需要保護(hù)的函數(shù)啟用堆棧保護(hù)。

proxy1.png

或者,您也可以使用Project>Options>C/C++ Compiler>Extra Options頁面,指定 --stack_protection命令行來啟用堆棧保護(hù)功能。

在實(shí)際應(yīng)用實(shí)現(xiàn)堆棧保護(hù)

要使用堆棧保護(hù),開發(fā)人員必須在應(yīng)用中定義以下對象:

·extern uint32_t __stack_chk_guard
全局變量 __stack_chk_guard在第一次使用前必須被初始化。如果初始化值是隨機(jī)的,則安全性會(huì)更高。

·__interwork __nounwind __noreturn void __stack_chk_fail(void)
__stack_chk_fail函數(shù)的作用是通知發(fā)生了錯(cuò)誤,然后終止應(yīng)用。請注意,這個(gè)函數(shù)的返回地址將指向失效函數(shù)。

arm\src\lib\runtime目錄下的文件stack_protection.c提供了 __stack_chk_guard和 __stack_chk_fail函數(shù)的參考模板。


總結(jié)

由于今天全球半導(dǎo)體供應(yīng)鏈緊張狀況尚未得到緩解,因此許多MCU等嵌入式應(yīng)用需要利用開發(fā)工具來保持核心技術(shù)和器件供應(yīng)上的靈活性,并最大限度地在不同硬件平臺上重用已完成的軟件。在這種情況下,無論是MCU芯片開發(fā)商還是嵌入式系統(tǒng)工程師,都需要利用那些已被業(yè)界最廣泛使用的開發(fā)工具,如IAR Embedded Workbench for Arm。由于這些工具也是其開發(fā)商和行業(yè)領(lǐng)先的MCU供應(yīng)商多年合作的成果,可以針對不同的硬件資源體系和應(yīng)用環(huán)境給出相應(yīng)的幫助,如IAR Embedded Workbench中的堆棧保護(hù)功能,因此可以以更短的研發(fā)周期,來實(shí)現(xiàn)嵌入式開發(fā)人員的研發(fā)目標(biāo)。

AETweidian.jpg

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點(diǎn)。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時(shí)通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
主站蜘蛛池模板: 中文字幕免费播放 | 婷婷国产在线 | 伊人欧美在线 | 午夜影院在线观看免费 | 国产三级全黄在线观看 | 黄色一级片在线播放 | 国产人成精品免费视频 | 日日干夜夜欢 | 狠狠色成人综合首页 | 中文字幕在线网 | 成人黄色三级视频 | 午夜久久免影院欧洲 | 色综久久天天综合绕视看 | 日韩欧美亚洲综合一区二区 | 日韩午夜影院 | 天天操天天舔 | 日韩第一| a丫久久久久久一级毛片 | 99久久er这里只有精品17 | 2021国产精品午夜久久 | 日本欧美成人 | 黄色污污 | 羞羞视频免费在线观看 | 亚洲aⅴ男人的天堂在线观看 | 男人和女人日皮视频 | 成人网在线播放 | 国产精品视频永久免费播放 | 免费国产成人高清在线观看不卡 | 久久澡人人澡狠狠澡 | 黄色在线小视频 | a级高清观看视频在线看 | 不卡国产| 深夜福利剧场 | 天天看天天碰 | 国产黄色在线免费观看 | 久久精品最新免费国产成人 | 免费国产一级特黄久久 | 在线视频观看一区 | 九月婷婷人人澡人人添人人爽 | 黄色生活毛片 | 日本三级香港三级久久99 |