国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

在 OpenHarmony 開發板上運行 WasmEdge

開發 前端
WasmEdge 目前已經支持了 Linux、macOS、Windows 與 實時操作系統 seL4。添加 OpenHarmony 的支持,將豐富 WasmEdge 的生態。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

Why

移動與 IoT 設備的特點是資源受限,軟硬件不統一,用戶體驗卻要求很高。設備要能安全,跨平臺地運行第三方開發者提供的軟件應用(例如,應用商店),因而直接原生編譯的軟件應用(Native Client, or NaCl)并不主流。鴻蒙與安卓這樣的主流操作系統一般提供基于 Java 或者 JavaScript 的軟件執行沙盒,來支持第三方應用。但是這樣的軟件執行沙盒有幾個大問題:

  • 支持的編程語言很有限
  • 支持的語言有 IP 與法律風險
  • 性能一般
  • 資源開銷大
  • 無法支持實時系統
  • 安全性一般(所以應用商店需要審查制)

而 WebAssembly 作為一個多語言,跨平臺,高性能,輕量級,安全的軟件執行環境,能讓開發者兼得性能,可移植性,與安全性。WebAssembly 是移動與 IoT 設備上系統中間件的最佳選擇。

WasmEdge 是由 CNCF 托管的輕量級、高性能和可擴展的 WebAssembly runtime,適用于云原生、邊緣和去中心化應用程序。WasmEdge 可以運行 C/C++、Rust、Swift、AssemblyScript 或 Kotlin 等語言編譯的標準 WebAssembly 字節碼程序。

OpenHarmony 是由開放原子開源基金會(OpenAtom Foundation)孵化及運營的開源項目,目標是面向全場景、全連接、全智能時代,基于開源的方式,搭建一個智能終端設備操作系統的框架和平臺,促進萬物互聯產業的繁榮發展。

WasmEdge 為 OpenHarmony 提供了一個與 JVM 與 JS engine 同級的 runtime,但是比 JVM、JS engine 更安全、更快、更小、更易于管理。通過 WasmEdge,可以在設備上安全地運行第三方開發者用 C、C++、Rust 等語言編寫的 Wasm 程序,擴大 OpenHarmony 的開發者群體。 WasmEdge 相當于 OpenHarmony 的一個完全開源的開發執行環境。社區開發者可以方便地運行編譯好的 WebAssembly 程序,降低門檻。

WasmEdge 目前已經支持了 Linux、macOS、Windows 與 實時操作系統 seL4。添加 OpenHarmony 的支持,將豐富 WasmEdge 的生態。

介紹完畢 ,下面進入編程時間。請參考下面的教程從源碼在 OpenHarmony 開發板中構建和測試 WasmEdge。

1. 全量編譯 OpenHarmony OS

2. 獲取 WasmEdge 源碼

3. 修改 OpenHarmony 標準系統配置文件

4. 構建 WasmEdge 與 OpenHarmony

5. 燒錄到開發板

6. 運行 WasmEdge 提供的測試用例

配合視頻觀看,效果更佳。

環境準備

OpenHarmony 標準系統

OpenHarmony 標準系統為開發者提供的 Docker 環境封裝了對應的編譯工具鏈,本文檔主要介紹在 Docker 環境下構建 WasmEdge 的步驟。

OpenHarmony 源碼的獲取與編譯可以參考 Open Harmony 提供的文檔 搭建Ubuntu環境-Docker方式。

請注意,在構建 WasmEdge 前需要將 Openharmony 進行一次全量編譯以便后續 WasmEdge 的交叉編譯過程。

  1. # 獲取到 docker 鏡像后 
  2. $ docker run -it -v $(pwd):/home/openharmony openharmony-docker-standard:0.0.5 
  3. $ ./build.sh --product-name Hi3516DV300 

獲取 WasmEdge 源碼

OpenHarmony 將第三方庫項目放在了 third_party 文件夾下,因此我們需要在 third_party 文件夾下獲取 WasmEdge 源碼。

這之后,用戶可以根據需要更改路徑并修改相關配置文件中的路徑。

  1. $ docker run -it -v $(pwd):/home/openharmony openharmony-docker-standard:0.0.5 
  2. $ cd third_party 
  3. $ git clone https://github.com/WasmEdge/WasmEdge.git 
  4. $ cd WasmEdge 

 修改 OpenHarmony 標準系統配置文件

添加 WasmEdge 子系統配置

