From 08bb11d101636693e6021530731443c9eec2ca9c Mon Sep 17 00:00:00 2001 From: Thiago Macieira Date: Tue, 23 Apr 2024 16:05:21 -0700 Subject: QResource: add support for memory mapping on Windows MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Change-Id: I6979d02a7395405cbf23fffd17c90b446cba1486 Reviewed-by: MÃ¥rten Nordheim --- src/corelib/io/qresource.cpp | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) (limited to 'src/corelib/io/qresource.cpp') diff --git a/src/corelib/io/qresource.cpp b/src/corelib/io/qresource.cpp index e40e7aeb0e0..df57d12efc8 100644 --- a/src/corelib/io/qresource.cpp +++ b/src/corelib/io/qresource.cpp @@ -37,6 +37,9 @@ # define QT_USE_MMAP # include #endif +#ifdef Q_OS_WIN +# include +#endif //#define DEBUG_RESOURCE_MATCH @@ -1147,6 +1150,9 @@ void QDynamicFileResourceRoot::unmap_sys(void *base, qsizetype size) { #if defined(QT_USE_MMAP) munmap(base, size); +#elif defined(Q_OS_WIN) + Q_UNUSED(size) + UnmapViewOfFile(reinterpret_cast(base)); #endif } @@ -1166,6 +1172,16 @@ uchar *QDynamicFileResourceRoot::map_sys(QFile &file, qint64 offset, qsizetype s ptr = QT_MMAP(nullptr, size, protection, flags, fd, offset); if (ptr == MAP_FAILED) ptr = nullptr; +#elif defined(Q_OS_WIN) + int fd = file.handle(); + HANDLE fileHandle = reinterpret_cast(_get_osfhandle(fd)); + if (fileHandle != INVALID_HANDLE_VALUE) { + HANDLE mapHandle = CreateFileMapping(fileHandle, 0, PAGE_WRITECOPY, 0, 0, 0); + if (mapHandle) { + ptr = MapViewOfFile(mapHandle, FILE_MAP_COPY, DWORD(offset >> 32), DWORD(offset), size); + CloseHandle(mapHandle); + } + } #endif // QT_USE_MMAP return static_cast(ptr); } -- cgit v1.2.3