I'm trying to pass off two addresses from a user mode program to my kernel mode driver via shared memory. I couldn't find any resources online about opening named mapped memory in kernel so I figured I could just use ZwOpenFile with the name I used in the user mode program. The issue is that the driver is logging "Could not load shmem" so I don't know how to open it correctly.
User mode code:
#define BUF_SIZE 256
TCHAR szName[] = TEXT("Global\\MyFileMappingObject");
TCHAR szMsg[] = TEXT("0x0\n0x1");
int main() {
HANDLE hMapFile;
LPCTSTR pBuf;
hMapFile = CreateFileMapping(
INVALID_HANDLE_VALUE, // use paging file
NULL, // default security
PAGE_READWRITE, // read/write access
0, // maximum object size (high-order DWORD)
BUF_SIZE, // maximum object size (low-order DWORD)
szName); // name of mapping object
if (hMapFile == NULL)
{
_tprintf(TEXT("Could not create file mapping object (%d).\n"),
GetLastError());
return 1;
}
pBuf = (LPTSTR)MapViewOfFile(hMapFile, // handle to map object
FILE_MAP_ALL_ACCESS, // read/write permission
0,
0,
BUF_SIZE);
if (pBuf == NULL)
{
_tprintf(TEXT("Could not map view of file (%d).\n"),
GetLastError());
CloseHandle(hMapFile);
return 1;
}
CopyMemory((PVOID)pBuf, szMsg, (_tcslen(szMsg) * sizeof(TCHAR)));
Pause(); // I run the kernel driver when code is here, shmem is still mapped
UnmapViewOfFile(pBuf);
CloseHandle(hMapFile);
Kernel driver code:
HANDLE shmem;
OBJECT_ATTRIBUTES attrs;
UNICODE_STRING uniName;
OBJECT_ATTRIBUTES objAttr;
IO_STATUS_BLOCK ioStatusBlock;
RtlInitUnicodeString(&uniName, L"Global\\MyFileMappingObject");
InitializeObjectAttributes(&attrs, &uniName, OBJ_CASE_INSENSITIVE, NULL, NULL);
if (!NT_SUCCESS(ZwOpenFile(&shmem, READ_CONTROL, &attrs, &ioStatusBlock, FILE_SHARE_READ, FILE_NON_DIRECTORY_FILE))) {
log("Could not load shmem");
}
else {
log("shmem loaded successfully");
ZwClose(shmem);
}
Thanks in advance
ZwOpenSectionand path must be\\BaseNamedObjects\\MyFileMappingObject- RbMmhMapFilewhen you callCreateFileMapping? i remember i had a problem withGlobalprefix in"Global\\MyFileMappingObject"(replaced byLocal) - LandstalkerKeParams params; SIZE_T ViewSize = 0; PVOID vParams = ¶ms; NTSTATUS status = ZwMapViewOfSection(shmem, ZwCurrentProcess(), &vParams, 0, 0, NULL, &ViewSize, ViewUnmap, MEM_RESERVE, PAGE_READWRITE);- Cow NationvParams = ¶msof course wrong. must bevParams = 0at second use 0 insteadMEM_RESERVEand finally i strong doubt that you gotSTATUS_INVALID_PARAMETERbut notSTATUS_INVALID_PARAMETER_3- RbMm