2003-06-10 03:04:54 +04:00
|
|
|
// KDiskDevice.h
|
|
|
|
|
|
|
|
#ifndef _K_DISK_DEVICE_H
|
|
|
|
#define _K_DISK_DEVICE_H
|
|
|
|
|
|
|
|
#include <OS.h>
|
|
|
|
|
|
|
|
#include "KPartition.h"
|
2003-06-11 02:35:12 +04:00
|
|
|
#include "RWLocker.h"
|
|
|
|
|
|
|
|
// disk device flags
|
|
|
|
// TODO: move to another header (must be accessible from userland API impl.)
|
|
|
|
enum {
|
|
|
|
B_DISK_DEVICE_REMOVABLE = 0x01,
|
|
|
|
B_DISK_DEVICE_HAS_MEDIA = 0x02,
|
|
|
|
};
|
2003-06-10 03:04:54 +04:00
|
|
|
|
|
|
|
namespace BPrivate {
|
|
|
|
namespace DiskDevice {
|
|
|
|
|
|
|
|
class KDiskDevice : public KPartition {
|
2003-06-11 02:35:12 +04:00
|
|
|
public:
|
2003-06-10 03:04:54 +04:00
|
|
|
KDiskDevice(partition_id id = -1);
|
|
|
|
virtual ~KDiskDevice();
|
|
|
|
|
2003-06-13 02:21:10 +04:00
|
|
|
status_t SetTo(const char *path);
|
|
|
|
void Unset();
|
2003-06-11 02:35:12 +04:00
|
|
|
status_t InitCheck() const;
|
2003-06-13 02:21:10 +04:00
|
|
|
// TODO: probably superfluous
|
2003-06-11 02:35:12 +04:00
|
|
|
|
2003-06-10 03:04:54 +04:00
|
|
|
// A read lock owner can be sure that the device (incl. all of its
|
|
|
|
// partitions won't be changed).
|
|
|
|
// A write lock owner is moreover allowed to make changes.
|
|
|
|
// The hierarchy is additionally protected by the disk device manager's
|
|
|
|
// lock -- only a device write lock owner is allowed to change it, but
|
|
|
|
// manager lock owners can be sure, that it won't change.
|
|
|
|
bool ReadLock();
|
|
|
|
void ReadUnlock();
|
|
|
|
bool WriteLock();
|
|
|
|
void WriteUnlock();
|
|
|
|
|
2003-06-11 02:35:12 +04:00
|
|
|
virtual void SetID(partition_id id);
|
|
|
|
|
2003-06-14 04:06:57 +04:00
|
|
|
virtual status_t PublishDevice();
|
|
|
|
virtual status_t UnpublishDevice();
|
|
|
|
|
2003-06-10 03:04:54 +04:00
|
|
|
void SetDeviceFlags(uint32 flags); // comprises the ones below
|
|
|
|
uint32 DeviceFlags() const;
|
|
|
|
bool IsRemovable() const;
|
|
|
|
bool HasMedia() const;
|
|
|
|
|
|
|
|
status_t SetPath(const char *path);
|
2003-06-11 02:35:12 +04:00
|
|
|
// TODO: Remove this method or make it private. Once initialized the
|
|
|
|
// path must not be changed.
|
|
|
|
const char *Path() const;
|
2003-06-10 03:04:54 +04:00
|
|
|
virtual status_t GetPath(char *path) const;
|
|
|
|
|
|
|
|
// File descriptor: Set only from a kernel thread, valid only for
|
|
|
|
// kernel threads.
|
|
|
|
void SetFD(int fd);
|
|
|
|
int FD() const;
|
|
|
|
|
|
|
|
// access to C style device data
|
|
|
|
disk_device_data *DeviceData();
|
|
|
|
const disk_device_data *DeviceData() const;
|
|
|
|
|
|
|
|
virtual KPartition *CreateShadowPartition();
|
|
|
|
|
|
|
|
void SetShadowOwner(team_id team);
|
|
|
|
team_id ShadowOwner() const;
|
2003-06-11 02:35:12 +04:00
|
|
|
|
|
|
|
private:
|
2003-06-13 02:21:10 +04:00
|
|
|
void _InitPartitionData();
|
|
|
|
|
2003-06-11 02:35:12 +04:00
|
|
|
disk_device_data fDeviceData;
|
|
|
|
RWLocker fLocker;
|
|
|
|
int fFD;
|
|
|
|
status_t fMediaStatus;
|
|
|
|
team_id fShadowOwner;
|
2003-06-10 03:04:54 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace DiskDevice
|
|
|
|
} // namespace BPrivate
|
|
|
|
|
|
|
|
using BPrivate::DiskDevice::KDiskDevice;
|
|
|
|
|
|
|
|
#endif // _K_DISK_DEVICE_H
|