((*(__IO uint32_t*)Addr) & 0x2FFE0000 ) == 0x20000000


  1. 128 Kbytes的SRAM 地址范圍是 0x2000 0000  --0x2001 FFFF;

  2. 堆棧指針(SP) 必須在 0x2000 0000 -- 0x2001 FFFF 這塊Region,這很好理解對吧,因為SRAM就在這嘛,只要SP位於這塊Region即可。

  3. 所以 SP & 0x2FFE 0000 == 0x2000 0000,不去管SP的bit16 - 0,只檢查bit27-17。

  4. 假如是 64 Kbytes 的 RAM,地址Region為 0x2000 0000 -- 0x2000 FFFF,那么此時應該這樣寫  SP & 0x2FFF 0000 == 0x2000 0000。當然,寫成 SP & 0x2FFE 0000 也能執行,只是會帶來隱患,這種Bug很討厭的,因為不好發現

  5. 鏈接:https://blog.csdn.net/qq_21226319/article/details/74516391


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM