Jan Kratochvil short@ucw.cz writes:
"is to use ROUND_SIZE and ROUND_ADDR together." && "We don't bother to round addresses" seems as a conflict for me - if you "don't bother" why do you use/have ROUND_ADDR at all?
Because there are other places where we need to round addresses. map_image() doesn't need to bother with that, but other functions do.
From code (virtual/memory.c):
DWORD base = imports->VirtualAddress & ~page_mask; DWORD end = imports->VirtualAddress + ROUND_SIZE( imports->VirtualAddress, imports->Size ); Either: There is useless "& ~page_mask" Or: There is bug during ROUND_SIZE() call as ROUND() size is used with unaligned address if "& ~page_mask" is needed.
As the current solution works for aligned executables it can be assumed that "& ~page_mask" is useless there.
Actually in that case the address is not necessarily aligned, so yes, that usage of ROUND_SIZE is slightly wrong. Thanks for spotting it.
"exotic"? Windows kernel is full of it. :-)
But loading Windows kernel binaries in Wine is exotic. There are some very specialized cases where we could actually make use of a kernel driver in user space, but there is no way Wine will provide full NT kernel support, and it's not an option to slow down the normal mmap support for that.
Why to not mmap it when it is possible? Missing protection may complicate the debugging which follows. If such unaligned mapping would be implemented there would be no longer use for the current unaligned_mmap() as it would be just a subset of the new function (that my unaligned_mmap_cached()): naming confusion: (old) unaligned_mmap() in fact requires page-aligned addr (new) unaligned_mmap_cached() doesn't require page-aligned addr
Well, you could make map_image_unaligned() use mmap if possible, and set page protections too. The important thing is that all of it is kept out of the common case. 99% of the mmap calls are aligned, and we don't want to do the work of maintaining the cache for the 1% case that can easily be done separately.
The summarizing question is whether Wine itself wants to go also to the kernel space emulation land. I found that ReactOS suits my needs better (kernel reimplementation, also it is fortunately GPL) and thus I no longer personally need my patch to Wine unaligned_mmap() although I can tune/finish it if wised.
Wine is going to remain a user-mode application. We may want to have some basic support for loading a small subset of kernel-mode drivers that can work in user mode, but a general Windows kernel emulation has to be done in the kernel, and this is a separate project.