July 27th, 2017

How am I supposed to free the memory the system allocates in the SetPrivateObjectSecurity function?

A customer noted that the Set­Private­Object­Security function updates a pointer provided by the Objects­Security­Descriptor parameter. Since it may allocate a new security descriptor, that means that it needs to deallocate the old one. But what function does it use to free the old one? After all, the allocation function must match the deallocation function. Similarly, how should the new security descriptor be freed? (I say “similarly” because the two answers had better be the same!)

The system allocates and frees the security descriptor from the proess heap, as reported by the Get­Process­Heap function. The allocation function is Heap­Alloc and the deallocation function is Heap­Free. That means that the security descriptor you pass in must have been allocated with

    SecurityDescriptor = HeapAlloc(GetProcessHeap(), flags, size);

and then you pass the pointer like this:

    SetPrivateObjectSecurity(..., &SecurityDescriptor, ...);
    // or
    SetPrivateObjectSecurityEx(..., &SecurityDescriptor, ...);

and after the Set­Private­Object­Security function is done, you must free the memory with

    HeapFree(GetProcessHeap(), SecurityDescriptor);

I wrote this post the same day that I submitted the change request to add this essential information to the documentation. We’ll see who wins.

Topics
Code

Author

Raymond has been involved in the evolution of Windows for more than 30 years. In 2003, he began a Web site known as The Old New Thing which has grown in popularity far beyond his wildest imagination, a development which still gives him the heebie-jeebies. The Web site spawned a book, coincidentally also titled The Old New Thing (Addison Wesley 2007). He occasionally appears on the Windows Dev Docs Twitter account to tell stories which convey no useful information.

0 comments

Discussion are closed.

Feedback