[LTP] [PATCH 07/16] testcases/lib: Implement tst_cgctl binary
Li Wang
liwang@redhat.com
Mon Jan 24 08:54:52 CET 2022
On Wed, Jan 19, 2022 at 10:44 PM Luke Nowakowski-Krijger <
luke.nowakowskikrijger@canonical.com> wrote:
>
> Implement a binary utility that creates an interface to make calls to
> the cgroup C API.
>
> This will effectively allow shell scripts to make calls to the cgroup C
> api.
>
> Signed-off-by: Luke Nowakowski-Krijger <
luke.nowakowskikrijger@canonical.com>
> ---
> testcases/lib/Makefile | 2 +-
> testcases/lib/tst_cgctl.c | 69 +++++++++++++++++++++++++++++++++++++++
> 2 files changed, 70 insertions(+), 1 deletion(-)
> create mode 100644 testcases/lib/tst_cgctl.c
>
> diff --git a/testcases/lib/Makefile b/testcases/lib/Makefile
> index f2de0c832..f4f8c8524 100644
> --- a/testcases/lib/Makefile
> +++ b/testcases/lib/Makefile
> @@ -12,6 +12,6 @@ MAKE_TARGETS := tst_sleep tst_random
tst_checkpoint tst_rod tst_kvcmp\
> tst_device tst_net_iface_prefix
tst_net_ip_prefix tst_net_vars\
> tst_getconf tst_supported_fs tst_check_drivers
tst_get_unused_port\
> tst_get_median tst_hexdump tst_get_free_pids
tst_timeout_kill\
> - tst_check_kconfigs
> + tst_check_kconfigs tst_cgctl
>
> include $(top_srcdir)/include/mk/generic_leaf_target.mk
> diff --git a/testcases/lib/tst_cgctl.c b/testcases/lib/tst_cgctl.c
> new file mode 100644
> index 000000000..a6cf88f41
> --- /dev/null
> +++ b/testcases/lib/tst_cgctl.c
> @@ -0,0 +1,69 @@
We need to add SPDX-License-Identifier and copyright for this file.
And better to use Tabs (8 characters) instead of 4 spaces for the code
indentation:).
See:
https://www.kernel.org/doc/html/latest/process/coding-style.html#indentation
> +#include <stdio.h>
> +#include <string.h>
> +#include <stdlib.h>
> +#include <stdint.h>
> +#include <unistd.h>
> +#include "tst_cgroup.h"
> +
> +static int cgctl_require(const char *ctrl, int test_pid)
> +{
> + struct tst_cgroup_opts opts;
> +
> + memset(&opts, 0, sizeof(opts));
> + opts.test_pid = test_pid;
> +
> + tst_cgroup_require(ctrl, &opts);
> + tst_cgroup_print_config();
> +
> + return 0;
> +}
> +
> +static int cgctl_cleanup(const char *config)
> +{
> + tst_cgroup_scan();
> + tst_cgroup_load_config(config);
> + tst_cgroup_cleanup();
> +
> + return 0;
> +}
> +
> +static int cgctl_print(void)
> +{
> + tst_cgroup_scan();
> + tst_cgroup_print_config();
> +
> + return 0;
> +}
> +
> +static int cgctl_process_cmd(int argc, char *argv[])
> +{
> + int test_pid;
> + const char *cmd_name = argv[1];
> +
> + if (!strcmp(cmd_name, "require")) {
> + test_pid = atoi(argv[3]);
> + if (!test_pid) {
> + fprintf(stderr, "tst_cgctl: Invalid test_pid '%s' given\n",
> + argv[3]);
> + return 1;
> + }
> + return cgctl_require(argv[2], test_pid);
> + } else if (!strcmp(cmd_name, "cleanup")) {
> + return cgctl_cleanup(argv[2]);
> + } else if (!strcmp(cmd_name, "print")) {
> + return cgctl_print();
> + }
> +
> + fprintf(stderr, "tst_cgctl: Unknown command '%s' given\n", cmd_name);
> + return 1;
> +}
> +
> +int main(int argc, char *argv[])
> +{
> + if (argc < 2 || argc > 4) {
> + fprintf(stderr, "tst_cgctl: Invalid number of arguements given");
> + return 1;
> + }
It'd be great to have a help() function to print the usage.
Something maybe looks like:
Usage: ./tst_cgctl require|print|cleanup ...
# cgroup_state=$(./tst_cgctl require "$ctrl" "$pid")
# echo "$cgroup_state" # to print detailed controllers
# tst_cgctl cleanup "$cgroup_state"
> +
> + return cgctl_process_cmd(argc, argv);
> +}
> --
> 2.32.0
>
--
Regards,
Li Wang
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.linux.it/pipermail/ltp/attachments/20220124/85bbb7f2/attachment-0001.htm>
More information about the ltp
mailing list