kernel32: Handle the SECURITY_* flags passed into CreateFileW by filling out the SECURITY_QUALITY_OF_SERVICE structure and passing it to NtCreateFile.

Robert Shearman rob at codeweavers.com
Fri Jan 19 07:00:29 CST 2007


Print a fixme in NtCreateFile if the SECURITY_QUALITY_OF_SERVICE 
structure is specified, since it isn't handled yet.
---
  dlls/kernel32/file.c |   12 +++++++++++-
  dlls/ntdll/file.c    |    4 ++++
  2 files changed, 15 insertions(+), 1 deletions(-)
-------------- next part --------------
diff --git a/dlls/kernel32/file.c b/dlls/kernel32/file.c
index 5a0c5cb..f92d37a 100644
--- a/dlls/kernel32/file.c
+++ b/dlls/kernel32/file.c
@@ -1281,6 +1281,7 @@ HANDLE WINAPI CreateFileW( LPCWSTR filen
     static const WCHAR bkslashes_with_dotW[] = {'\\','\\','.','\\',0};
     static const WCHAR coninW[] = {'C','O','N','I','N','$',0};
     static const WCHAR conoutW[] = {'C','O','N','O','U','T','$',0};
+    SECURITY_QUALITY_OF_SERVICE qos;
 
     static const UINT nt_disposition[5] =
     {
@@ -1406,7 +1407,16 @@ HANDLE WINAPI CreateFileW( LPCWSTR filen
     attr.Attributes = OBJ_CASE_INSENSITIVE;
     attr.ObjectName = &nameW;
     attr.SecurityDescriptor = sa ? sa->lpSecurityDescriptor : NULL;
-    attr.SecurityQualityOfService = NULL;
+    if (attributes & SECURITY_SQOS_PRESENT)
+    {
+        qos.Length = sizeof(qos);
+        qos.ImpersonationLevel = (attributes >> 16) & 0x3;
+        qos.ContextTrackingMode = attributes & SECURITY_CONTEXT_TRACKING ? SECURITY_DYNAMIC_TRACKING : SECURITY_STATIC_TRACKING;
+        qos.EffectiveOnly = attributes & SECURITY_EFFECTIVE_ONLY ? TRUE : FALSE;
+        attr.SecurityQualityOfService = &qos;
+    }
+    else
+        attr.SecurityQualityOfService = NULL;
 
     if (sa && sa->bInheritHandle) attr.Attributes |= OBJ_INHERIT;
 
diff --git a/dlls/ntdll/file.c b/dlls/ntdll/file.c
index a79d227..a9b9142 100644
--- a/dlls/ntdll/file.c
+++ b/dlls/ntdll/file.c
@@ -162,6 +162,8 @@ NTSTATUS WINAPI NtCreateFile( PHANDLE ha
     if (attr->ObjectName->Length > sizeof(pipeW) &&
         !memicmpW( attr->ObjectName->Buffer, pipeW, sizeof(pipeW)/sizeof(WCHAR) ))
     {
+        if (attr->SecurityQualityOfService)
+            FIXME("SecurityQualityOfService ignored\n");
         SERVER_START_REQ( open_named_pipe )
         {
             req->access = access;
@@ -182,6 +184,8 @@ NTSTATUS WINAPI NtCreateFile( PHANDLE ha
     if (attr->ObjectName->Length > sizeof(mailslotW) &&
         !memicmpW( attr->ObjectName->Buffer, mailslotW, sizeof(mailslotW)/sizeof(WCHAR) ))
     {
+        if (attr->SecurityQualityOfService)
+            FIXME("SecurityQualityOfService ignored\n");
         SERVER_START_REQ( open_mailslot )
         {
             req->access = access & GENERIC_WRITE;


More information about the wine-patches mailing list