Skip to content

Latest commit

 

History

History
58 lines (44 loc) · 1.5 KB

README.md

File metadata and controls

58 lines (44 loc) · 1.5 KB

VFS

This crate provides a virtual file system implementation, which can be used in the kernel or user space.

The virtual file system is a file system abstraction layer. The virtual file system is responsible for managing all file systems, and all file system types must be registered in the virtual file system.

Features

  • RamFs
  • DevFs
  • DynFs(It can be used as procfs/sysfs)
  • VfsCore
  • ExtFs
  • FatFs
  • ...

Demo

# run
RUST_LOG=info cargo run -p demo

Usage

devfs = { git = "https://github.com/os-module/rvfs" }
ramfs = { git = "https://github.com/os-module/rvfs" }
dynfs = { git = "https://github.com/os-module/rvfs" }
fat-vfs = { git = "https://github.com/os-module/rvfs" }
lwext-vfs = { git = "https://github.com/os-module/rvfs" }
vfscore = { git = "https://github.com/os-module/rvfs" }
// create a fs_type
let ramfs = Arc::new(RamFs::<_, Mutex<()>>::new(RamFsProviderImpl));
// create a fs instance
let root_dt = ramfs.i_mount(MountFlags::empty(), None, &[])?;
// get the inode
let root_inode = root_dt.inode()?;
// create a file
let f1 = root_inode.create(
    "f1.txt",
    VfsNodeType::File,
    VfsNodePerm::from_bits_truncate(0o666),
    None,
)?;

Reference

Overview of the Linux Virtual File System — The Linux Kernel documentation

https://github.com/rcore-os/arceos/tree/main/crates/axfs_vfs

https://github.com/yfblock/ByteOS