0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于OpenHarmony标准接口的文件读写实现案例

福州市凌睿智捷电子有限公司 2022-09-15 10:57 次阅读

一、简介

嵌入式领域,FLASH是一种常用的存储设备,Flash闪存作为嵌入式系统的主要存储设备有其自身的特性。Fash的写入操作只能把对应位置的1修改成0,而不能把0修改为1,而擦除Fash就是把对应存储块的内容恢复为1。因此,一般情况下向Fash写入内容时,需要先擦除对应的存储区间,这种擦除是以块(Bock)为单位进行的。闪存主要有NOR和NAND两种技术。因为Flash存储器的擦写次数是有限的,NAND闪存还有特殊的硬件接口和读写时序,于是就出现了专门针对FLASH的文件系统。比较常用的有jffs2,yaffs2,logfs,ubifs。本文基于小凌派-RK2206开发板 + OpenHarmony轻量级操作系统 + LitteFS文件系统,通过hal_file标准接口实现对Flash读写功能。

二、hal_file标准接口

头文件://utils/native/lite/hals/file/hal_file.h

1、HalFileOpen()

打开/创建文件,类似于Linux的open函数。

int HalFileOpen(const char *path, int oflag, int mode);

参数说明:

名字

描述

path

文件路径

oflag

参考///utils/native/lite/include/utils_file.hO_RDONLY_FS:只读O_WRONLY_FS:只写O_RDWR_FS:读写O_CREAT_FS:如果没有则创建O_EXCL_FS:如果没有则创建;如有则不能打开O_TRUNC_FS:如果文件存在,则清空文件内容O_APPEND_FS:如果文件存在,则标记位置移动到文件最后

mode

0

返回值为LOS_OK表示成功,其余为失败。

2、HalFileClose()

关闭文件,类似于Linux的close函数。

int HalFileClose(int fd);

参数说明:

名字

描述

fd

文件句柄

返回值为LOS_OK表示成功,其余为失败。

3、HalFileRead()

从文件中读取一段内容,类似于Linux的read函数。

int HalFileRead(int fd, char* buf, unsigned int len);

参数说明:

名字

描述

fd

文件句柄

buf

从文件读取内容的缓冲区

len

从文件读取内容的大小

返回值为从文件读取内容的大小,0或者小于0则为失败。

4、HalFileWrite()

往文件写入一段内容,类似于Linux的write函数。

int HalFileWrite(int fd, const char* buf, unsigned int len);

参数说明:

名字

描述

fd

文件句柄

buf

需要写入到文件的内容缓冲区

len

需要写入到文件的内容大小

返回值为成功写入到文件的内容大小,0或者小于0则为失败。

5、HalFileDelete()

删除文件,类似于Linux的unlink函数。

int HalFileDelete(const char* path);

参数说明:

名字

描述

path

文件路径

返回值为LOS_OK为成功,其余则为失败。

6、HalFileStat()

获取文件大小,类似于Linux的stat函数。

int HalFileStat(const char* path, unsigned int* fileSize);

参数说明:

名字

描述

path

文件路径

fileSize

文件内容大小

返回值为LOS_OK为成功,其余则为失败。

7、HalFileSeek()

文件所在位置移动,类似于Linux的lseek函数。

int HalFileSeek(int fd, int offset, unsigned int whence);

参数说明:

名字

描述

fd

文件句柄

offset

文件位置移动位数

whence

SEEK_SET_FS:从文件开头移动

SEEK_CUR_FS:从文件当前位置移动

SEEK_END_FS:从文件结尾移动

返回值为LOS_OK为成功,其余则为失败。

三、程序设计

本例程演示如何在小凌派-RK2206开发板上使用鸿蒙LiteOS-M内核接口,进行文件读写开发。例程流程如下所示:

(1)创建一个文件;

(2)每5秒进行1次文件读写操作;

(3)文件标识移动到文件起始处,读文件内容,并打印;

(4)文件标识移动到文件起始处,写文件内容;

(5)循环上述的第2~4步骤。

1、任务创建代码分析

在file_example函数中通过LOS_TaskCreate函数创建一个线程:hal_file_thread。

void file_example()
{
    unsigned int thread_id;
    TSK_INIT_PARAM_S task = {0};
    unsigned int ret = LOS_OK;

    task.pfnTaskEntry = (TSK_ENTRY_FUNC)hal_file_thread;
    task.uwStackSize = 1024 * 10;
    task.pcName = "hal_file_thread";
    task.usTaskPrio = 25;
    ret = LOS_TaskCreate(&thread_id, &task);
    if (ret != LOS_OK)
    {
        printf("Falied to create hal_file_thread ret:0x%x\n", ret);
        return;
    }
}

