當我爲Cortex-A15和Cortex-A9開發基準測試代碼時,發生了這個問題。它們都基於ARMv7-A體系結構,這意味着相同的程序集可以在兩者上運行,還是體系結構版本只定義一個通用設計?ARM體系結構是否意味着跨核心兼容性
2
A
回答
2
體系結構版本管理基本指令集,寄存器等,因此任何「v7」代碼都可以在任何v7體系結構上運行(注意到v7-M僅支持Thumb指令集) - 但如果它使用任何特定於v7的指令,則可能與v6和更早版本不兼容。
但是,有許多可選的架構擴展可能會或可能不會出現在任何給定的實現上,例如浮點,NEON,安全擴展等。任何依賴這些擴展的可移植代碼都應該檢查在嘗試使用可能不存在並可能導致異常的功能之前先讀取標準系統寄存器的功能。例如,A15具有虛擬化擴展和A9沒有的大型物理地址擴展。
基礎架構中還有一些特性被定義爲實現定義的,例如ACTLR
(輔助控制寄存器),它通常用於公開內核微架構的細節(例如控制位以啓用/禁用分支預測器)。這些內容的含義和用途甚至可以在覈心的不同修訂之間有所不同,但通常是大多數人不需要甚至看它們的低級別事情。
0
如果有的話,差異是微妙的。編寫適用於多種ARM體系結構的程序集不太難。真正的問題是,外圍設備等核心外的內容在供應商和產品之間非常顯着,所以在廣泛添加兩個數字端口的情況下,您對這些數字的處理方式最終會有所不同。
ARM在記錄這些事情方面做得很好。 ARM arm架構參考手冊(Arm arm)和trms技術參考手冊之間。無論誰擁有指令集詳細信息,都會記錄每條指令或每條指令的形式,哪些架構支持該指令。然後,您可以選擇您感興趣的所有變體支持的指令。
相關問題
- 1. @OneToOne是否意味着唯一性?
- 2. 究竟構建體系結構,有效的構建體系結構意味着什麼?
- 3. '!'是否意味着perl?
- 4. 構建LDAP V3兼容應用程序意味着什麼?
- 5. Angular + ASP.Net核心:插件體系結構
- 6. 核心庫的異常體系結構
- 7. dw,db和? (問號)是否意味着在TASM結構中?
- 8. ADO.NET實體框架中的持久性無知是否意味着我認爲這意味着什麼?
- 9. $是什麼?是否意味着在Ruby?
- 10. 是什麼;是否意味着在Ruby?
- 11. ARM體系結構和系列
- 12. Xcode 5:約64位體系結構和向後兼容性
- 13. iOS armv7s體系結構兼容性和最終問題
- 14. 更多的意見是否意味着ViewGroup的性能更差?
- 15. 一個可組合的應用程序是否必然意味着基於插件的體系結構
- 16. OpenGL的核心和兼容性
- 17. 「content-encoding:gzip」是否意味着內容是gzip格式?
- 18. 在AngularJS中結尾意味着什麼double意味着
- 19. 什麼是「U」意味着「性別」值?
- 20. ILOnly = 0是否意味着C++/CLI?
- 21. << - 是否意味着紅寶石?
- 22. 新的URL(...)。openConnection()是否意味着POST?
- 23. 這是否意味着數據步驟?
- 24. 「僅限邀請」是否意味着beta?
- 25. 正斜槓(/)是否意味着目錄?
- 26. ASP.NET是否意味着ASP.NET WebForms?
- 27. rollapply改性意味着
- 28. XmlSchemaElement類屬性意味着
- 29. 結構指針兼容性
- 30. 核心在iphone庫中意味着什麼?