-
128 Kbytes的SRAM 地址范圍是 0x2000 0000 --0x2001 FFFF;
-
堆棧指針(SP) 必須在 0x2000 0000 -- 0x2001 FFFF 這塊Region,這很好理解對吧,因為SRAM就在這嘛,只要SP位於這塊Region即可。
-
所以 SP & 0x2FFE 0000 == 0x2000 0000,不去管SP的bit16 - 0,只檢查bit27-17。
-
假如是 64 Kbytes 的 RAM,地址Region為 0x2000 0000 -- 0x2000 FFFF,那么此時應該這樣寫 SP & 0x2FFF 0000 == 0x2000 0000。當然,寫成 SP & 0x2FFE 0000 也能執行,只是會帶來隱患,這種Bug很討厭的,因為不好發現
- 鏈接:https://blog.csdn.net/qq_21226319/article/details/74516391