Page MenuHomeFreeBSD

usr.sbin/pmcstat: return non-zero if the launched command fails
Needs RevisionPublic

Authored by arichardson on Oct 12 2022, 4:54 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Jan 3, 9:37 PM
Unknown Object (File)
Dec 10 2024, 10:57 AM
Unknown Object (File)
Nov 29 2024, 12:25 AM
Unknown Object (File)
Nov 23 2024, 11:14 AM
Unknown Object (File)
Nov 14 2024, 8:33 AM
Unknown Object (File)
Nov 9 2024, 2:13 AM
Unknown Object (File)
Nov 3 2024, 9:04 PM
Unknown Object (File)
Oct 19 2024, 12:44 AM
Subscribers

Details

Summary

Previously pmcstat would return a success return code even if the process
that it launched crashed or returned a failure code. Returning a non-zero
exit code means that we can more easily detect if a benchmark did not
run as expected even when running it under pmcstat.

While it might make sense to propagate the exit code/signal via pmcstat,
I believe returning EX_IOERR if the child process fails should
be sufficient.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 47799
Build 44686: arc lint + arc unit

Event Timeline

While it might make sense to propagate the exit code/signal via pmcstat, I believe returning EX_IOERR if the child process fails should be sufficient.

I think it probably does; it looks like that's what ktrace does, for instance. Do you know what Linux perf does?

I don't object if you think this is best; I think returning EX_IOERR is better than EX_OK if the child reports failure anyhow.

While it might make sense to propagate the exit code/signal via pmcstat, I believe returning EX_IOERR if the child process fails should be sufficient.

I think it probably does; it looks like that's what ktrace does, for instance. Do you know what Linux perf does?

I don't object if you think this is best; I think returning EX_IOERR is better than EX_OK if the child reports failure anyhow.

It looks like perf stat passes through the exit code, so I'll do the same here.

emaste requested changes to this revision.Mar 21 2023, 4:29 PM

@arichardson plans to change this to return the child's exit code

This revision now requires changes to proceed.Mar 21 2023, 4:29 PM