Fw: [請益] Android Plugin 裡的 ABI

看板AndroidDev作者 (非常念舊)時間6年前 (2018/01/01 16:24), 6年前編輯推噓0(0058)
留言58則, 3人參與, 6年前最新討論串1/1
※ [本文轉錄自 GameDesign 看板 #1QIV0LNV ] 作者: gn00618777 (非常念舊) 看板: GameDesign 標題: [請益] Android Plugin 裡的 ABI 時間: Mon Jan 1 16:23:44 2018 我提供第三方 android sdk,一個aar檔。裡面有七個架構的 .so arm64-v8a armeabi armeabi-v7a mips mips64 x86 x86_64 我提供的 sdk 給客戶的專案,客戶的專案會 import 我的 aar,最後客戶 也會建置出app-release.aar,我將我的library.aar和客戶的app-release.aar 丟至Unity 的 Plugins輸出成apk出現 Failure to initialize! Your hardware does not support this application, sorry! 我最後解法是只留下 armeabi-v7a 才可以正常運作。 很奇怪!! 我在APK有加入 android.os.Build.SUPPORTED_ABIS 來看適合的ABI 它顯示出arm64-v8a阿!! 另外Unity平台不會自己選擇適合的 ABI嗎?我網路上查到的說是 Android 安裝包 會自己搜尋適合的ABI,但當我提供所有架構的.so,他感覺是從第一順位去找.. 感謝指教 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 119.14.189.37 ※ 文章網址: https://www.ptt.cc/bbs/GameDesign/M.1514795029.A.5DF.html ※ 發信站: 批踢踢實業坊(ptt.cc) ※ 轉錄者: gn00618777 (119.14.189.37), 01/01/2018 16:24:14 ※ 編輯: gn00618777 (119.14.189.37), 01/01/2018 16:25:32

01/01 16:32, 6年前 , 1F
我在Unity平台有看到設定Device Filter為
01/01 16:32, 1F

01/01 16:33, 6年前 , 2F
FAT(armeabi-v7a+x86) 不知道有沒有關聯 哈
01/01 16:33, 2F

01/01 16:45, 6年前 , 3F
https://goo.gl/sHngWS 好像非常有關!!
01/01 16:45, 3F

01/01 17:05, 6年前 , 4F
這應該是他PO的其他Library的問題
01/01 17:05, 4F

01/01 17:06, 6年前 , 5F
因為你的Library有提供到更適合該裝置的ABI 但是其他包沒有包
01/01 17:06, 5F

01/01 17:07, 6年前 , 6F
到這麼細XD 建議這樣給:1.全包 2.armeabi 3.armv7a+x86
01/01 17:07, 6F

01/01 17:08, 6年前 , 7F
檢驗這件事情非常簡單 把APK解開來看便知....
01/01 17:08, 7F

01/01 17:12, 6年前 , 8F
如果很堅持一定要發揮自己對armv8的優化 是可以反過來把Unity
01/01 17:12, 8F

01/01 17:13, 6年前 , 9F
的armv7a檔案複製一份到armv8跟你的放在一起
01/01 17:13, 9F

01/01 17:51, 6年前 , 10F
android只會先選一個目錄,然後那個目錄要所有so都有
01/01 17:51, 10F

01/01 17:52, 6年前 , 11F
不能有的lib包7平台有的只有3平台
01/01 17:52, 11F

01/01 17:54, 6年前 , 12F
跟res的找法不一樣,因為其實只是安裝時會設/lib的symlink
01/01 17:54, 12F

01/01 18:09, 6年前 , 13F
y大,我全包進去,就是出現不支援的狀況。
01/01 18:09, 13F

01/01 18:12, 6年前 , 14F
這網誌是我整理的 https://goo.gl/XintWw
01/01 18:12, 14F

01/01 18:14, 6年前 , 15F
@@我整理是覺得Unity平台是設定APP為armeabi-v7a
01/01 18:14, 15F

01/01 18:16, 6年前 , 16F
Manager偵測到我的裝置是arm64-v8a,所以去arm64-v8a/
01/01 18:16, 16F

01/01 18:17, 6年前 , 17F
尋找.so,但跟Unity設定的ABI,armeabi-v7a不符
01/01 18:17, 17F

01/01 18:18, 6年前 , 18F
所以才會跳出不supported的對話框
01/01 18:18, 18F

01/01 18:48, 6年前 , 19F
我覺得我講的不明白..這樣說好了 你要提供三個版本\
01/01 18:48, 19F

01/01 18:49, 6年前 , 20F
1.全部都包
01/01 18:49, 20F

01/01 18:49, 6年前 , 21F
2.只有armeabi
01/01 18:49, 21F

01/01 18:49, 6年前 , 22F
3.arvm7a+x86
01/01 18:49, 22F

01/01 18:49, 6年前 , 23F
然後可以註明版本3是for Unity3D 我的意思大概是這樣@@
01/01 18:49, 23F

01/01 18:50, 6年前 , 24F
舉個例子你的包有a.so Unity的包有b.so 但是跟你的包同時使用
01/01 18:50, 24F

01/01 18:52, 6年前 , 25F
時 在armv8那邊會只有a.so 而系統只會傻傻的去找他認為最適合
01/01 18:52, 25F

01/01 18:52, 6年前 , 26F
的armv8撈a.so跟b.so 這時候死的是Unity 但你難辭其咎XD
01/01 18:52, 26F

01/01 18:56, 6年前 , 27F
就如上面s大所說 這跟res的使用有差 我同事一開始也是轉不過
01/01 18:56, 27F

01/01 18:56, 6年前 , 28F
來....
01/01 18:56, 28F

01/01 19:04, 6年前 , 29F
y大,感謝你的解說,還有一件事不太解,就是你說把
01/01 19:04, 29F

01/01 19:06, 6年前 , 30F
Unity的armv7a檔案複製一分到armv8,所有的so
01/01 19:06, 30F

01/01 19:08, 6年前 , 31F
都由我提供阿,怎麼聽你說Unity會產出armeabi-v7a的
01/01 19:08, 31F

01/01 19:09, 6年前 , 32F
的感覺
01/01 19:09, 32F

01/01 19:11, 6年前 , 33F
會阿 你今天的問題就是因為Unity的package會帶進他自己的arm
01/01 19:11, 33F

01/01 19:12, 6年前 , 34F
v7a library(prebuilt的) 才會有之後的問題 你那個錯誤訊息也
01/01 19:12, 34F

01/01 19:13, 6年前 , 35F
是Unity自己出的 是你的包少了的話多半都是直接炸Unstaisfied
01/01 19:13, 35F

01/01 19:13, 6年前 , 36F
LinkException
01/01 19:13, 36F

01/01 19:24, 6年前 , 37F
請問Unity產出的armeabi-v7a我可以在哪邊找到呢?
01/01 19:24, 37F

01/01 19:28, 6年前 , 38F
把Unity包出來的apk解壓縮就可以了
01/01 19:28, 38F

01/01 19:29, 6年前 , 39F
不過這意味著每一版的Unity你都要這樣做一次喔 要想清楚 我不
01/01 19:29, 39F

01/01 19:32, 6年前 , 40F
太相信現在真的有人會去為了armv8a優化 這種狀況下有沒有這
01/01 19:32, 40F

01/01 19:33, 6年前 , 41F
樣強制支援armv8我覺得都沒差...
01/01 19:33, 41F

01/01 19:39, 6年前 , 42F
了解 純粹多問多吸%而已 XD我沒要做到那麼徹底
01/01 19:39, 42F

01/01 19:41, 6年前 , 43F
感謝 最後想再請問,Unity平台設定 armeabi-v7a
01/01 19:41, 43F

01/01 19:42, 6年前 , 44F
所謂的設定ABI是說compiler將app編譯成可以呼叫對應架
01/01 19:42, 44F

01/01 19:43, 6年前 , 45F
構so的意思嗎?應該說,程式可以編譯成對應的ABI架構
01/01 19:43, 45F

01/01 19:44, 6年前 , 46F
好讓它能呼叫正確的so?
01/01 19:44, 46F

01/01 19:54, 6年前 , 47F
Unity裡面的native library都是預包好的.so 他們不可能把tool
01/01 19:54, 47F

01/01 19:55, 6年前 , 48F
chain之類的東西包進去當場從source去build...
01/01 19:55, 48F

01/01 19:55, 6年前 , 49F
所以那個設定只是讓在產生Android專案時選擇要放進的lib而以
01/01 19:55, 49F

01/01 20:03, 6年前 , 50F
不不不,小弟的意思是問,一個程式要能使用某個架構
01/01 20:03, 50F

01/01 20:04, 6年前 , 51F
的native,是此程式需要被編譯成能夠使用此架構ABI模
01/01 20:04, 51F

01/01 20:04, 6年前 , 52F
式嗎@@?
01/01 20:04, 52F

01/01 20:11, 6年前 , 53F
解壓了之後的確有看到x86 和armeabi-v67a的lib
01/01 20:11, 53F

01/01 20:14, 6年前 , 54F
然後安卓系統卻在arm64找不到這些lib!!
01/01 20:14, 54F

01/01 20:15, 6年前 , 55F
所以才會出現這問題
01/01 20:15, 55F

01/01 20:22, 6年前 , 56F
只要在APK的/lib/裡面有對應的資料夾即可 我記得空的他也算..
01/01 20:22, 56F

01/01 20:47, 6年前 , 57F
感謝解說
01/01 20:47, 57F

01/01 20:48, 6年前 , 58F
空的它也算啥???
01/01 20:48, 58F
文章代碼(AID): #1QIV0lqz (AndroidDev)
文章代碼(AID): #1QIV0lqz (AndroidDev)