成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在 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網絡協議開發板

2021-10-11 14:14:42

鴻蒙HarmonyOS應用

2022-10-14 15:55:24

環境搭建鴻蒙

2020-11-24 11:41:30

websocket

2021-12-16 15:14:54

鴻蒙HarmonyOS應用

2021-09-10 10:01:04

鴻蒙HarmonyOS應用

2021-06-25 15:32:13

鴻蒙HarmonyOS應用

2022-02-24 16:39:41

OpenHarmonNiobe開發鴻蒙

2021-09-13 10:03:35

鴻蒙HarmonyOS應用

2020-12-29 09:59:01

鴻蒙HarmonyOS智能家居

2022-03-03 19:21:50

Harmony鴻蒙操作系統

2020-10-30 09:48:03

Hi3861開發板get請求

2022-06-06 10:44:10

C++語言鴻蒙

2020-12-16 10:05:48

鴻蒙開發板Onenet平臺

2021-09-08 15:44:56

鴻蒙HarmonyOS應用

2020-10-30 17:12:05

Hi3861

2022-08-19 10:54:47

操作系統鴻蒙

2023-03-07 15:54:45

鴻蒙Mesa庫

2011-06-15 14:19:11

QT 移植
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久久久久久久久免费看 | 99久久精品一区二区成人 | sese视频在线观看 | 久久精品国产亚洲夜色av网站 | 一级片免费网站 | 久久久黑人 | 91亚洲国产 | 国产视频精品在线观看 | 日韩中文字幕在线观看 | 天天搞天天操 | av国产精品 | 韩日精品一区 | 亚洲精品视频久久 | 天天综合久久 | 亚洲国产一区二区三区 | 99热视| 免费成人在线网站 | 精品美女 | 日韩在线观看一区 | 日韩免费一区二区 | 亚洲成人精 | 国内精品一区二区三区 | 欧美亚洲国产一区 | 国产精品色 | 日韩电影a | 国产精品久久精品 | 69精品久久久久久 | 久久88 | 久久se精品一区精品二区 | 亚洲精品一区二区三区在线 | 亚洲第1页| 天天射天天操天天干 | 国产精品久久久久久久久婷婷 | 欧美日韩国产一区二区三区 | 91精品国产综合久久久久 | 国产成人精品一区二区三区 | 久久久av一区 | 国产欧美二区 | 日韩中文字幕在线观看 | 99pao成人国产永久免费视频 | 国产精品一区久久久 |