I have a driver which can be installed on Windows (XP/Vista/7). It’s accessed via a native C++ DLL that 3rd-party applications link to, and which is also a Winsock Provider (WSP). It used to be installed under System32, but having seen advice not to, I changed it to install under ProgramFiles instead.
Now, the problem is that people are having to either copy it back into System32 or copy it into the application directory whenever they want to use it in their own applications, because Windows won’t search the install directory under ProgramFiles when the application tries to load the DLL.
I’ve been unable to find any Microsoft documentation discussing this issue, so if System32 shouldn’t be used then where should shared DLLs be installed?
Since it’s a DLL linked to your driver maybe it’s less of an issue, but I’d be wary of trying to share the DLL and would instead try to get all developers of client apps to keep their own version of the dll in their applications folders.
I’ve had too much fun in DLL Hell to want any more weird bugs because AppX overwrote the DLL with an old version that breaks AppY etc.