From: Petr Vorel <pvorel@suse.cz>
To: Yang Xu <xuyang2018.jy@fujitsu.com>
Cc: ltp@lists.linux.it
Subject: Re: [LTP] [PATCH v2 3/4] shell: add kconfig parse api
Date: Thu, 6 Jan 2022 11:40:56 +0100 [thread overview]
Message-ID: <YdbHODSAdEnILJ6K@pevik> (raw)
In-Reply-To: <1641461121-2212-3-git-send-email-xuyang2018.jy@fujitsu.com>
Hi Xu,
> +tst_require_kconfigs()
> +{
> + [ $# -eq 0 ] && return 0
> +
> + local kconfigs
> + local kconfig_i
> + local kconfig_max
> +
> + kconfigs=$@
> + [ -z "$kconfigs" ] && return 0
> +
> + tst_check_cmds cut tr wc
> + kconfig_max=$(( $(echo "$kconfigs" | tr -cd "$TST_NEEDS_KCONFIGS_IFS" | wc -c) +1))
> + if [ $kconfig_max -gt 10 ]; then
> + tst_brk TCONF "The max number of kconfig is 10!"
> + fi
> +
> + for kconfig_i in $(seq $kconfig_max); do
> + eval "local kconfig$kconfig_i"
> + eval "kconfig$kconfig_i='$(echo "$kconfigs" | cut -d"$TST_NEEDS_KCONFIGS_IFS" -f$kconfig_i)'"
Well, we use 2x eval and cut in order to have easy C code. How about move
splitting string to C (using e.g. strtok_r()? Although using this code is
probably safe for any shell (we use similar cut like delimiter in tst_test.sh),
I've had enough of fixing obscure shell bugs. And C code with strtok_r() is more
portable across libc than any shell code.
> + done
> +
> + tst_check_kconfigs $kconfig1 $kconfig2 $kconfig3 $kconfig4 $kconfig5 $kconfig6\
> + $kconfig7 $kconfig8 $kconfig9 $kconfig10
Now I see the need for the need to limit. First, you need to quote parameters:
tst_check_kconfigs "$kconfig1" "$kconfig2" "$kconfig3" "$kconfig4" "$kconfig5" "$kconfig6" \
"$kconfig7" "$kconfig8" "$kconfig9" "$kconfig10"
Because there might be config value with space. I found only one which is not
going to be used:
CONFIG_CC_VERSION_TEXT="gcc (SUSE Linux) 11.2.1 20211124 [revision 7510c23c1ec53aa4a62705f0384079661342ff7b]"
but we cannot rely on that.
Kind regards,
Petr
> + if [ $? -ne 0 ]; then
> + tst_brk TCONF "Aborting due to unsuitable kernel config, see above!"
> + fi
> +
> + return 0
> +}
--
Mailing list info: https://lists.linux.it/listinfo/ltp
next prev parent reply other threads:[~2022-01-06 10:41 UTC|newest]
Thread overview: 74+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-01-04 6:57 [LTP] [PATCH v1 1/3] lib/tst_kconfig: Modify the return type of tst_kconfig_check function Yang Xu
2022-01-04 6:57 ` [LTP] [PATCH v1 2/3] shell: add kconfig parse api Yang Xu
2022-01-04 11:04 ` Petr Vorel
2022-01-05 7:15 ` xuyang2018.jy
2022-01-05 14:34 ` Petr Vorel
2022-01-06 5:59 ` xuyang2018.jy
2022-01-06 8:16 ` xuyang2018.jy
2022-01-06 9:25 ` [LTP] [PATCH v2 1/4] lib/tst_kconfig: Modify the return type of tst_kconfig_check function Yang Xu
2022-01-06 9:25 ` [LTP] [PATCH v2 2/4] lib: Introduce LTP_KCONFIG_DISABLE environment variables Yang Xu
2022-01-06 9:49 ` Petr Vorel
2022-01-06 9:52 ` Petr Vorel
2022-01-06 11:07 ` Cyril Hrubis
2022-01-06 11:50 ` Petr Vorel
2022-01-06 13:59 ` Cyril Hrubis
2022-01-06 17:41 ` Petr Vorel
2022-01-07 2:00 ` xuyang2018.jy
2022-01-06 9:25 ` [LTP] [PATCH v2 3/4] shell: add kconfig parse api Yang Xu
2022-01-06 10:40 ` Petr Vorel [this message]
2022-01-06 11:19 ` Cyril Hrubis
2022-01-07 3:54 ` Li Wang
2022-01-07 4:08 ` xuyang2018.jy
2022-01-07 7:04 ` Li Wang
2022-01-07 8:28 ` xuyang2018.jy
2022-01-07 8:41 ` Li Wang
2022-01-07 9:46 ` Cyril Hrubis
2022-01-07 9:56 ` xuyang2018.jy
2022-01-07 9:05 ` Petr Vorel
2022-01-07 9:22 ` xuyang2018.jy
2022-01-07 12:07 ` Petr Vorel
2022-01-07 7:33 ` Petr Vorel
2022-01-06 9:25 ` [LTP] [PATCH v2 4/4] sysctl/sysctl02.sh: Use kconfig shell api Yang Xu
2022-01-06 11:20 ` Cyril Hrubis
2022-01-10 1:49 ` [LTP] [PATCH v3 1/4] lib/tst_kconfig: Modify the return type of tst_kconfig_check function Yang Xu
2022-01-10 1:49 ` [LTP] [PATCH v3 2/4] lib: Introduce KCONFIG_SKIP_CHECK environment variable Yang Xu
2022-01-10 8:14 ` Li Wang
2022-01-10 12:20 ` Cyril Hrubis
2022-01-11 1:38 ` xuyang2018.jy
2022-01-10 1:49 ` [LTP] [PATCH v3 3/4] shell: add kconfig parse api Yang Xu
2022-01-10 8:26 ` Li Wang
2022-01-10 8:46 ` xuyang2018.jy
2022-01-10 9:13 ` Li Wang
2022-01-10 13:43 ` Cyril Hrubis
2022-01-11 5:29 ` xuyang2018.jy
2022-01-11 6:10 ` [LTP] [PATCH v4 1/5] lib/tst_kconfig: Modify the return type of tst_kconfig_check function Yang Xu
2022-01-11 6:10 ` [LTP] [PATCH v4 2/5] lib: Introduce KCONFIG_SKIP_CHECK environment variable Yang Xu
2022-01-13 11:09 ` Petr Vorel
2022-01-14 5:36 ` xuyang2018.jy
2022-01-11 6:10 ` [LTP] [PATCH v4 3/5] shell: add kconfig parse api Yang Xu
2022-01-11 7:52 ` Li Wang
2022-01-11 8:37 ` xuyang2018.jy
2022-01-13 9:15 ` xuyang2018.jy
2022-01-13 9:42 ` Li Wang
2022-01-13 15:51 ` Cyril Hrubis
2022-01-14 6:26 ` xuyang2018.jy
2022-01-14 9:19 ` xuyang2018.jy
2022-01-14 9:49 ` Petr Vorel
2022-01-11 6:10 ` [LTP] [PATCH v4 4/5] sysctl/sysctl02.sh: Use kconfig shell api Yang Xu
2022-01-13 10:53 ` Petr Vorel
2022-01-13 16:06 ` Petr Vorel
2022-01-13 15:54 ` Cyril Hrubis
2022-01-11 6:10 ` [LTP] [PATCH v4 5/5] runtest.sh: add test_kconfig.sh into ltp c test target Yang Xu
2022-01-13 11:25 ` Petr Vorel
2022-01-13 15:54 ` Cyril Hrubis
2022-01-10 1:49 ` [LTP] [PATCH v3 4/4] sysctl/sysctl02.sh: Use kconfig shell api Yang Xu
2022-01-10 8:30 ` Li Wang
2022-01-10 14:15 ` Cyril Hrubis
2022-01-11 5:34 ` xuyang2018.jy
2022-01-10 8:10 ` [LTP] [PATCH v3 1/4] lib/tst_kconfig: Modify the return type of tst_kconfig_check function Li Wang
2022-01-10 12:18 ` Cyril Hrubis
2022-01-10 5:45 ` [LTP] [PATCH v2 4/4] sysctl/sysctl02.sh: Use kconfig shell api xuyang2018.jy
2022-01-06 9:54 ` [LTP] [PATCH v2 1/4] lib/tst_kconfig: Modify the return type of tst_kconfig_check function Petr Vorel
2022-01-06 10:57 ` Cyril Hrubis
2022-01-07 1:25 ` xuyang2018.jy
2022-01-04 6:57 ` [LTP] [PATCH v1 3/3] sysctl/sysctl02.sh: Use kconfig shell api Yang Xu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=YdbHODSAdEnILJ6K@pevik \
--to=pvorel@suse.cz \
--cc=ltp@lists.linux.it \
--cc=xuyang2018.jy@fujitsu.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox