Windows 媒体播放器崩溃

发布于 2024-08-31 14:04:36 字数 1925 浏览 14 评论 0原文

当我快速翻转媒体元素时,我的 WPF 应用程序似乎崩溃了。 使用 WinDbg 进行调试显示它崩溃,并显示以下堆栈跟踪:

0:028:x86> k 20
ChildEBP RetAddr  
15aff648 07acb2a9 wmp!CMGSessionHost::GetPDFromTopologySourceNode0+0xb
15aff670 07a080fc wmp!CMGSessionHost::IsWindowsMediaContent+0x8a
15aff688 07acd838 wmp!CMGPlayer::HandleOnError+0x2b
15aff6d8 07c9270c wmp!CMGSessionHost::HandleTopologySet+0x583
15aff714 07c928b9 wmp!CMGSessionHost::OnDShowSourceCreated+0x82
15aff720 6e701f7b wmp!CMGSessionHost::OnDShowSourceCreatedAsyncCallback::Invoke+0x16
15aff730 6e701b3c MFPlat!CCompletionPort::InvokeCallback+0x12
15aff838 6e708cab MFPlat!CWorkQueue::CThread::ThreadMain+0xa5
15aff840 74e71287 MFPlat!CWorkQueue::CThread::ThreadFunc+0xd
15aff878 74e71328 msvcrt!_endthreadex+0x44
15aff880 76473677 msvcrt!_endthreadex+0xce
15aff88c 76f79d72 KERNEL32!BaseThreadInitThunk+0xe
15aff8cc 76f79d45 ntdll_76f40000!__RtlUserThreadStart+0x70
15aff8e4 00000000 ntdll_76f40000!_RtlUserThreadStart+0x1b
0:028:x86> u 7a00881
wmp!CMGSessionHost::GetPDFromTopologySourceNode0:
07a00881 8bff            mov     edi,edi
07a00883 55              push    ebp
07a00884 8bec            mov     ebp,esp
07a00886 83ec0c          sub     esp,0Ch
07a00889 8b4508          mov     eax,dword ptr [ebp+8]
07a0088c 8b08            mov     ecx,dword ptr [eax]
07a0088e 56              push    esi
07a0088f 57              push    edi
0:028:x86> r
eax=00000000 ebx=00000000 ecx=15aff668 edx=00010000 esi=00000000 edi=05c53460
eip=07a0088c esp=15aff63c ebp=15aff648 iopl=0         nv up ei pl nz ac pe nc
cs=0023  ss=002b  ds=002b  es=002b  fs=0053  gs=002b             efl=00010216
wmp!CMGSessionHost::GetPDFromTopologySourceNode0+0xb:
07a0088c 8b08            mov     ecx,dword ptr [eax]  ds:002b:00000000=????????

在我看来,打开媒体后从 Windows 媒体播放器内部进行的回调因空指针而崩溃,因为我太快地更改了源。

我在更改源之前停止当前视频,但是我想知道是否应该等到返回 MediaOpened 事件后再再次更改源。

其他人遇到过这个问题吗?如果是的话,他们是如何解决的?

My WPF app seems to be crashing when I flip a media element around quickly.
Debugging with WinDbg shows it as crashing with the following stack trace:

0:028:x86> k 20
ChildEBP RetAddr  
15aff648 07acb2a9 wmp!CMGSessionHost::GetPDFromTopologySourceNode0+0xb
15aff670 07a080fc wmp!CMGSessionHost::IsWindowsMediaContent+0x8a
15aff688 07acd838 wmp!CMGPlayer::HandleOnError+0x2b
15aff6d8 07c9270c wmp!CMGSessionHost::HandleTopologySet+0x583
15aff714 07c928b9 wmp!CMGSessionHost::OnDShowSourceCreated+0x82
15aff720 6e701f7b wmp!CMGSessionHost::OnDShowSourceCreatedAsyncCallback::Invoke+0x16
15aff730 6e701b3c MFPlat!CCompletionPort::InvokeCallback+0x12
15aff838 6e708cab MFPlat!CWorkQueue::CThread::ThreadMain+0xa5
15aff840 74e71287 MFPlat!CWorkQueue::CThread::ThreadFunc+0xd
15aff878 74e71328 msvcrt!_endthreadex+0x44
15aff880 76473677 msvcrt!_endthreadex+0xce
15aff88c 76f79d72 KERNEL32!BaseThreadInitThunk+0xe
15aff8cc 76f79d45 ntdll_76f40000!__RtlUserThreadStart+0x70
15aff8e4 00000000 ntdll_76f40000!_RtlUserThreadStart+0x1b
0:028:x86> u 7a00881
wmp!CMGSessionHost::GetPDFromTopologySourceNode0:
07a00881 8bff            mov     edi,edi
07a00883 55              push    ebp
07a00884 8bec            mov     ebp,esp
07a00886 83ec0c          sub     esp,0Ch
07a00889 8b4508          mov     eax,dword ptr [ebp+8]
07a0088c 8b08            mov     ecx,dword ptr [eax]
07a0088e 56              push    esi
07a0088f 57              push    edi
0:028:x86> r
eax=00000000 ebx=00000000 ecx=15aff668 edx=00010000 esi=00000000 edi=05c53460
eip=07a0088c esp=15aff63c ebp=15aff648 iopl=0         nv up ei pl nz ac pe nc
cs=0023  ss=002b  ds=002b  es=002b  fs=0053  gs=002b             efl=00010216
wmp!CMGSessionHost::GetPDFromTopologySourceNode0+0xb:
07a0088c 8b08            mov     ecx,dword ptr [eax]  ds:002b:00000000=????????

Which to me looks like the callback from the interior of windows media player after it has opened the media is falling over with null pointer because I've changed the source too quickly.

I am stopping the current video before I change over the source, however I'm wondering if I should wait until I've gotten back a MediaOpened event before I change the source again.

Anyone else run into this and if so how did they fix it?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

羅雙樹 2024-09-07 14:04:36

我就此向 Microsoft 提出了一个支持案例,并得到了一个热修复程序,请注意,在我的案例中,它特定于播放 XVID / DIVX 文件。

http://support.microsoft.com/kb/981880

我的猜测是 XVID 编解码器打开所有内容两次并关闭一次,留下一些指针和一些打开的文件句柄。

I opened a support case with Microsoft on this and got back a hot fix, note in my case it was specific to playing back XVID / DIVX files.

http://support.microsoft.com/kb/981880

My guess is that the XVID codec was opening everything twice and closing it down once leaving behind some pointers and some open file handles as well.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文