mirror of
https://review.haiku-os.org/haiku
synced 2025-01-22 14:24:48 +01:00
da42afdf62
systems in order to retrieve some parameters. Changed the get_file_system() call to accept a Partition instead of just a node. Introduced the namespace boot to the public headers; I guess I should put all classes in there (compilation of the intel partitioning system fails without the namespace, because it defines a class Partition itself). git-svn-id: file:///srv/svn/repos/haiku/trunk/current@4674 a95241bf-73f2-0310-859d-f6bbb57e9c96
81 lines
2.4 KiB
C++
81 lines
2.4 KiB
C++
/*
|
|
** Copyright 2003, Axel Dörfler, axeld@pinc-software.de. All rights reserved.
|
|
** Distributed under the terms of the OpenBeOS License.
|
|
*/
|
|
#ifndef KERNEL_BOOT_PARTITIONS_H
|
|
#define KERNEL_BOOT_PARTITIONS_H
|
|
|
|
|
|
#include <boot/vfs.h>
|
|
#include <disk_device_manager.h>
|
|
|
|
|
|
namespace boot {
|
|
|
|
class Partition : public partition_data, public Node {
|
|
public:
|
|
Partition(int deviceFD);
|
|
virtual ~Partition();
|
|
|
|
virtual ssize_t ReadAt(void *cookie, off_t offset, void *buffer, size_t bufferSize);
|
|
virtual ssize_t WriteAt(void *cookie, off_t offset, const void *buffer, size_t bufferSize);
|
|
|
|
virtual off_t Size() const;
|
|
virtual int32 Type() const;
|
|
|
|
Partition *AddChild();
|
|
status_t Scan();
|
|
|
|
Partition *Parent() const { return fParent; }
|
|
bool IsFileSystem() const { return fIsFileSystem; }
|
|
|
|
static size_t LinkOffset() { return sizeof(partition_data); }
|
|
|
|
private:
|
|
void SetParent(Partition *parent) { fParent = parent; }
|
|
|
|
int fFD;
|
|
list fChildren;
|
|
Partition *fParent;
|
|
bool fIsFileSystem;
|
|
};
|
|
|
|
} // namespace boot
|
|
|
|
// DiskDeviceTypes we need/support in the boot loader
|
|
#define kPartitionTypeAmiga "Amiga RDB"
|
|
#define kPartitionTypeIntel "Intel"
|
|
#define kPartitionTypeIntelExtended "Intel Extended"
|
|
#define kPartitionTypeApple "Apple"
|
|
|
|
#define kPartitionTypeBFS "BFS Filesystem"
|
|
#define kPartitionTypeAmigaFFS "AmigaFFS Filesystem"
|
|
#define kPartitionTypeBFS "BFS Filesystem"
|
|
#define kPartitionTypeEXT2 "EXT2 Filesystem"
|
|
#define kPartitionTypeEXT3 "EXT3 Filesystem"
|
|
#define kPartitionTypeFAT12 "FAT12 Filesystem"
|
|
#define kPartitionTypeFAT32 "FAT32 Filesystem"
|
|
#define kPartitionTypeISO9660 "ISO9660 Filesystem"
|
|
#define kPartitionTypeReiser "Reiser Filesystem"
|
|
#define kPartitionTypeUDF "UDF Filesystem"
|
|
|
|
// structure definitions as used in the boot loader
|
|
struct partition_module_info;
|
|
extern partition_module_info gAmigaPartitionModule;
|
|
extern partition_module_info gIntelPartitionMapModule;
|
|
extern partition_module_info gIntelExtendedPartitionModule;
|
|
extern partition_module_info gApplePartitionModule;
|
|
|
|
// the file system module info is not a standard module info;
|
|
// their modules are specifically written for the boot loader,
|
|
// and hence, don't need to follow the standard module specs.
|
|
|
|
struct file_system_module_info {
|
|
const char *pretty_name;
|
|
status_t (*get_file_system)(boot::Partition *device, Directory **_root);
|
|
};
|
|
|
|
extern file_system_module_info gBFSFileSystemModule;
|
|
|
|
#endif /* KERNEL_BOOT_PARTITIONS_H */
|