RtlUnicodeStringPrintf格式化UNICODE_STRING字符串在win7 64位出现蓝屏,在XP上正常的情况

    以下是一段存在隐含错误的代码:

        UNICODE_STRING devlinkname; 

                //初始化链接名
RtlInitUnicodeString(&devlinkname,L"\\DosDevices\\COM00");

//格式成新的符号链接名
status = RtlUnicodeStringPrintf(&devlinkname,L"\\DosDevices\\COM%d",i);
if(!NT_SUCCESS(status)) 
{
DbgPrint("RtlUnicodeStringPrintf failed");
DbgPrint("status = 0x%x",status);
return status;

}

    上面绑定符号链接名功能的代码段,我在进行测试时,XP上没有出现蓝屏,但是在win7 64位上出现蓝屏,蓝屏错误为(0x000000BE)。

    经过查阅资料发现,因为使用了RtlInitUnicodeString函数初始化字符串变量后,初始化时进行的是浅复制,devlinkname的Buffer成指向常量区,导致使用RtlUnicodeStringPrintf格式化此变量时试图改变常量值,因而导致蓝屏。RtlInitUnicodeString初始化UnicodeString字符串时做了3件事:

                                                1.将Buffer指针指向静态常量区的值。

        2.修改Length为wcslen(L"\\DosDevices\\COM00”)*sizeof(WCHAR)。

                                    3.修改MaximumLength为(wcslen(L"\\DosDevices\\COM00”)+1)*sizeof(WCHAR)。

    修改后的正确代码:

                //声明变量并设置存储字符串长度

                DECLARE_UNICODE_STRING_SIZE(devlinkname, UNICODE_STRING_LENGTH); 

                //格式成新的符号链接名
status = RtlUnicodeStringPrintf(&devlinkname,L"\\DosDevices\\COM%d",i);
if(!NT_SUCCESS(status)) 
{
DbgPrint("RtlUnicodeStringPrintf failed");
DbgPrint("status = 0x%x",status);
return status;

}


  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值