X-Git-Url: https://wimlib.net/git/?p=wimlib;a=blobdiff_plain;f=include%2Fwimlib%2Fwin32_common.h;h=e669d5225a836b1f406b968b4a089e011ad0bd38;hp=691af744c9fc00eb04d4c34957fca98485760177;hb=686c407415c8e6ec022bd64678db65004631b194;hpb=aae154ad67444bc760bedff60bc60fd5b91b8ede diff --git a/include/wimlib/win32_common.h b/include/wimlib/win32_common.h index 691af744..e669d522 100644 --- a/include/wimlib/win32_common.h +++ b/include/wimlib/win32_common.h @@ -1,26 +1,21 @@ +/* + * win32_common.h - common header for Windows-specific files. This always + * should be included first. + */ + #ifndef _WIMLIB_WIN32_COMMON_H #define _WIMLIB_WIN32_COMMON_H +#include #include +#include + #ifdef ERROR # undef ERROR #endif - #include "wimlib/types.h" #include "wimlib/win32.h" -#include -#include - -extern void -set_errno_from_GetLastError(void); - -extern void -set_errno_from_win32_error(DWORD err); - -extern void -set_errno_from_nt_status(NTSTATUS status); - /* ntdll functions */ extern NTSTATUS (WINAPI *func_NtCreateFile)(PHANDLE FileHandle, @@ -35,6 +30,10 @@ extern NTSTATUS (WINAPI *func_NtCreateFile)(PHANDLE FileHandle, PVOID EaBuffer, ULONG EaLength); +#ifndef FILE_OPENED +# define FILE_OPENED 0x00000001 +#endif + extern NTSTATUS (WINAPI *func_NtOpenFile) (PHANDLE FileHandle, ACCESS_MASK DesiredAccess, POBJECT_ATTRIBUTES ObjectAttributes, @@ -102,17 +101,6 @@ extern NTSTATUS (WINAPI *func_NtSetSecurityObject)(HANDLE Handle, SECURITY_INFORMATION SecurityInformation, PSECURITY_DESCRIPTOR SecurityDescriptor); -extern NTSTATUS (WINAPI *func_NtFsControlFile) (HANDLE FileHandle, - HANDLE Event, - PIO_APC_ROUTINE ApcRoutine, - PVOID ApcContext, - PIO_STATUS_BLOCK IoStatusBlock, - ULONG FsControlCode, - PVOID InputBuffer, - ULONG InputBufferLength, - PVOID OutputBuffer, - ULONG OutputBufferLength); - extern NTSTATUS (WINAPI *func_NtClose) (HANDLE Handle); extern DWORD (WINAPI *func_RtlNtStatusToDosError)(NTSTATUS status); @@ -143,20 +131,40 @@ extern NTSTATUS (WINAPI *func_RtlDosPathNameToNtPathName_U_WithStatus) extern NTSTATUS (WINAPI *func_RtlCreateSystemVolumeInformationFolder) (PCUNICODE_STRING VolumeRootPath); +#define FSCTL_SET_PERSISTENT_VOLUME_STATE 0x90238 + +#define PERSISTENT_VOLUME_STATE_SHORT_NAME_CREATION_DISABLED 0x00000001 + +typedef struct _FILE_FS_PERSISTENT_VOLUME_INFORMATION { + ULONG VolumeFlags; + ULONG FlagMask; + ULONG Version; + ULONG Reserved; +} FILE_FS_PERSISTENT_VOLUME_INFORMATION, *PFILE_FS_PERSISTENT_VOLUME_INFORMATION; + +extern int +win32_path_to_nt_path(const wchar_t *win32_path, UNICODE_STRING *nt_path); + +extern int +win32_get_drive_path(const wchar_t *file_path, wchar_t drive_path[7]); extern bool -windows_version_is_at_least(unsigned major, unsigned minor); +win32_try_to_attach_wof(const wchar_t *drive); -#define running_on_windows_xp_or_later() \ - windows_version_is_at_least(5, 1) +extern void +win32_warning(DWORD err, const wchar_t *format, ...) _cold_attribute; -#define running_on_windows_vista_or_later() \ - windows_version_is_at_least(6, 0) +extern void +win32_error(DWORD err, const wchar_t *format, ...) _cold_attribute; -#define running_on_windows_7_or_later() \ - windows_version_is_at_least(6, 1) +extern void +winnt_warning(NTSTATUS status, const wchar_t *format, ...) _cold_attribute; -extern int -win32_path_to_nt_path(const wchar_t *win32_path, UNICODE_STRING *nt_path); +extern void +winnt_error(NTSTATUS status, const wchar_t *format, ...) _cold_attribute; + +extern NTSTATUS +winnt_fsctl(HANDLE h, u32 code, const void *in, u32 in_size, + void *out, u32 out_size_avail, u32 *actual_out_size_ret); #endif /* _WIMLIB_WIN32_COMMON_H */