/* * Copyright (c) 2022, Liav A. * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include namespace Kernel { UNMAP_AFTER_INIT NonnullRefPtr SysFSGlobalKernelStatsDirectory::must_create(SysFSRootDirectory const& root_directory) { auto global_kernel_stats_directory = adopt_ref_if_nonnull(new (nothrow) SysFSGlobalKernelStatsDirectory(root_directory)).release_nonnull(); MUST(global_kernel_stats_directory->m_child_components.with([&](auto& list) -> ErrorOr { list.append(SysFSDiskUsage::must_create(*global_kernel_stats_directory)); list.append(SysFSMemoryStatus::must_create(*global_kernel_stats_directory)); list.append(SysFSSystemStatistics::must_create(*global_kernel_stats_directory)); list.append(SysFSOverallProcesses::must_create(*global_kernel_stats_directory)); list.append(SysFSCPUInformation::must_create(*global_kernel_stats_directory)); list.append(SysFSKernelLog::must_create(*global_kernel_stats_directory)); list.append(SysFSInterrupts::must_create(*global_kernel_stats_directory)); list.append(SysFSKeymap::must_create(*global_kernel_stats_directory)); list.append(SysFSUptime::must_create(*global_kernel_stats_directory)); list.append(SysFSProfile::must_create(*global_kernel_stats_directory)); list.append(SysFSPowerStateSwitchNode::must_create(*global_kernel_stats_directory)); list.append(SysFSJails::must_create(*global_kernel_stats_directory)); list.append(SysFSSystemRequestPanic::must_create(*global_kernel_stats_directory)); list.append(SysFSGlobalNetworkStatsDirectory::must_create(*global_kernel_stats_directory)); list.append(SysFSKernelConfigurationDirectory::must_create(*global_kernel_stats_directory)); { auto builder = TRY(KBufferBuilder::try_create()); MUST(builder.appendff("{}", kernel_load_base)); auto load_base_buffer = builder.build(); VERIFY(load_base_buffer); list.append(SysFSSystemConstantInformation::must_create(*global_kernel_stats_directory, load_base_buffer.release_nonnull(), S_IRUSR, SysFSSystemConstantInformation::ReadableByJailedProcesses::No, SysFSSystemConstantInformation::NodeName::LoadBase)); } { auto builder = TRY(KBufferBuilder::try_create()); MUST(builder.append(kernel_command_line().string())); MUST(builder.append('\n')); auto command_line_buffer = builder.build(); VERIFY(command_line_buffer); list.append(SysFSSystemConstantInformation::must_create(*global_kernel_stats_directory, command_line_buffer.release_nonnull(), S_IRUSR | S_IRGRP | S_IROTH, SysFSSystemConstantInformation::ReadableByJailedProcesses::No, SysFSSystemConstantInformation::NodeName::CommandLine)); } { auto builder = TRY(KBufferBuilder::try_create()); MUST(builder.append(kernel_command_line().system_mode())); MUST(builder.append('\n')); auto system_mode_buffer = builder.build(); VERIFY(system_mode_buffer); list.append(SysFSSystemConstantInformation::must_create(*global_kernel_stats_directory, system_mode_buffer.release_nonnull(), S_IRUSR | S_IRGRP | S_IROTH, SysFSSystemConstantInformation::ReadableByJailedProcesses::No, SysFSSystemConstantInformation::NodeName::SystemMode)); } return {}; })); return global_kernel_stats_directory; } UNMAP_AFTER_INIT SysFSGlobalKernelStatsDirectory::SysFSGlobalKernelStatsDirectory(SysFSDirectory const& root_directory) : SysFSDirectory(root_directory) { } }