女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]基于ARM架構(gòu)的處理器的C語言程序設(shè)計遵循ATPCS(ARM-THUMB procedure call standard)和AAPCS(ARM Application Procedure Call Standard)。ATPCS規(guī)定數(shù)據(jù)棧為FD(滿遞減Full Decrease)類型,并且對數(shù)據(jù)棧的操作是8字節(jié)對

基于ARM架構(gòu)的處理器的C語言程序設(shè)計遵循ATPCS(ARM-THUMB procedure call standard)和AAPCS(ARM Application Procedure Call Standard)。ATPCS規(guī)定數(shù)據(jù)棧為FD(滿遞減Full Decrease)類型,并且對數(shù)據(jù)棧的操作是8字節(jié)對齊的。在我自己的輕量級的嵌入式操作系統(tǒng)tqOS中沒有考慮到線程工作棧的8字節(jié)對齊的問題,這樣從內(nèi)存池中分配到的棧的起始地址可能是4字節(jié)對齊的也可能是8字節(jié)對齊的,如果運氣好每一個線程的棧式8字節(jié)對齊的則不會有什么問題出現(xiàn),如果運氣差線程的棧式4字節(jié)對齊的,那么就會導(dǎo)致種種錯誤......例如,最要命的是在線程函數(shù)中進(jìn)行浮點數(shù)運算的時候,兩個浮點數(shù)初始化之后打印出來都是錯誤的數(shù)據(jù),進(jìn)行算術(shù)運算之后也是錯誤的結(jié)果。因為浮點數(shù)double是8字節(jié)的,可能非8字節(jié)對齊的棧會導(dǎo)致運算出錯。為了解決這個問題,我在tqOS的任務(wù)創(chuàng)建函數(shù)中對任務(wù)??臻g的分配中做了調(diào)整,將棧的起始地址始終設(shè)置為8字節(jié)對齊,如果不為8字節(jié)對齊則將棧指針下移至8字節(jié)對齊處。另外,APTCS要求了對棧的操作必須是8字節(jié)對齊的,所以對任務(wù)棧的初始化也是有要求的,也就是說一次要入棧兩個數(shù)據(jù),或者說一次要入棧偶數(shù)個數(shù)據(jù),因為一次只入棧一個數(shù)據(jù)(4字節(jié)長度)的話就會導(dǎo)致棧的地址變成非8字節(jié)對齊了,這是不允許的!C語言程序會由ARM的C編譯器會做好8字節(jié)對齊工作,但是涉及匯編和操作系統(tǒng)的時候就需要自己把握好入棧的數(shù)據(jù)問題。為此我把棧初始化函數(shù)里面的一個小小的部分改了一下,就是為了保證初始化完棧之后棧頂指針依然為8字節(jié)對齊的(詳見tqOS的修改版的注釋)。

綜上,程序設(shè)計時需要保證棧指針為8字節(jié)對齊,使用操作系統(tǒng)是要保證每個任務(wù)的工作棧為8字節(jié)對齊的。詳細(xì)信息搜索ATPCS和AAPCS。

引例:http://bbs.elecfans.com/jishu_468500_1_1.html

1. 當(dāng)堆棧為單字對齊時,將有可能導(dǎo)致lib c這樣嚴(yán)格按照AAPCS規(guī)范的庫函數(shù)使用異常。

2. 程序中MSP、PSP的地址應(yīng)盡量雙字對齊(即地址能被8整除)。

由于編譯器在后續(xù)的反匯編中保證堆棧的雙字對齊,但為了應(yīng)對極端情況,Cortex-M3and Cortex-M4中提供了一種硬件自動補(bǔ)齊功能。用戶可以通過將SCB->CCR[9]置1使能此項功能。(缺省為雙字對齊),當(dāng)發(fā)生中斷時由硬件自動檢測堆棧是否雙字對齊,如果對齊了,則不進(jìn)行任何操作,如果沒有對齊,則自動將SP減4這樣便對齊。同時將xPSR的第9位置位。詳細(xì)描述如下:

Another requirement of the AAPCS is that the stack pointer value should be double-wordaligned at function entry or exit boundary. As a result, the Cortex-M3 and Cortex-M4processors can insert an additional word of padding space in the stackautomatically if the stack pointer was not aligned to double-word location whenthe interrupt happened. In this way, we can guarantee that the stack pointer willbe at the beginning of the exception handler. This “double-word stack alignment”feature is programmable, and can be turned off if the exception handlers do notneed full AAPCS compliance.

