作者bfc00000 (mips)
標題Re: [問題] MIPS32 24kec 異常位址
時間Tue Oct 23 10:39:19 2018
找了一下 datasheet 都沒提到 memory map....
MT7688_Datasheet_v1_4.pdf
從mtk7688管網找到 build bootcode的方法 連到 github下找
注意到:build的 bootcode是放在 TEXT_BASE=0xBC000000
cache address是在 9c000000,
住意不是 bfc00000, 代表在 bfc00000已經有 romcode了。
你可以用 ice讀
0xbc000000是不是你 flash內容,
以及 0xbfc00000 作反組譯 看能不能反出有意義的 text code.
附上 找 mtk7688的過程
mtk7688介紹:
https://docs.labs.mediatek.com/resource/linkit-smart-7688/
en/tutorials/firmware-and-bootloader/bootloader-and-kernel-console
Step 1 — Get bootloader source code
Clone the UBOOT source from GitHub repository.
連到 github
https://github.com/MediaTek-Labs/linkit-smart-7688-uboot
尋找:TEXT_BASE
https://github.com/MediaTek-Labs/linkit-smart-7688-uboot/
search?q=TEXT_BASE&unscoped_q=TEXT_BASE
.config
TEXT_BASE=0xBC000000
config.mk
CPPFLAGS := $(DBGFLAGS) $(OPTFLAGS) $(RELFLAGS) \
-D__KERNEL__ -DTEXT_BASE=$(TEXT_BASE) \
-I$(TOPDIR)/include \
LDFLAGS += -Bstatic -T $(LDSCRIPT) -Ttext $(TEXT_BASE) $(PLATFORM_LDFLAGS)
Step 3 — Build and upload the modified bootloader
Now build the bootloader and upload it to the board.
※ 引述《ice0803 (SoFarSoGood)》之銘言:
: 目前在學習MIPS32 24Kec的cpu架構
: 使用 usbWiggler™ - Macraigor Systems LLC
: 用 Ocd Commander程式透過 jtag上觀察cpu的register
: 目前環境是 flash是完全清除下,也就是0xFFFFF....
: 照 MIPS的文件上說他會從 0xbfc00000開始讀指令
: https://www.dropbox.com/s/7x3hmo5qv1vrs1q/Exception%20Vectors.jpg?dl=0
: 但讀到0xffffffff之後,因為解不出來,所以產生exception
: 理論上 PC應該是跳轉到0xbfc00380才對
: 但在 Ocd Commander 卻顯示0x9c000380
: https://www.dropbox.com/s/iv65dpmdo09g5q6/issue.jpg?dl=0
: 請問這是為什麼?
: 謝謝大家
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 59.124.166.19
※ 文章網址: https://webptt.com/m.aspx?n=bbs/ASM/M.1540262365.A.42C.html