APP_FEATURE_INIT(file_example);

2. 文件读写代码分析

hal_file_thread函数负责打开文件,每5秒移动到文件头读取数据,再移动到文件头写入一段内容,重复以上流程。

void hal_file_thread()
{
    int fd;
    char buffer[1024];
    int read_length, write_length;
    int current = 0;

    /* 打开文件,如果没有该文件就创建,如有该文件则打开
     * O_TRUNC_FS => 清空文件内容
     */
    //fd = HalFileOpen(FILE_NAME, O_RDWR_FS | O_CREAT_FS, 0);
    fd = HalFileOpen(FILE_NAME, O_RDWR_FS | O_CREAT_FS | O_TRUNC_FS, 0);
    if (fd == -1)
    {
        printf("%s HalFileOpen failed!\n", FILE_NAME);
        return;
    }

    while (1)
    {
        /* 文件位置移动到文件开始位置 */
        HalFileSeek(fd, 0, SEEK_SET);
        memset(buffer, 0, sizeof(buffer));
        /* 读取文件内容 */
        read_length = HalFileRead(fd, buffer, sizeof(buffer));
        printf("read: \n");
        printf("    length = %d\n", read_length);
        printf("    content = %s\n", buffer);

        /* 文件位置移动到文件开始位置 */
        HalFileSeek(fd, 0, SEEK_SET);
        memset(buffer, 0, sizeof(buffer));
        snprintf(buffer, sizeof(buffer), "Hello World(%d) => ", current);
        /* 写入文件 */
        write_length = HalFileWrite(fd, buffer, strlen(buffer));

        current++;
        LOS_Msleep(5000);
    }

    HalFileClose(fd);
}

四、编译过程

1、搭建和下载源代码

我已将OpenHarmony源代码上传到Gitee社区中,大家可以根据以下网址下载。

https://gitee.com/Lockzhiner-Electronics/lockzhiner-rk2206-openharmony3.0lts

注意:编译环境可根据以下网址来操作:https://gitee.com/Lockzhiner-Electronics/lockzhiner-rk2206-openharmony3.0lts/blob/master/vendor/lockzhiner/rk2206/README_zh.md

2、修改编译脚本

修改vendor/lockzhiner/rk2206/sample路径下 BUILD.gn 文件,指定 a7_hal_file参与编译。

"./a7_hal_file:hal_file_example",

修改 device/lockzhiner/rk2206/sdk_liteos路径下 Makefile 文件,添加 -lhal_file_example参与编译。

apps_LIBS = -lhal_file_example

3、编译固件

hb set -root .

hb set

hb build -f

4、烧写固件

请参考Gitee网址的说明手册(“烧录打印”章节):https://gitee.com/Lockzhiner-Electronics/lockzhiner-rk2206-openharmony3.0lts/blob/master/device/rockchip/README_zh.md

五、实验结果

程序编译烧写到开发板后,按下开发板的RESET按键,通过串口软件查看日志如下:

HalFileInit: Flash Init Successful!

read:

length = 0

content =

read:

length = 18

content = Hello World(0) =>

read:

length = 18

content = Hello World(1) =>

好了,今天的课程就到这里,我们下次再见!

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • OpenHarmony
    +关注

    关注

    25

    文章

    3629

    浏览量

    16031