The bit 9 of the stacked xPSR is used to indicate if the valueof the stack pointer has been adjusted. In Figure8.2, the stack pointer was aligned to double-word address location,so no padding was inserted and bit 9 of the stack xPSR is set to 0. The samestack frame behavior can also be found when the double-word stack alignmentfeature is turned off, even if the value of stack pointer wasn’t aligned to double-word boundary.


本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

Sept. 8, 2025 ---- 根據(jù)TrendForce集邦咨詢最新調(diào)查,2025年第二季NVIDIA(英偉達(dá)) Blackwell平臺規(guī)模化出貨,以及北美CSP業(yè)者持續(xù)擴(kuò)大布局General Server(通用型...

關(guān)鍵字: SSD DDR4 服務(wù)器

Sept. 4, 2025 ---- Apple(蘋果)即將發(fā)布iPhone 17、iPhone 17 Air(暫名)、iPhone 17 Pro及Pro Max四款旗艦新機(jī),除了外觀辨識度升級,處理器性能、散熱和拍攝功...

關(guān)鍵字: iPhone 16 A19處理器 折疊機(jī)

Sept. 3, 2025 ---- 根據(jù)TrendForce集邦咨詢最新發(fā)布的《2025近眼顯示市場趨勢與技術(shù)分析》報告,2025年隨著國際品牌陸續(xù)推出AR眼鏡原型,以及Meta預(yù)計在近期發(fā)布AR眼鏡Celeste,市...

關(guān)鍵字: AR眼鏡 OLED

Sept. 2, 2025 ---- TrendForce集邦咨詢表示,2025年第二季DRAM產(chǎn)業(yè)因一般型DRAM (Conventional DRAM)合約價上漲、出貨量顯著增長,加上HBM出貨規(guī)模擴(kuò)張,整體營收為3...

關(guān)鍵字: DRAM 智能手機(jī) ASP

Sept. 1, 2025 ---- 根據(jù)TrendForce集邦咨詢最新調(diào)查,2025年第二季因中國市場消費補(bǔ)貼引發(fā)的提前備貨效應(yīng),以及下半年智能手機(jī)、筆電/PC、Server新品所需帶動,整體晶圓代工產(chǎn)能利用率與出貨...

關(guān)鍵字: 晶圓代工 智能手機(jī) 筆電

Aug. 28, 2025 ---- 根據(jù)TrendForce集邦咨詢最新調(diào)查,2025年第二季NAND Flash產(chǎn)業(yè)雖面臨平均銷售價格(ASP)小幅下滑,所幸原廠減產(chǎn)策略緩解供需失衡,疊加中、美兩大市場政策推動,整體...

關(guān)鍵字: NAND Flash SSD AI

Aug. 26, 2025 ---- NVIDIA(英偉達(dá))近日推出的Jetson Thor被視為機(jī)器人的物理智慧核心,以Blackwell GPU、128 GB記憶體堆疊出2070 FP4 TFLOPS AI算力,是前...

關(guān)鍵字: 機(jī)器人 大型語言模型 AI算力

Aug. 21, 2025 ---- 根據(jù)TrendForce集邦咨詢最新液冷產(chǎn)業(yè)研究,隨著NVIDIA GB200 NVL72機(jī)柜式服務(wù)器于2025年放量出貨,云端業(yè)者加速升級AI數(shù)據(jù)中心架構(gòu),促使液冷技術(shù)從早期試點邁...

關(guān)鍵字: AI 數(shù)據(jù)中心 服務(wù)器

除了充電電路外,鋰電池的放電過程也需要保護(hù)。鋰電池的放電電壓不能低于3.0V,否則電池壽命會大幅縮短。為了實現(xiàn)這一保護(hù),工程師們設(shè)計了DW01芯片與8205 MOS管的電路組合。DW01芯片能夠監(jiān)控鋰電池的放電電壓和電流...

關(guān)鍵字: 鋰電池 電池

在PCB設(shè)計的宏偉藍(lán)圖中,布局與布線規(guī)則猶如精密樂章中的指揮棒,是鑄就電路板卓越性能、堅不可摧的可靠性及經(jīng)濟(jì)高效的制造成本的靈魂所在。恰如一位巧手的園藝師,合理的布局藝術(shù)性地編排著每一寸空間,既削減了布線交織的繁復(fù)迷宮,...

關(guān)鍵字: PCB 電路板
關(guān)閉