2007-08-16 Corinna Vinschen <corinna@vinschen.de>
+ * ntdll.h (RtlAcquirePebLock): Declare.
+ (RtlReleasePebLock): Declare.
+ * path.cc (cwdstuff::set): Change PEB only while it's locked.
+
+2007-08-16 Corinna Vinschen <corinna@vinschen.de>
+
* fhandler.h (fhandler_base::get_namehash): Use NT native path.
* fhandler_disk_file.cc (readdir_get_ino): Ditto in call to
hash_path_name.
NTSTATUS NTAPI RtlAppendUnicodeToString (PUNICODE_STRING, PCWSTR);
NTSTATUS NTAPI RtlAppendUnicodeStringToString (PUNICODE_STRING,
PUNICODE_STRING);
+ VOID NTAPI RtlAcquirePebLock ();
NTSTATUS NTAPI RtlAnsiStringToUnicodeString (PUNICODE_STRING, PANSI_STRING,
BOOLEAN);
LONG NTAPI RtlCompareUnicodeString (PUNICODE_STRING, PUNICODE_STRING,
BOOLEAN);
BOOLEAN NTAPI RtlPrefixUnicodeString (PUNICODE_STRING, PUNICODE_STRING,
BOOLEAN);
+ VOID NTAPI RtlReleasePebLock ();
VOID NTAPI RtlSecondsSince1970ToTime (ULONG, PLARGE_INTEGER);
NTSTATUS NTAPI RtlUnicodeStringToAnsiString (PANSI_STRING, PUNICODE_STRING,
BOOLEAN);
strcpy (as.Buffer + len, "\\");
++as.Length;
}
+ RtlAcquirePebLock ();
if (current_codepage == ansi_cp)
RtlAnsiStringToUnicodeString (
&get_user_proc_parms ()->CurrentDirectoryName,
&as, FALSE);
PHANDLE phdl = &get_user_proc_parms ()->CurrentDirectoryHandle;
if (*phdl)
- {
- HANDLE old_h = *phdl;
- *phdl = h;
- CloseHandle (old_h);
- }
+ CloseHandle (*phdl);
+ *phdl = h;
+ RtlReleasePebLock ();
}
}
/* If there is no win32 path or it has the form c:xxx, get the value */