[SETUPLIB] Add some device utility functions; to be used later (#7258)

This commit is contained in:
Hermès Bélusca-Maïto 2024-07-12 18:39:39 +02:00
parent c59e2d20d9
commit 0f8dc6b2df
No known key found for this signature in database
GPG key ID: 3B2539C65E7B93D0
3 changed files with 112 additions and 0 deletions

View file

@ -11,6 +11,7 @@ list(APPEND SOURCE
spapisup/infsupp.c
utils/arcname.c
utils/bldrsup.c
utils/devutils.c
utils/filesup.c
utils/fsrec.c
utils/genlist.c

View file

@ -0,0 +1,87 @@
/*
* PROJECT: ReactOS Setup Library
* LICENSE: GPL-2.0-or-later (https://spdx.org/licenses/GPL-2.0-or-later)
* PURPOSE: Device utility functions
* COPYRIGHT: Copyright 2024 Hermès Bélusca-Maïto <hermes.belusca-maito@reactos.org>
*/
#include "precomp.h"
#include "devutils.h"
/* FUNCTIONS *****************************************************************/
/**
* @brief
* Open an existing device given by its NT-style path, which is assumed to be
* for a disk device or a partition. The open is for synchronous I/O access.
*
* @param[in] DevicePath
* Supplies the NT-style path to the device to open.
*
* @param[out] DeviceHandle
* If successful, receives the NT handle of the opened device.
* Once the handle is no longer in use, call NtClose() to close it.
*
* @param[in] DesiredAccess
* An ACCESS_MASK value combination that determines the requested access
* to the device. Because the open is for synchronous access, SYNCHRONIZE
* is automatically added to the access mask.
*
* @param[in] ShareAccess
* Specifies the type of share access for the device.
*
* @return An NTSTATUS code indicating success or failure.
**/
NTSTATUS
pOpenDeviceEx(
_In_ PCWSTR DevicePath,
_Out_ PHANDLE DeviceHandle,
_In_ ACCESS_MASK DesiredAccess,
_In_ ULONG ShareAccess)
{
UNICODE_STRING Name;
OBJECT_ATTRIBUTES ObjectAttributes;
IO_STATUS_BLOCK IoStatusBlock;
RtlInitUnicodeString(&Name, DevicePath);
InitializeObjectAttributes(&ObjectAttributes,
&Name,
OBJ_CASE_INSENSITIVE,
NULL,
NULL);
return NtOpenFile(DeviceHandle,
DesiredAccess | SYNCHRONIZE,
&ObjectAttributes,
&IoStatusBlock,
ShareAccess,
/* FILE_NON_DIRECTORY_FILE | */
FILE_SYNCHRONOUS_IO_NONALERT);
}
/**
* @brief
* Open an existing device given by its NT-style path, which is assumed to be
* for a disk device or a partition. The open is share read/write/delete, for
* synchronous I/O and read access.
*
* @param[in] DevicePath
* @param[out] DeviceHandle
* See the DevicePath and DeviceHandle parameters of pOpenDeviceEx().
*
* @return An NTSTATUS code indicating success or failure.
*
* @see pOpenDeviceEx()
**/
NTSTATUS
pOpenDevice(
_In_ PCWSTR DevicePath,
_Out_ PHANDLE DeviceHandle)
{
return pOpenDeviceEx(DevicePath,
DeviceHandle,
FILE_READ_DATA | FILE_READ_ATTRIBUTES,
FILE_SHARE_VALID_FLAGS // FILE_SHARE_READ,WRITE,DELETE
);
}
/* EOF */

View file

@ -0,0 +1,24 @@
/*
* PROJECT: ReactOS Setup Library
* LICENSE: GPL-2.0-or-later (https://spdx.org/licenses/GPL-2.0-or-later)
* PURPOSE: Device utility functions
* COPYRIGHT: Copyright 2024 Hermès Bélusca-Maïto <hermes.belusca-maito@reactos.org>
*/
#pragma once
/* FUNCTIONS *****************************************************************/
NTSTATUS
pOpenDeviceEx(
_In_ PCWSTR DevicePath,
_Out_ PHANDLE DeviceHandle,
_In_ ACCESS_MASK DesiredAccess,
_In_ ULONG ShareAccess);
NTSTATUS
pOpenDevice(
_In_ PCWSTR DevicePath,
_Out_ PHANDLE DeviceHandle);
/* EOF */