[Intel-gfx] [PATCH] lib/igt_core: document the caveats of magic code blocks
Daniel Vetter
daniel at ffwll.ch
Fri Mar 14 16:29:37 CET 2014
On Fri, Mar 14, 2014 at 02:49:16PM +0000, Tvrtko Ursulin wrote:
>
> 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? :)
I did frob the paragraph a bit before pushing. Can you please take a look
at what's committed and if you see some room for improvement send out
another patch?
>
> >+ * - 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.
Actually igt_fixture and igt_subtest, but usually it's igt_fixtures where
something gets set up and then clobbered. What I usually do is push them
out to global scope, but not at the top of the file but only right above
igt_main. That tends to avoid gcc warnings about shadowing.
Woud it be useful to add this bkm to the docs, too?
Thanks for the feedback, Daniel
--
Daniel Vetter
Software Engineer, Intel Corporation
+41 (0) 79 365 57 48 - http://blog.ffwll.ch
More information about the Intel-gfx
mailing list