Solved

find our where the exe is being aborted with abort()

Posted on 2010-11-29
11
4,332 Views
Last Modified: 2012-05-10
Hi,

My c++ is getting gets an error when under the MTD and it just exits when it is built under MT. In MTD i get this error:

"Debug Error!
R6010
- abort() has been called
(Press Retry to debug the application)"

Open in new window


I can choose to ignore it, cancel it or retry but they all lead to the exe getting closed. I gues that abort() is being called somewhere but i've been looking and searching for it and I cant find it. It is probably not in my code but a result when communicating with a socket while the internet connection goes down.

Is there a way that I can find out where this error is being called from (line and file)?

Thank you
0
Comment
Question by:xNejX
11 Comments
 
LVL 86

Expert Comment

by:jkr
ID: 34231973
>>Is there a way that I can find out where this error is being called from (line
>>and file)?

Yes - "Press Retry to debug the application" (pardon the pun) and examine the call stack. This will lead you to the file and line in your code that subsequently caused 'abort()' to be called.
0
 
LVL 86

Assisted Solution

by:jkr
jkr earned 100 total points
ID: 34231981
BTW, see also http://msdn.microsoft.com/en-us/library/a3694ts5.aspx ("How to: Use the Call Stack Window")
0
 

Author Comment

by:xNejX
ID: 34232003
i will try the second solution, the retry doesn't do anything
0
 
LVL 86

Expert Comment

by:jkr
ID: 34232089
You could also try to to rund your aqpp in the debugger from the start, it should then stop on the line with the 'abort()'.
0
 

Author Comment

by:xNejX
ID: 34232418
I tried to do it with the callstack but as soon as it aborts the callstact window dissapears from Visual Studio and when I reopen it it is empty.

All that I can get from the "Output" window in visual studio is The program '[22476] Unasl.exe: Native' has exited with code 1 (0x1).

How do i rund my aqpp?
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 86

Expert Comment

by:jkr
ID: 34232747
Hmm, can you try to set a breakpoint on 'abort()'? Press CTRL+B and enter 'abort' in the text field.
0
 
LVL 32

Assisted Solution

by:phoffric
phoffric earned 100 total points
ID: 34233035
If you need help in using the VS debugger, these articles may help:
C/C++ Beginner's Debugging Guide
Breakpoint Tips for C/C++
Watch, Memory, Stack Tips: C/C++
0
 

Author Comment

by:xNejX
ID: 34234018
@jkr

Do you know the shortcut or the function name in VS 2010? CTRL + B doesn't do anything => { (Ctrl+B) was pressed. Waiting for second key or chord... }?
0
 
LVL 86

Expert Comment

by:jkr
ID: 34234128
Try "Debug|New Breakpoint|Break at Function..."
0
 

Author Comment

by:xNejX
ID: 34234758
was i supposed to put a certain line number and char, should i put in abort or abort()?

cause it didn't break on anything...
0
 
LVL 22

Accepted Solution

by:
ambience earned 300 total points
ID: 34246485
heres a weird idea that I would have tried after all these efforts

write abort() right after main() (the first statement). Single step through the code F-11. Step inside abort() and set a breakpoint and stop debuging.

Then keeping the breakpoint open, remove the abort() statement and continue debugging F5. It should then hit the breakpoint.

This should work If you had installed CRT source code, otherwise you can set the break point in disassembly. In the worst case, set the breakpoint in disassembly and then drag the execution point to the [ret] statement of abort() (effectively skipping it manually the first time). Continue from that point and it should break the next time it enters abort().

Weird, but I know I have succeeded with things like that in the past so its worth a try when nothing else is working :)
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This tutorial is posted by Aaron Wojnowski, administrator at SDKExpert.net.  To view more iPhone tutorials, visit www.sdkexpert.net. This is a very simple tutorial on finding the user's current location easily. In this tutorial, you will learn ho…
This is a short and sweet, but (hopefully) to the point article. There seems to be some fundamental misunderstanding about the function prototype for the "main" function in C and C++, more specifically what type this function should return. I see so…
The goal of this video is to provide viewers with basic examples to understand opening and reading files in the C programming language.
The viewer will be introduced to the technique of using vectors in C++. The video will cover how to define a vector, store values in the vector and retrieve data from the values stored in the vector.

910 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

18 Experts available now in Live!

Get 1:1 Help Now