修改 OpenHarmony 的 build 目錄下的 subsystem_config.json 文件,如下添加 wasmedge 子系統。

  1.   ... 
  2.    
  3.   "wasmedge": { 
  4.     "path""third_party/WasmEdge"
  5.     "name""wasmedge" 
  6.   }, 
  7.    
  8.   ... 

 將組件添加到產品配置中

修改 OpenHarmony 產品配置文件,標準系統對應的配置文件為:productdefine/common/products/Hi3516DV300.json。

在該配置文件中添加 "wasmedge:wasmedge":{},表示該產品會編譯并打包 wasmedge 子系統下的 wasmedge 模塊到版本中。

  1.   ... 
  2.   "parts":{ 
  3.     ... 
  4.     "wasmedge:wasmedge":{} 
  5.   } 

構建 WasmEdge 與 OpenHarmony

說明

在 OpenHarmony 中構建的 WasmEdge 目前僅支持 wasmedge,即 wasm 的通用運行時。

wasmedge 可以在解釋器模式下執行一個 WASM 文件, 也可以執行從 WASM 文件 AOT 預編譯產生的機器碼二進制格式文件。但目前還不支持在 OpenHarmony 中對 WASM 文件進行 AOT 預編譯 。

執行構建腳本

執行 WasmEdge 源碼下的 utils/build_for_ohos.sh 命令行腳本,將自動執行以下工作:

將 .gn 等 OpenHarmony 需要的構建配置文件移動到 WasmEdge 項目根目錄;

使用 OpenHarmony 的編譯工具鏈進行交叉編譯構建 WasmEdge;

運行 OpenHarmony 的構建腳本 build.sh 進行全量編譯,該步驟將 wasmedge 添加進 OpenHarmony OS;

  1. $ docker run -it -v $(pwd):/home/openharmony openharmony-docker-standard:0.0.5 
  2. $ cd third_party/WasmEdge/utils/ohos 
  3. $ ./build_for_ohos.sh /home/openharmony 

 當 terminal 顯示以下信息時,表明編譯完成。

  1. ... 
  2.  
  3. post_process 
  4. =====build Hi3516DV300 successful. 
  5. 2021-12-15 03:18:50 
  6. ++++++++++++++++++++++++++++++++++++++++ 

 檢查 wasmedge 是否編譯打包進 OpenHarmony OS。

  1. $ cd /home/openharmony/out/ohos-arm-release/packages/phone/system/bin 
  2. $ ls  

當輸出的文件名中存在 wasmedge 時,就表明 WasmEdge 已經成功導入到 OpenHarmony OS。

測試

燒錄鏡像

將重新編譯后的 OpenHarmony 標準系統鏡像燒錄進開發板,具體見 OpenHarmony 提供的文檔 Hi3516DV300 開發板燒錄。

運行應用

WasmEdge 在 tools/wasmedge/examples/ 文件夾提供了測試樣例。在 OpenHarmony 標準系統中,這些樣例寫入了 system 鏡像中,依然可以進行測試。通過串口工具連接上開發板并啟動OpenHarmony 標準系統后,我們就可以進行以下的測試。

  1. # cd /system/usr/wasmedge_example 
  2. # wasmedge hello.wasm 1 2 3 
  3. hello 
  4. # wasmedge --reactor add.wasm add 2 2 
  5. # wasmedge --reactor fibonacci.wasm fib 8 
  6. 34 
  7. # wasmedge --reactor factorial.wasm fac 12 
  8. 479001600 
  9. # cd js 
  10. # wasmedge --dir .:. qjs.wasm hello.js 1 2 3 
  11. Hello 1 2 3 

下一步

接下來,你可以參考 WasmEdge Book 在 OpenHarmony 標準系統中使用 WasmEdge Runtime 來運行你自己的 WebAssembly 應用。

移植過程踩過的坑

最后和大家分享一下,在移植 WasmEdge 到 OpenHarmony OS 過程出現的一些問題與值得注意的地方。

交叉編譯

