0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

OpenHarmony L1(3.0)串口功能開發(fā)

電子發(fā)燒友開源社區(qū) ? 來源:未知 ? 2023-03-11 14:15 ? 次閱讀
OpenHarmony 3.0 LTS是面向全場景的開源分布式操作系統(tǒng),能夠在物聯(lián)網(wǎng)上使用。可以支持三種系統(tǒng)類型,標(biāo)準(zhǔn)系統(tǒng)、輕量系統(tǒng)和小型系統(tǒng)。本文提供了在OpenHarmony 3.0 LTS實(shí)現(xiàn)串口調(diào)試功能的開發(fā)方案。

1.編寫代碼生成對應(yīng)動態(tài)庫文件

串口功能開發(fā)包括串口初始化、數(shù)據(jù)讀寫、修改數(shù)據(jù)開發(fā)格式等。具體代碼不便展示。編寫gn文件生成對應(yīng)動態(tài)庫文件
shared_library("serial_service_api") { sources = [ "service/serial_service.cpp" ] include_dirs = ["include","service", ]

2.提供API接口

2.1依賴router模塊開發(fā)

如果串口權(quán)限不受限制,可以直接在router模塊增加串口相關(guān)功能,節(jié)省開發(fā)時間。foundationaceace_engine_liteframeworkssrccoremodules outer_module.cpp
void InitRouterModule(JSIValue exports)
{
JSI::SetModuleAPI(exports, "replace", RouterModule::Replace);
JSI::SetModuleAPI(exports, "init", RouterModule::Init);
JSI::SetModuleAPI(exports, "format", RouterModule::Format);
JSI::SetModuleAPI(exports, "write", RouterModule::Write);
JSI::SetModuleAPI(exports, "read", RouterModule::ReadFormat);
JSI::SetModuleAPI(exports, "disable", RouterModule::Disable);
JSI::SetModuleAPI(exports, "on", RouterModule::OnRead);    
COMMUNICATION::GetInstance()->SerialRead(RouterModule::ReadingCallback);
}
串口初始化及進(jìn)制轉(zhuǎn)換相關(guān)代碼可直接調(diào)用庫函數(shù)。串口讀回調(diào)的相關(guān)代碼如下:
JSIValue ReadCallback = JSI::CreateUndefined();
void RouterModule::ReadingCallback(const char* buffer, int length)
{
if(!JSI::ValueIsUndefined(ReadCallback) && gSerialFlag){
if(length < 0){
           SERIAL_LOGI("JS ReadingCallback == 0");
           JSIValue evt = JSI::CreateString("error");
           JSI::CallFunction(ReadCallback, JSI::CreateUndefined(), &evt, 1);
return;
       } else if(length >= 0){
           SERIAL_LOGI("JS ReadingCallback == 1");
           JSIValue evt = JSI::CreateString(buffer);
           JSI::CallFunction(ReadCallback, JSI::CreateUndefined(), &evt, 1);
       }
   }
}
JSIValue RouterModule::OnRead(const JSIValue thisVal, const JSIValue *args, uint8_t argsSize)
{
if(!JSI::ValueIsUndefined(ReadCallback)){
      JSI::ReleaseValue(ReadCallback);
return JSI::CreateBoolean(false);
  }
if (JSI::ValueIsUndefined(args[0])) {
return JSI::CreateBoolean(false);
  }
  ReadCallback = JSI::GetNamedProperty(args[0], "ReadingCallback");
if(JSI::ValueIsUndefined(ReadCallback)){
      SERIAL_LOGI("Read Callbk is not got it");
  }
}
在route模塊增加相關(guān)依賴foundationaceace_engine_liteframeworksBUILD.gn
deps = [
"http://device/hals/communication/serial_port:serial_service_api",
]

2.2輕量級服務(wù)開發(fā)

串口權(quán)限受限時,需要啟用輕量級服務(wù),應(yīng)用可以通過服務(wù),跨進(jìn)程操作串口。具體配置如下:foundationaceace_engine_liteframeworksmodule_managerohos_module_config.h
extern void InitSerialPortModule(JSIValue exports);const Module OHOS_MODULES[] = {{"serialport", InitSerialPortModule},}
配置服務(wù)自啟動:vendor/ingenic/halley5/rootfs-overlay/etc/init.d/S99WmsStart:sleep 1 && /bin/wifi_server &
#! /bin/sh
sleep 1 && /bin/wms_server &
sleep 1 && /bin/wifi_server &
sleep 1 && /bin/util_server &
sleep 1 && /bin/serial_port_service &
配置服務(wù):basesecuritypermissionservicespermission_liteipc_authincludepolicy_preset.h
FeaturePolicy serialServiceFeature[] = {
   {
NULL,
       {
           {
               .type = RANGE,
               .uidMin=0,
               .uidMax=__INT_MAX__,
           }
       },
   },
};
static PolicySetting g_presetPolicies[] = {
   {"serialportservice", serialServiceFeature, 1},
};
代碼實(shí)現(xiàn)服務(wù)初始化,具體實(shí)現(xiàn)可參考wifi_lite相關(guān)代碼。在Invoke中去調(diào)用串口相關(guān)功能**serial_portserial_port_liteservicesamgr_serial_port_service.cpp
//繼承并重新定義服務(wù):
struct SamgrSerialPortService {
   INHERIT_SERVICE;
   INHERIT_IUNKNOWNENTRY(DefaultFeatureApi);
   Identity identity;
};
static const char *GetName(Service *service)
{
//(void)service;
return SERIAL_PORT_SERVICE_NAME;
}
static int32 Invoke(IServerProxy *iProxy, int funcId, void *origin, IpcIo *req, IpcIo *reply)
{
   SerialPortService::RequestHandle(funcId, origin, req, reply);
return EC_SUCCESS;
}
//創(chuàng)建服務(wù)對象:
static SamgrSerialPortService SerialPortSvc = {
   .GetName = GetName,
   .Initialize = Initialize,
   .MessageHandle = MessageHandle,
   .GetTaskConfig = GetTaskConfig,
   SERVER_IPROXY_IMPL_BEGIN,
   .Invoke = Invoke,
   IPROXY_END,
};
//向SAMGR注冊服務(wù)及接口:
static void Init()
{ 
   SERIAL_LOGI("serial RegisterService Init, ver = %u", SerialPortSvc.ver);
bool ret = SAMGR_GetInstance()->RegisterService((Service *)&SerialPortSvc);
if (!ret) {
       SERIAL_LOGI("RegisterService error");
return;
   }
   ret = SAMGR_GetInstance()->RegisterDefaultFeatureApi(SERIAL_PORT_SERVICE_NAME, GET_IUNKNOWN(SerialPortSvc));
if (!ret) {
       SERIAL_LOGI("RegisterDefaultFeatureApi error");
return;
   }
   SERIAL_LOGI("serial RegisterService out, ver = %u", SerialPortSvc.ver);
}
SYSEX_SERVICE_INIT(Init);

3.開發(fā)應(yīng)用

3.1 簽名配置

使用 DevEco Studio 3.0.0.800 軟件進(jìn)行應(yīng)用開發(fā),真機(jī)設(shè)備運(yùn)行和調(diào)試OpenHarmony應(yīng)用前,需要對應(yīng)用進(jìn)行簽名才能正常運(yùn)行。主要分為四個步驟:生成密鑰和證書請求文件,生成應(yīng)用證書文件,生成應(yīng)用profile文件,配置應(yīng)用簽名信息。a2a5e708-bfd2-11ed-bfe3-dac502259ad0.png

3.2 調(diào)試命令

adb push entry-release-lite-signed.hap /userdataadb shellalias ls='ls --color=never'//解決ls亂碼bm uninstall -n com.ingenic.curtainbm install -p entry-release-lite-signed.hap

4.總結(jié)

本文介紹了在OpenHarmony 3.0 LTS系統(tǒng)上重串口功能實(shí)現(xiàn)到應(yīng)用開發(fā)的整套流程。簡單的API接口開發(fā),可直接依賴系統(tǒng)模塊。難點(diǎn)主要在輕量級系統(tǒng)開發(fā),讀者可參考開源鴻蒙中輕量級系統(tǒng)服務(wù)管理部件中的相關(guān)介紹進(jìn)行開發(fā)。

更多熱點(diǎn)文章閱讀
  • 如何使用DevEco Studio創(chuàng)建Native C++應(yīng)用
  • 基于小凌派RK2206的智能垃圾桶設(shè)計
  • 大咖齊聚!OpenHarmony技術(shù)峰會豪華嘉賓陣容揭曉
  • ArkUI新能力,助力應(yīng)用開發(fā)更便捷
  • 小白指南:手把手教你用低代碼開發(fā)一個應(yīng)用頁面

提示:本文由電子發(fā)燒友論壇發(fā)布,轉(zhuǎn)載請注明來源。如需社區(qū)合作及入群交流,請?zhí)砑游⑿臙EFans0806,或者發(fā)郵箱liuyong@huaqiu.com。


