日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[architecture]-CPU(ARM)启动的第一条指令

發布時間:2025/3/21 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [architecture]-CPU(ARM)启动的第一条指令 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

👉👉👉 個人博客筆記導讀目錄(全部) 👈👈👈


思考:

對于使用ARM設計的SOC,開機/Reset后的第一條指令是啥?一上電PC指向哪里呢?

總結寫在前面:

  • aarch64
    boot address 是允許設置的,軟件可配,根據信號RVBARADDR 具體設計而定
  • aarch32
    0x00000000(或VBAR) 和 0xffff0000, 二選一,根據VINIT value軟件可配
  • ARM M系列
    boot address 是固定的,比如M4/M0 是0x00000000

詳細說明:
在aarch64中,exception vector中是沒有Reset的。在Reset時,由RVBARADDR信號決定RVBAR_EL3的值,PC指向的第一條地址從RVBAR_EL3中讀出

在aarch32中,Reset做為exception vector的一部分,芯片復位即PC跳轉到向量表的reset offset,那么第一條指令的地址是什么?這就和Exception vectors start相關。而VINITHI信號決定了SCTLR.V的值.

  • 對于未實現secure monitore的情況:
    SCTLR.V = 0 : Exception vectors start=0x00000000
    SCTLR.V = 1 : Exception vectors start=0xffff0000
  • 對于實現secure monitor的情況:
    對于secure monitor level, Exception vectors start = MVBAR
    對于Normal EL1 level:
    normal SCTLR.V = 0 : Exception vectors start=normal VBAR
    normal SCTLR.V = 1 : Exception vectors start=0xffff0000
    對于Secure EL1 level:
    secure SCTLR.V = 0 : Exception vectors start=secure VBAR
    secure SCTLR.V = 1 : Exception vectors start=0xffff0000

參考:
1、 ARMV7-AR的page 1164
2、RVBARADDR信號VINITHI信號的介紹請參考<Cortex-A53的configuration signals>

總結

以上是生活随笔為你收集整理的[architecture]-CPU(ARM)启动的第一条指令的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。