cmake 項目進行交叉編譯需要配置工具鏈,官方的交叉編譯配置給出了參考,但需要在此基礎上細化,如指明 Clang 及 Clang++ 的位置。此外,標準版 sysroot 的路徑也有所不同,具體可以參考 WasmEdge 中的配置:

  1. set(TOOLSCHAIN_PATH "${OHOS_DIR_PATH}/prebuilts/clang/ohos/linux-x86_64/llvm"
  2. set(TOOLCHAIN_HOST "${TOOLSCHAIN_PATH}/bin"
  3. set(OHOS_SYSROOT_PATH "${OHOS_DIR_PATH}/out/ohos-arm-release/obj/third_party/musl"
  4. set(CMAKE_SYSROOT ${OHOS_SYSROOT_PATH}) 
  5. set(CMAKE_CROSSCOMPILING TRUE
  6. set(CMAKE_SYSTEM_NAME "Generic"
  7. set(CMAKE_CXX_COMPILER_ID Clang) 
  8. set(CMAKE_TOOLCHAIN_PREFIX llvm-) 
  9. set(LLVM_PATH "${OHOS_DIR_PATH}/prebuilts/clang/ohos/linux-x86_64/llvm"
  10. include_directories(${LLVM_PATH}/include/c++/v1) 
  11. include_directories(${OHOS_SYSROOT_PATH}/usr/include/arm-linux-ohosmusl) 
  12. link_directories(${OHOS_SYSROOT_PATH}/usr/lib/arm-linux-ohosmusl) 
  13. set(TOOLCHAIN_CC "${TOOLCHAIN_HOST}/clang"
  14. set(TOOLCHAIN_CXX "${TOOLCHAIN_HOST}/clang++"
  15. set(CMAKE_C_COMPILER ${TOOLCHAIN_CC}) 
  16. set(CMAKE_C_FLAGS "--target=arm-linux-ohosmusl -D__clang__ -march=armv7-a -mfloat-abi=softfp -mtune=generic-armv7-a -mfpu=neon -mthumb -w --sysroot=${OHOS_SYSROOT_PATH}"
  17. set(CMAKE_CXX_COMPILER ${TOOLCHAIN_CXX}) 
  18. set(CMAKE_CXX_FLAGS "--target=arm-linux-ohosmusl -D__clang__ -march=armv7-a -mfloat-abi=softfp -mtune=generic-armv7-a -mfpu=neon -mthumb -w --sysroot=${OHOS_SYSROOT_PATH}"
  19. set(MY_LINK_FLAGS "--target=arm-linux-ohosmusl --sysroot=${OHOS_SYSROOT_PATH}"
  20. set(CMAKE_LINKER clang) 
  21. set(CMAKE_CXX_LINKER clang++) 
  22. set(CMAKE_C_LINKER clang) 
  23. set(CMAKE_C_LINK_EXECUTABLE "${CMAKE_C_LINKER} ${MY_LINK_FLAGS} <FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> <LINK_LIBRARIES>"
  24. set(CMAKE_CXX_LINK_EXECUTABLE "${CMAKE_CXX_LINKER} ${MY_LINK_FLAGS} <FLAGS> <LINK_FLAGS> <OBJECTS> -o <TARGET> <LINK_LIBRARIES>"

編譯工具鏈

OpenHarmony OS 使用 gn+ninja 進行編譯。對于 cmake 組織編譯的項目來說,官方提供的 cmake 項目移植文檔給出的案例是基于輕量級系統的,并不完全適用于標準版系統上的移植。要想將項目寫入 OpenHarmony OS 編譯生成的鏡像燒錄到開發板上,需要編寫 gn 腳本參與進 OpenHarmony OS 的編譯過程。

在 WasmEdge 編譯過程中,需要使用到 spqlog 項目,構建過程中存在 spdlog 項目拉取及編譯生成 sqdlog 靜態庫的動作,這意味著只將 WasmEdge 相關庫的編譯過程改寫為 gn 腳本是不夠的,還需要對 spdlog 的編譯過程進行改寫,使得工作量急劇增加。

那么對于項目所依賴但并不屬于 OpenHarmony OS 中的靜態庫模塊,編譯過程中要如何將這一模塊引入 OpenHarmony OS 呢?

OpenHarmony OS 提供的 gn 編寫模板中有 ohos_copy ,它可以將生成的靜態庫移至生成的目標文件夾。這樣在真正編譯需要鏈接時,就能將這一靜態庫視為 OpenHarmony OS 的原生模塊而不是查無此庫。在 WasmEdge 的移植過程中,所執行的編譯腳本便是事先進行一遍交叉編譯,生成需要 copy 的 spdlog 靜態庫,然后再執行 OpenHarmony OS 的編譯腳本,從而按照項目目錄下的 BUILD.gn 內的定義組織編譯。

在 WasmEdge 的 BUILD.gn 中,關于 spdlog 靜態庫的描述如下:

  1. ohos_copy("spdlog"){ 
  2.     sources = [ 
  3.         "$WASMEDGE_ROOT_DIR/build/_deps/spdlog-build/libspdlog.a"
  4.     ] 
  5.     outputs = [ 
  6.         target_out_dir + "/lib/libspdlog.a" 
  7.     ] 
  8.     module_install_name = "" 

標準 C 庫

平時我們常用的標準 C 庫是 GNU 發布的 libc 庫,而 OpenHarmony 中使用的是 Musl-libc,因此如果需要移植的項目代碼中使用了 glibc 的宏變量的代碼,那么需要進行修改或者在開頭重新定義為 Musl-libc 中的宏變量。

鏈接項

  1. ../../third_party/WasmEdge/lib/system/allocator.cpp:64:40: error: unused variable 'k4G' [-Werror,-Wunused-const-variable] 
  2. static inline constexpr const uint64_t k4G = UINT64_C(0x100000000); 
  3.                                        ^ 
  4. ../../third_party/WasmEdge/lib/system/allocator.cpp:65:40: error: unused variable 'k12G' [-Werror,-Wunused-const-variable] 
  5. static inline constexpr const uint64_t k12G = UINT64_C(0x300000000); 
  6.                                        ^ 
  7. 1 warning and 2 errors generated. 

 諸如這類報錯,在 BUILD.gn 中使用到該源碼的模塊中添加 cflags.例如,對上面的報錯,可以添加如下的 cflags :

  1. cflags = [ 
  2.   ... 
  3.   "-Wno-unused-const-variable"
  4.   ... 

 如果出現下面的 C++ 的鏈接編譯報錯,

  1. ../../third_party/WasmEdge/lib/host/wasi/inode-linux.cpp:745:3: error: cannot use 'try' with exceptions disabled 
  2.   try { 
  3.   ^ 

 則添加 cflags_cc:

  1. # BUILD.gn 使用到該源碼的相應模塊 
  2.   ... 
  3.   cflags_cc = [  
  4.     ... 
  5.     "-fexceptions"
  6.     ... 
  7.   ] 

 移植過程中還有許多諸如此類的編譯報錯,在此不進行一一列舉。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2022-04-01 15:54:01

DHCP網絡協議開發板

2022-10-14 15:55:24

環境搭建鴻蒙

2021-10-11 14:14:42

鴻蒙HarmonyOS應用

2020-11-24 11:41:30

websocket

2021-09-10 10:01:04

鴻蒙HarmonyOS應用

2021-12-16 15:14:54

鴻蒙HarmonyOS應用

2022-03-03 19:21:50

Harmony鴻蒙操作系統

2020-12-29 09:59:01

鴻蒙HarmonyOS智能家居

2022-02-24 16:39:41

OpenHarmonNiobe開發鴻蒙

2021-06-25 15:32:13

鴻蒙HarmonyOS應用

2021-09-13 10:03:35

鴻蒙HarmonyOS應用

2022-06-06 10:44:10

C++語言鴻蒙

2020-10-30 09:48:03

Hi3861開發板get請求

2020-12-16 10:05:48

鴻蒙開發板Onenet平臺

2021-09-08 15:44:56

鴻蒙HarmonyOS應用

2020-10-30 17:12:05

Hi3861

2022-04-14 11:44:25

LiteOS線程鴻蒙

2022-08-19 10:54:47

操作系統鴻蒙

2023-03-07 15:54:45

鴻蒙Mesa庫
點贊
收藏

51CTO技術棧公眾號

欧美午夜小视频| 69ww免费视频播放器| 欧美a级一区| 国产91精品久久久| 中文字幕免费一区二区三区| 中文在线二区| 成人一区二区三区视频| 欧美专区在线播放| 成人免费在线播放| 国产成人亚洲精品| 最新地址在线观看| 亚洲国产精品一区二区久久| 成人在线免费视频| 欧美麻豆精品久久久久久| 日本在线天堂| 亚洲黄色av女优在线观看| 91精品秘密在线观看| 午夜精品区一区二区三| 亚洲成人资源在线| 国产一区二区三区黄网站| 国产资源第一页| 亚洲国产日韩精品在线| 日本欧美久久久久免费播放网| 日韩电影网址| 亚洲jizzjizz日本少妇| 婷婷六月综合网| 欧美伦理影院| 日韩大片b站免费观看直播| 国产成人精品一区二区在线 | 欧美成人激情在线| 国产偷v国产偷v亚洲高清| 日本另类视频| 国产欧美久久久久| 一区二区三区四区视频| 成人av一区二区三区| 国产成+人+综合+亚洲欧美| 久久国产精品免费观看| 日韩精品在线免费观看视频| 国产成人亚洲综合a∨婷婷 | 国产精品一久久香蕉国产线看观看| 久久这里只有精品6| 欧美午夜三级| 在线影院福利| 欧美一进一出视频| 亚洲视频欧洲视频| 国产午夜亚洲精品理论片色戒| 日韩中文字幕| 欧美色图另类| 久久66热这里只有精品| 精品剧情v国产在线观看在线| 国产精品正在播放| 一区二区三区在线资源| 男女视频在线观看免费| 伊人久久99| 国产成人精品久久久| 日韩美一区二区三区| 国产91精品一区二区麻豆亚洲| 欧美成年网站| 男女av在线| 国产小视频精品| 精品无人区一区二区三区| 国产亚洲精品综合一区91| 欧美韩国日本一区| 国产精品亚洲综合久久| 视频一区日韩| 亚洲天堂av在线免费观看| 99精品中文字幕在线不卡 | 一区二区三区在线播放| 国产视频一区三区| 色综合综合网| 日本网站在线免费观看视频| 菠萝蜜视频在线观看入口| 国产日韩欧美视频| 在线观看日韩av| 亚洲成av人电影| 中文在线а√在线| 黄页网站在线观看视频| 国产自产精品| 国产精品美女久久久免费 | 国产欧美日韩在线观看视频| 欧美成人黄色| 视频二区在线| 成人网18免费软件大全| 黄色国产小视频| 91久久国产精品| 一区二区欧美亚洲| 中文字幕日韩欧美一区二区三区| 国产一级精品在线| 日韩成人dvd| 99视频一区| a天堂中文在线88| 日本欧美亚洲| 免费h片在线观看| 日韩欧美电影在线观看| 国产69精品久久app免费版| 黄色片在线免费看| 欧美女优在线| 黄色毛片在线观看| 户外极限露出调教在线视频| 国产在线自天天| aaa日本高清在线播放免费观看| 青青草在线视频免费观看| 视频一区二区三区在线看免费看| 欧洲毛片在线| 亚洲精品动漫| jizz性欧美23| 综合激情婷婷| 欧美国产不卡| 美女www一区二区| 日韩精品成人| 精品国产综合久久| 欧美日韩精品一二三区| 精品电影在线观看| 在线播放的av| 亚洲成色999久久网站| 久久综合99| 中文字幕一区二区三区在线观看| 亚洲色图色老头| 秋霞久久久久久一区二区| 亚洲欧美一区二区三区久久 | 成年女人在线看片| 免费在线观看视频a| 欧美老人xxxx18| 丰满少妇久久久久久久| 日本综合视频| 情趣网站在线观看| 日产精品久久久一区二区福利 | 亚洲精品一区av在线播放| 欧美大片va欧美在线播放| 国产欧美在线看| 欧美无砖砖区免费| 国产欧美大片| 丝袜诱惑亚洲看片| 成人性生交大片免费网站| 天天影视久久综合| av在线不卡播放| 亚洲男女性事视频| 欧美综合影院| 欧洲精品亚洲精品| 欧美午夜片欧美片在线观看| 亚洲一区av| 亚洲成人a**址| 色爱区综合激月婷婷| 精品成av人一区二区三区| 国产三级三级三级看三级| 国产视频亚洲精品| 日本不卡视频在线| 麻豆网站在线免费观看| 亚洲黄色www网站| 成人乱人伦精品视频在线观看| 国产wwww| 雨宫琴音一区二区三区| 一区在线观看视频| 欧美va日韩va| 91av在线国产| 欧美激情二区三区| 色综合视频一区中文字幕| 中文字幕日韩在线播放| 亚洲第一精品自拍| 精品国产999| 亚洲同性gay激情无套| 精品视频色一区| 91久久人澡人人添人人爽欧美 | 韩国亚洲精品| 欧美12一14sex性hd| 国产精品9999| 国产精品久久毛片a| 大奶在线精品| 欧美极品欧美精品欧美| 原创国产精品91| 成人av在线电影| 大桥未久女教师av一区二区| 成人免费淫片在线费观看| 国产成人一区二区三区电影| 婷婷一区二区三区| 亚洲黄色一区| 国产黄大片在线观看| 久久这里只有精品23| 欧美激情精品久久久久久免费印度| 久久九九99视频| 美女网站色精品尤物极品姐弟| 少妇高潮露脸国语对白| 国产精品久久久久久久久久直播| 欧美日韩精品一区视频| 经典三级在线一区| 视频欧美一区| 伊人春色在线| 日韩欧美三级一区二区| 色偷偷偷亚洲综合网另类| 亚洲少妇中出一区| 午夜精品偷拍| 成人bbav| 男女羞羞视频教学| 国产精品yjizz| 亚洲人成电影在线播放| 国产精品久久久久久久久快鸭 | 一区二区三区免费播放| 国产精品人人做人人爽| 欧美一级黄色大片| 26uuu色噜噜精品一区二区|