2013-04-06 06:26:40 +04:00
|
|
|
/*
|
|
|
|
* Copyright 2013, Haiku, Inc. All Rights Reserved.
|
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Ingo Weinhold <ingo_weinhold@gmx.de>
|
|
|
|
*/
|
|
|
|
#ifndef _PACKAGE__PRIVATE__PACKAGE_FS_H_
|
|
|
|
#define _PACKAGE__PRIVATE__PACKAGE_FS_H_
|
|
|
|
|
|
|
|
|
|
|
|
#include <Drivers.h>
|
|
|
|
|
|
|
|
|
|
|
|
enum PackageFSMountType {
|
|
|
|
PACKAGE_FS_MOUNT_TYPE_SYSTEM,
|
|
|
|
PACKAGE_FS_MOUNT_TYPE_HOME,
|
2013-04-29 17:31:13 +04:00
|
|
|
PACKAGE_FS_MOUNT_TYPE_CUSTOM,
|
|
|
|
|
|
|
|
PACKAGE_FS_MOUNT_TYPE_ENUM_COUNT
|
2013-04-06 06:26:40 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
enum {
|
2013-04-07 13:53:50 +04:00
|
|
|
PACKAGE_FS_OPERATION_GET_VOLUME_INFO = B_DEVICE_OP_CODES_END + 1,
|
|
|
|
PACKAGE_FS_OPERATION_GET_PACKAGE_INFOS,
|
|
|
|
PACKAGE_FS_OPERATION_CHANGE_ACTIVATION
|
2013-04-06 06:26:40 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-04-07 13:53:50 +04:00
|
|
|
// PACKAGE_FS_OPERATION_GET_VOLUME_INFO
|
|
|
|
|
2014-04-19 01:29:59 +04:00
|
|
|
struct PackageFSDirectoryInfo {
|
|
|
|
// node_ref of the directory
|
|
|
|
dev_t deviceID;
|
|
|
|
ino_t nodeID;
|
|
|
|
};
|
|
|
|
|
2013-04-06 06:26:40 +04:00
|
|
|
struct PackageFSVolumeInfo {
|
|
|
|
PackageFSMountType mountType;
|
|
|
|
|
|
|
|
// device and node id of the respective package FS root scope (e.g. "/boot"
|
|
|
|
// for the three standard volumes)
|
2014-04-19 01:29:59 +04:00
|
|
|
dev_t rootDeviceID;
|
|
|
|
ino_t rootDirectoryID;
|
|
|
|
|
|
|
|
// packageCount is set to the actual packages directory count, even if it is
|
|
|
|
// greater than the array, so the caller can determine whether the array was
|
|
|
|
// large enough.
|
|
|
|
// The directories are ordered from the most recent state (the actual
|
|
|
|
// "packages" directory) to the oldest one, the one that is actually active.
|
|
|
|
uint32 packagesDirectoryCount;
|
|
|
|
PackageFSDirectoryInfo packagesDirectoryInfos[1];
|
2013-04-07 13:53:50 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// PACKAGE_FS_OPERATION_GET_PACKAGE_INFOS
|
|
|
|
|
|
|
|
struct PackageFSPackageInfo {
|
2014-04-19 01:29:59 +04:00
|
|
|
// node_ref of the package file and the containing directory
|
2013-04-07 13:53:50 +04:00
|
|
|
dev_t packageDeviceID;
|
2014-04-19 01:29:59 +04:00
|
|
|
dev_t directoryDeviceID;
|
2013-04-07 13:53:50 +04:00
|
|
|
ino_t packageNodeID;
|
2014-04-19 01:29:59 +04:00
|
|
|
ino_t directoryNodeID;
|
2013-04-07 13:53:50 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
struct PackageFSGetPackageInfosRequest {
|
|
|
|
// Filled in by the FS. packageCount is set to the actual package count,
|
|
|
|
// even if it is greater than the array, so the caller can determine whether
|
|
|
|
// the array was large enough.
|
|
|
|
uint32 packageCount;
|
|
|
|
PackageFSPackageInfo infos[1];
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// PACKAGE_FS_OPERATION_CHANGE_ACTIVATION
|
|
|
|
|
|
|
|
enum PackageFSActivationChangeType {
|
|
|
|
PACKAGE_FS_ACTIVATE_PACKAGE,
|
|
|
|
PACKAGE_FS_DEACTIVATE_PACKAGE,
|
|
|
|
PACKAGE_FS_REACTIVATE_PACKAGE
|
|
|
|
};
|
|
|
|
|
|
|
|
struct PackageFSActivationChangeItem {
|
|
|
|
PackageFSActivationChangeType type;
|
|
|
|
|
|
|
|
// node_ref of the package file
|
|
|
|
dev_t packageDeviceID;
|
|
|
|
ino_t packageNodeID;
|
|
|
|
|
|
|
|
// entry_ref of the package file
|
|
|
|
uint32 nameLength;
|
|
|
|
dev_t parentDeviceID;
|
|
|
|
ino_t parentDirectoryID;
|
2013-04-08 21:06:18 +04:00
|
|
|
char* name;
|
|
|
|
// must point to a location within the
|
|
|
|
// request
|
2013-04-07 13:53:50 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
struct PackageFSActivationChangeRequest {
|
|
|
|
uint32 itemCount;
|
2013-04-08 19:44:43 +04:00
|
|
|
PackageFSActivationChangeItem items[0];
|
2013-04-06 06:26:40 +04:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif // _PACKAGE__PRIVATE__PACKAGE_FS_H_
|