OpenHarmony开发者论坛

标题: 【移植】轻量级系统之文件子系统移植 [打印本页]

作者: 诚迈_雨哥    时间: 2024-1-18 20:39
标题: 【移植】轻量级系统之文件子系统移植
[md]# 移植文件子系统

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",
     ]
   }
   ```

## 声明

* 本文转载自 https://gitee.com/openharmony/do ... device-dev/porting;
* 源文件目录 ./docs/zh-cn/device-dev/porting/porting-minichip-subsys-filesystem.md;
* 文件修改截止日期 2024.01.01
[/md]




欢迎光临 OpenHarmony开发者论坛 (https://forums.openharmony.cn/) Powered by Discuz! X3.5