OpenHarmony之消息机制实现
OpenHarmony之消息机制实现
背景
在之前的介绍(OpenHarmony之HDF驱动框架)中,了解到OpenHarmony的消息机制主要有以下两种:
- 用户态应用发送消息到驱动。
- 用户态应用接收驱动主动上报事件。
下面我们分别来看看两种机制用户态的流程及实现
用户态应用发送消息到驱动
用户态主要代码
struct HdfIoService *serv = HdfIoServiceBind(SAMPLE_SERVICE_NAME);
......
ret = serv->dispatcher->Dispatch(&serv->object, SAMPLE_WRITE_READ, data, reply);
if (ret != HDF_SUCCESS) {
HDF_LOGE("fail to send service call");
goto out;
}
重点就是通过HdfIoServiceBind
绑定服务,调用服务的Dispatch
接口
HdfIoServiceBind
接口流程
HdfIoServiceBind
接口的主要作用是open
对应服务的字符设备节点/dev/hdf/serviceName
,细节流程如下:
HdfIoServiceBind(`drivers/hdf_core/framework/core/shared/src/hdf_io_service.c`)
-> HdfIoServiceAdapterObtain
-> open /dev/hdf/serviceName
-> .Dispatch = HdfSyscallAdapterDispatch
HdfIoServiceAdapterObtain
函数有两处实现:
- 针对内核态,给内核用:
drivers/hdf_core/framework/core/adapter/vnode/src/hdf_vnode_adapter.c
- 针对用户态,给应用用:
drivers/hdf_core/framework/core/adapter/syscall/src/hdf_syscall_adapter.c
这里主要看用户态的实现,即hdf_syscall_adapter.c
Dispatch
接口流程
serv->dispatcher->Dispatch()
dispatcher
-> Dispatch()
-> HdfSyscallAdapterDispatch
-> ioctl - HDF_WRITE_READ
最底层就是通过系统调用ioctl
来读写消息(HDF_WRITE_READ
)。
用户态应用接收驱动上报事件
用户态代码
struct HdfIoService *serv = HdfIoServiceBind(SAMPLE_SERVICE_NAME);
......
static struct HdfDevEventlistener listener = {
.callBack = OnDevEventReceived,
.priv ="Service0"
};
if (HdfDeviceRegisterEventListener(serv, &listener) != HDF_SUCCESS) {
HDF_LOGE("fail to register event listener");
return HDF_FAILURE;
}
主要是通过HdfDeviceRegisterEventListener
注册回调函数
HdfDeviceRegisterEventListener
函数流程
drivers/hdf_core/framework/core/adapter/syscall/src/hdf_syscall_adapter.c
HdfDeviceRegisterEventListener
-> HdfDeviceRegisterEventListenerWithSchedPolicy
-> HdfIoServiceStartListen
-> HdfIoServiceThreadBindLocked
-> HdfDevListenerThreadInit
-> HdfDevListenerThreadDoInit
-> OsalThreadCreate HdfDevEventListenTask
-> HdfDevListenerThreadStart
-> HdfAdapterStartListenIoctl
-> ioctl - HDF_LISTEN_EVENT_START
-> OsalThreadStart HdfDevEventListenTask
调到最后,就是通过osal的接口OsalThreadCreate
创建线程,OsalThreadStart
开始线程,而对应的线程就是下面的HdfDevEventListenTask
:
HdfDevEventListenTask - poll
-> HdfDevEventReadAndDispatch
-> ioctl - HDF_READ_DEV_EVENT
-> HdfDevEventDispatchLocked
-> listener->callBack
以上的核心就是基于poll
,通过ioctl
来读取消息(HDF_READ_DEV_EVENT
),然后再去调用上面传过来的回调函数
总结
以上只是消息机制核外用户态的实现,最后会执行到系统调用
参考
OpenHarmony源码
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 DD'Notes!
评论