Revert previous patch.

* autoload.cc (GetVolumePathNamesForVolumeNameA): Remove.
	* autoload.cc (GetVolumeNameForVolumeMountPointA): Add.
	* syscalls.cc (sync): Rewrite guid case to skip floppies also on
	Windows 2000.
This commit is contained in:
Corinna Vinschen 2005-04-11 21:54:54 +00:00
parent 48d304ef5a
commit 98e103aac9
5 changed files with 37 additions and 29 deletions

View File

@ -1,3 +1,11 @@
2005-04-11 Corinna Vinschen <corinna@vinschen.de>
Revert previous patch.
* autoload.cc (GetVolumePathNamesForVolumeNameA): Remove.
* autoload.cc (GetVolumeNameForVolumeMountPointA): Add.
* syscalls.cc (sync): Rewrite guid case to skip floppies also on
Windows 2000.
2005-04-11 Corinna Vinschen <corinna@vinschen.de> 2005-04-11 Corinna Vinschen <corinna@vinschen.de>
* syscalls.cc (sync): Use renamed has_get_volume_pathnames wincap. * syscalls.cc (sync): Use renamed has_get_volume_pathnames wincap.

View File

@ -517,7 +517,7 @@ LoadDLLfuncEx (GetConsoleWindow, 0, kernel32, 1)
LoadDLLfuncEx (GetDiskFreeSpaceEx, 16, kernel32, 1) LoadDLLfuncEx (GetDiskFreeSpaceEx, 16, kernel32, 1)
LoadDLLfuncEx (GetNativeSystemInfo, 4, kernel32, 1) LoadDLLfuncEx (GetNativeSystemInfo, 4, kernel32, 1)
LoadDLLfuncEx (GetSystemTimes, 12, kernel32, 1) LoadDLLfuncEx (GetSystemTimes, 12, kernel32, 1)
LoadDLLfuncEx (GetVolumePathNamesForVolumeNameA, 16, kernel32, 1) LoadDLLfuncEx (GetVolumeNameForVolumeMountPointA, 12, kernel32, 1)
LoadDLLfuncEx2 (IsDebuggerPresent, 0, kernel32, 1, 1) LoadDLLfuncEx2 (IsDebuggerPresent, 0, kernel32, 1, 1)
LoadDLLfunc (IsProcessorFeaturePresent, 4, kernel32); LoadDLLfunc (IsProcessorFeaturePresent, 4, kernel32);
LoadDLLfuncEx (IsWow64Process, 8, kernel32, 1); LoadDLLfuncEx (IsWow64Process, 8, kernel32, 1);

View File

