[Intel-gfx] [PATCH] lib/igt_core: document the caveats of magic code blocks

Tvrtko Ursulin tvrtko.ursulin at linux.intel.com
Fri Mar 14 15:49:16 CET 2014


On 03/14/2014 07:18 AM, Daniel Vetter wrote:
[snip]
> + * # Magic Control Blocks
> + *
> + * i-g-t makes heavy use of C macros which serve as magic control blocks. They
> + * work fairly well and transparently but since C doesn't have full-blown
> + * closures there are caveats:
> + *
> + * - Asynchronous blocks which are used to spawn children internally use fork().
> + *   Which means that impossible control flow like jumping out of the control
> + *   block is possible, but it will horribly badly the i-g-t library code. And

I suggest to add a verb and reorder the "horribly badly" part of the 
sentence a bit. Or perhaps you tried to illustrate the program flow 
after jumping out of the control block? :)

> + * - Code blocks with magic control flow are implemented with setjmp() and
> + *   longjmp(). This applies to #igt_fixture and #igt_subtest blocks and all the
> + *   three variants to finish test: igt_success(), igt_skip() and igt_fail().
> + *   Mostly this is of no concern, except when such a control block changes
> + *   stack variables defined in the same function as the control block resides.
> + *   Any store/load behaviour after a longjmp() is ill-defined for these
> + *   variables. Avoid such code.
> + *
> + *   Quoting the man page for longjmp():
> + *
> + *   "The values of automatic variables are unspecified after a call to
> + *   longjmp() if they meet all the following criteria:"
> + *    - "they are local to the function that made the corresponding setjmp() call;
> + *    - "their values are changed between the calls to setjmp() and longjmp(); and
> + *    - "they are not declared as volatile."
>    */

So all variables which are getting initialised in igt_fixture should be 
moved out to file scope? Gcc does warn about potential clobbering 
although I haven't exactly gotten my head round understanding if and 
when it can really happen with igt_fixture.

Tvrtko



More information about the Intel-gfx mailing list