OpenHarmony 3.0 LTS是面向全场景的开源分布式操作系统,能够在物联网上使用。可以支持三种系统类型,标准系统、轻量系统和小型系统。本文提供了在OpenHarmony 3.0 LTS实现串口调试功能的开发方案。
1.编写代码生成对应动态库文件
串口功能开发包括串口初始化、数据读写、修改数据开发格式等。具体代码不便展示。编写gn文件生成对应动态库文件
shared_library("serial_service_api") { sources = [ "service/serial_service.cpp" ] include_dirs = ["include","service", ]
2.提供API接口
2.1依赖router模块开发
如果串口权限不受限制,可以直接在router模块增加串口相关功能,节省开发时间。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);
}
串口初始化及进制转换相关代码可直接调用库函数。串口读回调的相关代码如下:
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模块增加相关依赖foundationaceace_engine_liteframeworksBUILD.gn
deps = [
"//device/hals/communication/serial_port:serial_service_api",
]
2.2轻量级服务开发
串口权限受限时,需要启用轻量级服务,应用可以通过服务,跨进程操作串口。具体配置如下:foundationaceace_engine_liteframeworksmodule_managerohos_module_config.h
extern void InitSerialPortModule(JSIValue exports);const Module OHOS_MODULES[] = {{"serialport", InitSerialPortModule},}
配置服务自启动: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 &
配置服务:basesecuritypermissionservicespermission_liteipc_authincludepolicy_preset.h
FeaturePolicy serialServiceFeature[] = {
{
NULL,
{
{
.type = RANGE,
.uidMin=0,
.uidMax=__INT_MAX__,
}
},
},
};
static PolicySetting g_presetPolicies[] = {
{"serialportservice", serialServiceFeature, 1},
};
代码实现服务初始化,具体实现可参考wifi_lite相关代码。在Invoke中去调用串口相关功能**serial_portserial_port_liteservicesamgr_serial_port_service.cpp
//继承并重新定义服务:
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;
}
//创建服务对象:
static SamgrSerialPortService SerialPortSvc = {
.GetName = GetName,
.Initialize = Initialize,
.MessageHandle = MessageHandle,
.GetTaskConfig = GetTaskConfig,
SERVER_IPROXY_IMPL_BEGIN,
.Invoke = Invoke,
IPROXY_END,
};
//向SAMGR注册服务及接口:
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.开发应用
3.1 签名配置
使用 DevEco Studio 3.0.0.800 软件进行应用开发,真机设备运行和调试OpenHarmony应用前,需要对应用进行签名才能正常运行。主要分为四个步骤:生成密钥和证书请求文件,生成应用证书文件,生成应用profile文件,配置应用签名信息。3.2 调试命令
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.hap4.总结
本文介绍了在OpenHarmony 3.0 LTS系统上重串口功能实现到应用开发的整套流程。简单的API接口开发,可直接依赖系统模块。难点主要在轻量级系统开发,读者可参考开源鸿蒙中轻量级系统服务管理部件中的相关介绍进行开发。更多热点文章阅读
- 如何使用DevEco Studio创建Native C++应用
- 基于小凌派RK2206的智能垃圾桶设计
- 大咖齐聚!OpenHarmony技术峰会豪华嘉宾阵容揭晓
- ArkUI新能力,助力应用开发更便捷
-
小白指南:手把手教你用低代码开发一个应用页面
提示:本文由电子发烧友论坛发布,转载请注明来源。如需社区合作及入群交流,请添加微信EEFans0806,或者发邮箱liuyong@huaqiu.com。
原文标题:OpenHarmony L1(3.0)串口功能开发
文章出处:【微信公众号:电子发烧友开源社区】欢迎添加关注!文章转载请注明出处。
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。
举报投诉
-
电子发烧友
+关注
关注
33文章
546浏览量
32359 -
开源社区
+关注
关注
0文章
92浏览量
342
原文标题:OpenHarmony L1(3.0)串口功能开发
文章出处:【微信号:HarmonyOS_Community,微信公众号:电子发烧友开源社区】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
OpenHarmony南向开发案例:【智能照相机】
基于Hi3516开发板,使用OpenHarmony3.0-LTS开发的应用。通过获取摄像头数据,实现预览拍照以及路视频等功能。并且通过后台AI服务识别唤醒词来进行语音控制拍照及录制视频
OpenHarmony南向能力征集令
1、适配过程中缺少哪些接口能力或者南向能力,需要OpenHarmony去补齐的?例如内核、编译、器件适配、单板适配等;
2、对标linux,需要OpenHarmony提供哪些能力?比如V4L
发表于 04-09 15:32
请问使用ST25R3916方案的NFC读卡器能否通过EMVCo 3.0 L1认证测试?
1.目前使用st25r3916方案的读卡器是否能顺利通过EMV3.0 L1测试?
2.有没有可以通过认证测试的套件并提供技术支持,或者提供样品定制开发验证服务?
3.其他型号推荐?
发表于 03-21 07:08
【OpenHarmony鸿蒙实战】在RK3399开发板实现智能门禁人脸识别
基于RK3399开发板,使用OpenHarmony3.0-LTS开发的应用。通过定时获取摄像头数据,实现人脸识别比对等功能。
使用ADI官方提供的no-OS來接收GPS L1(1575.42MHz)的資料
目前使用ad9361在接收GPS L1(1575.42MHz)頻段的資料,但收到的IQ在頻域和時域上分析,看起來皆不太正確。希望有版友可以提供一些設定上的建議,若能協助開發接收這頻段的IQ,請直接私訊我謝謝。
发表于 01-21 21:53
鸿蒙next开发-OpenHarmony的NDK开发
Native API是OpenHarmony SDK上提供的一组native开发接口与工具集合(也称为NDK),方便开发者使用C或者C++语言实现应用的关键功能。
润开鸿AT32开发平台通过OpenHarmony兼容性测评
支持深度学习的路径规划与路标识别等功能开发,可覆盖人工智能、机器人等多学科知识点教学,适用于自动驾驶ROS实训。而该无人车教具的推出,也完成了润开鸿AT32开发平台在OpenHarmony产业生态中
发表于 12-21 17:20
openharmony开发应用
随着智能设备的普及和多样化,开发者们对于更加灵活、高效的操作系统需求与日俱增。在这个背景下,华为推出了OpenHarmony,一个全场景智能终端操作系统和生态平台。本文将详细探讨
单片机新手求助该警告怎么消除*** WARNING L1:?
WARNING L1: UNRESOLVED EXTERNAL SYMBOL
SYMBOL:_SENDCHAR
MODULE:main1051.obj (MAIN1051
发表于 10-08 07:21
DevEco Studio中如何设置HarmonyOS/OpenHarmony应用开发
为OpenHarmony。
二、具体步骤1
三、具体步骤2
四、具体步骤3
五、具体步骤4
*附件:DevEco Studio中如何设置HarmonyOSOpenHarmony应用开发
发表于 09-14 14:50
Windows搭建OpenHarmony编译环境
://gitee.com/Lockzhiner-Electronics/lockzhiner-rk2206-openharmony3.0lts
1、下载并安装Docker Desktop
请小伙伴们到
发表于 08-16 16:07
OpenHarmony轻量系统书籍推荐《OpenHarmony轻量设备开发理论与实战》
最近大家问的智能家居套件方面有没有可以参考的资料,这里给大家统一回复一下 推荐大家可以看这本书 《OpenHarmony轻量设备开发理论与实战》 本书系统地讲授OpenHarmony 轻量系统 设备
《OpenHarmony嵌入式系统原理与应用——基于RK2206芯片(微课视频版)》学习记录1 环境配置与源码编译
的子系统或功能 / 模块。OpenHarmony 在传统的单设备系统能力的基础上,创造性地提出了基于同一套系统能力、适配多种终端形态的理念,支持多种终端设备上运行。
四、开发工具的使用
Eclipse插件
发表于 06-25 11:26
HarmonyOS/OpenHarmony应用开发API-ConnectOptions能力
说明:
在连接指定的后台服务时作为入参用于接收连接过程中的状态变化。
编译环境:
编译器版本:release3.0
Api:8
语言:js
示例
*附件:HarmonyOSOpenHarmony应用开发API-ConnectOp
发表于 05-08 17:29
评论