Fixed handling of partition and device flags and statuses.

git-svn-id: file:///srv/svn/repos/haiku/trunk/current@3898 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Ingo Weinhold 2003-07-08 17:25:32 +00:00
parent 6cef630541
commit 55bf93d80d
7 changed files with 76 additions and 18 deletions

View File

@ -43,6 +43,8 @@ public:
void SetDeviceFlags(uint32 flags); // comprises the ones below void SetDeviceFlags(uint32 flags); // comprises the ones below
uint32 DeviceFlags() const; uint32 DeviceFlags() const;
bool IsReadOnlyMedia() const;
bool IsWriteOnce() const;
bool IsRemovable() const; bool IsRemovable() const;
bool HasMedia() const; bool HasMedia() const;

View File

@ -27,10 +27,19 @@ enum {
B_PARTITION_DESCENDANT_BUSY = 0x40, B_PARTITION_DESCENDANT_BUSY = 0x40,
}; };
// partition statuses
enum {
B_PARTITION_VALID,
B_PARTITION_CORRUPT,
B_PARTITION_UNRECOGNIZED,
};
// disk device flags // disk device flags
enum { enum {
B_DISK_DEVICE_REMOVABLE = 0x01, B_DISK_DEVICE_REMOVABLE = 0x01,
B_DISK_DEVICE_HAS_MEDIA = 0x02, B_DISK_DEVICE_HAS_MEDIA = 0x02,
B_DISK_DEVICE_READ_ONLY = 0x04,
B_DISK_DEVICE_WRITE_ONCE = 0x08,
}; };
#ifdef __cplusplus #ifdef __cplusplus

View File

@ -19,13 +19,6 @@ class BDiskSystem;
class BVolume; class BVolume;
struct user_partition_data; struct user_partition_data;
// partition statuses
enum {
B_PARTITION_VALID,
B_PARTITION_CORRUPT,
B_PARTITION_UNRECOGNIZED,
};
class BPartition { class BPartition {
public: public:
// Partition Info // Partition Info

View File

@ -375,7 +375,7 @@ bfs_identify_partition(int fd, partition_data *partition, void **cookie)
return 0.5; return 0.5;
} }
// pm_scan_partition // bfs_scan_partition
static static
status_t status_t
bfs_scan_partition(int fd, partition_data *partition, void *cookie) bfs_scan_partition(int fd, partition_data *partition, void *cookie)
@ -389,6 +389,8 @@ bfs_scan_partition(int fd, partition_data *partition, void *cookie)
partition->block_size)); partition->block_size));
superBlock = (disk_super_block*)cookie; superBlock = (disk_super_block*)cookie;
// fill in the partition_data structure // fill in the partition_data structure
partition->status = B_PARTITION_VALID;
partition->flags |= B_PARTITION_MOUNTABLE;
partition->block_size = superBlock->block_size; partition->block_size = superBlock->block_size;
partition->content_name = strdup(superBlock->name); partition->content_name = strdup(superBlock->name);
partition->content_type = strdup(kPartitionTypeBFS); partition->content_type = strdup(kPartitionTypeBFS);
@ -400,7 +402,7 @@ bfs_scan_partition(int fd, partition_data *partition, void *cookie)
return B_OK; return B_OK;
} }
// pm_free_identify_partition_cookie // bfs_free_identify_partition_cookie
static static
void void
bfs_free_identify_partition_cookie(partition_data *partition, void *cookie) bfs_free_identify_partition_cookie(partition_data *partition, void *cookie)
@ -409,7 +411,7 @@ bfs_free_identify_partition_cookie(partition_data *partition, void *cookie)
free(cookie); free(cookie);
} }
// pm_free_partition_content_cookie // bfs_free_partition_content_cookie
static static
void void
bfs_free_partition_content_cookie(partition_data *partition) bfs_free_partition_content_cookie(partition_data *partition)

View File

@ -482,6 +482,9 @@ pm_scan_partition(int fd, partition_data *partition, void *cookie)
partition->block_size)); partition->block_size));
PartitionMap *map = (PartitionMap*)cookie; PartitionMap *map = (PartitionMap*)cookie;
// fill in the partition_data structure // fill in the partition_data structure
partition->status = B_PARTITION_VALID;
partition->flags |= B_PARTITION_PARTITIONABLE | B_PARTITION_READ_ONLY;
// TODO: Update when write functionality is implemented.
// (no content_name and content_parameters) // (no content_name and content_parameters)
partition->content_type = strdup(kPartitionTypeIntel); partition->content_type = strdup(kPartitionTypeIntel);
if (!partition->content_type) if (!partition->content_type)
@ -621,6 +624,9 @@ ep_scan_partition(int fd, partition_data *partition, void *cookie)
return B_ERROR; return B_ERROR;
PrimaryPartition *primary = (PrimaryPartition*)partition->cookie; PrimaryPartition *primary = (PrimaryPartition*)partition->cookie;
// fill in the partition_data structure // fill in the partition_data structure
partition->status = B_PARTITION_VALID;
partition->flags |= B_PARTITION_PARTITIONABLE | B_PARTITION_READ_ONLY;
// TODO: Update when write functionality is implemented.
// (no content_name and content_parameters) // (no content_name and content_parameters)
partition->content_type = strdup(kPartitionTypeIntelExtended); partition->content_type = strdup(kPartitionTypeIntelExtended);
if (!partition->content_type) if (!partition->content_type)

View File

