未验证 提交 6d474372 编写于 作者: L liyan 提交者: Gitee

规范性检查

Signed-off-by: Nli-yan339 <liyan339@h-partners.com>
上级 0546ba86
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
驱动服务是HDF驱动设备对外提供能力的对象,由HDF框架统一管理。驱动服务管理主要包含驱动服务的发布和获取。 驱动服务是HDF驱动设备对外提供能力的对象,由HDF框架统一管理。驱动服务管理主要包含驱动服务的发布和获取。
HDF框架定义了驱动对外发布服务的策略,由配置文件中的policy字段来控制,policy字段的取值范围以及含义如下: HDF框架定义了驱动对外发布服务的策略,由配置文件中的policy字段来控制,policy字段的取值范围以及含义如下:
...@@ -39,26 +39,26 @@ typedef enum { ...@@ -39,26 +39,26 @@ typedef enum {
| 方法 | 描述 | | 方法 | 描述 |
| -------- | -------- | | -------- | -------- |
| int32_t&nbsp;(\*Bind)(struct&nbsp;HdfDeviceObject&nbsp;\*deviceObject); | 需要驱动开发者实现Bind函数,将自己的服务接口绑定到HDF框架中。 | | int32_t&nbsp;(\*Bind)(struct&nbsp;HdfDeviceObject&nbsp;\*deviceObject) | 需要驱动开发者实现Bind函数,将自己的服务接口绑定到HDF框架中。 |
| const&nbsp;struct&nbsp;HdfObject&nbsp;\*DevSvcManagerClntGetService(const&nbsp;char&nbsp;\*svcName); | 获取驱动的服务。 | | const&nbsp;struct&nbsp;HdfObject&nbsp;\*DevSvcManagerClntGetService(const&nbsp;char&nbsp;\*svcName)| 获取驱动的服务。 |
| int&nbsp;HdfDeviceSubscribeService(<br/>struct&nbsp;HdfDeviceObject&nbsp;\*deviceObject,&nbsp;const&nbsp;char&nbsp;\*serviceName,&nbsp;struct&nbsp;SubscriberCallback&nbsp;callback); | 订阅驱动的服务。 | |int&nbsp;HdfDeviceSubscribeService(<br/>struct&nbsp;HdfDeviceObject&nbsp;\*deviceObject,&nbsp;const&nbsp;char&nbsp;\*serviceName,&nbsp;struct&nbsp;SubscriberCallback&nbsp;callback) | 订阅驱动的服务。 |
## 开发步骤 ## 开发步骤
驱动服务管理的开发包括驱动服务的编写、绑定、获取或者订阅,详细步骤如下。 驱动服务管理的开发包括驱动服务的编写、绑定、获取或者订阅,详细步骤如下。
1. 驱动服务发布 1. 驱动服务编写
``` ```
驱动服务结构的定义 // 驱动服务结构的定义
struct ISampleDriverService { struct ISampleDriverService {
struct IDeviceIoService ioService; // 服务结构的首个成员必须是IDeviceIoService类型的成员 struct IDeviceIoService ioService; // 服务结构的首个成员必须是IDeviceIoService类型的成员。
int32_t (*ServiceA)(void); // 驱动的第一个服务接口 int32_t (*ServiceA)(void); // 驱动的第一个服务接口
int32_t (*ServiceB)(uint32_t inputCode); // 驱动的第二个服务接口,有多个可以依次往下累加 int32_t (*ServiceB)(uint32_t inputCode); // 驱动的第二个服务接口,有多个可以依次往下累加
}; };
驱动服务接口的实现 // 驱动服务接口的实现
int32_t SampleDriverServiceA(void) int32_t SampleDriverServiceA(void)
{ {
// 驱动开发者实现业务逻辑 // 驱动开发者实现业务逻辑
...@@ -77,7 +77,7 @@ typedef enum { ...@@ -77,7 +77,7 @@ typedef enum {
``` ```
int32_t SampleDriverBind(struct HdfDeviceObject *deviceObject) int32_t SampleDriverBind(struct HdfDeviceObject *deviceObject)
{ {
// deviceObject为HDF框架给每一个驱动创建的设备对象,用来保存设备相关的私有数据和服务接口 // deviceObject为HDF框架给每一个驱动创建的设备对象,用来保存设备相关的私有数据和服务接口
if (deviceObject == NULL) { if (deviceObject == NULL) {
HDF_LOGE("Sample device object is null!"); HDF_LOGE("Sample device object is null!");
return -1; return -1;
...@@ -92,10 +92,11 @@ typedef enum { ...@@ -92,10 +92,11 @@ typedef enum {
``` ```
3. 驱动服务获取。 3. 驱动服务获取。
驱动服务的获取有两种方式,HDF框架提供接口直接获取和HDF框架提供订阅机制获取。 驱动服务的获取有两种方式,HDF框架提供接口直接获取和订阅机制获取。
- 通过HDF接口直接获取 - 通过HDF接口直接获取
当明确驱动已经加载完成时,获取该驱动的服务可以通过HDF框架提供的能力接口直接获取,如下所示:
当明确驱动已经加载完成时,获取该驱动的服务可以通过HDF框架提供的能力接口直接获取,如下所示:
``` ```
...@@ -108,7 +109,8 @@ typedef enum { ...@@ -108,7 +109,8 @@ typedef enum {
sampleService->ServiceB(5); sampleService->ServiceB(5);
``` ```
- 通过HDF提供的订阅机制获取 - 通过HDF提供的订阅机制获取
当内核态对驱动(同一个host)加载的时机不感知时,可以通过HDF框架提供的订阅机制来订阅该驱动,当该驱动加载完成时,HDF框架会将被订阅的驱动服务发布给订阅者,实现方式如下所示:
当内核态对驱动(同一个host)加载的时机不感知时,可以通过HDF框架提供的订阅机制来订阅该驱动。当该驱动加载完成时,HDF框架会将被订阅的驱动服务发布给订阅者,实现方式如下所示:
``` ```
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册