[LTP] [PATCH 1/1] select03: Fix false positive on TCONF

Petr Vorel pvorel@suse.cz
Wed Nov 13 15:07:12 CET 2024


Hi Cyril,

> Hi!
> > ---
> > Alternatively, we could revert to previous state (remove
> > "!WEXITSTATUS(status)" check), if we really don't care about any other
> > exit code.

> > Kind regards,
> > Petr

> >  testcases/kernel/syscalls/select/select03.c | 4 +++-
> >  1 file changed, 3 insertions(+), 1 deletion(-)

> > diff --git a/testcases/kernel/syscalls/select/select03.c b/testcases/kernel/syscalls/select/select03.c
> > index 216b22104f..34aea12603 100644
> > --- a/testcases/kernel/syscalls/select/select03.c
> > +++ b/testcases/kernel/syscalls/select/select03.c
> > @@ -77,8 +77,10 @@ static void run(unsigned int n)

> >  	SAFE_WAITPID(pid, &status, 0);

> > -	if (WIFEXITED(status) && !WEXITSTATUS(status))
> > +	if (WIFEXITED(status) &&
> > +		(WEXITSTATUS(status) == 0 || WEXITSTATUS(status) == TCONF)) {
> >  		return;

> I think that the main mistake here is that I kept the code in
> tst_vbrk_() that exits the test with a return value in the case of a
> child processes.

I suppose you talk about in tst_vbrk_ (lib/tst_test.c):

	if (getpid() == lib_pid)
		do_exit(TTYPE_RESULT(ttype));

> So ideal fix would be to change the test library not to
> do that,

So would you just do_exit(0) or even just exit(0)?
Or exit 0 for TPASS or TCONF and 1 otherwise (TBROK, TFAIL, TWARN)? Or what
exactly did you meant?

Other option could be to keep library as is and have a custom functions which
"translate" LTP exit codes. I was thinking something like this:

bool tst_exit_status(int status)
{
	if (!WEXITSTATUS(status))
		return false;

	if (WEXITSTATUS(status) == TPASS || WEXITSTATUS(status) == TCONF)
		return true;

	return false;
}

But we actually have check_child_status(pid_t pid, int status) for this:

static void check_child_status(pid_t pid, int status)
{
	int ret;

	if (WIFSIGNALED(status)) {
		tst_brk(TBROK, "Child (%i) killed by signal %s", pid,
			tst_strsig(WTERMSIG(status)));
	}

	if (!(WIFEXITED(status)))
		tst_brk(TBROK, "Child (%i) exited abnormally", pid);

	ret = WEXITSTATUS(status);
	switch (ret) {
	case TPASS:
	case TBROK:
	case TCONF:
	break;
	default:
		tst_brk(TBROK, "Invalid child (%i) exit value %i", pid, ret);
	}
}

BTW I'm surprised that there is TBROK whitelisted.

> but that would require a bit more work, especially we would
> have to look at all WAITPID() usages in newlib tests and make sure that
> there are not tests that depends on such behavior. If there are none it
> would stil require a few changes in the test library.

Well, what I fear more is to broke even more tests :). But if you consider is
useful enough I can do the cleanup.

Kind regards,
Petr


More information about the ltp mailing list