为什么我的驱动程序只读取字符串的一部分?

Why is my driver only reading part of the string?

我正在尝试使用内核驱动程序从虚拟程序中读取字符串。但是只有前 4 个字符被读取,我不明白为什么。

读取字符串的部分IOCTL代码:

else if (ControlCode = IO_READ_STRING_REQUEST)
{
    PREAD_REQUEST Values = (PREAD_REQUEST)buffer;
    PREAD_REQUEST ValuesOutput = (PREAD_REQUEST)buffer;
    PEPROCESS process;

    if (NT_SUCCESS(PsLookupProcessByProcessId(PID, &process)))
    {
        KeReadProcessMemory(process, Values->Address, &ValuesOutput->buffer, Values->Size);
        DbgPrint((PCSTR)Values->buffer);
        status = STATUS_SUCCESS;
    }
    else
        status = STATUS_INVALID_PARAMETER;

    BytesIO = sizeof(READ_REQUEST);
}

这是读取的结构:

typedef struct ReadStruct
{
    ULONGLONG Address;
    ULONGLONG Response;
    ULONGLONG Size;
    char buffer[128];

} READ_REQUEST, *PREAD_REQUEST;

DbgPrint 总是在应该打印 stringChar 时打印 stri,并将 stri 返回到用户模式。

这是从用户模式调用它的方式:

void ReadString(std::string *string, DWORD64 address)
{
    ReadValues Values;
    std::memset(Values.buffer, '[=12=]', 128);
    Values.Address = address;
    Values.Response = 0;    
    Values.Size = sizeof(128);

    if (!(DeviceIoControl(hDriver, IO_READ_STRING_REQUEST, &Values, sizeof(Values), &Values, sizeof(Values), 0, 0)))
    {
        std::cout << "RPM Failed!\n";
        exit(1);
    }

    *string = (std::string)Values.buffer;
}

结构相同:

struct ReadValues
{
    ULONGLONG Address;
    ULONGLONG Response;
    ULONGLONG Size;
    char buffer[128];
};

我以为是大小,但当我将大小指定为 11 (10 + \0) 时,它也只读取了 4 个字符。

问题出在这里:

Values.Size = sizeof(128);
              ^^^^^^^^^^^

这与 sizeof(int) 相同(我猜,在您的平台中是 4)。

使用 128sizeof(buffer)(后者可以说更好,因为您不会在多个地方硬编码相同的常量)。