<div dir="ltr">I just retested this on windows and this patch set should be considered critical, because on any recent release of windows ( For example, Windows Vista and Windows 7) have piglit grind to a halt when running tests because when a program crashes, windows will always bring up a dialog stating... "(Insert application name or exe file here) has stopped responding"<br>
</div><div class="gmail_extra"><br><br><div class="gmail_quote">On Sat, Feb 23, 2013 at 2:03 PM, Ken Phillis Jr <span dir="ltr"><<a href="mailto:kphillisjr@gmail.com" target="_blank">kphillisjr@gmail.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5">On Sat, Feb 23, 2013 at 4:33 AM, Jose Fonseca <<a href="mailto:jfonseca@vmware.com">jfonseca@vmware.com</a>> wrote:<br>

> ----- Original Message -----<br>
>> Ken Phillis Jr <<a href="mailto:kphillisjr@gmail.com">kphillisjr@gmail.com</a>> writes:<br>
>><br>
>> > I updated the Code for piglit to include windows. I also added the<br>
>> > "standard Copyright" to the new source files... The two new files are<br>
>> > as follows:<br>
>> ><br>
>> > tests/util/piglit-util-sighandler.c<br>
>> > Automatic Backtrace Handling using posix compliant signals. Please<br>
>> > note that register dumps are probably the least portable portion of<br>
>> > the code, and will need changes on a per platform basis<br>
>> ><br>
>> > tests/util/piglit-util-win32.c<br>
>> > Automatic Backtrace Handling on windows. Please note that windows in<br>
>> > general has a much more limited compliance to than most other posix<br>
>> > platforms and thus requires it's own separate file.<br>
>> ><br>
>> ><br>
>> > NOTE: By default if the platform does not have a handler there will be<br>
>> > no system changes. This however, Cannot be kept true for windows. The<br>
>> > changes so far make the software incompatible with versions of windows<br>
>> > made before Windows XP and Windows Server 2003. However, This only<br>
>> > applies if someone builds piglit using Visual Studio 2005 and up.<br>
>><br>
>> I noted on IRC that I generally don't like this idea.<br>
>><br>
>> I think that the value in piglit is for Mesa developers that have access<br>
>> to the hardware -- it helps very little to see a backtrace if you don't<br>
>> have access to the machine to directly test your fix, and if you have<br>
>> access to the machine then you just re-run the test under gdb/valgrind,<br>
>> which gets you massively better information and wastes less of your time<br>
>> overall.  In fact, I think that piglit-run.py re-running the test under<br>
>> valgrind when the exit code indicates a crash would be far more useful<br>
>> for the developer than a signal handler.<br>
>><br>
>> What I definitely don't want to see is signal handling landing in piglit<br>
>> binaries by default.  Maybe someone wants to enable it for<br>
>> ./piglit-run.py in a test farm, but what I'd hate to see is our normal<br>
>> gdb or valgrind workflows changing for the worse.  The experiences I've<br>
>> had with signal handlers and debugging so far has been awful (The X<br>
>> server and SDL, in particular)<br>
><br>
> I have no preference as far as Linux is concerned. But I thought that signal handlers would do no worse -- at least apitrace's signal handler is transparent -- it simply gives the opportunity to take some action (print some message), and then pass it on to the default handler. That is, gdb, any debugger, will work precisely the same way.<br>

><br>
<br>
</div></div>For Mac OSX and Linux, This is statement is true, and it still<br>
produces the stock core dump files... It just happens to make note of<br>
some of the machine state in the piglit log before closing out.<br>
<br>
<br>
For windows, This is also true, and if you want to remove the handler<br>
when a debugger ( like visual studio ) is present, windows has a<br>
single call to make this happen... Just call the IsDebuggerPresent<br>
when the initialization happens.<br>
<a href="http://msdn.microsoft.com/en-us/library/windows/desktop/ms680345%28v=vs.85%29.aspx" target="_blank">http://msdn.microsoft.com/en-us/library/windows/desktop/ms680345%28v=vs.85%29.aspx</a><br>
<div class="im"><br>
> However on Windows we do need something to avoid halting with dialog boxes. In-process signal handling is one solution. Another is to use out-of-process signal handling, like this tool I wrote/use <a href="http://code.google.com/p/jrfonseca/wiki/StackDump" target="_blank">http://code.google.com/p/jrfonseca/wiki/StackDump</a><br>

><br>
<br>
</div>On windows, It works really well for my code. The only thing Is it<br>
needs a little testing to make absolutely sure that the signal handler<br>
for abort is functioning properly. For windows, if you do not handle<br>
the abort signal, the program will always produce an error dialog.<br>
Anyways, on windows the debugging functionality does not change and<br>
visual studio displays no difference... Based on my user space tests,<br>
There is absolutely no change. in work flow. The only bit I had<br>
problems with is the fact that Windows 7 by default does not enable<br>
the floating point exceptions for things like divide by zero. However,<br>
the access violation, and integer divide by zero exception handling<br>
works completely as expected.<br>
<div class="im"><br>
> For Linux too, I suppose we could enable core dumps by default via ulimit, and then use gdb to output stack trace if any core is generated. I use that on most of the internal test automation I do. It also works quite nicely on MacOSX.<br>

><br>
> Jose<br>
<br>
</div>Mac OSX on intel chips ( and powerpc systems)  there is support to<br>
implement the register dumps... I just don't have a mac to finish<br>
writing the quick handler for also including register output.  This is<br>
the one section of code that is not portable.<br>
<br>
for Mac OSX 10.6 to avoid deprecation errors, it's required to use the<br>
header: sys/ucontext.h  or to simply define _XOPEN_SOURCE to an<br>
appropriate version.<br>
Mac OSX manual page for ucontext:<br>
<a href="https://developer.apple.com/library/mac/#documentation/Darwin/Reference/ManPages/man3/ucontext.3.html" target="_blank">https://developer.apple.com/library/mac/#documentation/Darwin/Reference/ManPages/man3/ucontext.3.html</a><br>

<br>
Since piglit specifically supports Mac OSX, windows and linux there is<br>
no problems now. However, if a developer is using a system like<br>
netbsd, freebsd, etc... they will need to refer to the system headers<br>
and documentation to find out how to properly handle some of the<br>
missing functionality provided by this patch set.<br>
</blockquote></div><br></div>