[Piglit] [PATCH 00/14] Move main() from libpiglitutil into each test

Brian Paul brianp at vmware.com
Wed Jun 13 09:06:48 PDT 2012


On 06/12/2012 05:02 PM, Chad Versace wrote:
> The goal that this series achieves is to replace the main() function in
> piglit-framework.c with a new function, piglit_gl_test_run(), that takes as
> its input a data structure describing the test initialization info.  This goal
> is a stepping stone towards a larger set of goals discussed earlier this month [1].
> In the future, the piglit_gl_test_info struct will also contain a declarative
> desciption of each test's requirements on GL context flavor, extensions, and
> window systems.
>
> There is another reason, in addition to those discussed in [1], for why main()
> should be moved out of libpiglitutil.  The EGL tests, GLX tests, and glean all
> define main(), yet also link to libpiglitutil.  Surprisingly, the linker
> doesn't complain. However, the situation is fragile. If you modify the
> libraries or tests in a way that changes the order in which the linker
> resolves things, link failure occurs.  The proper solution is not to tiptoe
> around the linker; it's to remove main() from the library.
>
> If you want to skip to the important stuff, see patches 11-14. All the other
> patches are just prerequisite cleanups that prepare for those last 4.
>
> This series taks a few detours, cleans out the closet, and reorganizes your
> kitchen junk drawer.  Often, you must clean up the house before remodeling it.
> I feel that all the little detours were needed and that Piglit really benefits
> from them. I wanted to clean up a lot more, but I restrained myself only to
> the cleanups that directly benefited the series' stated goal.
>
> No regresssions found on Sandybridge.

Could you check this into a branch first for additional testing (MSVC, 
mingw32, etc)?

-Brian



More information about the Piglit mailing list