Kernel: You don't have to check whether VFS is initialized or not
VFS now returns Error when attempting to traverse inodes if it did not find root partition
This commit is contained in:
parent
fc58baf54d
commit
8940ff8002
|
@ -11,7 +11,7 @@ namespace Kernel
|
||||||
public:
|
public:
|
||||||
static BAN::ErrorOr<void> initialize();
|
static BAN::ErrorOr<void> initialize();
|
||||||
static VirtualFileSystem& get();
|
static VirtualFileSystem& get();
|
||||||
static bool is_initialized();
|
virtual ~VirtualFileSystem() {};
|
||||||
|
|
||||||
virtual const BAN::RefPtr<Inode> root_inode() const override { return m_root_inode; }
|
virtual const BAN::RefPtr<Inode> root_inode() const override { return m_root_inode; }
|
||||||
|
|
||||||
|
|
|
@ -33,11 +33,6 @@ namespace Kernel
|
||||||
return *s_instance;
|
return *s_instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool VirtualFileSystem::is_initialized()
|
|
||||||
{
|
|
||||||
return s_instance != nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
BAN::ErrorOr<void> VirtualFileSystem::initialize_impl()
|
BAN::ErrorOr<void> VirtualFileSystem::initialize_impl()
|
||||||
{
|
{
|
||||||
// Initialize all storage controllers
|
// Initialize all storage controllers
|
||||||
|
@ -115,9 +110,9 @@ namespace Kernel
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_root_inode)
|
if (m_root_inode.empty())
|
||||||
|
derrorln("Could not locate root partition");
|
||||||
return {};
|
return {};
|
||||||
return BAN::Error::from_c_string("Could not locate root partition");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
BAN::ErrorOr<BAN::RefPtr<Inode>> VirtualFileSystem::from_absolute_path(BAN::StringView path)
|
BAN::ErrorOr<BAN::RefPtr<Inode>> VirtualFileSystem::from_absolute_path(BAN::StringView path)
|
||||||
|
@ -126,6 +121,9 @@ namespace Kernel
|
||||||
return BAN::Error::from_c_string("Path must be an absolute path");
|
return BAN::Error::from_c_string("Path must be an absolute path");
|
||||||
|
|
||||||
auto inode = root_inode();
|
auto inode = root_inode();
|
||||||
|
if (!inode)
|
||||||
|
return BAN::Error::from_c_string("No root inode available");
|
||||||
|
|
||||||
auto path_parts = TRY(path.split('/'));
|
auto path_parts = TRY(path.split('/'));
|
||||||
|
|
||||||
for (BAN::StringView part : path_parts)
|
for (BAN::StringView part : path_parts)
|
||||||
|
|
|
@ -25,9 +25,6 @@ namespace Kernel
|
||||||
|
|
||||||
BAN::ErrorOr<Font> Font::load(BAN::StringView path)
|
BAN::ErrorOr<Font> Font::load(BAN::StringView path)
|
||||||
{
|
{
|
||||||
if (!VirtualFileSystem::is_initialized())
|
|
||||||
return BAN::Error::from_c_string("Virtual Filesystem is not initialized");
|
|
||||||
|
|
||||||
auto inode = TRY(VirtualFileSystem::get().from_absolute_path(path));
|
auto inode = TRY(VirtualFileSystem::get().from_absolute_path(path));
|
||||||
|
|
||||||
auto file_data = TRY(inode->read_all());
|
auto file_data = TRY(inode->read_all());
|
||||||
|
|
|
@ -265,9 +265,6 @@ argument_done:
|
||||||
}
|
}
|
||||||
else if (arguments.front() == "ls")
|
else if (arguments.front() == "ls")
|
||||||
{
|
{
|
||||||
if (!VirtualFileSystem::is_initialized())
|
|
||||||
return BAN::Error::from_c_string("VFS not initialized :(");
|
|
||||||
|
|
||||||
if (arguments.size() > 2)
|
if (arguments.size() > 2)
|
||||||
return BAN::Error::from_c_string("usage: 'ls [path]'");
|
return BAN::Error::from_c_string("usage: 'ls [path]'");
|
||||||
|
|
||||||
|
@ -304,9 +301,6 @@ argument_done:
|
||||||
}
|
}
|
||||||
else if (arguments.front() == "cat")
|
else if (arguments.front() == "cat")
|
||||||
{
|
{
|
||||||
if (!VirtualFileSystem::is_initialized())
|
|
||||||
return BAN::Error::from_c_string("VFS not initialized :(");
|
|
||||||
|
|
||||||
if (arguments.size() != 2)
|
if (arguments.size() != 2)
|
||||||
return BAN::Error::from_c_string("usage: 'cat path'");
|
return BAN::Error::from_c_string("usage: 'cat path'");
|
||||||
|
|
||||||
|
@ -316,9 +310,6 @@ argument_done:
|
||||||
}
|
}
|
||||||
else if (arguments.front() == "loadfont")
|
else if (arguments.front() == "loadfont")
|
||||||
{
|
{
|
||||||
if (!VirtualFileSystem::is_initialized())
|
|
||||||
return BAN::Error::from_c_string("VFS not initialized :(");
|
|
||||||
|
|
||||||
if (arguments.size() != 2)
|
if (arguments.size() != 2)
|
||||||
return BAN::Error::from_c_string("usage: 'loadfont font_path'");
|
return BAN::Error::from_c_string("usage: 'loadfont font_path'");
|
||||||
|
|
||||||
|
|
|
@ -127,11 +127,7 @@ extern "C" void kernel_main()
|
||||||
MUST(scheduler.add_thread(MUST(Thread::create(
|
MUST(scheduler.add_thread(MUST(Thread::create(
|
||||||
[terminal_driver]
|
[terminal_driver]
|
||||||
{
|
{
|
||||||
if (auto error = VirtualFileSystem::initialize(); error.is_error())
|
MUST(VirtualFileSystem::initialize());
|
||||||
{
|
|
||||||
derrorln("{}", error.error());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
auto font_or_error = Font::load("/usr/share/fonts/zap-ext-vga16.psf");
|
auto font_or_error = Font::load("/usr/share/fonts/zap-ext-vga16.psf");
|
||||||
if (font_or_error.is_error())
|
if (font_or_error.is_error())
|
||||||
|
|
Loading…
Reference in New Issue