Открытие именованной разделяемой памяти в ядре windows - PullRequest
0 голосов
/ 28 марта 2020

Я пытаюсь передать два адреса из программы пользовательского режима моему драйверу режима ядра через общую память. Я не смог найти в Интернете никаких ресурсов об открытии именованной отображенной памяти в ядре, поэтому решил, что могу просто использовать ZwOpenFile с именем, которое я использовал в программе пользовательского режима. Проблема заключается в том, что драйвер регистрирует «Не удалось загрузить shmem», поэтому я не знаю, как его правильно открыть.

Код режима пользователя:

#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);

Код драйвера ядра:

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);
}

Заранее спасибо

1 Ответ

0 голосов
/ 28 марта 2020

Решено, используйте ZwOpenSection и путь начинается с \\ BaseNamedObjects \\

HANDLE shmem;
OBJECT_ATTRIBUTES attrs;
UNICODE_STRING     uniName;

RtlInitUnicodeString(&uniName, L"\\BaseNamedObjects\\MyFileMappingObject");
InitializeObjectAttributes(&attrs, &uniName, OBJ_CASE_INSENSITIVE, NULL, NULL);
if (!NT_SUCCESS(ZwOpenSection(&shmem, FILE_SHARE_READ, &attrs))) {
    log("Could not load shmem");
}
else {
    log("shmem loaded successfully");
    ZwClose(shmem);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...