收藏 人收藏

    评论

    相关推荐

    写实用程序-mflash

    电子发烧友网站提供《刷写实用程序-mflash.pdf》资料免费下载
    发表于 10-10 09:19 0次下载
    刷<b class='flag-5'>写实</b>用程序-mflash

    接口芯片的读写信号与系统的关系

    接口芯片在现代电子系统中扮演着至关重要的角色,它们负责在不同设备或系统之间传输数据。接口芯片的读写信号是数据传输的基础,它们确保数据能够正确、高效地在系统中流动。 1. 接口芯片的基本
    的头像 发表于 09-30 14:05 216次阅读

    如何在标准接口电路中将光耦合器替换为数字隔离器

    电子发烧友网站提供《如何在标准接口电路中将光耦合器替换为数字隔离器.pdf》资料免费下载
    发表于 09-27 09:45 0次下载
    如何在<b class='flag-5'>标准接口</b>电路中将光耦合器替换为数字隔离器

    基于ArkTS语言的OpenHarmony APP应用开发:HelloOpenharmony

    1、程序简介该程序是基于OpenHarmony标准系统编写的UI应用类:HelloOpenHarmony。本案例是基于API9接口开发。本案例已在O
    的头像 发表于 09-15 08:09 272次阅读
    基于ArkTS语言的<b class='flag-5'>OpenHarmony</b> APP应用开发:Hello<b class='flag-5'>Openharmony</b>

    基于ArkTS语言的OpenHarmony APP应用开发:HelloOpenharmony

    1、程序简介 该程序是基于OpenHarmony标准系统编写的UI应用类:HelloOpenHarmony。 本案例是基于API 9接口开发。 本案例已在
    发表于 09-14 12:47

    基于OpenHarmony标准系统的C++公共基础类库案例:SafeBlockQueue

    1、程序简介该程序是基于OpenHarmony的C++公共基础类库的读写锁:SafeBlockQueue。线程安全阻塞队列SafeBlockQueue类,提供阻塞和非阻塞版的入队入队和出队接口,并提
    的头像 发表于 08-30 12:41 237次阅读
    基于<b class='flag-5'>OpenHarmony</b><b class='flag-5'>标准</b>系统的C++公共基础类库案例:SafeBlockQueue

    电源芯片研发生产测试系统开发API接口实现与ERP的数据共享

    为了实现电源芯片测试系统的测试数据可以传输至客户的ERP系统中,纳米软件开发了API接口。作为标准接口,既保证了数据传输的稳定性,同时也确保了数据的安全性。
    的头像 发表于 08-13 16:49 252次阅读
    电源芯片研发生产测试系统开发API<b class='flag-5'>接口</b>,<b class='flag-5'>实现</b>与ERP的数据共享

    基于Openharmony轻量级操作系统的分布式数据管理开发案例

    ,一个负责读取KvStore存储;(2)每1秒进行1次读写操作;程序设计在本章节中,我们将了解OpenHarmonyKvStore存储接口,如文件如何获取数据、设置
    的头像 发表于 08-07 08:23 799次阅读
    基于<b class='flag-5'>Openharmony</b>轻量级操作系统的分布式数据管理开发案例

    【GD32F303红枫派开发板使用手册】第二十三讲 SDIO-SD卡读写实

    通过本实验主要学习以下内容: •SDIO操作原理 •SD卡读写实现
    的头像 发表于 06-23 10:49 509次阅读
    【GD32F303红枫派开发板使用手册】第二十三讲 SDIO-SD卡<b class='flag-5'>读写实</b>验

    如何在Openharmony实现USB复合设备

    如何让Openharmony设备HDC接口(OTG接口)作为一个复合设备,实现HDC(HDC:鸿蒙设备连接器) + CDC ACM(USB 虚拟串口),而设备本身支持HDC。所以需要增
    的头像 发表于 06-13 15:03 1283次阅读
    如何在<b class='flag-5'>Openharmony</b>中<b class='flag-5'>实现</b>USB复合设备

    【GD32F470紫藤派开发板使用手册】第十二讲 SDIO-SD卡读写实

    通过本实验主要学习以下内容: •SDIO操作原理 •SD卡读写实现
    的头像 发表于 05-18 09:36 1254次阅读
    【GD32F470紫藤派开发板使用手册】第十二讲 SDIO-SD卡<b class='flag-5'>读写实</b>验

    【鸿蒙】OpenHarmony 4.0蓝牙代码结构简析

    /master/api当前所有应用层接口统一归并到interface仓;api 10中蓝牙接口按照profile拆分了多个d.ts文件 框架层https://gitee.com/openhar
    的头像 发表于 02-26 16:08 1390次阅读
    【鸿蒙】<b class='flag-5'>OpenHarmony</b> 4.0蓝牙代码结构简析

    OpenHarmony之NAPI框架介绍

    。 可以看到,NAPI 接口本身是 C++语言实现的,这些接口可以帮助 C++代码创建 JS 变量,或访问 JavaScript 运行环境中的 JS 变量与方法。 OpenHarmony
    发表于 11-23 15:36

    安全存储文件的创建

    OP-TEE中调用GP标准接口使用安全存储功能时,对文件读写操作最终是由REE侧来完成的。 OP-TEE无法直接操作REE侧的
    的头像 发表于 11-21 15:02 505次阅读
    安全存储<b class='flag-5'>文件</b>的创建

    Nand Flash接口定义解析 基于AMD FPGA的Nand Flash接口读写实现

    Nand Flash因其具有容量大、成本低、寿命长的特点,被广泛的用作数据存储的解决方案。然而NandFlash的读写控制较为复杂,Nand Flash的接口控制器大多是基于PC机或ARM处理器为架构进行开发的,存在操作不方便的问题。
    的头像 发表于 11-10 09:40 7201次阅读
    Nand Flash<b class='flag-5'>接口</b>定义解析 基于AMD FPGA的Nand Flash<b class='flag-5'>接口</b><b class='flag-5'>读写实现</b>