无法将结构的Marshal指针转换回struct

时间:2017-08-20 14:12:16

标签: c# c++ pointers windows-services marshalling

我编写了一个与我的驱动程序通信的Windows服务,因此我尝试将结构传递给它并获得返回的结构。

在C ++中,这是在C#中工作的,我无法使用Marshal将IntPtr转换为Struct,这就是为什么我无法从驱动程序返回结构。

STRUCT:

[StructLayout(LayoutKind.Sequential)]
struct TestEst
{
    public int value;
}

然后在我的司机中:

typedef struct _TEST_EST
{
    int value;
} TEST_EST, *PTEST_EST;

通过IOCTL传递结构的代码是:

void SendIOCTL<T>(IntPtr hDevice, uint dwIoControlCode, ref T inObj, ref T outObj)
    {
        IntPtr inPointer = IntPtr.Zero;
        IntPtr outPointer = IntPtr.Zero;
        int inObjSize = 0;
        int outObjSize = 0;
        uint bytesReturned = 0;

        if(inObj != null)
        {
            inObjSize = Marshal.SizeOf(inObj.GetType());
            inPointer = Marshal.AllocHGlobal(inObjSize);
            Marshal.StructureToPtr(inObj, inPointer, false);

            if (dwIoControlCode == TEST_CTL) // the TEST IOCTL
            {
                TestEst lets = new TestEst();

                Logger.Log("IsNull: " + (inPointer == IntPtr.Zero));
                Logger.Log("SizeObj: " + inObjSize);

                Marshal.PtrToStructure(inPointer, lets);
                Logger.Log("Working!: " + lets.value);
            }
        }
    }



public void SendTest()
    {
        TestEst request = new TestEst();
        TestEst result = new TestEst();

        request.value = 30;

        SendIOCTL(hDriver, TEST_CTL, ref request, ref result);

        Logger.Log("RA: " + result.value + " " + request.value);
    }

Logger.Log()只是将一个条目写入windows事件查看器。

我省略了实际的DeviceIoControl,因为它不是失败的地方,正在发生的事情是在

Marshal.PtrToStructure(inPointer, lets);

导致我的服务在日志中显示:

Windows Event Viewer

并且inPointer不为null且inObjSize为4

我也试过从SendIOCTL中删除T,A并只放置T但它是一样的。

提前致谢

1 个答案:

答案 0 :(得分:1)

编组指向结构的指针使用这种方法

var test = (T) Marshal.PtrToStructure(inPointer, typeof(T));

当你完成我们分配的内存块时,不要忘记使用Marshal.FreeHGlobal(inPointer)