@ -56,13 +56,32 @@ KDiskDevice::SetTo(const char *path)
fFD = open(path, O_RDONLY); fFD = open(path, O_RDONLY);
if (fFD < 0) if (fFD < 0)
return errno; return errno;
// get device geometry and media status // get media status
error = GetMediaStatus(&fMediaStatus); error = GetMediaStatus(&fMediaStatus);
if (error != B_OK) if (error != B_OK)
return error; return error;
if (fMediaStatus == B_DEV_MEDIA_CHANGED)
fMediaStatus = B_OK;
// get device geometry
if (fMediaStatus == B_OK) {
error = GetGeometry(&fDeviceData.geometry); error = GetGeometry(&fDeviceData.geometry);
if (error != B_OK) if (error != B_OK)
return error; return error;
} else {
// no media: try to get the device geometry, but don't fail, if
// we can't get it
GetGeometry(&fDeviceData.geometry);
}
// set device flags
if (fDeviceData.geometry.removable)
SetDeviceFlags(DeviceFlags() | B_DISK_DEVICE_REMOVABLE);
if (fMediaStatus == B_OK)
SetDeviceFlags(DeviceFlags() | B_DISK_DEVICE_HAS_MEDIA);
if (fDeviceData.geometry.read_only)
SetDeviceFlags(DeviceFlags() | B_DISK_DEVICE_READ_ONLY);
if (fDeviceData.geometry.write_once)
SetDeviceFlags(DeviceFlags() | B_DISK_DEVICE_WRITE_ONCE);
// update partition data
_InitPartitionData(); _InitPartitionData();
return B_OK; return B_OK;
} }
@ -88,7 +107,7 @@ KDiskDevice::Unset()
fDeviceData.geometry.cylinder_count = 0; fDeviceData.geometry.cylinder_count = 0;
fDeviceData.geometry.head_count = 0; fDeviceData.geometry.head_count = 0;
fDeviceData.geometry.device_type = B_DISK; fDeviceData.geometry.device_type = B_DISK;
fDeviceData.geometry.removable = false; fDeviceData.geometry.removable = true;
fDeviceData.geometry.read_only = true; fDeviceData.geometry.read_only = true;
fDeviceData.geometry.write_once = false; fDeviceData.geometry.write_once = false;
} }
@ -183,6 +202,20 @@ KDiskDevice::DeviceFlags() const
return fDeviceData.flags; return fDeviceData.flags;
} }
// IsReadOnlyMedia
bool
KDiskDevice::IsReadOnlyMedia() const
{
return fDeviceData.geometry.read_only;
}
// IsWriteOnce
bool
KDiskDevice::IsWriteOnce() const
{
return fDeviceData.geometry.write_once;
}
// IsRemovable // IsRemovable
bool bool
KDiskDevice::IsRemovable() const KDiskDevice::IsRemovable() const

View File

@ -41,7 +41,7 @@ KPartition::KPartition(partition_id id)
fPartitionData.block_size = 0; fPartitionData.block_size = 0;
fPartitionData.child_count = 0; fPartitionData.child_count = 0;
fPartitionData.index = -1; fPartitionData.index = -1;
fPartitionData.status = /*B_PARTITION_UNRECOGNIZED*/ 0; fPartitionData.status = B_PARTITION_UNRECOGNIZED;
fPartitionData.flags = 0; fPartitionData.flags = 0;
fPartitionData.volume = -1; fPartitionData.volume = -1;
fPartitionData.name = NULL; fPartitionData.name = NULL;
@ -194,7 +194,7 @@ KPartition::SetBusy(bool busy)
if (busy) if (busy)
fPartitionData.flags |= B_PARTITION_BUSY; fPartitionData.flags |= B_PARTITION_BUSY;
else else
fPartitionData.flags &= ~B_PARTITION_BUSY; fPartitionData.flags &= ~(uint32)B_PARTITION_BUSY;
} }
// IsBusy // IsBusy
@ -211,7 +211,7 @@ KPartition::SetDescendantBusy(bool busy)
if (busy) if (busy)
fPartitionData.flags |= B_PARTITION_DESCENDANT_BUSY; fPartitionData.flags |= B_PARTITION_DESCENDANT_BUSY;
else else
fPartitionData.flags &= ~B_PARTITION_DESCENDANT_BUSY; fPartitionData.flags &= ~(uint32)B_PARTITION_DESCENDANT_BUSY;
} }
// IsDescendantBusy // IsDescendantBusy
@ -469,6 +469,10 @@ void
KPartition::SetVolumeID(dev_t volumeID) KPartition::SetVolumeID(dev_t volumeID)
{ {
fPartitionData.volume = volumeID; fPartitionData.volume = volumeID;
if (VolumeID() >= 0)
SetFlags(Flags() | B_PARTITION_MOUNTED);
else
SetFlags(Flags() & ~(uint32)B_PARTITION_MOUNTED);
} }
// VolumeID // VolumeID
@ -527,6 +531,8 @@ void
KPartition::SetDevice(KDiskDevice *device) KPartition::SetDevice(KDiskDevice *device)
{ {
fDevice = device; fDevice = device;
if (fDevice && fDevice->IsReadOnlyMedia())
SetFlags(Flags() | B_PARTITION_READ_ONLY);
} }
// Device // Device
@ -672,6 +678,13 @@ KPartition::SetDiskSystem(KDiskSystem *diskSystem)
fDiskSystem = diskSystem; fDiskSystem = diskSystem;
if (fDiskSystem) if (fDiskSystem)
fDiskSystem->Load(); // can't fail, since it's already loaded fDiskSystem->Load(); // can't fail, since it's already loaded
// update concerned partition flags
if (fDiskSystem) {
if (fDiskSystem->IsFileSystem())
SetFlags(Flags() | B_PARTITION_MOUNTABLE);
else
SetFlags(Flags() | B_PARTITION_PARTITIONABLE);
}
} }
// DiskSystem // DiskSystem