Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754248AbbHCP6N (ORCPT ); Mon, 3 Aug 2015 11:58:13 -0400 Received: from www62.your-server.de ([213.133.104.62]:54851 "EHLO www62.your-server.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753702AbbHCP6L (ORCPT ); Mon, 3 Aug 2015 11:58:11 -0400 Message-ID: <55BF8F90.5030001@iogearbox.net> Date: Mon, 03 Aug 2015 17:58:08 +0200 From: Daniel Borkmann User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.4.0 MIME-Version: 1.0 To: Nicolas Schichan , Alexei Starovoitov , "David S. Miller" , netdev@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 4/6] test_bpf: add module parameters to filter the tests to run. References: <1438610528-14245-1-git-send-email-nschichan@freebox.fr> <1438610528-14245-5-git-send-email-nschichan@freebox.fr> In-Reply-To: <1438610528-14245-5-git-send-email-nschichan@freebox.fr> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit X-Authenticated-Sender: daniel@iogearbox.net Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2995 Lines: 105 On 08/03/2015 04:02 PM, Nicolas Schichan wrote: > When developping on the interpreter or a particular JIT, it can be > insteresting to restrict the test list to a specific test or a s/insteresting/interesting/ > particular range of tests. > > This patch adds the following module parameters to the test_bpf module: > > * test_name=: only the specified named test will be run. > > * test_id=: only the test with the specified id will be run > (see the output of test_pbf without parameters to get the test id). s/test_pbf/test_bpf/ > * test_range=,: only the tests with IDs in the > specified id range are run (see the output of test_pbf without s/test_pbf/test_bpf/ > parameters to get the test ids). > > Any invalid range, test id or test name will result in -EINVAL being > returned and no tests being run. > > Signed-off-by: Nicolas Schichan Seems very useful for the test suite, thanks. Acked-by: Daniel Borkmann > --- > lib/test_bpf.c | 73 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ > 1 file changed, 73 insertions(+) > > diff --git a/lib/test_bpf.c b/lib/test_bpf.c > index f5606fb..abd0507 100644 > --- a/lib/test_bpf.c > +++ b/lib/test_bpf.c > @@ -4870,10 +4870,72 @@ static int run_one(const struct bpf_prog *fp, struct bpf_test *test) > return err_cnt; > } > > +static char test_name[64]; > +module_param_string(test_name, test_name, sizeof(test_name), 0); > + > +static int test_id = -1; > +module_param(test_id, int, 0); > + > +static int test_range[2] = { -1, -1 }; > +module_param_array(test_range, int, NULL, 0); > + > +static __init int find_test_index(const char *test_name) > +{ > + int i; > + > + for (i = 0; i < ARRAY_SIZE(tests); i++) { > + if (!strcmp(tests[i].descr, test_name)) > + return i; > + } > + return -1; > +} > + > static __init int prepare_bpf_tests(void) > { > int i; > > + if (test_id >= 0) { > + /* > + * if a test_id was specified, use test_range to > + * conver only that test. s/conver/cover/ > + */ > + if (test_id >= ARRAY_SIZE(tests)) { > + pr_err("test_bpf: invalid test_id specified.\n"); > + return -EINVAL; > + } [...] > @@ -4893,6 +4955,14 @@ static __init void destroy_bpf_tests(void) > } > } > > +static bool exclude_test(int test_id) > +{ > + if (test_range[0] >= 0 && > + (test_id < test_range[0] || test_id > test_range[1])) > + return true; > + return false; Minor nit: could directly return it, f.e.: return test_range[0] >= 0 && (test_id < test_range[0] || test_id > test_range[1]); Btw, for the range test in prepare_bpf_tests(), you could also reject a negative lower bound index right there. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/