如何将char *(char指针)转换为PCSZ?

时间:2017-08-15 10:55:33

标签: c++ c visual-studio driver kernel-mode

我有一个方法,其强制参数为char*,我希望在PCSZ之前转换为RtlInitiAnsiString(),在uName之后转换为RtlAnsiStringToUnicodeString()的结果是正确的价值。

我该怎么做?

NTSTATUS myMethod(char *myName)
{        
    ANSI_STRING aName;
    UNICODE_STRING uName;
    OBJECT_ATTRIBUTES ObjAttr;

    RtlInitAnsiString(&aName, myName);
    status = RtlAnsiStringToUnicodeString(&uName, &aName, TRUE);
    if(!NT_SUCCESS(status))
    {
       DbgPrint("RtlAnsiStringToUnicodeString Error");
       return status;
    }

    InitializeObjectAttributes(&ObjAttr, &uName, OBJ_KERNEL_HANDLE | OBJ_CASE_INSENSITIVE, NULL, NULL); 
    // some code here
    //...
    RtlFreeUnicodeString(&uName);
    return status;    
}

EDITION 01:

为了更好地理解这里是如何在我的内核驱动程序中使用MyMethod()

struct MyData
{
    ULONG Value[3];
    char *Str1;
    char *Str2;
};

NTSTATUS Function_IRP_DEVICE_CONTROL(PDEVICE_OBJECT pDeviceObject, PIRP Irp)
{
    PIO_STACK_LOCATION pIoStackLocation;
    struct MyData *pData = (struct MyData*) Irp->AssociatedIrp.SystemBuffer;
    pIoStackLocation = IoGetCurrentIrpStackLocation(Irp);
    switch (pIoStackLocation->Parameters.DeviceIoControl.IoControlCode)
    {
        case IOCTL_DATA :
            DbgPrint("IOCTL DATA");
            DbgPrint("%lu \n %lu \n %lu \n %s \n %s", pData->Value[0], pData->Value[1], pData->Value[2], pData->Str1, pData->Str2);
            ...
            break;
    }

...

//////////// Calling MyMethod() //////////////

myMethod(pData->Str1);

1 个答案:

答案 0 :(得分:5)

没有什么可以转换的。 PCSZ是对 C onstant S tring Z P ointer。所以,它只是const char *char *可隐式转换为const char *

我认为这样的typedef 可怕的,但不幸的是,Microsoft API大量使用它们。