【入门到实战】OpenHarmony南向设备轻量系统芯片移植指南:移植文件子系统

往期鸿蒙5.0全套实战文章必看:(文中附带全栈鸿蒙5.0学习资料)


移植文件子系统

utils部件可被各业务子系统及上层应用使用,依赖芯片文件系统实现,需要芯片平台提供文件打开、关闭、读写、获取大小等功能。

移植指导

OpenHarmony文件系统需要适配如下HAL层接口:

表1 文件打开或关闭

接口名描述
HalFileOpen文件打开或创建新文件。
HalFileClose文件关闭。

表2 文件操作

接口名描述
HalFileRead读文件。
HalFileWrite写文件。
HalFileDelete删除文件。
HalFileStat获取文件属性。
HalFileSeek文件查找。

厂商适配相关接口的实现,请参考OpenHarmony中file的接口和hal层适配接口的定义:

//utils/native/lite/file
├── BUILD.gn
└── src
     └── file_impl_hal
            └── file.c             #file接口。
//utils/native/lite/hals
└── file
└── hal_file.h                   #hal层接口头文件。

其中BUILD.gn的内容如下:

import("//build/lite/config/component/lite_component.gni")
 
static_library("native_file") {
  sources = [
    "src/file_impl_hal/file.c",
  ]
  include_dirs = [
    "//utils/native/lite/include",
    "//utils/native/lite/hals/file",
  ]
  deps = ["$ohos_vendor_adapter_dir/hals/utils/file:hal_file_static"]  #依赖厂商的适配。
}
 
lite_component("file") {
  features = [
    ":native_file",
  ]
}

从中可以看到厂商适配相关接口的存放目录应为“$ohos_vendor_adapter_dir/hals/utils/file”,且该目录下BUILD.gn文件中的目标应为hal_file_static。

通常厂商可以采用下面三种方式适配hal层接口:

  1. 直接flash读写,模拟文件的操作。

  2. 使用littlefs或者fatfs文件系统进行适配,littlefs或者fatfs都是轻量级文件系统适配简单,其中OpenHarmony的“//thirdparty”目录下已有fatfs可供参考。

  3. 使用厂商已有的文件系统进行适配。

移植实例

  1. “config.json”添加文件系统。 路径:“vendor/MyVendorCompany/MyProduct/config.json”

    修改如下:

    {
    "subsystem": "utils",
    "components": [
        { "component": "file", "features":[] }
      ]
    },
    
  2. 添加适配文件。 在“vendor/MyVendorCompany/MyProduct/config.json”文件中,vendor_adapter_dir配置项通常进行如下配置:

    “vendor_adapter_dir”: “//device/MyDeviceCompany/MyBoard/adapter”。

    在该目录下进行UtilsFile接口适配:

    hals/utils/file
    ├── BUILD.gn
    └── src
        └── hal_file.c
    

    其中BUILD.gn内容如下:

    import("//build/lite/config/component/lite_component.gni")
    static_library("hal_file_static") {     #目标名。
      sources = [ "src/hal_file.c" ]        #厂商适配的源文件。
      include_dirs = [
        "//utils/native/lite/hals/file",
      ]
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值