@ -939,27 +939,27 @@ sync ()
{ {
char vol[CYG_MAX_PATH]; char vol[CYG_MAX_PATH];
if (wincap.has_get_volume_pathnames ()) /* Win2k and newer */ if (wincap.has_guid_volumes ()) /* Win2k and newer */
{ {
char a_drive[CYG_MAX_PATH] = {0};
char b_drive[CYG_MAX_PATH] = {0};
if (is_floppy ("A:"))
GetVolumeNameForVolumeMountPointA ("A:\\", a_drive, CYG_MAX_PATH);
if (is_floppy ("B:"))
GetVolumeNameForVolumeMountPointA ("B:\\", a_drive, CYG_MAX_PATH);
HANDLE sh = FindFirstVolumeA (vol, CYG_MAX_PATH); HANDLE sh = FindFirstVolumeA (vol, CYG_MAX_PATH);
if (sh != INVALID_HANDLE_VALUE) if (sh != INVALID_HANDLE_VALUE)
{ {
do do
{ {
char pvol[CYG_MAX_PATH];
DWORD len;
if (GetVolumePathNamesForVolumeNameA (vol, pvol, CYG_MAX_PATH,
&len))
debug_printf ("Try volume %s (GUID: %s)", pvol, vol);
else
debug_printf ("Try volume %s", vol); debug_printf ("Try volume %s", vol);
/* Check pvol for being a floppy on A: or B:. Skip them. */ /* Check vol for being a floppy on A: or B:. Skip them. */
if (strncasematch (pvol, "A:", 2) if (strcasematch (vol, a_drive) || strcasematch (vol, b_drive))
|| strncasematch (pvol, "B:", 2))
{ {
pvol[2] = '\0'; debug_printf ("Is floppy, don't sync");
if (is_floppy (pvol))
continue; continue;
} }

View File

@ -57,7 +57,7 @@ static NO_COPY wincaps wincap_unknown = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:true, start_proc_suspended:true,
has_extended_priority_class:false, has_extended_priority_class:false,
has_get_volume_pathnames:false has_guid_volumes:false
}; };
static NO_COPY wincaps wincap_95 = { static NO_COPY wincaps wincap_95 = {
@ -106,7 +106,7 @@ static NO_COPY wincaps wincap_95 = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:true, start_proc_suspended:true,
has_extended_priority_class:false, has_extended_priority_class:false,
has_get_volume_pathnames:false has_guid_volumes:false
}; };
static NO_COPY wincaps wincap_95osr2 = { static NO_COPY wincaps wincap_95osr2 = {
@ -155,7 +155,7 @@ static NO_COPY wincaps wincap_95osr2 = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:true, start_proc_suspended:true,
has_extended_priority_class:false, has_extended_priority_class:false,
has_get_volume_pathnames:false has_guid_volumes:false
}; };
static NO_COPY wincaps wincap_98 = { static NO_COPY wincaps wincap_98 = {
@ -204,7 +204,7 @@ static NO_COPY wincaps wincap_98 = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:true, start_proc_suspended:true,
has_extended_priority_class:false, has_extended_priority_class:false,
has_get_volume_pathnames:false has_guid_volumes:false
}; };
static NO_COPY wincaps wincap_98se = { static NO_COPY wincaps wincap_98se = {
@ -253,7 +253,7 @@ static NO_COPY wincaps wincap_98se = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:true, start_proc_suspended:true,
has_extended_priority_class:false, has_extended_priority_class:false,
has_get_volume_pathnames:false has_guid_volumes:false
}; };
static NO_COPY wincaps wincap_me = { static NO_COPY wincaps wincap_me = {
@ -302,7 +302,7 @@ static NO_COPY wincaps wincap_me = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:true, start_proc_suspended:true,
has_extended_priority_class:false, has_extended_priority_class:false,
has_get_volume_pathnames:false has_guid_volumes:false
}; };
static NO_COPY wincaps wincap_nt3 = { static NO_COPY wincaps wincap_nt3 = {
@ -351,7 +351,7 @@ static NO_COPY wincaps wincap_nt3 = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:false, start_proc_suspended:false,
has_extended_priority_class:false, has_extended_priority_class:false,
has_get_volume_pathnames:false has_guid_volumes:false
}; };
static NO_COPY wincaps wincap_nt4 = { static NO_COPY wincaps wincap_nt4 = {
@ -400,7 +400,7 @@ static NO_COPY wincaps wincap_nt4 = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:false, start_proc_suspended:false,
has_extended_priority_class:false, has_extended_priority_class:false,
has_get_volume_pathnames:false has_guid_volumes:false
}; };
static NO_COPY wincaps wincap_nt4sp4 = { static NO_COPY wincaps wincap_nt4sp4 = {
@ -449,7 +449,7 @@ static NO_COPY wincaps wincap_nt4sp4 = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:false, start_proc_suspended:false,
has_extended_priority_class:false, has_extended_priority_class:false,
has_get_volume_pathnames:false has_guid_volumes:false
}; };
static NO_COPY wincaps wincap_2000 = { static NO_COPY wincaps wincap_2000 = {
@ -498,7 +498,7 @@ static NO_COPY wincaps wincap_2000 = {
has_ioctl_storage_get_media_types_ex:false, has_ioctl_storage_get_media_types_ex:false,
start_proc_suspended:false, start_proc_suspended:false,
has_extended_priority_class:true, has_extended_priority_class:true,
has_get_volume_pathnames:false has_guid_volumes:true
}; };
static NO_COPY wincaps wincap_xp = { static NO_COPY wincaps wincap_xp = {
@ -547,7 +547,7 @@ static NO_COPY wincaps wincap_xp = {
has_ioctl_storage_get_media_types_ex:true, has_ioctl_storage_get_media_types_ex:true,
start_proc_suspended:false, start_proc_suspended:false,
has_extended_priority_class:true, has_extended_priority_class:true,
has_get_volume_pathnames:true has_guid_volumes:true
}; };
static NO_COPY wincaps wincap_2003 = { static NO_COPY wincaps wincap_2003 = {
@ -596,7 +596,7 @@ static NO_COPY wincaps wincap_2003 = {
has_ioctl_storage_get_media_types_ex:true, has_ioctl_storage_get_media_types_ex:true,
start_proc_suspended:false, start_proc_suspended:false,
has_extended_priority_class:true, has_extended_priority_class:true,
has_get_volume_pathnames:true has_guid_volumes:true
}; };
wincapc wincap; wincapc wincap;

View File

@ -58,7 +58,7 @@ struct wincaps
unsigned has_ioctl_storage_get_media_types_ex : 1; unsigned has_ioctl_storage_get_media_types_ex : 1;
unsigned start_proc_suspended : 1; unsigned start_proc_suspended : 1;
unsigned has_extended_priority_class : 1; unsigned has_extended_priority_class : 1;
unsigned has_get_volume_pathnames : 1; unsigned has_guid_volumes : 1;
}; };
class wincapc class wincapc
@ -121,7 +121,7 @@ public:
bool IMPLEMENT (has_ioctl_storage_get_media_types_ex) bool IMPLEMENT (has_ioctl_storage_get_media_types_ex)
bool IMPLEMENT (start_proc_suspended) bool IMPLEMENT (start_proc_suspended)
bool IMPLEMENT (has_extended_priority_class) bool IMPLEMENT (has_extended_priority_class)
bool IMPLEMENT (has_get_volume_pathnames) bool IMPLEMENT (has_guid_volumes)
#undef IMPLEMENT #undef IMPLEMENT
}; };