Vista中的Microsoft Async RPC崩溃

时间:2008-10-14 21:38:36

标签: windows crash operating-system rpc windows-vista

我正在开发一个程序,它在客户端和服务器在同一台机器上运行时进行RPC调用。我希望客户端对服务器的调用超时,因为我们遇到了在服务器上等待无响应的问题。

为了解决这个问题,我们使用了异步RPC调用,并在超时时将其取消。

这在XP中运行良好,但现在我发现在Vista中崩溃,我有一个测试程序,每次都可以重现这些崩溃(仅在Vista中,而不是在XP中)。这似乎是微软方面的一个漏洞。来自崩溃线程的调用堆栈不包括对我们代码的任何调用。以下是崩溃转储中的信息:

Call stack:
rpcrt4!_SEH_epilog4_GS+0x3979
rpcrt4!LRPC_CCALL::AbortCall+0x68
rpcrt4!LRPC_BASE_CCALL::HandleCancelMessage+0x6b
rpcrt4!LRPC_CCALL::HandleCancelMessage+0x42
rpcrt4!LRPC_CASSOCIATION::IoCompleted+0x341
rpcrt4!ProcessLrpcComplete+0x3b
rpcrt4!LOADABLE_TRANSPORT:Stick out tonguerocessIOEvents+0x212
rpcrt4!ProcessIOEventsWrapper+0xd
rpcrt4!BaseCachedThreadRoutine+0x5c
rpcrt4!ThreadStartRoutine+0x1e
kernel32!BaseThreadInitThunk+0xe
ntdll!__RtlUserThreadStart+0x23
ntdll!_RtlUserThreadStart+0x1b

Problem:
(ee4.139c): Access violation - code c0000005 (first/second chance not
available)
eax=01e0fcc4 ebx=002f8930 ecx=002f87e4 edx=002f87fc esi=002f87b0 edi=00000000
eip=76f08d9e esp=0200fe2c ebp=0200fe34 iopl=0 nv up ei pl nz na pe nc
cs=001b ss=0023 ds=0023 es=0023 fs=003b gs=0000 efl=00010206
rpcrt4!_SEH_epilog4_GS+0x3979:
76f08d9e a300000000 mov dword ptr ds:[00000000h],eax
ds:0023:00000000=????????

我想知道是否有人遇到类似的问题,并找到了解决方法?也许在这种情况下使用RPC以外的东西会更好吗?

0 个答案:

没有答案