mirror of
https://github.com/DragonOS-Community/DragonOS.git
synced 2025-06-09 23:46:48 +00:00
为vfs挂载文件系统增加挂载点路径参数
This commit is contained in:
parent
339053a20e
commit
86a5f25e07
@ -10,25 +10,31 @@
|
|||||||
|
|
||||||
// 为filesystem_type_t结构体实例化一个链表头
|
// 为filesystem_type_t结构体实例化一个链表头
|
||||||
static struct vfs_filesystem_type_t vfs_fs = {"filesystem", 0};
|
static struct vfs_filesystem_type_t vfs_fs = {"filesystem", 0};
|
||||||
|
struct vfs_superblock_t *vfs_root_sb = NULL;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 挂载文件系统
|
* @brief 挂载文件系统
|
||||||
*
|
*
|
||||||
|
* @param path 要挂载到的路径
|
||||||
* @param name 文件系统名
|
* @param name 文件系统名
|
||||||
* @param blk 块设备结构体
|
* @param blk 块设备结构体
|
||||||
* @return struct vfs_superblock_t*
|
* @return struct vfs_superblock_t* 挂载后,文件系统的超级块
|
||||||
*/
|
*/
|
||||||
struct vfs_superblock_t *vfs_mount_fs(char *name, struct block_device *blk)
|
struct vfs_superblock_t *vfs_mount_fs(const char *path, char *name, struct block_device *blk)
|
||||||
{
|
{
|
||||||
|
// todo: 选择挂载点
|
||||||
struct vfs_filesystem_type_t *p = NULL;
|
struct vfs_filesystem_type_t *p = NULL;
|
||||||
for (p = &vfs_fs; p; p = p->next)
|
for (p = &vfs_fs; p; p = p->next)
|
||||||
{
|
{
|
||||||
if (!strcmp(p->name, name)) // 存在符合的文件系统
|
if (!strcmp(p->name, name)) // 存在符合的文件系统
|
||||||
{
|
{
|
||||||
return p->read_superblock(blk);
|
struct vfs_superblock_t *sb = p->read_superblock(blk);
|
||||||
|
if (strcmp(path, "/") == 0) // 如果挂载到的是'/'挂载点,则让其成为最顶层的文件系统
|
||||||
|
vfs_root_sb = sb;
|
||||||
|
return sb;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
kdebug("unsupported fs: %s", name);
|
kdebug("unsupported fs: %s", name);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -15,7 +15,7 @@
|
|||||||
#include <common/fcntl.h>
|
#include <common/fcntl.h>
|
||||||
#include <common/blk_types.h>
|
#include <common/blk_types.h>
|
||||||
|
|
||||||
struct vfs_superblock_t *vfs_root_sb = NULL;
|
extern struct vfs_superblock_t *vfs_root_sb;
|
||||||
|
|
||||||
#define VFS_DPT_MBR 0 // MBR分区表
|
#define VFS_DPT_MBR 0 // MBR分区表
|
||||||
#define VFS_DPT_GPT 1 // GPT分区表
|
#define VFS_DPT_GPT 1 // GPT分区表
|
||||||
@ -54,7 +54,7 @@ struct vfs_superblock_t
|
|||||||
{
|
{
|
||||||
struct vfs_dir_entry_t *root;
|
struct vfs_dir_entry_t *root;
|
||||||
struct vfs_super_block_operations_t *sb_ops;
|
struct vfs_super_block_operations_t *sb_ops;
|
||||||
struct block_device * blk_device;
|
struct block_device *blk_device;
|
||||||
void *private_sb_info;
|
void *private_sb_info;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -175,11 +175,12 @@ uint64_t vfs_unregister_filesystem(struct vfs_filesystem_type_t *fs);
|
|||||||
/**
|
/**
|
||||||
* @brief 挂载文件系统
|
* @brief 挂载文件系统
|
||||||
*
|
*
|
||||||
|
* @param path 要挂载到的路径
|
||||||
* @param name 文件系统名
|
* @param name 文件系统名
|
||||||
* @param blk 块设备结构体
|
* @param blk 块设备结构体
|
||||||
* @return struct vfs_superblock_t*
|
* @return struct vfs_superblock_t* 挂载后,文件系统的超级块
|
||||||
*/
|
*/
|
||||||
struct vfs_superblock_t *vfs_mount_fs(char *name, struct block_device *blk);
|
struct vfs_superblock_t *vfs_mount_fs(const char *path, char *name, struct block_device *blk);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief 按照路径查找文件
|
* @brief 按照路径查找文件
|
||||||
|
@ -28,7 +28,7 @@ struct vfs_superblock_t *fat32_register_partition(uint8_t ahci_ctrl_num, uint8_t
|
|||||||
{
|
{
|
||||||
|
|
||||||
// 挂载文件系统到vfs
|
// 挂载文件系统到vfs
|
||||||
return vfs_mount_fs("FAT32", (ahci_gendisk0.partition + 0));
|
return vfs_mount_fs("/", "FAT32", (ahci_gendisk0.partition + 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -552,7 +552,7 @@ long fat32_read(struct vfs_file_t *file_ptr, char *buf, int64_t count, long *pos
|
|||||||
|
|
||||||
// find the actual cluster on disk of the specified position
|
// find the actual cluster on disk of the specified position
|
||||||
for (int i = 0; i < clus_offset_in_file; ++i)
|
for (int i = 0; i < clus_offset_in_file; ++i)
|
||||||
cluster = fat32_read_FAT_entry(blk,fsbi, cluster);
|
cluster = fat32_read_FAT_entry(blk, fsbi, cluster);
|
||||||
|
|
||||||
// 如果需要读取的数据边界大于文件大小
|
// 如果需要读取的数据边界大于文件大小
|
||||||
if (*position + count > file_ptr->dEntry->dir_inode->file_size)
|
if (*position + count > file_ptr->dEntry->dir_inode->file_size)
|
||||||
@ -597,7 +597,7 @@ long fat32_read(struct vfs_file_t *file_ptr, char *buf, int64_t count, long *pos
|
|||||||
|
|
||||||
*position += step_trans_len; // 更新文件指针
|
*position += step_trans_len; // 更新文件指针
|
||||||
|
|
||||||
cluster = fat32_read_FAT_entry(blk,fsbi, cluster);
|
cluster = fat32_read_FAT_entry(blk, fsbi, cluster);
|
||||||
} while (bytes_remain && (cluster < 0x0ffffff8) && cluster != 0);
|
} while (bytes_remain && (cluster < 0x0ffffff8) && cluster != 0);
|
||||||
|
|
||||||
kfree(tmp_buffer);
|
kfree(tmp_buffer);
|
||||||
@ -641,7 +641,7 @@ long fat32_write(struct vfs_file_t *file_ptr, char *buf, int64_t count, long *po
|
|||||||
{
|
{
|
||||||
// 跳转到position所在的簇
|
// 跳转到position所在的簇
|
||||||
for (uint64_t i = 0; i < clus_offset_in_file; ++i)
|
for (uint64_t i = 0; i < clus_offset_in_file; ++i)
|
||||||
cluster = fat32_read_FAT_entry(blk,fsbi, cluster);
|
cluster = fat32_read_FAT_entry(blk, fsbi, cluster);
|
||||||
}
|
}
|
||||||
// kdebug("cluster(start)=%d", cluster);
|
// kdebug("cluster(start)=%d", cluster);
|
||||||
// 没有可用的磁盘空间
|
// 没有可用的磁盘空间
|
||||||
@ -704,7 +704,7 @@ long fat32_write(struct vfs_file_t *file_ptr, char *buf, int64_t count, long *po
|
|||||||
|
|
||||||
int next_clus = 0;
|
int next_clus = 0;
|
||||||
if (bytes_remain)
|
if (bytes_remain)
|
||||||
next_clus = fat32_read_FAT_entry(blk,fsbi, cluster);
|
next_clus = fat32_read_FAT_entry(blk, fsbi, cluster);
|
||||||
else
|
else
|
||||||
break;
|
break;
|
||||||
if (next_clus >= 0x0ffffff8) // 已经到达了最后一个簇,需要分配新簇
|
if (next_clus >= 0x0ffffff8) // 已经到达了最后一个簇,需要分配新簇
|
||||||
@ -1069,7 +1069,7 @@ int64_t fat32_readdir(struct vfs_file_t *file_ptr, void *dirent, vfs_filldir_t f
|
|||||||
// 循环读取fat entry,直到读取到文件当前位置的所在簇号
|
// 循环读取fat entry,直到读取到文件当前位置的所在簇号
|
||||||
for (int i = 0; i < clus_num; ++i)
|
for (int i = 0; i < clus_num; ++i)
|
||||||
{
|
{
|
||||||
cluster = fat32_read_FAT_entry(blk,fsbi, cluster);
|
cluster = fat32_read_FAT_entry(blk, fsbi, cluster);
|
||||||
if (cluster > 0x0ffffff7) // 文件结尾
|
if (cluster > 0x0ffffff7) // 文件结尾
|
||||||
{
|
{
|
||||||
kerror("file position out of range! (cluster not exists)");
|
kerror("file position out of range! (cluster not exists)");
|
||||||
@ -1263,6 +1263,6 @@ void fat32_init()
|
|||||||
vfs_register_filesystem(&fat32_fs_type);
|
vfs_register_filesystem(&fat32_fs_type);
|
||||||
|
|
||||||
// 挂载根文件系统
|
// 挂载根文件系统
|
||||||
vfs_root_sb = fat32_register_partition(0, 0, 0);
|
fat32_register_partition(0, 0, 0);
|
||||||
kinfo("FAT32 initialized.");
|
kinfo("FAT32 initialized.");
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user