同步操作将从 AliOS Things/vfs 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
@page vfs vfs
VFS 虚拟文件系统为各种文件(包括设备文件和普通文件)提供统一的操作接口。它是具体设备文件和文件系统之上的抽象层。其目的是允许应用程序以统一的方式访问不同类型的具体文件和设备。用户可以将ramfs,little fs等具体的文件系统注册到 VFS 中,然后使用标准操作接口(open,read,write,close 等)访问其中的文件。
组件支持以下功能:
Apache license v2.0
├── src
│ ├── vfs_adapt.c # vfs OS adapt layer 具体实现代码
│ ├── vfs_aos.c # VFS 的aos api接口实现
│ ├── vfs.c # vfs 核心逻辑代码
│ ├── vfs_file.c # vfs file descriptor 管理具体实现代码
│ └── vfs_inode.c # vfs inode 管理代码
├── include
│ ├── aos
│ │ └── vfs.h # VFS的对外AOS API
| ├── vfs_api.h # VFS的对外 API
| ├── vfs_conf.h # VFS 的参数配置
| ├── vfs_file.h # VFS 文件相关操作
| ├── vfs_inode.h # VFS inode 管理
| ├── vfs_types.h # VFS 数据结构定义
│ └── vfs_adapt.h # vfs OS adapt layer declaration
├── package.yaml # 编译配置文件
└── example
└── vfs_example.c # VFS 示例代码
系统中相关配置已有默认值,如需修改配置,统一在yaml中def_config节点修改,具体如下:
VFS 设备node数量,默认4096, 可修改yaml配置如:
def_config:
VFS_CONFIG_DEVICE_NODES: 4096
VFS FD 默认起始值,默认 512,可修改yaml配置如:
def_config:
VFS_CONFIG_FD_OFFSET: 512
VFS 路径长度最大字节数,默认256,可修改yaml配置如:
def_config:
VFS_CONFIG_PATH_MAX: 256
VFS 最大文件数量,默认50,可修改yaml配置如:
def_config:
VFS_CONFIG_MAX_FILE_NUM: 50
int vfs_init(void);
int aos_open(const char *path, int flags);
参数
返回值
flags:
参数 | 描述 |
---|---|
O_RDONLY | 只读方式打开文件 |
O_WRONLY | 只写方式打开文件 |
O_RDWR | 以读写方式打开文件 |
O_CREAT | 如果要打开的文件不存在,则建立该文件 |
O_APPEND | 当读写文件时会从文件尾开始移动,也就是所写入的数据会以附加的方式添加到文件的尾部 |
O_TRUNC | 如果文件已经存在,则清空文件中的内容 |
O_EXCL | 如果存在指定文件,返回出错 |
int aos_close(int fd);
ssize_t aos_read(int fd, void *buf, size_t nbytes);
ssize_t aos_write(int fd, const void *buf, size_t nbytes);
int aos_ioctl(int fd, int cmd, unsigned long arg);
int aos_fcntl(int fd, int cmd, int val);
cmd
的参数off_t aos_lseek(int fd, off_t offset, int whence);
whence
来移动读写位置的位移数offset
即为新的读写位置 SEEK_CUR 以目前的读写位置往后增加`offset` 个位移量
SEEK_END 将读写位置指向文件尾后再增加`offset`个位移量. 当whence 值为SEEK_CUR 或SEEK_END 时, 参数`offet`允许负值的出现.
int aos_sync(int fd);
int aos_stat(const char *path, struct stat *st);
int aos_unlink(const char *path);
int aos_rename(const char *oldpath, const char *newpath);
aos_dir_t *aos_opendir(const char *path);
int aos_closedir(aos_dir_t *dir);
aos_dirent_t *aos_readdir(aos_dir_t *dir);
int aos_mkdir(const char *path);
int aos_rmdir(const char *path);
组件使用示例相关的代码下载、编译和固件烧录均依赖AliOS Things配套的开发工具,所以首先需要参考《AliOS Things集成开发环境使用说明之搭建开发环境》,下载安装。 待开发环境搭建完成后,可以按照以下步骤进行示例的测试。
打开已有工程
如果用于测试的案例工程已存在,可参考《AliOS Things集成开发环境使用说明之打开工程》打开已有工程。
创建新的工程
组件的示例代码可以通过编译链接到AliOS Things的任意案例(solution)来运行,这里选择helloworld_demo案例。helloworld_demo案例相关的源代码下载可参考《AliOS Things集成开发环境使用说明之创建工程》。
案例下载完成后,需要在helloworld_demo组件的package.yaml中添加对组件的依赖:
在helloworld_demo组件的package.yaml中添加
depends:
- vfs: master # helloworld_demo中引入vfs组件
在已安装了 的开发环境工具栏中,选择Terminal -> New Terminal启动终端,并且默认工作路径为当前工程的workspace,此时在终端命令行中输入:
aos install vfs
上述命令执行成功后,组件源码则被下载到了./components/vfs路径中。
vfs组件的package.yaml中添加example示例代码:
source_file:
- "example/vfs_example.c" # add vfs_example.c
在示例代码已经添加至组件的配置文件,并且helloworld_demo已添加了对该组件的依赖后,就可以编译helloworld_demo案例来生成固件了,具体编译方法可参考《AliOS Things集成开发环境使用说明之编译固件》。
helloworld_demo案例的固件生成后,可参考《AliOS Things集成开发环境使用说明之烧录固件》来烧录固件。
固件烧录完成后,可以通过串口查看示例的运行结果,打开串口的具体方法可参考《AliOS Things集成开发环境使用说明之查看日志》。
当串口终端打开成功后,可在串口中输入help来查看已添加的测试命令。
CLI命令行输入:
vfs_example
关键日志:
vfs example test success!
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。