原文標(biāo)題:OpenHarmony L1(3.0)串口功能開發(fā)

文章出處:【微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 電子發(fā)燒友
    +關(guān)注

    關(guān)注

    33

    文章

    548

    瀏覽量

    32881
  • 開源社區(qū)
    +關(guān)注

    關(guān)注

    0

    文章

    93

    瀏覽量

    397

原文標(biāo)題:OpenHarmony L1(3.0)串口功能開發(fā)

文章出處:【微信號:HarmonyOS_Community,微信公眾號:電子發(fā)燒友開源社區(qū)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    基于ArkTS語言的OpenHarmony APP應(yīng)用開發(fā):HelloOpenharmony

    1、程序簡介該程序是基于OpenHarmony標(biāo)準(zhǔn)系統(tǒng)編寫的UI應(yīng)用類:HelloOpenHarmony。本案例是基于API9接口開發(fā)。本案例已在O
    的頭像 發(fā)表于 09-15 08:09 ?284次閱讀
    基于ArkTS語言的<b class='flag-5'>OpenHarmony</b> APP應(yīng)用<b class='flag-5'>開發(fā)</b>:Hello<b class='flag-5'>Openharmony</b>

    MSPM0 L1測量儀表解決方案指南

    電子發(fā)燒友網(wǎng)站提供《MSPM0 L1測量儀表解決方案指南.pdf》資料免費(fèi)下載
    發(fā)表于 09-04 10:47 ?1次下載
    MSPM0 <b class='flag-5'>L1</b>測量儀表解決方案指南

    【迅為RK3568開發(fā)板】OpenHarmony學(xué)習(xí)開發(fā)系列教程(第1期 北向基礎(chǔ)篇一)

    P1P0_先導(dǎo)課1:30 P2P1_OpenHarmony系統(tǒng)概述8:12 P3P2_OpenHarmony功能框架5:38 P4P3_
    發(fā)表于 08-16 15:27

    鴻蒙OpenHarmony南向/北向快速開發(fā)教程-迅為RK3568開發(fā)

    4.1學(xué)習(xí)之旅了嗎?快來加入我們,一起探索鴻蒙4.1系統(tǒng)的無限魅力吧! 【北京迅為】OpenHarmony學(xué)習(xí)開發(fā)系列教程(第1期 北向基礎(chǔ)篇一) P0_先導(dǎo)課 P1_OpenHarmony
    發(fā)表于 07-23 10:44

    BK1661 全集成的單芯片 L1 頻段 GNSS 解決方案

    LDO ? 內(nèi)置 DC-DC ? 低功耗: L1 連續(xù)跟蹤模式 : 12 mA 休眠待機(jī)模式 : 14 μA 外設(shè)接口 ? 17 GPIOs ? 3x UART, 其中一個具備下載功能 ? 1x I2C
    發(fā)表于 06-03 09:40

    BK1662 單芯片L1/L5雙頻GNSS解決方案

    概 述 BK1662是完全集成的單芯片L1/L5雙頻GNSS解決方案,專為需要低功耗和高性能的應(yīng)用而設(shè)計。 BK1662通過優(yōu)化多頻段和多模式信號跟蹤、先進(jìn)的抗多徑技術(shù)和抗干擾射頻前端,顯著提高了
    發(fā)表于 06-03 09:31

    BK1616P 全集成的單芯片 L1 頻段 GNSS 解決方案(高性價比FLASH版本)

    BK1616P 是全集成的單芯片 L1 頻段 GNSS 解決方案,專為需要低成本、低功耗和高性能的應(yīng)用而設(shè)計。其可以實(shí)現(xiàn)優(yōu)化的多模式信號跟蹤。同時其實(shí)現(xiàn)了先進(jìn)的抗多徑和抗干擾射頻前端,顯著提高了實(shí)際
    發(fā)表于 05-29 10:50

    鴻蒙OS開發(fā):典型頁面場景【一次開發(fā),多端部署】(功能開發(fā)

    應(yīng)用開發(fā)至少包含兩部分工作: UI頁面開發(fā)和底層功能開發(fā)(部分需要聯(lián)網(wǎng)的應(yīng)用還會涉及服務(wù)端開發(fā))。前面章節(jié)介紹了如何解決頁面適配的問題,本章節(jié)主要介紹應(yīng)用如何解決設(shè)備系統(tǒng)能力差異的兼容
    的頭像 發(fā)表于 05-28 17:32 ?505次閱讀
    鴻蒙OS<b class='flag-5'>開發(fā)</b>:典型頁面場景【一次<b class='flag-5'>開發(fā)</b>,多端部署】(<b class='flag-5'>功能開發(fā)</b>)

    OpenHarmony南向開發(fā)案例:【智能照相機(jī)】

    基于Hi3516開發(fā)板,使用OpenHarmony3.0-LTS開發(fā)的應(yīng)用。通過獲取攝像頭數(shù)據(jù),實(shí)現(xiàn)預(yù)覽拍照以及路視頻等功能。并且通過后臺AI服務(wù)識別喚醒詞來進(jìn)行語音控制拍照及錄制視頻
    的頭像 發(fā)表于 04-18 22:19 ?399次閱讀
    <b class='flag-5'>OpenHarmony</b>南向<b class='flag-5'>開發(fā)</b>案例:【智能照相機(jī)】

    功能開發(fā)板EoRa PI,支持Wi-Fi和低功耗藍(lán)牙

    通過對客戶需求的深度調(diào)研,億佰特近期推出兩款專為LoRa類模組設(shè)計的多功能開發(fā)板,內(nèi)嵌LoRa通信模塊億佰特E22-400/90
    的頭像 發(fā)表于 04-05 08:19 ?396次閱讀
    多<b class='flag-5'>功能開發(fā)</b>板EoRa PI,支持Wi-Fi和低功耗藍(lán)牙

    請問使用ST25R3916方案的NFC讀卡器能否通過EMVCo 3.0 L1認(rèn)證測試?

    1.目前使用st25r3916方案的讀卡器是否能順利通過EMV3.0 L1測試? 2.有沒有可以通過認(rèn)證測試的套件并提供技術(shù)支持,或者提供樣品定制開發(fā)驗(yàn)證服務(wù)? 3.其他型號推薦?
    發(fā)表于 03-21 07:08

    OpenHarmony鴻蒙實(shí)戰(zhàn)】在RK3399開發(fā)板實(shí)現(xiàn)智能門禁人臉識別

    基于RK3399開發(fā)板,使用OpenHarmony3.0-LTS開發(fā)的應(yīng)用。通過定時獲取攝像頭數(shù)據(jù),實(shí)現(xiàn)人臉識別比對等功能。
    的頭像 發(fā)表于 03-20 17:38 ?1139次閱讀
    【<b class='flag-5'>OpenHarmony</b>鴻蒙實(shí)戰(zhàn)】在RK3399<b class='flag-5'>開發(fā)</b>板實(shí)現(xiàn)智能門禁人臉識別

    使用ADI官方提供的no-OS來接收GPS L1(1575.42MHz)的資料

    目前使用ad9361在接收GPS L1(1575.42MHz)頻段的資料,但收到的IQ在頻域和時域上分析,看起來皆不太正確。希望有版友可以提供一些設(shè)定上的建議,若能協(xié)助開發(fā)接收這頻段的IQ,請直接私訊我謝謝。
    發(fā)表于 01-21 21:53

    鴻蒙next開發(fā)-OpenHarmony的NDK開發(fā)

    Native API是OpenHarmony SDK上提供的一組native開發(fā)接口與工具集合(也稱為NDK),方便開發(fā)者使用C或者C++語言實(shí)現(xiàn)應(yīng)用的關(guān)鍵功能。
    的頭像 發(fā)表于 01-20 11:35 ?1710次閱讀
    鴻蒙next<b class='flag-5'>開發(fā)</b>-<b class='flag-5'>OpenHarmony</b>的NDK<b class='flag-5'>開發(fā)</b>

    openharmony開發(fā)應(yīng)用

    隨著智能設(shè)備的普及和多樣化,開發(fā)者們對于更加靈活、高效的操作系統(tǒng)需求與日俱增。在這個背景下,華為推出了OpenHarmony,一個全場景智能終端操作系統(tǒng)和生態(tài)平臺。本文將詳細(xì)探討
    的頭像 發(fā)表于 12-19 09:42 ?621次閱讀