Tips & Tricks for debugging difficult crashes?
Tips & Tricks for debugging difficult crashes?
- Subject: Tips & Tricks for debugging difficult crashes?
- From: Adam Iser <email@hidden>
- Date: Tue, 12 Feb 2002 22:16:43 -0500
What's the best way to track down a crash that happens in 100% system
code?
One of my app's threads is crashing with a backtrace completely absent
of code belonging to my app.
My app has 2 threads, each with it's own run loop. The secondary thread
is nothing but an NSTimer scheduled to fire 4 times a second, take
strings from an open socket, and stick them in a shared que. The main
thread then pulls these strings out later on.
The crash occurs in the secondary thread, sometime in-between fires of
my timer.
The crash is an EXC_BAD_ACCESS, KERN_PROTECTION_FAILURE at 0x00000008
The crash only happens with users who have some sort of proxy setup for
their net connection (it seems)
The crash occurs in httpStreamCallBack, yet my app is doing nothing with
http at the time.
The challenge?, to figure out what in the world Adam has done
incorrectly to cause this crash... the reward? An email full of
thanks. :)
The users who get this crash get it with all the computers in their
houses/offices, so it's not a machine specific problem. It appears to
be related to the way their networks are set up, and they all seem to be
using proxy servers.
The users all seem to crash about 1 to 1 and 1/2 minutes after they
connect with my app. Changing port & host settings doesn't appear to
have an effect.
Where should I start?
-Adam Iser
All the backtraces are eerily similar:
Exception: EXC_BAD_ACCESS (0x0001)
Codes: KERN_PROTECTION_FAILURE (0x0002) at 0x00000008
Thread 0 Crashed:
#0 0x701b6968 in CFReadStreamGetInfoPointer
#1 0x7518208c in httpStreamCallBack
#2 0x701c9edc in _CFStreamSignalEvent
#3 0x701e2a14 in readFilterStreamCallBack
#4 0x701c9edc in _CFStreamSignalEvent
#5 0x701e2d4c in sendSignalForSource
#6 0x701e2488 in performSocketSource
#7 0x7017c85c in __CFRunLoopDoSources0
#8 0x7017bdf8 in __CFRunLoopRun
#9 0x701b7100 in CFRunLoopRunSpecific
#10 0x7017b8e0 in CFRunLoopRunInMode
#11 0x7312cccc in RunEventLoopInModeUntilEventArrives
#12 0x7313fe60 in ReceiveNextEventCommon
#13 0x73171120 in BlockUntilNextEventMatchingListInMode
#14 0x70bd70b8 in _DPSNextEvent
#15 0x70bfe5d8 in -[NSApplication
nextEventMatchingMask:untilDate:inMode:dequeue:]
#16 0x70c23468 in -[NSApplication run]
#17 0x70c91ed0 in NSApplicationMain
#18 0x00003e78 in _start
#19 0x00003ca8 in start
Thread 1:
#0 0x70000978 in mach_msg_overwrite_trap
#1 0x70005a04 in mach_msg
#2 0x7017bf98 in __CFRunLoopRun
#3 0x701b7100 in CFRunLoopRunSpecific
#4 0x7017b8e0 in CFRunLoopRunInMode
#5 0x7083e750 in -[NSRunLoop runMode:beforeDate:]
#6 0x70896398 in -[NSRunLoop runUntilDate:]
#7 0x0003921c in -[AIAIMPigeon runPigeonWithParameters:]
#8 0x70842358 in forkThreadForFunction
#9 0x7002054c in _pthread_body
Thread 2:
#0 0x70000978 in mach_msg_overwrite_trap
#1 0x70005a04 in mach_msg
#2 0x7017bf98 in __CFRunLoopRun
#3 0x701b7100 in CFRunLoopRunSpecific
#4 0x7017b8e0 in CFRunLoopRunInMode
#5 0x7061be08 in
XIOAudioDeviceManager::NotificationThread(XIOAudioDeviceManager *)
#6 0x706141c0 in CAPThread::Entry(CAPThread *)
#7 0x7002054c in _pthread_body
Thread 3:
#0 0x7003f4c8 in semaphore_wait_signal_trap
#1 0x7003f2c8 in _pthread_cond_wait
#2 0x70250ab0 in TSWaitOnCondition
#3 0x7027d730 in TSWaitOnSemaphoreCommon
#4 0x702c2078 in TimerThread
#5 0x7002054c in _pthread_body
Thread 4:
#0 0x700252fc in select
#1 0x701955fc in __CFSocketManager
#2 0x7002054c in _pthread_body
Thread 5:
#0 0x70000978 in mach_msg_overwrite_trap
#1 0x70005a04 in mach_msg
#2 0x70026a2c in _pthread_become_available
#3 0x70026724 in pthread_exit
#4 0x70020550 in _pthread_body
PPC Thread State:
srr0: 0x701b6968 srr1: 0x0200f030 vrsave: 0x00000000
xer: 0x00000010 lr: 0x7518208c ctr: 0x701b6968 mq: 0x00000000
r0: 0x7518208c r1: 0xbfffee60 r2: 0x01d6b23c r3: 0x00000000
r4: 0x00000008 r5: 0x00000000 r6: 0x00000001 r7: 0x00001c01
r8: 0x80162e38 r9: 0x024cf5f0 r10: 0x80810264 r11: 0x851800e8
r12: 0x701b6968 r13: 0x00000000 r14: 0x00000000 r15: 0x00000000
r16: 0x00000001 r17: 0x00000000 r18: 0x00000000 r19: 0x0000461f
r20: 0xbffff138 r21: 0x00000000 r22: 0x00000001 r23: 0x00000000
r24: 0x000b2758 r25: 0x000b2750 r26: 0x00000001 r27: 0x0196fa30
r28: 0x00000008 r29: 0x00000008 r30: 0x00000000 r31: 0x75182074
--
Adam Iser (email@hidden)
http://www.adiumx.com
_______________________________________________
cocoa-dev mailing list | email@hidden
Help/Unsubscribe/Archives:
http://www.lists.apple.com/mailman/listinfo/cocoa-dev
Do not post admin requests to the list. They will be ignored.