Implemented some basics of KDiskDeviceManager.

git-svn-id: file:///srv/svn/repos/haiku/trunk/current@3460 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Ingo Weinhold 2003-06-10 22:35:57 +00:00
parent 537635f1d1
commit 29a37d780d
2 changed files with 295 additions and 12 deletions

View File

@ -4,6 +4,8 @@
#define _K_DISK_DEVICE_MANAGER_H #define _K_DISK_DEVICE_MANAGER_H
#include "disk_device_manager.h" #include "disk_device_manager.h"
#include "List.h"
#include "Locker.h"
namespace BPrivate { namespace BPrivate {
namespace DiskDevice { namespace DiskDevice {
@ -15,9 +17,12 @@ class KDiskSystem;
class KPartition; class KPartition;
class KDiskDeviceManager { class KDiskDeviceManager {
public:
KDiskDeviceManager(); KDiskDeviceManager();
~KDiskDeviceManager(); ~KDiskDeviceManager();
status_t InitCheck() const;
// Singleton Creation, Deletion, and Access // Singleton Creation, Deletion, and Access
static status_t CreateDefault(); static status_t CreateDefault();
@ -37,36 +42,45 @@ class KDiskDeviceManager {
KPartition *RegisterPartition(partition_id id, bool noShadow = true); KPartition *RegisterPartition(partition_id id, bool noShadow = true);
// manager must be locked // manager must be locked
int32 CountDiskDevices() const; int32 CountDiskDevices();
KDiskDevice *DiskDeviceAt(int32 index) const; KDiskDevice *DiskDeviceAt(int32 index);
void PartitionAdded(KPartition *partition); // implementation internal bool PartitionAdded(KPartition *partition); // implementation internal
void PartitionRemoved(KPartition *partition); // bool PartitionRemoved(KPartition *partition); //
// Jobs // Jobs
// manager must be locked // manager must be locked
KDiskDeviceJob *JobWithID(disk_job_id id) const; KDiskDeviceJob *JobWithID(disk_job_id id);
int32 CountJobs() const; int32 CountJobs();
KDiskDeviceJob *JobAt(int32 index) const; KDiskDeviceJob *JobAt(int32 index);
// manager must be locked // manager must be locked
bool AddJobQueue(KDiskDeviceJobQueue *jobQueue) const; bool AddJobQueue(KDiskDeviceJobQueue *jobQueue);
int32 CountJobQueues() const; int32 CountJobQueues();
KDiskDeviceJobQueue *JobQueueAt(int32 index) const; KDiskDeviceJobQueue *JobQueueAt(int32 index);
// Disk Systems // Disk Systems
// manager must be locked // manager must be locked
KDiskSystem *DiskSystemWithName(const char *name); KDiskSystem *DiskSystemWithName(const char *name);
KDiskSystem *DiskSystemWithID(disk_system_id id); KDiskSystem *DiskSystemWithID(disk_system_id id);
int32 CountDiskSystems() const; int32 CountDiskSystems();
KDiskSystem *DiskSystemAt(int32 index) const; KDiskSystem *DiskSystemAt(int32 index);
// Watching // Watching
// TODO: Watching service for the kernel. The userland watching is handled // TODO: Watching service for the kernel. The userland watching is handled
// by the registrar. // by the registrar.
private:
KPartition *_FindPartition(partition_id id) const;
BLocker fLock;
List<KDiskDevice*> fDevices; // TODO: Optimize!
List<KPartition*> fPartitions; //
static KDiskDeviceManager *fDefaultManager;
}; };
} // namespace DiskDevice } // namespace DiskDevice

View File

@ -1,3 +1,272 @@
// KDiskDeviceManager.cpp // KDiskDeviceManager.cpp
#include <stdlib.h>
#include <string.h>
#include "KDiskDevice.h"
#include "KDiskDeviceManager.h" #include "KDiskDeviceManager.h"
#include "KDiskDeviceUtils.h"
#include "KPartition.h"
// TODO: Remove when not longer needed.
using BPrivate::DiskDevice::KDiskDeviceJob;
using BPrivate::DiskDevice::KDiskDeviceJobQueue;
using BPrivate::DiskDevice::KDiskSystem;
// constructor
KDiskDeviceManager::KDiskDeviceManager()
: fLock("disk device manager"),
fDevices(20),
fPartitions(100)
{
}
// destructor
KDiskDeviceManager::~KDiskDeviceManager()
{
}
// InitCheck
status_t
KDiskDeviceManager::InitCheck() const
{
return B_OK;
}
// CreateDefault
status_t
KDiskDeviceManager::CreateDefault()
{
status_t error = B_OK;
if (!fDefaultManager) {
fDefaultManager = new(nothrow) KDiskDeviceManager;
if (fDefaultManager) {
error = fDefaultManager->InitCheck();
if (error != B_OK)
DeleteDefault();
} else
error = B_NO_MEMORY;
}
return (fDefaultManager ? B_OK : B_NO_MEMORY);
}
// DeleteDefault
void
KDiskDeviceManager::DeleteDefault()
{
if (fDefaultManager) {
delete fDefaultManager;
fDefaultManager = NULL;
}
}
// Default
KDiskDeviceManager *
KDiskDeviceManager::Default()
{
return fDefaultManager;
}
// Lock
bool
KDiskDeviceManager::Lock()
{
return fLock.Lock();
}
// Unlock
void
KDiskDeviceManager::Unlock()
{
fLock.Unlock();
}
// RegisterDevice
KDiskDevice *
KDiskDeviceManager::RegisterDevice(const char *path, bool noShadow)
{
// TODO: Handle shadows correctly!
if (ManagerLocker locker = this) {
for (int32 i = 0; KDiskDevice *device = fDevices.ItemAt(i); i++) {
if (device->Path() && !strcmp(path, device->Path())) {
device->Register();
return device;
}
}
}
return NULL;
}
// RegisterDevice
KDiskDevice *
KDiskDeviceManager::RegisterDevice(partition_id id, bool noShadow)
{
// TODO: Handle shadows correctly!
if (ManagerLocker locker = this) {
if (KPartition *partition = _FindPartition(id)) {
KDiskDevice *device = partition->Device();
device->Register();
return device;
}
}
return NULL;
}
// RegisterPartition
KPartition *
KDiskDeviceManager::RegisterPartition(const char *path, bool noShadow)
{
// TODO: Handle shadows correctly!
// TODO: Optimize!
if (ManagerLocker locker = this) {
for (int32 i = 0; KPartition *partition = fPartitions.ItemAt(i); i++) {
char partitionPath[B_PATH_NAME_LENGTH];
if (partition->GetPath(partitionPath) == B_OK
&& !strcmp(path, partitionPath)) {
partition->Register();
return partition;
}
}
}
return NULL;
}
// RegisterPartition
KPartition *
KDiskDeviceManager::RegisterPartition(partition_id id, bool noShadow)
{
// TODO: Handle shadows correctly!
if (ManagerLocker locker = this) {
if (KPartition *partition = _FindPartition(id)) {
partition->Register();
return partition;
}
}
return NULL;
}
// CountDiskDevices
int32
KDiskDeviceManager::CountDiskDevices()
{
if (ManagerLocker locker = this)
return fDevices.CountItems();
return 0;
}
// DiskDeviceAt
KDiskDevice *
KDiskDeviceManager::DiskDeviceAt(int32 index)
{
if (ManagerLocker locker = this)
return fDevices.ItemAt(index);
return 0;
}
// PartitionAdded
bool
KDiskDeviceManager::PartitionAdded(KPartition *partition)
{
return (partition && fPartitions.AddItem(partition));
}
// PartitionRemoved
bool
KDiskDeviceManager::PartitionRemoved(KPartition *partition)
{
return (partition && fPartitions.RemoveItem(partition));
}
// JobWithID
KDiskDeviceJob *
KDiskDeviceManager::JobWithID(disk_job_id id)
{
// not implemented
return NULL;
}
// CountJobs
int32
KDiskDeviceManager::CountJobs()
{
// not implemented
return 0;
}
// JobAt
KDiskDeviceJob *
KDiskDeviceManager::JobAt(int32 index)
{
// not implemented
return NULL;
}
// AddJobQueue
bool
KDiskDeviceManager::AddJobQueue(KDiskDeviceJobQueue *jobQueue)
{
// not implemented
return false;
}
// CountJobQueues
int32
KDiskDeviceManager::CountJobQueues()
{
// not implemented
return 0;
}
// JobQueueAt
KDiskDeviceJobQueue *
KDiskDeviceManager::JobQueueAt(int32 index)
{
// not implemented
return NULL;
}
// DiskSystemWithName
KDiskSystem *
KDiskDeviceManager::DiskSystemWithName(const char *name)
{
// not implemented
return NULL;
}
// DiskSystemWithID
KDiskSystem *
KDiskDeviceManager::DiskSystemWithID(disk_system_id id)
{
// not implemented
return NULL;
}
// CountDiskSystems
int32
KDiskDeviceManager::CountDiskSystems()
{
// not implemented
return 0;
}
// DiskSystemAt
KDiskSystem *
KDiskDeviceManager::DiskSystemAt(int32 index)
{
// not implemented
return NULL;
}
// _FindPartition
KPartition *
KDiskDeviceManager::_FindPartition(partition_id id) const
{
for (int32 i = 0; KPartition *partition = fPartitions.ItemAt(i); i++) {
if (partition->ID() == id)
return partition;
}
}
// singleton instance
KDiskDeviceManager *KDiskDeviceManager::fDefaultManager = NULL;