[LTP] [PATCH 1/2] SAFE_MACROS: Redirect to tst_brk_() early

Jan Stancek jstancek@redhat.com
Thu Feb 9 16:56:46 CET 2017





----- Original Message -----
> From: "Cyril Hrubis" <chrubis@suse.cz>
> To: ltp@lists.linux.it
> Sent: Thursday, 9 February, 2017 3:44:44 PM
> Subject: [LTP] [PATCH 1/2] SAFE_MACROS: Redirect to tst_brk_() early

> +#ifndef BRKM_REDIRECT_H__
> +#define BRKM_REDIRECT_H__
> +
> +#include "ltp_priv.h"
> +
> +#ifdef tst_brkm
> +# undef tst_brkm
> +#endif
> +
> +#define tst_brkm(flags, cleanup, fmt, ...) do { \
> +	if (tst_test) \
> +		tst_brk_(__FILE__, __LINE__, flags, fmt, ##__VA_ARGS__); \
> +	else \
> +                tst_brkm_(__FILE__, __LINE__, flags, cleanup, fmt,
> ##__VA_ARGS__); \
> +	} while (0)

Stil trying to wrap my head around all this, but after first look,..
How does this related to "tst_brkm_" from lib/tst_res.c?
Can it be simplified? It doesn't look like we can reach newlib branch
now, because tst_test condition is now in tst_brkm macro.
Did we loose the check for "Non-NULL cleanup in newlib"?

> +
> +#define tst_brkr(rval, flags, cleanup, fmt, ...) do { \
> +		tst_brkm(flags, cleanup, fmt, ##__VA_ARGS__); \
> +		return rval; \
> +	} while (0)
> +
> +#define tst_brkv(flags, cleanup, fmt, ...) do { \
> +		tst_brkm(flags, cleanup, fmt, ##__VA_ARGS__); \
> +		return; \
> +	} while (0)

All variants of tst_brk_ are more and more tricky to remember.
Would it be too much to ask people "when writing new safe function,
take into account that tst_brkm can return" and leave it up to
them how they do it. Maybe they'll see goto more fitting.

Example:
// stuff in your safe function
if (bad) {
    tst_brkm();
    return;
}
// more stuff in your safe function

> +
> +#endif /* BRKM_REDIRECT_H__ */
> diff --git a/lib/safe_file_ops.c b/lib/safe_file_ops.c
> index 01f64ed..51853b4 100644


More information about the ltp mailing list