2003-06-10 03:04:54 +04:00
|
|
|
// KPartition.h
|
|
|
|
|
|
|
|
#ifndef _K_DISK_DEVICE_PARTITION_H
|
|
|
|
#define _K_DISK_DEVICE_PARTITION_H
|
|
|
|
|
2003-09-29 02:04:13 +04:00
|
|
|
#include <disk_device_manager.h>
|
2003-07-02 20:29:33 +04:00
|
|
|
#include <Vector.h>
|
|
|
|
|
2003-07-07 03:01:22 +04:00
|
|
|
struct user_partition_data;
|
2003-06-10 03:04:54 +04:00
|
|
|
|
2003-06-11 02:37:43 +04:00
|
|
|
namespace BPrivate {
|
|
|
|
namespace DiskDevice {
|
|
|
|
|
2003-07-07 03:01:22 +04:00
|
|
|
class UserDataWriter;
|
|
|
|
|
2003-06-11 02:37:43 +04:00
|
|
|
class KDiskDevice;
|
|
|
|
class KDiskSystem;
|
2003-09-29 02:04:13 +04:00
|
|
|
class KPartitionListener;
|
2003-08-03 22:27:33 +04:00
|
|
|
class KPartitionVisitor;
|
2003-07-05 03:45:26 +04:00
|
|
|
class KPhysicalPartition;
|
|
|
|
class KShadowPartition;
|
2003-06-11 02:37:43 +04:00
|
|
|
|
2003-06-10 03:04:54 +04:00
|
|
|
class KPartition {
|
2003-06-11 02:37:43 +04:00
|
|
|
public:
|
2003-06-10 03:04:54 +04:00
|
|
|
KPartition(partition_id id = -1);
|
|
|
|
virtual ~KPartition();
|
|
|
|
|
|
|
|
// Reference counting. As long as there's at least one referrer, the
|
|
|
|
// object won't be deleted.
|
2003-06-12 02:03:26 +04:00
|
|
|
// manager must be locked (Unregister() locks itself)
|
2003-06-11 02:37:43 +04:00
|
|
|
void Register();
|
|
|
|
void Unregister();
|
2003-06-10 03:04:54 +04:00
|
|
|
int32 CountReferences() const;
|
|
|
|
|
2003-06-25 03:56:16 +04:00
|
|
|
void MarkObsolete();
|
|
|
|
// called by the manager only
|
|
|
|
bool IsObsolete() const;
|
|
|
|
|
|
|
|
virtual bool PrepareForRemoval();
|
|
|
|
virtual bool PrepareForDeletion();
|
|
|
|
|
2003-07-05 03:45:26 +04:00
|
|
|
virtual status_t Open(int flags, int *fd);
|
2003-06-14 04:06:57 +04:00
|
|
|
virtual status_t PublishDevice();
|
|
|
|
virtual status_t UnpublishDevice();
|
2003-06-11 02:37:43 +04:00
|
|
|
|
2003-06-10 03:04:54 +04:00
|
|
|
void SetBusy(bool busy);
|
|
|
|
bool IsBusy() const;
|
|
|
|
// == jobs which may affect this partition are scheduled/in progress
|
|
|
|
void SetDescendantBusy(bool busy);
|
|
|
|
bool IsDescendantBusy() const;
|
|
|
|
// == jobs which may affect a descendant of this partition are
|
|
|
|
// scheduled/in progress; IsBusy() => IsDescendantBusy()
|
2003-07-05 03:45:26 +04:00
|
|
|
// In the userland API, both can probably be mapped to one flag.
|
2003-06-10 03:04:54 +04:00
|
|
|
|
|
|
|
void SetOffset(off_t offset);
|
|
|
|
off_t Offset() const; // 0 for devices
|
|
|
|
|
|
|
|
void SetSize(off_t size);
|
|
|
|
off_t Size() const;
|
|
|
|
|
2003-07-30 04:21:21 +04:00
|
|
|
void SetContentSize(off_t size);
|
|
|
|
off_t ContentSize() const;
|
|
|
|
|
2003-06-10 03:04:54 +04:00
|
|
|
void SetBlockSize(uint32 blockSize);
|
|
|
|
uint32 BlockSize() const;
|
|
|
|
|
|
|
|
void SetIndex(int32 index);
|
|
|
|
int32 Index() const; // 0 for devices
|
|
|
|
|
|
|
|
void SetStatus(uint32 status);
|
|
|
|
uint32 Status() const;
|
2003-09-22 01:21:10 +04:00
|
|
|
bool IsUninitialized() const;
|
2003-06-10 03:04:54 +04:00
|
|
|
|
|
|
|
void SetFlags(uint32 flags); // comprises the ones below
|
2003-08-03 22:27:33 +04:00
|
|
|
void AddFlags(uint32 flags);
|
|
|
|
void ClearFlags(uint32 flags);
|
2003-06-10 03:04:54 +04:00
|
|
|
uint32 Flags() const;
|
2003-07-08 21:38:45 +04:00
|
|
|
bool ContainsFileSystem() const;
|
|
|
|
bool ContainsPartitioningSystem() const;
|
2003-06-10 03:04:54 +04:00
|
|
|
bool IsReadOnly() const;
|
|
|
|
bool IsMounted() const;
|
|
|
|
|
|
|
|
bool IsDevice() const;
|
|
|
|
|
|
|
|
status_t SetName(const char *name);
|
|
|
|
const char *Name() const;
|
|
|
|
|
|
|
|
status_t SetContentName(const char *name);
|
|
|
|
const char *ContentName() const;
|
|
|
|
|
|
|
|
status_t SetType(const char *type);
|
|
|
|
const char *Type() const;
|
|
|
|
|
|
|
|
const char *ContentType() const;
|
2003-07-22 04:03:35 +04:00
|
|
|
// ContentType() == DiskSystem()->NamePretty()
|
2003-06-10 03:04:54 +04:00
|
|
|
|
|
|
|
// access to C style partition data
|
|
|
|
partition_data *PartitionData();
|
|
|
|
const partition_data *PartitionData() const;
|
|
|
|
|
2003-06-11 02:37:43 +04:00
|
|
|
virtual void SetID(partition_id id);
|
2003-06-10 03:04:54 +04:00
|
|
|
partition_id ID() const;
|
|
|
|
|
|
|
|
virtual status_t GetPath(char *path) const;
|
|
|
|
// no setter (see BDiskDevice) -- built on the fly
|
|
|
|
|
|
|
|
void SetVolumeID(dev_t volumeID);
|
|
|
|
dev_t VolumeID() const;
|
|
|
|
|
2003-09-21 22:25:42 +04:00
|
|
|
void SetMountCookie(void *cookie);
|
|
|
|
void *MountCookie() const;
|
|
|
|
|
2003-07-05 03:45:26 +04:00
|
|
|
virtual status_t Mount(uint32 mountFlags, const char *parameters);
|
|
|
|
virtual status_t Unmount();
|
2003-06-10 03:04:54 +04:00
|
|
|
|
|
|
|
// Parameters
|
|
|
|
|
|
|
|
status_t SetParameters(const char *parameters);
|
|
|
|
const char *Parameters() const;
|
|
|
|
|
|
|
|
status_t SetContentParameters(const char *parameters);
|
|
|
|
const char *ContentParameters() const;
|
|
|
|
|
|
|
|
// Hierarchy
|
|
|
|
|
|
|
|
void SetDevice(KDiskDevice *device);
|
|
|
|
KDiskDevice *Device() const;
|
|
|
|
|
|
|
|
void SetParent(KPartition *parent);
|
|
|
|
KPartition *Parent() const;
|
|
|
|
|
|
|
|
status_t AddChild(KPartition *partition, int32 index = -1);
|
2003-07-05 03:45:26 +04:00
|
|
|
virtual status_t CreateChild(partition_id id, int32 index,
|
|
|
|
KPartition **child = NULL) = 0;
|
2003-06-25 03:56:16 +04:00
|
|
|
bool RemoveChild(int32 index);
|
|
|
|
bool RemoveChild(KPartition *child);
|
|
|
|
bool RemoveAllChildren();
|
2003-06-10 03:04:54 +04:00
|
|
|
KPartition *ChildAt(int32 index) const;
|
|
|
|
int32 CountChildren() const;
|
2003-08-01 02:48:08 +04:00
|
|
|
int32 CountDescendants() const;
|
2003-06-10 03:04:54 +04:00
|
|
|
|
2003-08-03 22:27:33 +04:00
|
|
|
KPartition *VisitEachDescendant(KPartitionVisitor *visitor);
|
|
|
|
|
2003-06-10 03:04:54 +04:00
|
|
|
// Shadow Partition
|
|
|
|
|
2003-07-05 03:45:26 +04:00
|
|
|
virtual status_t CreateShadowPartition(); // creates a complete tree
|
2003-07-15 05:00:24 +04:00
|
|
|
virtual void UnsetShadowPartition(bool doDelete);
|
2003-07-07 03:01:22 +04:00
|
|
|
virtual KShadowPartition *ShadowPartition() const = 0;
|
2003-07-05 03:45:26 +04:00
|
|
|
virtual bool IsShadowPartition() const = 0;
|
2003-07-07 03:01:22 +04:00
|
|
|
virtual KPhysicalPartition *PhysicalPartition() const = 0;
|
2003-06-10 03:04:54 +04:00
|
|
|
|
|
|
|
// DiskSystem
|
|
|
|
|
|
|
|
void SetDiskSystem(KDiskSystem *diskSystem);
|
|
|
|
KDiskSystem *DiskSystem() const;
|
|
|
|
KDiskSystem *ParentDiskSystem() const;
|
2003-06-13 02:21:10 +04:00
|
|
|
// When setting a disk system, it must already be loaded.
|
|
|
|
// The partition will load it too, hence it won't be unloaded before
|
|
|
|
// it is unset here.
|
2003-06-10 03:04:54 +04:00
|
|
|
|
|
|
|
void SetCookie(void *cookie);
|
|
|
|
void *Cookie() const;
|
|
|
|
|
|
|
|
void SetContentCookie(void *cookie);
|
|
|
|
void *ContentCookie() const;
|
|
|
|
|
2003-09-29 02:04:13 +04:00
|
|
|
// Listener Support
|
|
|
|
|
|
|
|
bool AddListener(KPartitionListener *listener);
|
|
|
|
bool RemoveListener(KPartitionListener *listener);
|
|
|
|
|
2003-07-25 02:56:53 +04:00
|
|
|
// Change Tracking
|
|
|
|
|
|
|
|
void Changed(uint32 flags, uint32 clearFlags = 0);
|
|
|
|
void SetChangeFlags(uint32 flags);
|
|
|
|
uint32 ChangeFlags() const;
|
|
|
|
int32 ChangeCounter() const;
|
2003-09-28 23:26:18 +04:00
|
|
|
status_t UninitializeContents(bool logChanges = true);
|
2003-07-22 04:03:35 +04:00
|
|
|
|
2003-07-25 02:56:53 +04:00
|
|
|
void SetAlgorithmData(uint32 data);
|
|
|
|
uint32 AlgorithmData() const;
|
|
|
|
// temporary storage freely usable by algorithms
|
|
|
|
|
2003-07-15 05:00:24 +04:00
|
|
|
virtual void WriteUserData(UserDataWriter &writer,
|
|
|
|
user_partition_data *data);
|
2003-07-07 03:01:22 +04:00
|
|
|
|
2003-06-23 03:04:56 +04:00
|
|
|
virtual void Dump(bool deep, int32 level);
|
|
|
|
|
2003-09-29 02:04:13 +04:00
|
|
|
protected:
|
|
|
|
void FireOffsetChanged(off_t offset);
|
|
|
|
void FireSizeChanged(off_t size);
|
|
|
|
void FireContentSizeChanged(off_t size);
|
|
|
|
void FireBlockSizeChanged(uint32 blockSize);
|
|
|
|
void FireIndexChanged(int32 index);
|
|
|
|
void FireStatusChanged(uint32 status);
|
|
|
|
void FireFlagsChanged(uint32 flags);
|
|
|
|
void FireNameChanged(const char *name);
|
|
|
|
void FireContentNameChanged(const char *name);
|
|
|
|
void FireTypeChanged(const char *type);
|
|
|
|
void FireIDChanged(partition_id id);
|
|
|
|
void FireVolumeIDChanged(dev_t volumeID);
|
|
|
|
void FireMountCookieChanged(void *cookie);
|
|
|
|
void FireParametersChanged(const char *parameters);
|
|
|
|
void FireContentParametersChanged(const char *parameters);
|
|
|
|
void FireChildAdded(KPartition *child, int32 index);
|
|
|
|
void FireChildRemoved(KPartition *child, int32 index);
|
|
|
|
void FireDiskSystemChanged(KDiskSystem *diskSystem);
|
|
|
|
void FireCookieChanged(void *cookie);
|
|
|
|
void FireContentCookieChanged(void *cookie);
|
|
|
|
|
2003-06-11 02:37:43 +04:00
|
|
|
private:
|
|
|
|
void _UpdateChildIndices(int32 index);
|
2003-06-13 02:21:10 +04:00
|
|
|
static int32 _NextID();
|
2003-06-11 02:37:43 +04:00
|
|
|
|
2003-06-10 03:04:54 +04:00
|
|
|
protected:
|
2003-07-02 20:29:33 +04:00
|
|
|
typedef Vector<KPartition*> PartitionVector;
|
2003-09-29 02:04:13 +04:00
|
|
|
struct ListenerSet;
|
2003-07-02 20:29:33 +04:00
|
|
|
|
2003-06-10 03:04:54 +04:00
|
|
|
partition_data fPartitionData;
|
2003-07-02 20:29:33 +04:00
|
|
|
PartitionVector fChildren;
|
2003-06-10 03:04:54 +04:00
|
|
|
KDiskDevice *fDevice;
|
|
|
|
KPartition *fParent;
|
|
|
|
KDiskSystem *fDiskSystem;
|
2003-09-29 02:04:13 +04:00
|
|
|
ListenerSet *fListeners;
|
2003-07-22 04:03:35 +04:00
|
|
|
uint32 fChangeFlags;
|
|
|
|
int32 fChangeCounter;
|
2003-07-25 02:56:53 +04:00
|
|
|
uint32 fAlgorithmData;
|
2003-06-10 03:04:54 +04:00
|
|
|
int32 fReferenceCount;
|
2003-06-25 03:56:16 +04:00
|
|
|
bool fObsolete;
|
2003-06-13 02:21:10 +04:00
|
|
|
static int32 fNextID;
|
2003-06-10 03:04:54 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace DiskDevice
|
|
|
|
} // namespace BPrivate
|
|
|
|
|
|
|
|
using BPrivate::DiskDevice::KPartition;
|
|
|
|
|
|
|
|
#endif // _K_DISK_DEVICE_PARTITION_H
|