From af327271cca9ab5b0893b788c66bd411d8473bf5 Mon Sep 17 00:00:00 2001 From: Ingo Weinhold Date: Fri, 29 Oct 2004 01:33:59 +0000 Subject: [PATCH] Made C-safe. Now no longer declares the syscall prototypes, but the prototypes for the respective _user_*() functions. git-svn-id: file:///srv/svn/repos/haiku/trunk/current@9632 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- .../ddm_userland_interface.h | 147 ++++++++---------- 1 file changed, 68 insertions(+), 79 deletions(-) diff --git a/headers/private/kernel/disk_device_manager/ddm_userland_interface.h b/headers/private/kernel/disk_device_manager/ddm_userland_interface.h index d5b282bfde..789d108d99 100644 --- a/headers/private/kernel/disk_device_manager/ddm_userland_interface.h +++ b/headers/private/kernel/disk_device_manager/ddm_userland_interface.h @@ -3,15 +3,18 @@ #ifndef _DISK_DEVICE_MANAGER_USERLAND_INTERFACE_H #define _DISK_DEVICE_MANAGER_USERLAND_INTERFACE_H -#include -#include #include +#include + +#include + #ifdef __cplusplus extern "C" { #endif // userland partition representation +typedef struct user_partition_data user_partition_data; struct user_partition_data { partition_id id; partition_id shadow_id; @@ -37,193 +40,179 @@ struct user_partition_data { }; // userland disk device representation -struct user_disk_device_data { +typedef struct user_disk_device_data { uint32 device_flags; char *path; user_partition_data device_partition_data; -}; +} user_disk_device_data; // userland partitionable space representation -struct user_disk_system_info { +typedef struct user_disk_system_info { disk_system_id id; char name[B_FILE_NAME_LENGTH]; // better B_PATH_NAME_LENGTH? char pretty_name[B_OS_NAME_LENGTH]; uint32 flags; -}; +} user_disk_system_info; // userland disk device job representation -struct user_disk_device_job_info { +typedef struct user_disk_device_job_info { disk_job_id id; uint32 type; partition_id partition; char description[256]; -}; +} user_disk_device_job_info; + + +/*! Syscalls entries */ // iterating, retrieving device/partition data -partition_id _kern_get_next_disk_device_id(int32 *cookie, - size_t *neededSize = NULL); -partition_id _kern_find_disk_device(const char *filename, - size_t *neededSize = NULL); -partition_id _kern_find_partition(const char *filename, - size_t *neededSize = NULL); -status_t _kern_get_disk_device_data(partition_id deviceID, bool deviceOnly, +partition_id _user_get_next_disk_device_id(int32 *cookie, size_t *neededSize); +partition_id _user_find_disk_device(const char *filename, size_t *neededSize); +partition_id _user_find_partition(const char *filename, size_t *neededSize); +status_t _user_get_disk_device_data(partition_id deviceID, bool deviceOnly, bool shadow, user_disk_device_data *buffer, size_t bufferSize, size_t *neededSize); -status_t _kern_get_partition_data(partition_id partitionID, bool shadow, - user_partition_data *buffer, - size_t bufferSize, size_t *neededSize); - // Dangerous?! -partition_id _kern_register_file_device(const char *filename); -status_t _kern_unregister_file_device(partition_id deviceID, +partition_id _user_register_file_device(const char *filename); +status_t _user_unregister_file_device(partition_id deviceID, const char *filename); // Only a valid deviceID or filename need to be passed. The other one // is -1/NULL. If both is given only filename is ignored. // disk systems -status_t _kern_get_disk_system_info(disk_system_id id, +status_t _user_get_disk_system_info(disk_system_id id, user_disk_system_info *info); -status_t _kern_get_next_disk_system_info(int32 *cookie, +status_t _user_get_next_disk_system_info(int32 *cookie, user_disk_system_info *info); -status_t _kern_find_disk_system(const char *name, user_disk_system_info *info); +status_t _user_find_disk_system(const char *name, user_disk_system_info *info); -bool _kern_supports_defragmenting_partition(partition_id partitionID, +bool _user_supports_defragmenting_partition(partition_id partitionID, int32 changeCounter, bool *whileMounted); -bool _kern_supports_repairing_partition(partition_id partitionID, +bool _user_supports_repairing_partition(partition_id partitionID, int32 changeCounter, bool checkOnly, bool *whileMounted); -bool _kern_supports_resizing_partition(partition_id partitionID, +bool _user_supports_resizing_partition(partition_id partitionID, int32 changeCounter, bool *canResizeContents, bool *whileMounted); -bool _kern_supports_moving_partition(partition_id partitionID, +bool _user_supports_moving_partition(partition_id partitionID, int32 changeCounter, partition_id *unmovable, partition_id *needUnmounting, size_t bufferSize); -bool _kern_supports_setting_partition_name(partition_id partitionID, +bool _user_supports_setting_partition_name(partition_id partitionID, int32 changeCounter); -bool _kern_supports_setting_partition_content_name(partition_id partitionID, +bool _user_supports_setting_partition_content_name(partition_id partitionID, int32 changeCounter, bool *whileMounted); -bool _kern_supports_setting_partition_type(partition_id partitionID, +bool _user_supports_setting_partition_type(partition_id partitionID, int32 changeCounter); -bool _kern_supports_setting_partition_parameters(partition_id partitionID, +bool _user_supports_setting_partition_parameters(partition_id partitionID, int32 changeCounter); -bool _kern_supports_setting_partition_content_parameters( +bool _user_supports_setting_partition_content_parameters( partition_id partitionID, int32 changeCounter, bool *whileMounted); -bool _kern_supports_initializing_partition(partition_id partitionID, +bool _user_supports_initializing_partition(partition_id partitionID, int32 changeCounter, const char *diskSystemName); -bool _kern_supports_creating_child_partition(partition_id partitionID, +bool _user_supports_creating_child_partition(partition_id partitionID, int32 changeCounter); -bool _kern_supports_deleting_child_partition(partition_id partitionID, +bool _user_supports_deleting_child_partition(partition_id partitionID, int32 changeCounter); -bool _kern_is_sub_disk_system_for(disk_system_id diskSystemID, +bool _user_is_sub_disk_system_for(disk_system_id diskSystemID, partition_id partitionID, int32 changeCounter); -status_t _kern_validate_resize_partition(partition_id partitionID, +status_t _user_validate_resize_partition(partition_id partitionID, int32 changeCounter, off_t *size); -status_t _kern_validate_move_partition(partition_id partitionID, +status_t _user_validate_move_partition(partition_id partitionID, int32 changeCounter, off_t *newOffset); -status_t _kern_validate_set_partition_name(partition_id partitionID, +status_t _user_validate_set_partition_name(partition_id partitionID, int32 changeCounter, char *name); -status_t _kern_validate_set_partition_content_name(partition_id partitionID, +status_t _user_validate_set_partition_content_name(partition_id partitionID, int32 changeCounter, char *name); -status_t _kern_validate_set_partition_type(partition_id partitionID, +status_t _user_validate_set_partition_type(partition_id partitionID, int32 changeCounter, const char *type); -status_t _kern_validate_initialize_partition(partition_id partitionID, +status_t _user_validate_initialize_partition(partition_id partitionID, int32 changeCounter, const char *diskSystemName, char *name, const char *parameters, size_t parametersSize); -status_t _kern_validate_create_child_partition(partition_id partitionID, +status_t _user_validate_create_child_partition(partition_id partitionID, int32 changeCounter, off_t *offset, off_t *size, const char *type, const char *parameters, size_t parametersSize); -status_t _kern_get_partitionable_spaces(partition_id partitionID, +status_t _user_get_partitionable_spaces(partition_id partitionID, int32 changeCounter, partitionable_space_data *buffer, int32 count, int32 *actualCount); -status_t _kern_get_next_supported_partition_type(partition_id partitionID, +status_t _user_get_next_supported_partition_type(partition_id partitionID, int32 changeCounter, int32 *cookie, char *type); -status_t _kern_get_partition_type_for_content_type(disk_system_id diskSystemID, +status_t _user_get_partition_type_for_content_type(disk_system_id diskSystemID, const char *contentType, char *type); // disk device modification -status_t _kern_prepare_disk_device_modifications(partition_id deviceID); -status_t _kern_commit_disk_device_modifications(partition_id deviceID, +status_t _user_prepare_disk_device_modifications(partition_id deviceID); +status_t _user_commit_disk_device_modifications(partition_id deviceID, port_id port, int32 token, bool completeProgress); -status_t _kern_cancel_disk_device_modifications(partition_id deviceID); -bool _kern_is_disk_device_modified(partition_id deviceID); +status_t _user_cancel_disk_device_modifications(partition_id deviceID); +bool _user_is_disk_device_modified(partition_id deviceID); -status_t _kern_defragment_partition(partition_id partitionID, +status_t _user_defragment_partition(partition_id partitionID, int32 changeCounter); -status_t _kern_repair_partition(partition_id partitionID, int32 changeCounter, +status_t _user_repair_partition(partition_id partitionID, int32 changeCounter, bool checkOnly); -status_t _kern_resize_partition(partition_id partitionID, int32 changeCounter, +status_t _user_resize_partition(partition_id partitionID, int32 changeCounter, off_t size); -status_t _kern_move_partition(partition_id partitionID, int32 changeCounter, +status_t _user_move_partition(partition_id partitionID, int32 changeCounter, off_t newOffset); -status_t _kern_set_partition_name(partition_id partitionID, +status_t _user_set_partition_name(partition_id partitionID, int32 changeCounter, const char *name); -status_t _kern_set_partition_content_name(partition_id partitionID, +status_t _user_set_partition_content_name(partition_id partitionID, int32 changeCounter, const char *name); -status_t _kern_set_partition_type(partition_id partitionID, +status_t _user_set_partition_type(partition_id partitionID, int32 changeCounter, const char *type); -status_t _kern_set_partition_parameters(partition_id partitionID, +status_t _user_set_partition_parameters(partition_id partitionID, int32 changeCounter, const char *parameters, size_t parametersSize); -status_t _kern_set_partition_content_parameters(partition_id partitionID, +status_t _user_set_partition_content_parameters(partition_id partitionID, int32 changeCounter, const char *parameters, size_t parametersSize); -status_t _kern_initialize_partition(partition_id partitionID, +status_t _user_initialize_partition(partition_id partitionID, int32 changeCounter, const char *diskSystemName, const char *name, const char *parameters, size_t parametersSize); -status_t _kern_uninitialize_partition(partition_id partitionID, +status_t _user_uninitialize_partition(partition_id partitionID, int32 changeCounter); -status_t _kern_create_child_partition(partition_id partitionID, +status_t _user_create_child_partition(partition_id partitionID, int32 changeCounter, off_t offset, off_t size, const char *type, const char *parameters, size_t parametersSize, partition_id *childID); -status_t _kern_delete_partition(partition_id partitionID, int32 changeCounter); +status_t _user_delete_partition(partition_id partitionID, int32 changeCounter); // jobs -status_t _kern_get_next_disk_device_job_info(int32 *cookie, +status_t _user_get_next_disk_device_job_info(int32 *cookie, user_disk_device_job_info *info); -status_t _kern_get_disk_device_job_info(disk_job_id id, +status_t _user_get_disk_device_job_info(disk_job_id id, user_disk_device_job_info *info); -status_t _kern_get_disk_device_job_progress_info(disk_job_id id, +status_t _user_get_disk_device_job_progress_info(disk_job_id id, disk_device_job_progress_info *info); -status_t _kern_pause_disk_device_job(disk_job_id id); -status_t _kern_cancel_disk_device_job(disk_job_id id, bool reverse); - -#if 0 - -// watching -status_t start_disk_device_watching(port_id, int32 token, uint32 flags); -status_t start_disk_device_job_watching(disk_job_id job, port_id, int32 token, - uint32 flags); -status_t stop_disk_device_watching(port_id, int32 token); - -#endif // 0 +status_t _user_pause_disk_device_job(disk_job_id id); +status_t _user_cancel_disk_device_job(disk_job_id id, bool reverse); #ifdef __cplusplus }