![](/img/trans.png)
[英]Block Matching optimization using x86/x64 Streaming SIMD Extension
[英]x86 inline yasm convert to x64
我有使用嵌入式Yasm實施的項目。 現在,該項目使用openMP並行執行任務以獲得更好的性能。 在x86平台上,openMP無法運行,原因是x86環境沒有足夠的內存。 所以我用x64環境編譯它並且可以運行。 但是當我使用yasm代碼優化性能時,它就不能正常工作。(yasm的代碼是由x86環境編寫的。)
我搜索了所有內容,但是找不到任何有用的信息來解決此問題。
誰能告訴我解決問題的方法。 我想看一些帶有關聯信息的文檔。
謝謝您的幫助。
沒有你的代碼我最好的猜測是,你應該閱讀這對於AMD64 ABI看看調用約定標准的x64平台。 我認為這對你有用。 如該文檔中所述,您必須按以下方式傳遞參數(請注意,必須首先使用ABI標准中描述的方法對參數進行分類):
- 如果類是MEMORY,則在堆棧上傳遞參數。
- 如果該類是INTEGER,則使用序列
%rdi
,%rsi
,%rdx
,%rcx
,%r8
和%r9
的下一個可用寄存器。- 如果類是SSE,則使用下一個可用的向量寄存器,這些寄存器的順序為
%xmm0
到%xmm7
。
...
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.