Closed Bug 571208 Opened 15 years ago Closed 15 years ago

[WebM] Crash when switching from 360p to 720p [@ nestegg_free_packet | PacketQueue::Reset()]

Categories

(Core :: Audio/Video, defect)

x86
Windows 7
defect
Not set
critical

Tracking

()

RESOLVED FIXED
Tracking Status
blocking2.0 --- betaN+

People

(Reporter: jmjjeffery, Assigned: kinetik)

References

()

Details

(Keywords: crash)

Crash Data

Attachments

(1 file)

Open the URL for the Prince of Persia video using a nightly build from 6/10/2010 After a few secs switch from 360p to 720p - the video will then start over, and after 3secs or so.. I crashed. http://crash-stats.mozilla.com/report/index/83902a1d-b257-4c45-889c-20c232100610 After restarting browser from the crash, I again played the URL, and switched to 720p without issue. Mozilla/5.0 (Windows; U; Windows NT 6.1; WOW64; en-US; rv:1.9.3a5pre) Gecko/20100610 Minefield/3.7a5pre ID:20100610035756 Win7 x64 AMD Phenom II Quad hd3200 on-board video, 8 gig RAM
Crashed again, Started in 360p switched to 720p, and this time the video was lagging, not sure why as it played smoothly before. Trying to pause the video by clicking on the 'pause' button it seemed unresponsive, so I clicked several times eventually leading to the crash.
blocking2.0: --- → ?
Signature nestegg_free_packet | PacketQueue::Reset() UUID 83902a1d-b257-4c45-889c-20c232100610 Time 2010-06-10 05:05:48.888578 Uptime 490 Last Crash 157057 seconds before submission Product Firefox Version 3.7a5pre Build ID 20100610035756 Branch 1.9.3 OS Windows NT OS Version 6.1.7600 CPU x86 CPU Info AuthenticAMD family 16 model 2 stepping 3 Crash Reason EXCEPTION_ACCESS_VIOLATION Crash Address 0x10 User Comments playing prince of persia webM 720p Crashing Thread Frame Module Signature [Expand] Source 0 xul.dll nestegg_free_packet media/libnestegg/src/nestegg.c:1853 1 xul.dll PacketQueue::Reset content/media/webm/nsWebMReader.h:90 2 xul.dll nsWebMReader::~nsWebMReader content/media/webm/nsWebMReader.cpp:130 3 xul.dll nsWebMReader::`vector deleting destructor' 4 xul.dll nsAutoPtr<nsBuiltinDecoderReader>::~nsAutoPtr<nsBuiltinDecoderReader> obj-firefox/dist/include/nsAutoPtr.h:104 5 xul.dll nsBuiltinDecoderStateMachine::~nsBuiltinDecoderStateMachine content/media/nsBuiltinDecoderStateMachine.cpp:128 6 xul.dll nsBuiltinDecoderStateMachine::`scalar deleting destructor' 7 xul.dll nsRunnable::Release obj-firefox/xpcom/build/nsThreadUtils.cpp:55 8 xul.dll nsRefPtr<nsAccessNode>::assign_assuming_AddRef obj-firefox/dist/include/nsAutoPtr.h:957 9 xul.dll nsCOMPtr_base::assign_with_AddRef obj-firefox/xpcom/build/nsCOMPtr.cpp:89 10 xul.dll nsBuiltinDecoder::Stop content/media/nsBuiltinDecoder.cpp:136 11 xul.dll nsRunnableMethodImpl<void obj-firefox/dist/include/nsThreadUtils.h:347 12 xul.dll nsThread::ProcessNextEvent xpcom/threads/nsThread.cpp:547 13 xul.dll mozilla::ipc::MessagePump::Run ipc/glue/MessagePump.cpp:118
Severity: normal → critical
Keywords: crash
Summary: [WebM] Crash when switching from 360p to 720p → [WebM] Crash when switching from 360p to 720p [@ nestegg_free_packet | PacketQueue::Reset()]
so, this should mean that packet was 0, i tried wandering around but couldn't figure out who dropped the ball, i'm pretty sure nsDeque is innocent (I own it). It should mean that someone pushed a null pointer into the deque, which probably happens as a result of something jim did :)
http://crash-stats.mozilla.com/report/index/bp-99aff675-4ed0-4ea9-9086-e588d2100610 Wasn't switching - crashed while leaving a page. I had been repeatedly entering and exiting videos, looking for how many were html5 (right clicking and checking for flash - I guess I should have just disabled the plugin).
(In reply to comment #1) > Crashed again, Started in 360p switched to 720p, and this time the video was > lagging, not sure why as it played smoothly before. Maybe it was dumped from the cache between runs? > Trying to pause the video by clicking on the 'pause' button it seemed > unresponsive Seems like bug 566920
FWIW, I didn't see anyone testing builds from the first batch of checkins yesterday talking about crashes, so its likely it came from the second set of patches last night.
Assignee: nobody → kinetik
Status: NEW → ASSIGNED
Attached patch patch v0Splinter Review
Only push packet back on top of queue when we actually have one. Don't bother trying to free the packet in a code path we know it's NULL. Add an assert to the PacketQueue code that would've caught this earlier.
Attachment #450486 - Flags: review?(chris.double)
(In reply to comment #7) > FWIW, I didn't see anyone testing builds from the first batch of checkins > yesterday talking about crashes, so its likely it came from the second set of > patches last night. That's a good data point, thanks. The suspicious code I just posted a fix for landed with the second batch (bug 568431).
Blocks: 568431
Attachment #450486 - Flags: review?(chris.double) → review+
Keywords: checkin-needed
Whiteboard: [needs landing]
Status: ASSIGNED → RESOLVED
Closed: 15 years ago
Resolution: --- → FIXED
Keywords: checkin-needed
Whiteboard: [needs landing]
Crash Signature: [@ nestegg_free_packet | PacketQueue::Reset()]
You need to log in before you can comment on or make changes to this bug.

Attachment

General

Created:
Updated:
Size: