mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-06-10 18:10:56 +09:00
Kernel: Use Forward.h headers more
This commit is contained in:
parent
47bfd366a8
commit
98080497d2
Notes:
sideshowbarker
2024-07-18 09:20:28 +09:00
Author: https://github.com/awesomekling
Commit: 98080497d2
18 changed files with 52 additions and 88 deletions
|
@ -16,22 +16,20 @@
|
||||||
#include <Kernel/Arch/x86/DescriptorTable.h>
|
#include <Kernel/Arch/x86/DescriptorTable.h>
|
||||||
#include <Kernel/Arch/x86/PageDirectory.h>
|
#include <Kernel/Arch/x86/PageDirectory.h>
|
||||||
#include <Kernel/Arch/x86/TSS.h>
|
#include <Kernel/Arch/x86/TSS.h>
|
||||||
|
#include <Kernel/Forward.h>
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
|
class ProcessorInfo;
|
||||||
|
class SchedulerPerProcessorData;
|
||||||
|
struct MemoryManagerData;
|
||||||
|
struct ProcessorMessageEntry;
|
||||||
|
|
||||||
#if ARCH(X86_64)
|
#if ARCH(X86_64)
|
||||||
# define MSR_FS_BASE 0xc0000100
|
# define MSR_FS_BASE 0xc0000100
|
||||||
# define MSR_GS_BASE 0xc0000101
|
# define MSR_GS_BASE 0xc0000101
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
class Thread;
|
|
||||||
class SchedulerPerProcessorData;
|
|
||||||
struct MemoryManagerData;
|
|
||||||
struct ProcessorMessageEntry;
|
|
||||||
|
|
||||||
struct TrapFrame;
|
|
||||||
class ProcessorInfo;
|
|
||||||
|
|
||||||
// FIXME: Find a better place for these
|
// FIXME: Find a better place for these
|
||||||
extern "C" void thread_context_first_enter(void);
|
extern "C" void thread_context_first_enter(void);
|
||||||
extern "C" void exit_kernel_thread(void);
|
extern "C" void exit_kernel_thread(void);
|
||||||
|
|
|
@ -13,8 +13,6 @@
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class Process;
|
|
||||||
|
|
||||||
class CoreDump {
|
class CoreDump {
|
||||||
public:
|
public:
|
||||||
static OwnPtr<CoreDump> create(NonnullRefPtr<Process>, const String& output_path);
|
static OwnPtr<CoreDump> create(NonnullRefPtr<Process>, const String& output_path);
|
||||||
|
|
|
@ -14,13 +14,6 @@
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class DevFSInode;
|
|
||||||
class DevFSDeviceInode;
|
|
||||||
class DevFSDirectoryInode;
|
|
||||||
class DevFSRootDirectoryInode;
|
|
||||||
class DevFSDevicesDirectoryInode;
|
|
||||||
class DevFSPtsDirectoryInode;
|
|
||||||
class Device;
|
|
||||||
class DevFS final : public FileSystem {
|
class DevFS final : public FileSystem {
|
||||||
friend class DevFSInode;
|
friend class DevFSInode;
|
||||||
friend class DevFSRootDirectoryInode;
|
friend class DevFSRootDirectoryInode;
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
#include <AK/RefPtr.h>
|
#include <AK/RefPtr.h>
|
||||||
#include <AK/StringView.h>
|
#include <AK/StringView.h>
|
||||||
#include <Kernel/FileSystem/InodeIdentifier.h>
|
#include <Kernel/FileSystem/InodeIdentifier.h>
|
||||||
|
#include <Kernel/Forward.h>
|
||||||
#include <Kernel/KResult.h>
|
#include <Kernel/KResult.h>
|
||||||
#include <Kernel/Lock.h>
|
#include <Kernel/Lock.h>
|
||||||
#include <Kernel/UnixTypes.h>
|
#include <Kernel/UnixTypes.h>
|
||||||
|
@ -19,11 +20,6 @@ namespace Kernel {
|
||||||
|
|
||||||
static constexpr u32 mepoch = 476763780;
|
static constexpr u32 mepoch = 476763780;
|
||||||
|
|
||||||
class Inode;
|
|
||||||
class FileDescription;
|
|
||||||
class LocalSocket;
|
|
||||||
class VMObject;
|
|
||||||
|
|
||||||
class FileSystem : public RefCounted<FileSystem> {
|
class FileSystem : public RefCounted<FileSystem> {
|
||||||
friend class Inode;
|
friend class Inode;
|
||||||
|
|
||||||
|
|
|
@ -1,20 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright (c) 2018-2021, Andreas Kling <kling@serenityos.org>
|
|
||||||
*
|
|
||||||
* SPDX-License-Identifier: BSD-2-Clause
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
namespace Kernel {
|
|
||||||
|
|
||||||
class FileSystem;
|
|
||||||
class Inode;
|
|
||||||
class Mount;
|
|
||||||
class SysFS;
|
|
||||||
class SysFSDirectoryInode;
|
|
||||||
class SysFSInode;
|
|
||||||
class VirtualFileSystem;
|
|
||||||
struct InodeMetadata;
|
|
||||||
|
|
||||||
}
|
|
|
@ -14,11 +14,10 @@
|
||||||
#include <AK/NonnullOwnPtr.h>
|
#include <AK/NonnullOwnPtr.h>
|
||||||
#include <Kernel/API/InodeWatcherEvent.h>
|
#include <Kernel/API/InodeWatcherEvent.h>
|
||||||
#include <Kernel/FileSystem/File.h>
|
#include <Kernel/FileSystem/File.h>
|
||||||
|
#include <Kernel/Forward.h>
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class Inode;
|
|
||||||
|
|
||||||
// A specific description of a watch.
|
// A specific description of a watch.
|
||||||
struct WatchDescription {
|
struct WatchDescription {
|
||||||
int wd;
|
int wd;
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <AK/NonnullRefPtr.h>
|
#include <AK/NonnullRefPtr.h>
|
||||||
#include <Kernel/FileSystem/Forward.h>
|
#include <Kernel/Forward.h>
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
|
|
|
@ -10,17 +10,13 @@
|
||||||
#include <AK/Types.h>
|
#include <AK/Types.h>
|
||||||
#include <Kernel/FileSystem/FileSystem.h>
|
#include <Kernel/FileSystem/FileSystem.h>
|
||||||
#include <Kernel/FileSystem/Inode.h>
|
#include <Kernel/FileSystem/Inode.h>
|
||||||
|
#include <Kernel/Forward.h>
|
||||||
#include <Kernel/KBufferBuilder.h>
|
#include <Kernel/KBufferBuilder.h>
|
||||||
#include <Kernel/Lock.h>
|
#include <Kernel/Lock.h>
|
||||||
#include <Kernel/ProcessExposed.h>
|
#include <Kernel/ProcessExposed.h>
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class Process;
|
|
||||||
|
|
||||||
class ProcFSInode;
|
|
||||||
class ProcFSDirectoryInode;
|
|
||||||
|
|
||||||
class ProcFS final : public FileSystem {
|
class ProcFS final : public FileSystem {
|
||||||
friend class ProcFSInode;
|
friend class ProcFSInode;
|
||||||
friend class ProcFSDirectoryInode;
|
friend class ProcFSDirectoryInode;
|
||||||
|
@ -99,4 +95,5 @@ protected:
|
||||||
|
|
||||||
ProcFS& m_parent_fs;
|
ProcFS& m_parent_fs;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
#include <AK/Types.h>
|
#include <AK/Types.h>
|
||||||
#include <Kernel/FileSystem/File.h>
|
#include <Kernel/FileSystem/File.h>
|
||||||
#include <Kernel/FileSystem/FileSystem.h>
|
#include <Kernel/FileSystem/FileSystem.h>
|
||||||
#include <Kernel/FileSystem/Forward.h>
|
#include <Kernel/Forward.h>
|
||||||
#include <Kernel/KResult.h>
|
#include <Kernel/KResult.h>
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
|
@ -17,15 +17,12 @@
|
||||||
#include <Kernel/FileSystem/InodeIdentifier.h>
|
#include <Kernel/FileSystem/InodeIdentifier.h>
|
||||||
#include <Kernel/FileSystem/InodeMetadata.h>
|
#include <Kernel/FileSystem/InodeMetadata.h>
|
||||||
#include <Kernel/FileSystem/Mount.h>
|
#include <Kernel/FileSystem/Mount.h>
|
||||||
|
#include <Kernel/Forward.h>
|
||||||
#include <Kernel/KResult.h>
|
#include <Kernel/KResult.h>
|
||||||
#include <Kernel/UnveilNode.h>
|
#include <Kernel/UnveilNode.h>
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class Custody;
|
|
||||||
class Device;
|
|
||||||
class FileDescription;
|
|
||||||
|
|
||||||
struct UidAndGid {
|
struct UidAndGid {
|
||||||
uid_t uid;
|
uid_t uid;
|
||||||
gid_t gid;
|
gid_t gid;
|
||||||
|
|
|
@ -12,16 +12,23 @@ class BlockDevice;
|
||||||
class CharacterDevice;
|
class CharacterDevice;
|
||||||
class CoreDump;
|
class CoreDump;
|
||||||
class Custody;
|
class Custody;
|
||||||
|
class DevFSDeviceInode;
|
||||||
|
class DevFSDirectoryInode;
|
||||||
|
class DevFSInode;
|
||||||
|
class DevFSPtsDirectoryInode;
|
||||||
|
class DevFSRootDirectoryInode;
|
||||||
|
class Device;
|
||||||
class Device;
|
class Device;
|
||||||
class DiskCache;
|
class DiskCache;
|
||||||
class DoubleBuffer;
|
class DoubleBuffer;
|
||||||
class File;
|
class File;
|
||||||
class FileDescription;
|
class FileDescription;
|
||||||
|
class FileSystem;
|
||||||
class FutexQueue;
|
class FutexQueue;
|
||||||
class IPv4Socket;
|
class IPv4Socket;
|
||||||
class Inode;
|
class Inode;
|
||||||
|
class Inode;
|
||||||
class InodeIdentifier;
|
class InodeIdentifier;
|
||||||
class SharedInodeVMObject;
|
|
||||||
class InodeWatcher;
|
class InodeWatcher;
|
||||||
class KBuffer;
|
class KBuffer;
|
||||||
class KResult;
|
class KResult;
|
||||||
|
@ -29,36 +36,55 @@ class LocalSocket;
|
||||||
class Lock;
|
class Lock;
|
||||||
class MappedROM;
|
class MappedROM;
|
||||||
class MasterPTY;
|
class MasterPTY;
|
||||||
|
class Mount;
|
||||||
class PageDirectory;
|
class PageDirectory;
|
||||||
class PerformanceEventBuffer;
|
class PerformanceEventBuffer;
|
||||||
class PhysicalPage;
|
class PhysicalPage;
|
||||||
class PhysicalRegion;
|
class PhysicalRegion;
|
||||||
|
class ProcFS;
|
||||||
|
class ProcFSBusDirectory;
|
||||||
|
class ProcFSDirectoryInode;
|
||||||
|
class ProcFSExposedComponent;
|
||||||
|
class ProcFSExposedDirectory;
|
||||||
|
class ProcFSInode;
|
||||||
|
class ProcFSProcessInformation;
|
||||||
|
class ProcFSRootDirectory;
|
||||||
|
class ProcFSSystemBoolean;
|
||||||
|
class ProcFSSystemDirectory;
|
||||||
class Process;
|
class Process;
|
||||||
class ProcessGroup;
|
class ProcessGroup;
|
||||||
class ThreadTracer;
|
|
||||||
class Range;
|
class Range;
|
||||||
class RangeAllocator;
|
class RangeAllocator;
|
||||||
|
class RecursiveSpinLock;
|
||||||
class Region;
|
class Region;
|
||||||
class Scheduler;
|
class Scheduler;
|
||||||
class SchedulerPerProcessorData;
|
class SchedulerPerProcessorData;
|
||||||
|
class SharedInodeVMObject;
|
||||||
class Socket;
|
class Socket;
|
||||||
class Space;
|
class Space;
|
||||||
template<typename BaseType>
|
class SysFS;
|
||||||
class SpinLock;
|
class SysFSDirectoryInode;
|
||||||
class RecursiveSpinLock;
|
class SysFSInode;
|
||||||
template<typename LockType>
|
|
||||||
class ScopedSpinLock;
|
|
||||||
class TCPSocket;
|
class TCPSocket;
|
||||||
class TTY;
|
class TTY;
|
||||||
class Thread;
|
class Thread;
|
||||||
|
class ThreadTracer;
|
||||||
class UDPSocket;
|
class UDPSocket;
|
||||||
class UserOrKernelBuffer;
|
class UserOrKernelBuffer;
|
||||||
class VirtualFileSystem;
|
|
||||||
class VMObject;
|
class VMObject;
|
||||||
|
class VirtualFileSystem;
|
||||||
|
class VirtualFileSystem;
|
||||||
class WaitQueue;
|
class WaitQueue;
|
||||||
class WorkQueue;
|
class WorkQueue;
|
||||||
|
|
||||||
|
template<typename BaseType>
|
||||||
|
class SpinLock;
|
||||||
|
template<typename LockType>
|
||||||
|
class ScopedSpinLock;
|
||||||
template<typename T>
|
template<typename T>
|
||||||
class KResultOr;
|
class KResultOr;
|
||||||
|
|
||||||
|
struct InodeMetadata;
|
||||||
|
struct TrapFrame;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -231,8 +231,6 @@ UNMAP_AFTER_INIT ProcFSNetworkDirectory::ProcFSNetworkDirectory(const ProcFSRoot
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
class ProcFSSystemDirectory;
|
|
||||||
|
|
||||||
class ProcFSDumpKmallocStacks : public ProcFSSystemBoolean {
|
class ProcFSDumpKmallocStacks : public ProcFSSystemBoolean {
|
||||||
public:
|
public:
|
||||||
static NonnullRefPtr<ProcFSDumpKmallocStacks> must_create(const ProcFSSystemDirectory&);
|
static NonnullRefPtr<ProcFSDumpKmallocStacks> must_create(const ProcFSSystemDirectory&);
|
||||||
|
|
|
@ -21,13 +21,6 @@
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class ProcFS;
|
|
||||||
class ProcFSExposedComponent;
|
|
||||||
class ProcFSExposedDirectory;
|
|
||||||
class ProcFSRootDirectory;
|
|
||||||
class ProcFSBusDirectory;
|
|
||||||
class ProcFSSystemBoolean;
|
|
||||||
|
|
||||||
class ProcFSComponentRegistry {
|
class ProcFSComponentRegistry {
|
||||||
public:
|
public:
|
||||||
static ProcFSComponentRegistry& the();
|
static ProcFSComponentRegistry& the();
|
||||||
|
@ -130,9 +123,6 @@ protected:
|
||||||
mutable Lock m_lock { "ProcFSLink" };
|
mutable Lock m_lock { "ProcFSLink" };
|
||||||
};
|
};
|
||||||
|
|
||||||
class ProcFSRootDirectory;
|
|
||||||
class ProcFSProcessInformation;
|
|
||||||
|
|
||||||
class ProcFSProcessDirectory final
|
class ProcFSProcessDirectory final
|
||||||
: public ProcFSExposedDirectory {
|
: public ProcFSExposedDirectory {
|
||||||
friend class ProcFSComponentRegistry;
|
friend class ProcFSComponentRegistry;
|
||||||
|
@ -167,8 +157,6 @@ private:
|
||||||
NonnullRefPtr<Process> m_associated_process;
|
NonnullRefPtr<Process> m_associated_process;
|
||||||
};
|
};
|
||||||
|
|
||||||
class ProcFSRootDirectory;
|
|
||||||
|
|
||||||
class ProcFSBusDirectory : public ProcFSExposedDirectory {
|
class ProcFSBusDirectory : public ProcFSExposedDirectory {
|
||||||
friend class ProcFSComponentRegistry;
|
friend class ProcFSComponentRegistry;
|
||||||
|
|
||||||
|
|
|
@ -10,15 +10,13 @@
|
||||||
#include <AK/Function.h>
|
#include <AK/Function.h>
|
||||||
#include <AK/IntrusiveList.h>
|
#include <AK/IntrusiveList.h>
|
||||||
#include <AK/Types.h>
|
#include <AK/Types.h>
|
||||||
|
#include <Kernel/Forward.h>
|
||||||
#include <Kernel/SpinLock.h>
|
#include <Kernel/SpinLock.h>
|
||||||
#include <Kernel/Time/TimeManagement.h>
|
#include <Kernel/Time/TimeManagement.h>
|
||||||
#include <Kernel/UnixTypes.h>
|
#include <Kernel/UnixTypes.h>
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class Process;
|
|
||||||
class Thread;
|
|
||||||
class WaitQueue;
|
|
||||||
struct RegisterState;
|
struct RegisterState;
|
||||||
|
|
||||||
extern Thread* g_finalizer;
|
extern Thread* g_finalizer;
|
||||||
|
|
|
@ -11,6 +11,7 @@
|
||||||
#include <AK/NonnullRefPtrVector.h>
|
#include <AK/NonnullRefPtrVector.h>
|
||||||
#include <AK/String.h>
|
#include <AK/String.h>
|
||||||
#include <Kernel/Arch/x86/PageFault.h>
|
#include <Kernel/Arch/x86/PageFault.h>
|
||||||
|
#include <Kernel/Arch/x86/TrapFrame.h>
|
||||||
#include <Kernel/Forward.h>
|
#include <Kernel/Forward.h>
|
||||||
#include <Kernel/SpinLock.h>
|
#include <Kernel/SpinLock.h>
|
||||||
#include <Kernel/VM/AllocationStrategy.h>
|
#include <Kernel/VM/AllocationStrategy.h>
|
||||||
|
|
|
@ -9,13 +9,12 @@
|
||||||
#include <AK/HashMap.h>
|
#include <AK/HashMap.h>
|
||||||
#include <AK/RefCounted.h>
|
#include <AK/RefCounted.h>
|
||||||
#include <AK/RefPtr.h>
|
#include <AK/RefPtr.h>
|
||||||
|
#include <Kernel/Forward.h>
|
||||||
#include <Kernel/VM/PhysicalPage.h>
|
#include <Kernel/VM/PhysicalPage.h>
|
||||||
#include <Kernel/VM/RangeAllocator.h>
|
#include <Kernel/VM/RangeAllocator.h>
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class Process;
|
|
||||||
|
|
||||||
class PageDirectory : public RefCounted<PageDirectory> {
|
class PageDirectory : public RefCounted<PageDirectory> {
|
||||||
friend class MemoryManager;
|
friend class MemoryManager;
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,7 @@
|
||||||
#include <AK/WeakPtr.h>
|
#include <AK/WeakPtr.h>
|
||||||
#include <AK/Weakable.h>
|
#include <AK/Weakable.h>
|
||||||
#include <Kernel/Arch/x86/PageFault.h>
|
#include <Kernel/Arch/x86/PageFault.h>
|
||||||
|
#include <Kernel/Forward.h>
|
||||||
#include <Kernel/Heap/SlabAllocator.h>
|
#include <Kernel/Heap/SlabAllocator.h>
|
||||||
#include <Kernel/KString.h>
|
#include <Kernel/KString.h>
|
||||||
#include <Kernel/Sections.h>
|
#include <Kernel/Sections.h>
|
||||||
|
@ -21,9 +22,6 @@
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class Inode;
|
|
||||||
class VMObject;
|
|
||||||
|
|
||||||
enum class ShouldFlushTLB {
|
enum class ShouldFlushTLB {
|
||||||
No,
|
No,
|
||||||
Yes,
|
Yes,
|
||||||
|
|
|
@ -12,13 +12,11 @@
|
||||||
#include <AK/RefPtr.h>
|
#include <AK/RefPtr.h>
|
||||||
#include <AK/Vector.h>
|
#include <AK/Vector.h>
|
||||||
#include <AK/Weakable.h>
|
#include <AK/Weakable.h>
|
||||||
|
#include <Kernel/Forward.h>
|
||||||
#include <Kernel/Lock.h>
|
#include <Kernel/Lock.h>
|
||||||
|
|
||||||
namespace Kernel {
|
namespace Kernel {
|
||||||
|
|
||||||
class Inode;
|
|
||||||
class PhysicalPage;
|
|
||||||
|
|
||||||
class VMObjectDeletedHandler {
|
class VMObjectDeletedHandler {
|
||||||
public:
|
public:
|
||||||
virtual ~VMObjectDeletedHandler() = default;
|
virtual ~VMObjectDeletedHandler() = default;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue