* shared.cc (shared_info::init_obcaseinsensitive): Check actual state
of case sensitivity on post-Windows 2000 systems. * wincap.h (wincaps::kernel_is_always_casesensitive): New element. * wincap.cc: Implement above element throughout.
This commit is contained in:
parent
db05364aa9
commit
801bf9f272
|
@ -1,3 +1,11 @@
|
|||
2012-02-21 Corinna Vinschen <corinna@vinschen.de>
|
||||
|
||||
Based on an idea from Nick Lowe <nick.lowe@gmail.com>:
|
||||
* shared.cc (shared_info::init_obcaseinsensitive): Check actual state
|
||||
of case sensitivity on post-Windows 2000 systems.
|
||||
* wincap.h (wincaps::kernel_is_always_casesensitive): New element.
|
||||
* wincap.cc: Implement above element throughout.
|
||||
|
||||
2012-02-20 Corinna Vinschen <corinna@vinschen.de>
|
||||
|
||||
* flock.cc (inode_t::del_my_locks): Drop useless counter lc. Close
|
||||
|
|
|
@ -286,11 +286,14 @@ shared_destroy ()
|
|||
UnmapViewOfFile (user_shared);
|
||||
}
|
||||
|
||||
/* Initialize obcaseinsensitive. Default to case insensitive on pre-XP. */
|
||||
/* Initialize obcaseinsensitive.*/
|
||||
void
|
||||
shared_info::init_obcaseinsensitive ()
|
||||
{
|
||||
NTSTATUS status;
|
||||
if (wincap.kernel_is_always_casesensitive ())
|
||||
{
|
||||
/* Only Windows 2000. Default to case insensitive unless the user
|
||||
sets the obcaseinsensitive registry value explicitely to 0. */
|
||||
DWORD def_obcaseinsensitive = 1;
|
||||
|
||||
obcaseinsensitive = def_obcaseinsensitive;
|
||||
|
@ -300,10 +303,28 @@ shared_info::init_obcaseinsensitive ()
|
|||
&def_obcaseinsensitive, sizeof (DWORD) },
|
||||
{ NULL, 0, NULL, NULL, 0, NULL, 0 }
|
||||
};
|
||||
status = RtlQueryRegistryValues (RTL_REGISTRY_CONTROL,
|
||||
RtlQueryRegistryValues (RTL_REGISTRY_CONTROL,
|
||||
L"Session Manager\\kernel",
|
||||
tab, NULL, NULL);
|
||||
}
|
||||
else
|
||||
{
|
||||
/* Instead of reading the obcaseinsensitive registry value, test the
|
||||
actual state of case sensitivity handling in the kernel. */
|
||||
UNICODE_STRING sysroot;
|
||||
OBJECT_ATTRIBUTES attr;
|
||||
HANDLE h;
|
||||
|
||||
RtlInitUnicodeString (&sysroot, L"\\SYSTEMROOT");
|
||||
InitializeObjectAttributes (&attr, &sysroot, 0, NULL, NULL);
|
||||
/* NtOpenSymbolicLinkObject returns STATUS_ACCESS_DENIED when called
|
||||
with a 0 access mask. However, if the kernel is case sensitive,
|
||||
it returns STATUS_OBJECT_NAME_NOT_FOUND because we used the incorrect
|
||||
case for the filename (It's actually "\\SystemRoot"). */
|
||||
obcaseinsensitive = NtOpenSymbolicLinkObject (&h, 0, &attr)
|
||||
!= STATUS_OBJECT_NAME_NOT_FOUND;
|
||||
}
|
||||
}
|
||||
|
||||
void inline
|
||||
shared_info::create ()
|
||||
|
|
|
@ -54,6 +54,7 @@ wincaps wincap_2000 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
|||
has_console_logon_sid:false,
|
||||
wow64_has_secondary_stack:false,
|
||||
has_program_compatibility_assitant:false,
|
||||
kernel_is_always_casesensitive:true,
|
||||
};
|
||||
|
||||
wincaps wincap_2000sp4 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
||||
|
@ -87,6 +88,7 @@ wincaps wincap_2000sp4 __attribute__((section (".cygwin_dll_common"), shared)) =
|
|||
has_console_logon_sid:false,
|
||||
wow64_has_secondary_stack:false,
|
||||
has_program_compatibility_assitant:false,
|
||||
kernel_is_always_casesensitive:true,
|
||||
};
|
||||
|
||||
wincaps wincap_xp __attribute__((section (".cygwin_dll_common"), shared)) = {
|
||||
|
@ -120,6 +122,7 @@ wincaps wincap_xp __attribute__((section (".cygwin_dll_common"), shared)) = {
|
|||
has_console_logon_sid:false,
|
||||
wow64_has_secondary_stack:false,
|
||||
has_program_compatibility_assitant:false,
|
||||
kernel_is_always_casesensitive:false,
|
||||
};
|
||||
|
||||
wincaps wincap_xpsp1 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
||||
|
@ -153,6 +156,7 @@ wincaps wincap_xpsp1 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
|||
has_console_logon_sid:false,
|
||||
wow64_has_secondary_stack:false,
|
||||
has_program_compatibility_assitant:false,
|
||||
kernel_is_always_casesensitive:false,
|
||||
};
|
||||
|
||||
wincaps wincap_xpsp2 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
||||
|
@ -186,6 +190,7 @@ wincaps wincap_xpsp2 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
|||
has_console_logon_sid:false,
|
||||
wow64_has_secondary_stack:false,
|
||||
has_program_compatibility_assitant:false,
|
||||
kernel_is_always_casesensitive:false,
|
||||
};
|
||||
|
||||
wincaps wincap_2003 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
||||
|
@ -219,6 +224,7 @@ wincaps wincap_2003 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
|||
has_console_logon_sid:false,
|
||||
wow64_has_secondary_stack:true,
|
||||
has_program_compatibility_assitant:false,
|
||||
kernel_is_always_casesensitive:false,
|
||||
};
|
||||
|
||||
wincaps wincap_vista __attribute__((section (".cygwin_dll_common"), shared)) = {
|
||||
|
@ -252,6 +258,7 @@ wincaps wincap_vista __attribute__((section (".cygwin_dll_common"), shared)) = {
|
|||
has_console_logon_sid:false,
|
||||
wow64_has_secondary_stack:false,
|
||||
has_program_compatibility_assitant:true,
|
||||
kernel_is_always_casesensitive:false,
|
||||
};
|
||||
|
||||
wincaps wincap_7 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
||||
|
@ -285,6 +292,7 @@ wincaps wincap_7 __attribute__((section (".cygwin_dll_common"), shared)) = {
|
|||
has_console_logon_sid:true,
|
||||
wow64_has_secondary_stack:false,
|
||||
has_program_compatibility_assitant:true,
|
||||
kernel_is_always_casesensitive:false,
|
||||
};
|
||||
|
||||
wincapc wincap __attribute__((section (".cygwin_dll_common"), shared));
|
||||
|
|
|
@ -44,6 +44,7 @@ struct wincaps
|
|||
unsigned has_console_logon_sid : 1;
|
||||
unsigned wow64_has_secondary_stack : 1;
|
||||
unsigned has_program_compatibility_assitant : 1;
|
||||
unsigned kernel_is_always_casesensitive : 1;
|
||||
};
|
||||
|
||||
class wincapc
|
||||
|
@ -96,6 +97,7 @@ public:
|
|||
bool IMPLEMENT (has_console_logon_sid)
|
||||
bool IMPLEMENT (wow64_has_secondary_stack)
|
||||
bool IMPLEMENT (has_program_compatibility_assitant)
|
||||
bool IMPLEMENT (kernel_is_always_casesensitive)
|
||||
|
||||
#undef IMPLEMENT
|
||||
};
|
||||
|
|
Loading…
Reference in New Issue