在这一步,我们会在源码目录//device/vendor_name/soc_name/drivers目录下创建平台驱动。
建议的目录结构:
device
├── vendor_name
│ ├── drivers
│ │ │ ├── common
│ │ │ ├── Kconfig # 厂商驱动内核菜单入口
│ │ │ └── lite.mk # 构建的入口
│ ├── soc_name
│ │ ├── drivers
│ │ │ ├── dmac
│ │ │ ├── gpio
│ │ │ ├── i2c
│ │ │ ├── LICENSE
│ │ │ ├── mipi_dsi
│ │ │ ├── mmc
│ │ │ ├── pwm
│ │ │ ├── README.md # docs 如果需要的话
│ │ │ ├── README_zh.md
│ │ │ ├── rtc
│ │ │ ├── spi
│ │ │ ├── uart
│ │ │ └── watchdog
│ ├── board_name
HDF为所有的平台驱动都创建了驱动模型,移植平台驱动的主要工作是向模型注入实例。 这些模型你可以在源码目录//drivers/hdf_core/framework/support/platform/include中找到定义。
本节我们会以GPIO为例,讲解如何移植平台驱动,移植过程包含以下步骤:
-
创建GPIO驱动
在源码目录
//device/vendor_name/soc_name/drivers/gpio中创建文件soc_name_gpio.c。内容模板如下:#include "gpio_core.h" // 定义GPIO结构体,如果需要的话 struct SocNameGpioCntlr { struct GpioCntlr cntlr; // 这是HDF GPIO驱动框架需要的结构体 int myData; // 以下是当前驱动自身需要的 }; // Bind 方法在HDF驱动中主要用户对外发布服务,这里我们不需要,直接返回成功即可 static int32_t GpioBind(struct HdfDeviceObject *device) { (void)device; return HDF_SUCCESS; } // Init方法时驱动初始化的入口,我们需要在Init方法中完成模型实例的注册 static int32_t GpioInit(struct HdfDeviceObject *device) { SocNameGpioCntlr *impl = CreateGpio(); // 你的创建代码 ret = GpioCntlrAdd(&impl->cntlr); // 注册GPIO模型实例 if (ret != HDF_SUCCESS) { HDF_LOGE("%s: err add controller:%d", __func__, ret); return ret; } return HDF_SUCCESS; } // Release方法会在驱动卸载时被调用,这里主要完成资源回收 static void GpioRel

最低0.47元/天 解锁文章
1321

被折叠的 条评论
为什么被折叠?



