mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-26 16:02:37 +00:00 
			
		
		
		
	 3d6b838df3
			
		
	
	
		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;
 | |
| };
 | |
| 
 | |
| }
 |