mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-01-24 10:12:25 -05:00
3d6b838df3
The implemented cloning mechanism should be sound: - If a PartitionTable is passed a File with ShouldCloseFileDescriptor::Yes, then it will keep it alive until the PartitionTable is destroyed. - If a PartitionTable is passed a File with ShouldCloseFileDescriptor::No, then the caller has to ensure that the file descriptor remains alive. If the caller is EBRPartitionTable, the same consideration holds. If the caller is PartitionEditor::PartitionModel, this is satisfied by keeping an OwnPtr<Core::File> around which is the originally opened file. Therefore, we never leak any fds, and never access a Core::File or fd after destroying it.
63 lines
1.5 KiB
C++
63 lines
1.5 KiB
C++
/*
|
|
* Copyright (c) 2020-2022, Liav A. <liavalb@hotmail.co.il>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/Error.h>
|
|
#include <LibPartition/PartitionTable.h>
|
|
|
|
namespace Partition {
|
|
|
|
class MBRPartitionTable : public PartitionTable {
|
|
public:
|
|
struct [[gnu::packed]] Entry {
|
|
u8 status;
|
|
u8 chs1[3];
|
|
u8 type;
|
|
u8 chs2[3];
|
|
u32 offset;
|
|
u32 length;
|
|
};
|
|
struct [[gnu::packed]] Header {
|
|
u8 code1[218];
|
|
u16 ts_zero;
|
|
u8 ts_drive;
|
|
u8 ts_seconds;
|
|
u8 ts_minutes;
|
|
u8 ts_hours;
|
|
u8 code2[216];
|
|
u32 disk_signature;
|
|
u16 disk_signature_zero;
|
|
Entry entry[4];
|
|
u16 mbr_signature;
|
|
};
|
|
|
|
public:
|
|
~MBRPartitionTable();
|
|
|
|
static ErrorOr<NonnullOwnPtr<MBRPartitionTable>> try_to_initialize(PartitionableDevice);
|
|
static OwnPtr<MBRPartitionTable> try_to_initialize(PartitionableDevice, u32 start_lba);
|
|
explicit MBRPartitionTable(PartitionableDevice);
|
|
MBRPartitionTable(PartitionableDevice, u32 start_lba);
|
|
|
|
bool is_protective_mbr() const;
|
|
bool contains_ebr() const;
|
|
virtual bool is_valid() const override { return m_valid; };
|
|
|
|
protected:
|
|
Header const& header() const;
|
|
bool is_header_valid() const { return m_header_valid; };
|
|
|
|
private:
|
|
bool read_boot_record();
|
|
bool initialize();
|
|
bool m_valid { false };
|
|
bool m_header_valid { false };
|
|
const u32 m_start_lba;
|
|
ByteBuffer m_cached_header;
|
|
};
|
|
|
|
}
|