Parcourir la source

为vfs挂载文件系统增加挂载点路径参数

fslongjin il y a 2 ans
Parent
commit
86a5f25e07
3 fichiers modifiés avec 22 ajouts et 15 suppressions
  1. 10 4
      kernel/filesystem/VFS/VFS.c
  2. 5 4
      kernel/filesystem/VFS/VFS.h
  3. 7 7
      kernel/filesystem/fat32/fat32.c

+ 10 - 4
kernel/filesystem/VFS/VFS.c

@@ -10,25 +10,31 @@
 
 // 为filesystem_type_t结构体实例化一个链表头
 static struct vfs_filesystem_type_t vfs_fs = {"filesystem", 0};
+struct vfs_superblock_t *vfs_root_sb = NULL;
 
 /**
  * @brief 挂载文件系统
  *
+ * @param path 要挂载到的路径
  * @param name 文件系统名
  * @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;
     for (p = &vfs_fs; p; p = p->next)
     {
         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);
     return NULL;
 }

+ 5 - 4
kernel/filesystem/VFS/VFS.h

@@ -15,7 +15,7 @@
 #include <common/fcntl.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_GPT 1 // GPT分区表
@@ -54,7 +54,7 @@ struct vfs_superblock_t
 {
     struct vfs_dir_entry_t *root;
     struct vfs_super_block_operations_t *sb_ops;
-    struct block_device * blk_device;
+    struct block_device *blk_device;
     void *private_sb_info;
 };
 
@@ -175,11 +175,12 @@ uint64_t vfs_unregister_filesystem(struct vfs_filesystem_type_t *fs);
 /**
  * @brief 挂载文件系统
  *
+ * @param path 要挂载到的路径
  * @param name 文件系统名
  * @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 按照路径查找文件

+ 7 - 7
kernel/filesystem/fat32/fat32.c

@@ -28,7 +28,7 @@ struct vfs_superblock_t *fat32_register_partition(uint8_t ahci_ctrl_num, uint8_t
 {
 
     // 挂载文件系统到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
     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)
@@ -597,7 +597,7 @@ long fat32_read(struct vfs_file_t *file_ptr, char *buf, int64_t count, long *pos
 
         *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);
 
     kfree(tmp_buffer);
@@ -641,7 +641,7 @@ long fat32_write(struct vfs_file_t *file_ptr, char *buf, int64_t count, long *po
     {
         // 跳转到position所在的簇
         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);
     //  没有可用的磁盘空间
@@ -704,7 +704,7 @@ long fat32_write(struct vfs_file_t *file_ptr, char *buf, int64_t count, long *po
 
         int next_clus = 0;
         if (bytes_remain)
-            next_clus = fat32_read_FAT_entry(blk,fsbi, cluster);
+            next_clus = fat32_read_FAT_entry(blk, fsbi, cluster);
         else
             break;
         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,直到读取到文件当前位置的所在簇号
     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) // 文件结尾
         {
             kerror("file position out of range! (cluster not exists)");
@@ -1263,6 +1263,6 @@ void fat32_init()
     vfs_register_filesystem(&fat32_fs_type);
 
     // 挂载根文件系统
-    vfs_root_sb = fat32_register_partition(0, 0, 0);
+    fat32_register_partition(0, 0, 0);
     kinfo("FAT32 initialized.");
 }