* Added back and partially reimplemented the
K{Disk,File,Partitioning}System writing methods. It is now required that the caller has marked the concerned partitions busy, hence we can (read-)access them without needing a lock. The module interfaces will will be changed to take advantage of the fact as well. The methods take a disk_job_id instead of a KDiskDeviceJob* now, though I haven't quite decided, whether we need it at all or just want to add a special handling in the cases where notifications during the operation make sense. * Reimplemented the disk device write support syscalls (save _user_move_partition() for which other module hooks are needed). They call the KDiskSystem methods, now. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@22832 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
2128ea4f31
commit
7b45b55be1
@ -3,21 +3,24 @@
|
||||
* Distributed under the terms of the MIT License.
|
||||
*
|
||||
* Authors:
|
||||
* Ingo Weinhold <bonefish@cs.tu-berlin.de>
|
||||
* Ingo Weinhold <ingo_weinhold@gmx.de>
|
||||
*/
|
||||
#ifndef _K_DISK_DEVICE_SYSTEM_H
|
||||
#define _K_DISK_DEVICE_SYSTEM_H
|
||||
|
||||
#include "disk_device_manager.h"
|
||||
|
||||
|
||||
struct user_disk_system_info;
|
||||
|
||||
|
||||
namespace BPrivate {
|
||||
namespace DiskDevice {
|
||||
|
||||
//class KDiskDeviceJob;
|
||||
|
||||
class KPartition;
|
||||
|
||||
|
||||
//! \brief Common ancestor for disk system add-on wrappers
|
||||
class KDiskSystem {
|
||||
public:
|
||||
@ -28,6 +31,7 @@ public:
|
||||
|
||||
// void SetID(disk_system_id id);
|
||||
disk_system_id ID() const;
|
||||
|
||||
const char* Name() const;
|
||||
const char* PrettyName();
|
||||
uint32 Flags() const;
|
||||
@ -47,50 +51,47 @@ public:
|
||||
|
||||
virtual float Identify(KPartition* partition, void** cookie);
|
||||
virtual status_t Scan(KPartition* partition, void* cookie);
|
||||
virtual void FreeIdentifyCookie(KPartition *partition, void *cookie);
|
||||
virtual void FreeIdentifyCookie(KPartition* partition,
|
||||
void* cookie);
|
||||
virtual void FreeCookie(KPartition* partition);
|
||||
virtual void FreeContentCookie(KPartition* partition);
|
||||
|
||||
// Writing
|
||||
// Device should not be locked.
|
||||
// Device should not be locked, but all affected partitions are marked
|
||||
// busy, meaning that no one else is allowed to modify it (and we only,
|
||||
// if we get a write lock).
|
||||
|
||||
#if 0
|
||||
virtual status_t Defragment(KPartition *partition, KDiskDeviceJob *job);
|
||||
virtual status_t Defragment(KPartition* partition,
|
||||
disk_job_id job);
|
||||
virtual status_t Repair(KPartition* partition, bool checkOnly,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t Resize(KPartition* partition, off_t size,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t ResizeChild(KPartition* child, off_t size,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t Move(KPartition* partition, off_t offset,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t MoveChild(KPartition* child, off_t offset,
|
||||
KDiskDeviceJob *job);
|
||||
virtual status_t SetName(KPartition *partition, char *name,
|
||||
KDiskDeviceJob *job);
|
||||
virtual status_t SetContentName(KPartition *partition, char *name,
|
||||
KDiskDeviceJob *job);
|
||||
virtual status_t SetType(KPartition *partition, char *type,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t SetName(KPartition* partition, const char* name,
|
||||
disk_job_id job);
|
||||
virtual status_t SetContentName(KPartition* partition,
|
||||
const char* name, disk_job_id job);
|
||||
virtual status_t SetType(KPartition* partition, const char* type,
|
||||
disk_job_id job);
|
||||
virtual status_t SetParameters(KPartition* partition,
|
||||
const char *parameters,
|
||||
KDiskDeviceJob *job);
|
||||
const char* parameters, disk_job_id job);
|
||||
virtual status_t SetContentParameters(KPartition* partition,
|
||||
const char *parameters,
|
||||
KDiskDeviceJob *job);
|
||||
virtual status_t Initialize(KPartition *partition, const char *name,
|
||||
const char *parameters, KDiskDeviceJob *job);
|
||||
const char* parameters, disk_job_id job);
|
||||
virtual status_t Initialize(KPartition* partition,
|
||||
const char* name, const char* parameters,
|
||||
disk_job_id job);
|
||||
virtual status_t CreateChild(KPartition* partition, off_t offset,
|
||||
off_t size, const char* type,
|
||||
const char *parameters, KDiskDeviceJob *job,
|
||||
KPartition **child = NULL,
|
||||
const char* name, const char* parameters,
|
||||
disk_job_id job, KPartition** child = NULL,
|
||||
partition_id childID = -1);
|
||||
virtual status_t DeleteChild(KPartition *child, KDiskDeviceJob *job);
|
||||
// The KPartition* parameters for the writing methods are a bit `volatile',
|
||||
// since the device will not be locked, when they are called. The KPartition
|
||||
// is registered though, so that it is at least guaranteed that the object
|
||||
// won't go away.
|
||||
#endif // 0
|
||||
virtual status_t DeleteChild(KPartition* child, disk_job_id job);
|
||||
|
||||
protected:
|
||||
virtual status_t LoadModule();
|
||||
@ -111,6 +112,7 @@ private:
|
||||
static int32 fNextID;
|
||||
};
|
||||
|
||||
|
||||
} // namespace DiskDevice
|
||||
} // namespace BPrivate
|
||||
|
||||
|
@ -6,18 +6,20 @@
|
||||
* Ingo Weinhold <bonefish@cs.tu-berlin.de>
|
||||
*
|
||||
* KFileSystem implements the KDiskSystem interface for file systems.
|
||||
* It works with the FS API.
|
||||
*/
|
||||
#ifndef _K_FILE_DISK_DEVICE_SYSTEM_H
|
||||
#define _K_FILE_DISK_DEVICE_SYSTEM_H
|
||||
|
||||
#include "KDiskSystem.h"
|
||||
|
||||
|
||||
struct file_system_module_info;
|
||||
|
||||
|
||||
namespace BPrivate {
|
||||
namespace DiskDevice {
|
||||
|
||||
|
||||
//! \brief Wrapper for the C interface of a filesystem add-on.
|
||||
class KFileSystem : public KDiskSystem {
|
||||
public:
|
||||
@ -30,27 +32,27 @@ public:
|
||||
|
||||
virtual float Identify(KPartition* partition, void** cookie);
|
||||
virtual status_t Scan(KPartition* partition, void* cookie);
|
||||
virtual void FreeIdentifyCookie(KPartition *partition, void *cookie);
|
||||
virtual void FreeIdentifyCookie(KPartition* partition,
|
||||
void* cookie);
|
||||
virtual void FreeContentCookie(KPartition* partition);
|
||||
|
||||
// Writing
|
||||
|
||||
#if 0
|
||||
virtual status_t Defragment(KPartition *partition, KDiskDeviceJob *job);
|
||||
virtual status_t Defragment(KPartition* partition,
|
||||
disk_job_id job);
|
||||
virtual status_t Repair(KPartition* partition, bool checkOnly,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t Resize(KPartition* partition, off_t size,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t Move(KPartition* partition, off_t offset,
|
||||
KDiskDeviceJob *job);
|
||||
virtual status_t SetContentName(KPartition *partition, char *name,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t SetContentName(KPartition* partition,
|
||||
const char* name, disk_job_id job);
|
||||
virtual status_t SetContentParameters(KPartition* partition,
|
||||
const char *parameters,
|
||||
KDiskDeviceJob *job);
|
||||
virtual status_t Initialize(KPartition *partition, const char *name,
|
||||
const char *parameters, KDiskDeviceJob *job);
|
||||
#endif // 0
|
||||
const char* parameters, disk_job_id job);
|
||||
virtual status_t Initialize(KPartition* partition,
|
||||
const char* name, const char* parameters,
|
||||
disk_job_id job);
|
||||
|
||||
protected:
|
||||
virtual status_t LoadModule();
|
||||
@ -60,6 +62,7 @@ private:
|
||||
file_system_module_info* fModule;
|
||||
};
|
||||
|
||||
|
||||
} // namespace DiskDevice
|
||||
} // namespace BPrivate
|
||||
|
||||
|
@ -10,11 +10,14 @@
|
||||
|
||||
#include "KDiskSystem.h"
|
||||
|
||||
|
||||
struct partition_module_info;
|
||||
|
||||
|
||||
namespace BPrivate {
|
||||
namespace DiskDevice {
|
||||
|
||||
|
||||
/**
|
||||
* \brief Wrapper for the C interface of a partitioning system add-on.
|
||||
*
|
||||
@ -31,44 +34,42 @@ public:
|
||||
|
||||
virtual float Identify(KPartition* partition, void** cookie);
|
||||
virtual status_t Scan(KPartition* partition, void* cookie);
|
||||
virtual void FreeIdentifyCookie(KPartition *partition, void *cookie);
|
||||
virtual void FreeIdentifyCookie(KPartition* partition,
|
||||
void* cookie);
|
||||
virtual void FreeCookie(KPartition* partition);
|
||||
virtual void FreeContentCookie(KPartition* partition);
|
||||
|
||||
// Writing
|
||||
|
||||
#if 0
|
||||
virtual status_t Repair(KPartition* partition, bool checkOnly,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t Resize(KPartition* partition, off_t size,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t ResizeChild(KPartition* child, off_t size,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t Move(KPartition* partition, off_t offset,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t MoveChild(KPartition* child, off_t offset,
|
||||
KDiskDeviceJob *job);
|
||||
virtual status_t SetName(KPartition *partition, char *name,
|
||||
KDiskDeviceJob *job);
|
||||
virtual status_t SetContentName(KPartition *partition, char *name,
|
||||
KDiskDeviceJob *job);
|
||||
virtual status_t SetType(KPartition *partition, char *type,
|
||||
KDiskDeviceJob *job);
|
||||
disk_job_id job);
|
||||
virtual status_t SetName(KPartition* partition, const char* name,
|
||||
disk_job_id job);
|
||||
virtual status_t SetContentName(KPartition* partition,
|
||||
const char* name, disk_job_id job);
|
||||
virtual status_t SetType(KPartition* partition, const char* type,
|
||||
disk_job_id job);
|
||||
virtual status_t SetParameters(KPartition* partition,
|
||||
const char *parameters,
|
||||
KDiskDeviceJob *job);
|
||||
const char* parameters, disk_job_id job);
|
||||
virtual status_t SetContentParameters(KPartition* partition,
|
||||
const char *parameters,
|
||||
KDiskDeviceJob *job);
|
||||
const char* parameters, disk_job_id job);
|
||||
virtual status_t Initialize(KPartition* partition,
|
||||
const char* name, const char* parameters,
|
||||
disk_job_id job);
|
||||
virtual status_t CreateChild(KPartition* partition, off_t offset,
|
||||
off_t size, const char* type,
|
||||
const char *parameters, KDiskDeviceJob *job,
|
||||
KPartition **child = NULL,
|
||||
const char* name, const char* parameters,
|
||||
disk_job_id job, KPartition** child = NULL,
|
||||
partition_id childID = -1);
|
||||
virtual status_t DeleteChild(KPartition *child, KDiskDeviceJob *job);
|
||||
virtual status_t Initialize(KPartition *partition, const char *name,
|
||||
const char *parameters, KDiskDeviceJob *job);
|
||||
#endif // 0
|
||||
virtual status_t DeleteChild(KPartition* child, disk_job_id job);
|
||||
|
||||
protected:
|
||||
virtual status_t LoadModule();
|
||||
@ -78,6 +79,7 @@ private:
|
||||
partition_module_info* fModule;
|
||||
};
|
||||
|
||||
|
||||
} // namespace DiskDevice
|
||||
} // namespace BPrivate
|
||||
|
||||
|
@ -190,11 +190,9 @@ KDiskSystem::FreeContentCookie(KPartition *partition)
|
||||
}
|
||||
|
||||
|
||||
#if 0
|
||||
|
||||
// Defragment
|
||||
status_t
|
||||
KDiskSystem::Defragment(KPartition *partition, KDiskDeviceJob *job)
|
||||
KDiskSystem::Defragment(KPartition* partition, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -203,8 +201,7 @@ KDiskSystem::Defragment(KPartition *partition, KDiskDeviceJob *job)
|
||||
|
||||
// Repair
|
||||
status_t
|
||||
KDiskSystem::Repair(KPartition *partition, bool checkOnly,
|
||||
KDiskDeviceJob *job)
|
||||
KDiskSystem::Repair(KPartition* partition, bool checkOnly, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -213,7 +210,7 @@ KDiskSystem::Repair(KPartition *partition, bool checkOnly,
|
||||
|
||||
// Resize
|
||||
status_t
|
||||
KDiskSystem::Resize(KPartition *partition, off_t size, KDiskDeviceJob *job)
|
||||
KDiskSystem::Resize(KPartition* partition, off_t size, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -222,7 +219,7 @@ KDiskSystem::Resize(KPartition *partition, off_t size, KDiskDeviceJob *job)
|
||||
|
||||
// ResizeChild
|
||||
status_t
|
||||
KDiskSystem::ResizeChild(KPartition *child, off_t size, KDiskDeviceJob *job)
|
||||
KDiskSystem::ResizeChild(KPartition* child, off_t size, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -231,7 +228,7 @@ KDiskSystem::ResizeChild(KPartition *child, off_t size, KDiskDeviceJob *job)
|
||||
|
||||
// Move
|
||||
status_t
|
||||
KDiskSystem::Move(KPartition *partition, off_t offset, KDiskDeviceJob *job)
|
||||
KDiskSystem::Move(KPartition* partition, off_t offset, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -240,7 +237,7 @@ KDiskSystem::Move(KPartition *partition, off_t offset, KDiskDeviceJob *job)
|
||||
|
||||
// MoveChild
|
||||
status_t
|
||||
KDiskSystem::MoveChild(KPartition *child, off_t offset, KDiskDeviceJob *job)
|
||||
KDiskSystem::MoveChild(KPartition* child, off_t offset, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -249,7 +246,7 @@ KDiskSystem::MoveChild(KPartition *child, off_t offset, KDiskDeviceJob *job)
|
||||
|
||||
// SetName
|
||||
status_t
|
||||
KDiskSystem::SetName(KPartition *partition, char *name, KDiskDeviceJob *job)
|
||||
KDiskSystem::SetName(KPartition* partition, const char* name, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -258,8 +255,8 @@ KDiskSystem::SetName(KPartition *partition, char *name, KDiskDeviceJob *job)
|
||||
|
||||
// SetContentName
|
||||
status_t
|
||||
KDiskSystem::SetContentName(KPartition *partition, char *name,
|
||||
KDiskDeviceJob *job)
|
||||
KDiskSystem::SetContentName(KPartition* partition, const char* name,
|
||||
disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -268,7 +265,7 @@ KDiskSystem::SetContentName(KPartition *partition, char *name,
|
||||
|
||||
// SetType
|
||||
status_t
|
||||
KDiskSystem::SetType(KPartition *partition, char *type, KDiskDeviceJob *job)
|
||||
KDiskSystem::SetType(KPartition* partition, const char *type, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -278,7 +275,7 @@ KDiskSystem::SetType(KPartition *partition, char *type, KDiskDeviceJob *job)
|
||||
// SetParameters
|
||||
status_t
|
||||
KDiskSystem::SetParameters(KPartition* partition, const char* parameters,
|
||||
KDiskDeviceJob *job)
|
||||
disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -288,7 +285,7 @@ KDiskSystem::SetParameters(KPartition *partition, const char *parameters,
|
||||
// SetContentParameters
|
||||
status_t
|
||||
KDiskSystem::SetContentParameters(KPartition* partition,
|
||||
const char *parameters, KDiskDeviceJob *job)
|
||||
const char* parameters, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -298,7 +295,7 @@ KDiskSystem::SetContentParameters(KPartition *partition,
|
||||
// Initialize
|
||||
status_t
|
||||
KDiskSystem::Initialize(KPartition* partition, const char* name,
|
||||
const char *parameters, KDiskDeviceJob *job)
|
||||
const char* parameters, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -308,9 +305,8 @@ KDiskSystem::Initialize(KPartition *partition, const char *name,
|
||||
// CreateChild
|
||||
status_t
|
||||
KDiskSystem::CreateChild(KPartition* partition, off_t offset, off_t size,
|
||||
const char *type, const char *parameters,
|
||||
KDiskDeviceJob *job, KPartition **child,
|
||||
partition_id childID)
|
||||
const char* type, const char* name, const char* parameters, disk_job_id job,
|
||||
KPartition **child, partition_id childID)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
@ -319,14 +315,12 @@ KDiskSystem::CreateChild(KPartition *partition, off_t offset, off_t size,
|
||||
|
||||
// DeleteChild
|
||||
status_t
|
||||
KDiskSystem::DeleteChild(KPartition *child, KDiskDeviceJob *job)
|
||||
KDiskSystem::DeleteChild(KPartition* child, disk_job_id job)
|
||||
{
|
||||
// to be implemented by derived classes
|
||||
return B_ERROR;
|
||||
}
|
||||
|
||||
#endif // 0
|
||||
|
||||
|
||||
// LoadModule
|
||||
status_t
|
||||
|
@ -97,11 +97,9 @@ KFileSystem::FreeContentCookie(KPartition *partition)
|
||||
}
|
||||
|
||||
|
||||
#if 0
|
||||
|
||||
// Defragment
|
||||
status_t
|
||||
KFileSystem::Defragment(KPartition *partition, KDiskDeviceJob *job)
|
||||
KFileSystem::Defragment(KPartition* partition, disk_job_id job)
|
||||
{
|
||||
// to be implemented
|
||||
return B_ERROR;
|
||||
@ -110,7 +108,7 @@ KFileSystem::Defragment(KPartition *partition, KDiskDeviceJob *job)
|
||||
|
||||
// Repair
|
||||
status_t
|
||||
KFileSystem::Repair(KPartition *partition, bool checkOnly, KDiskDeviceJob *job)
|
||||
KFileSystem::Repair(KPartition* partition, bool checkOnly, disk_job_id job)
|
||||
{
|
||||
// to be implemented
|
||||
return B_ERROR;
|
||||
@ -119,7 +117,7 @@ KFileSystem::Repair(KPartition *partition, bool checkOnly, KDiskDeviceJob *job)
|
||||
|
||||
// Resize
|
||||
status_t
|
||||
KFileSystem::Resize(KPartition *partition, off_t size, KDiskDeviceJob *job)
|
||||
KFileSystem::Resize(KPartition* partition, off_t size, disk_job_id job)
|
||||
{
|
||||
// to be implemented
|
||||
return B_ERROR;
|
||||
@ -128,7 +126,7 @@ KFileSystem::Resize(KPartition *partition, off_t size, KDiskDeviceJob *job)
|
||||
|
||||
// Move
|
||||
status_t
|
||||
KFileSystem::Move(KPartition *partition, off_t offset, KDiskDeviceJob *job)
|
||||
KFileSystem::Move(KPartition* partition, off_t offset, disk_job_id job)
|
||||
{
|
||||
// to be implemented
|
||||
return B_ERROR;
|
||||
@ -137,58 +135,50 @@ KFileSystem::Move(KPartition *partition, off_t offset, KDiskDeviceJob *job)
|
||||
|
||||
// SetContentName
|
||||
status_t
|
||||
KFileSystem::SetContentName(KPartition *partition, char *name,
|
||||
KDiskDeviceJob *job)
|
||||
KFileSystem::SetContentName(KPartition* partition, const char* name,
|
||||
disk_job_id job)
|
||||
{
|
||||
// to be implemented
|
||||
return B_ERROR;
|
||||
}
|
||||
|
||||
|
||||
// SetContentParameters
|
||||
status_t
|
||||
KFileSystem::SetContentParameters(KPartition* partition,
|
||||
const char *parameters, KDiskDeviceJob *job)
|
||||
const char* parameters, disk_job_id job)
|
||||
{
|
||||
// to be implemented
|
||||
return B_ERROR;
|
||||
}
|
||||
|
||||
|
||||
// Initialize
|
||||
status_t
|
||||
KFileSystem::Initialize(KPartition* partition, const char* name,
|
||||
const char *parameters, KDiskDeviceJob *job)
|
||||
const char* parameters, disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job || !fModule)
|
||||
if (!partition || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->initialize)
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// open partition device (we need a temporary read-lock)
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
if (!manager->ReadLockPartition(partition->ID()))
|
||||
return B_ERROR;
|
||||
DeviceReadLocker locker(partition->Device(), true);
|
||||
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
|
||||
off_t partitionSize = partition->Size();
|
||||
|
||||
locker.Unlock();
|
||||
|
||||
// call the module hook
|
||||
// let the module do its job
|
||||
result = fModule->initialize(fd, partition->ID(), name, parameters,
|
||||
partitionSize, job->ID());
|
||||
partition->Size(), job);
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
return result;
|
||||
}
|
||||
|
||||
#endif // 0
|
||||
|
||||
|
||||
// LoadModule
|
||||
status_t
|
||||
|
@ -127,13 +127,11 @@ KPartitioningSystem::FreeContentCookie(KPartition *partition)
|
||||
}
|
||||
|
||||
|
||||
#if 0
|
||||
|
||||
// Repair
|
||||
//! Repairs a partition
|
||||
status_t
|
||||
KPartitioningSystem::Repair(KPartition* partition, bool checkOnly,
|
||||
KDiskDeviceJob *job)
|
||||
disk_job_id job)
|
||||
{
|
||||
// to be implemented
|
||||
return B_ERROR;
|
||||
@ -143,34 +141,22 @@ KPartitioningSystem::Repair(KPartition *partition, bool checkOnly,
|
||||
// Resize
|
||||
//! Resizes a partition
|
||||
status_t
|
||||
KPartitioningSystem::Resize(KPartition *partition, off_t size,
|
||||
KDiskDeviceJob *job)
|
||||
KPartitioningSystem::Resize(KPartition* partition, off_t size, disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job || size < 0)
|
||||
if (!partition || size < 0 || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->resize)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(partition->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (partition != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->resize(fd, partition->ID(), size, job->ID());
|
||||
result = fModule->resize(fd, partition->ID(), size, job);
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -181,35 +167,22 @@ KPartitioningSystem::Resize(KPartition *partition, off_t size,
|
||||
// ResizeChild
|
||||
//! Resizes child of a partition
|
||||
status_t
|
||||
KPartitioningSystem::ResizeChild(KPartition *child, off_t size,
|
||||
KDiskDeviceJob *job)
|
||||
KPartitioningSystem::ResizeChild(KPartition* child, off_t size, disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!child || !job || !child->Parent() || size < 0)
|
||||
if (!child || !child->Parent() || size < 0 || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->resize_child)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open (parent) partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(child->ID());
|
||||
KPartition *_parent = manager->WriteLockPartition(child->Parent()->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (child != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = child->Parent()->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->resize_child(fd, child->ID(), size, job->ID());
|
||||
result = fModule->resize_child(fd, child->ID(), size, job);
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -220,34 +193,22 @@ KPartitioningSystem::ResizeChild(KPartition *child, off_t size,
|
||||
// Move
|
||||
//! Moves a partition
|
||||
status_t
|
||||
KPartitioningSystem::Move(KPartition *partition, off_t offset,
|
||||
KDiskDeviceJob *job)
|
||||
KPartitioningSystem::Move(KPartition* partition, off_t offset, disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job)
|
||||
if (!partition)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->move)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(partition->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (partition != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->move(fd, partition->ID(), offset, job->ID());
|
||||
result = fModule->move(fd, partition->ID(), offset, job);
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -258,36 +219,23 @@ KPartitioningSystem::Move(KPartition *partition, off_t offset,
|
||||
// MoveChild
|
||||
//! Moves child of a partition
|
||||
status_t
|
||||
KPartitioningSystem::MoveChild(KPartition *child, off_t offset,
|
||||
KDiskDeviceJob *job)
|
||||
KPartitioningSystem::MoveChild(KPartition* child, off_t offset, disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!child || !job || !child->Parent())
|
||||
if (!child || !child->Parent() || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->move_child)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open (parent) partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(child->ID());
|
||||
KPartition *_parent = manager->WriteLockPartition(child->Parent()->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (child != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = child->Parent()->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->move_child(fd, child->Parent()->ID(),
|
||||
child->ID(), offset, job->ID());
|
||||
result = fModule->move_child(fd, child->Parent()->ID(), child->ID(), offset,
|
||||
job);
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -298,34 +246,24 @@ KPartitioningSystem::MoveChild(KPartition *child, off_t offset,
|
||||
// SetName
|
||||
//! Sets name of a partition
|
||||
status_t
|
||||
KPartitioningSystem::SetName(KPartition *partition, char *name,
|
||||
KDiskDeviceJob *job)
|
||||
KPartitioningSystem::SetName(KPartition* child, const char* name,
|
||||
disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job || !name)
|
||||
if (!child || !child->Parent() || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->set_name)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(partition->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (partition != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
status_t result = child->Parent()->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->set_name(fd, partition->ID(), name, job->ID());
|
||||
result = fModule->set_name(fd, child->ID(), name, job);
|
||||
// TODO: Change hook interface!
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -336,35 +274,23 @@ KPartitioningSystem::SetName(KPartition *partition, char *name,
|
||||
// SetContentName
|
||||
//! Sets name of the content of a partition
|
||||
status_t
|
||||
KPartitioningSystem::SetContentName(KPartition *partition, char *name,
|
||||
KDiskDeviceJob *job)
|
||||
KPartitioningSystem::SetContentName(KPartition* partition, const char* name,
|
||||
disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job || !name)
|
||||
if (!partition || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->set_content_name)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(partition->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (partition != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->set_content_name(fd, partition->ID(), name,
|
||||
job->ID());
|
||||
result = fModule->set_content_name(fd, partition->ID(), name, job);
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -375,34 +301,24 @@ KPartitioningSystem::SetContentName(KPartition *partition, char *name,
|
||||
// SetType
|
||||
//! Sets type of a partition
|
||||
status_t
|
||||
KPartitioningSystem::SetType(KPartition *partition, char *type,
|
||||
KDiskDeviceJob *job)
|
||||
KPartitioningSystem::SetType(KPartition* child, const char* type,
|
||||
disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job || !type)
|
||||
if (!child || !child->Parent() || !type || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->set_type)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(partition->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (partition != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
status_t result = child->Parent()->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->set_type(fd, partition->ID(), type, job->ID());
|
||||
result = fModule->set_type(fd, child->Parent()->ID(), type, job);
|
||||
// TODO: Change hook interface!
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -413,35 +329,24 @@ KPartitioningSystem::SetType(KPartition *partition, char *type,
|
||||
// SetParameters
|
||||
//! Sets parameters of a partition
|
||||
status_t
|
||||
KPartitioningSystem::SetParameters(KPartition *partition,
|
||||
const char *parameters, KDiskDeviceJob *job)
|
||||
KPartitioningSystem::SetParameters(KPartition* child, const char* parameters,
|
||||
disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job || !parameters)
|
||||
if (!child || !child->Parent() || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->set_parameters)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(partition->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (partition != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
status_t result = child->Parent()->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->set_parameters(fd, partition->ID(), parameters,
|
||||
job->ID());
|
||||
result = fModule->set_parameters(fd, child->ID(), parameters, job);
|
||||
// TODO: Change hook interface!
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -453,34 +358,23 @@ KPartitioningSystem::SetParameters(KPartition *partition,
|
||||
//! Sets parameters of the content of a partition
|
||||
status_t
|
||||
KPartitioningSystem::SetContentParameters(KPartition* partition,
|
||||
const char *parameters, KDiskDeviceJob *job)
|
||||
const char* parameters, disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job || !parameters)
|
||||
if (!partition || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->set_content_parameters)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(partition->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (partition != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->set_content_parameters(fd, partition->ID(),
|
||||
parameters, job->ID());
|
||||
result = fModule->set_content_parameters(fd, partition->ID(), parameters,
|
||||
job);
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -492,38 +386,23 @@ KPartitioningSystem::SetContentParameters(KPartition *partition,
|
||||
//! Initializes a partition with this partitioning system
|
||||
status_t
|
||||
KPartitioningSystem::Initialize(KPartition* partition, const char* name,
|
||||
const char *parameters, KDiskDeviceJob *job)
|
||||
const char* parameters, disk_job_id job)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job /*|| !parameters*/)
|
||||
if (!partition || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->initialize)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
// TODO: This looks overly complicated.
|
||||
KPartition *_partition = manager->WriteLockPartition(partition->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
off_t partitionSize;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (partition != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
|
||||
partitionSize = partition->Size();
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->initialize(fd, partition->ID(), name, parameters,
|
||||
partitionSize, job->ID());
|
||||
result = fModule->initialize(fd, partition->ID(), name, parameters,
|
||||
partition->Size(), job);
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -535,38 +414,28 @@ KPartitioningSystem::Initialize(KPartition *partition, const char *name,
|
||||
//! Creates a child partition
|
||||
status_t
|
||||
KPartitioningSystem::CreateChild(KPartition* partition, off_t offset,
|
||||
off_t size, const char *type, const char *parameters, KDiskDeviceJob *job,
|
||||
KPartition **child, partition_id childID)
|
||||
off_t size, const char* type, const char* name, const char* parameters,
|
||||
disk_job_id job, KPartition** child, partition_id childID)
|
||||
{
|
||||
// check parameters
|
||||
if (!partition || !job || !type /*|| !parameters*/ || !child)
|
||||
if (!partition || !type || !parameters || !child || !fModule)
|
||||
return B_BAD_VALUE;
|
||||
if (!fModule->create_child)
|
||||
return B_ENTRY_NOT_FOUND;
|
||||
return B_NOT_SUPPORTED;
|
||||
|
||||
// lock partition and open partition device
|
||||
KDiskDeviceManager *manager = KDiskDeviceManager::Default();
|
||||
KPartition *_partition = manager->WriteLockPartition(partition->ID());
|
||||
if (!_partition)
|
||||
return B_ERROR;
|
||||
// open partition device
|
||||
int fd = -1;
|
||||
{
|
||||
PartitionRegistrar registrar(_partition, true);
|
||||
PartitionRegistrar deviceRegistrar(_partition->Device(), true);
|
||||
DeviceWriteLocker locker(_partition->Device(), true);
|
||||
if (partition != _partition)
|
||||
return B_ERROR;
|
||||
status_t result = partition->Open(O_RDWR, &fd);
|
||||
if (result != B_OK)
|
||||
return result;
|
||||
}
|
||||
|
||||
// let the module do its job
|
||||
status_t result = fModule->create_child(fd, partition->ID(), offset, size,
|
||||
type, parameters, job->ID(), &childID);
|
||||
result = fModule->create_child(fd, partition->ID(), offset, size,
|
||||
type, parameters, job, &childID);
|
||||
// TODO: Added name parameter to create_child() hook.
|
||||
|
||||
// find and return the child
|
||||
*child = manager->FindPartition(childID, false);
|
||||
*child = KDiskDeviceManager::Default()->FindPartition(childID);
|
||||
|
||||
// cleanup and return
|
||||
close(fd);
|
||||
@ -577,14 +446,12 @@ KPartitioningSystem::CreateChild(KPartition *partition, off_t offset,
|
||||
// DeleteChild
|
||||
//! Deletes a child partition
|
||||
status_t
|
||||
KPartitioningSystem::DeleteChild(KPartition *child, KDiskDeviceJob *job)
|
||||
KPartitioningSystem::DeleteChild(KPartition* child, disk_job_id job)
|
||||
{
|
||||
// to be implemented
|
||||
return B_ERROR;
|
||||
}
|
||||
|
||||
#endif // 0
|
||||
|
||||
|
||||
// LoadModule
|
||||
status_t
|
||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user