mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-04 20:19:47 +08:00

kunit tool: - Changes to kunit tool to use qboot on QEMU x86_64, and build GDB scripts. - Fixes kunit tool bug in parsing test plan. - Adds test to kunit tool to check parsing late test plan. kunit: - Clarifies kunit_skip() argument name. - Adds Kunit check for the longest symbol length. - Changes qemu_configs for sparc to use Zilog console. -----BEGIN PGP SIGNATURE----- iQIzBAABCgAdFiEEPZKym/RZuOCGeA/kCwJExA0NQxwFAmfkvDYACgkQCwJExA0N Qxwljg//ZRoF/Jncvlb0vapnOIYywHbJEPRVTKfNurRjhb7stAX7CpLKXing4Gtq ewy3UXRaAZKg1BvugDYWoUsDDD5o7jx6y9rOMOWM+aAHPzYgxY6gbIzyUVolNZg/ 50/ANMhT0bvME8KBB2k2l6p1NAblzOpH3zH35CCDL/40eVodwMPrhq0V5AqccOaE C5Bn+tDiviS6Icw+b/mVUw8fvmoJSTSKvdjaSeRAqThJN3KtqBVyX383++A1zNqy Y6tItu9wG06FDjuQ1miOlSMwhgMEYK4TS4GwbX4PUucR8ETaZNUXVviMRou7vMEa GGOdtsBG3CBgFNtO2VK1qJLWbJesw2G9+w2oIZ2KQKtyfoF7nDMj+DBO2QD/T+GB u2g/xlSDJ5PTzZBMVKENDMy+C9Q+ux8Y2PsQ0fTCdpYgadytKYBFA23EAiZaMdKa d1AweNvFS5gi8WkpS8SyMjs0D5pZnKMgHQqOIfRFjCi0HXsGE9RJfkOjLOzRnaOc zldLAgDcrhtdG8Xin08bux5UuCoqg/e/RJiXF+xQLLJkE7cltN/CuWMrHX4kija+ 8xmJtj4Oe0p7JCwnIaXjLAQDuFfxHYHM9wM0nKm+YpVJLPSWqSXk4+xtQEOlvZhN DJW61ez+pYVCmXuIZ/bgeRzpwXJMfALmI3kn+UtCYwqdTt6Xhp8= =h8xS -----END PGP SIGNATURE----- Merge tag 'linux_kselftest-kunit-6.15-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest Pull kunit updates from Shuah Khan: "kunit tool: - Changes to kunit tool to use qboot on QEMU x86_64, and build GDB scripts - Fixes kunit tool bug in parsing test plan - Adds test to kunit tool to check parsing late test plan kunit: - Clarifies kunit_skip() argument name - Adds Kunit check for the longest symbol length - Changes qemu_configs for sparc to use Zilog console" * tag 'linux_kselftest-kunit-6.15-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest: kunit: tool: add test to check parsing late test plan kunit: tool: Fix bug in parsing test plan Kunit to check the longest symbol length kunit: Clarify kunit_skip() argument name kunit: tool: Build GDB scripts kunit: qemu_configs: sparc: use Zilog console kunit: tool: Use qboot on QEMU x86_64
83 lines
2.4 KiB
C
83 lines
2.4 KiB
C
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* Test the longest symbol length. Execute with:
|
|
* ./tools/testing/kunit/kunit.py run longest-symbol
|
|
* --arch=x86_64 --kconfig_add CONFIG_KPROBES=y --kconfig_add CONFIG_MODULES=y
|
|
* --kconfig_add CONFIG_RETPOLINE=n --kconfig_add CONFIG_CFI_CLANG=n
|
|
* --kconfig_add CONFIG_MITIGATION_RETPOLINE=n
|
|
*/
|
|
|
|
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
|
|
|
|
#include <kunit/test.h>
|
|
#include <linux/stringify.h>
|
|
#include <linux/kprobes.h>
|
|
#include <linux/kallsyms.h>
|
|
|
|
#define DI(name) s##name##name
|
|
#define DDI(name) DI(n##name##name)
|
|
#define DDDI(name) DDI(n##name##name)
|
|
#define DDDDI(name) DDDI(n##name##name)
|
|
#define DDDDDI(name) DDDDI(n##name##name)
|
|
|
|
/*Generate a symbol whose name length is 511 */
|
|
#define LONGEST_SYM_NAME DDDDDI(g1h2i3j4k5l6m7n)
|
|
|
|
#define RETURN_LONGEST_SYM 0xAAAAA
|
|
|
|
noinline int LONGEST_SYM_NAME(void);
|
|
noinline int LONGEST_SYM_NAME(void)
|
|
{
|
|
return RETURN_LONGEST_SYM;
|
|
}
|
|
|
|
_Static_assert(sizeof(__stringify(LONGEST_SYM_NAME)) == KSYM_NAME_LEN,
|
|
"Incorrect symbol length found. Expected KSYM_NAME_LEN: "
|
|
__stringify(KSYM_NAME_LEN) ", but found: "
|
|
__stringify(sizeof(LONGEST_SYM_NAME)));
|
|
|
|
static void test_longest_symbol(struct kunit *test)
|
|
{
|
|
KUNIT_EXPECT_EQ(test, RETURN_LONGEST_SYM, LONGEST_SYM_NAME());
|
|
};
|
|
|
|
static void test_longest_symbol_kallsyms(struct kunit *test)
|
|
{
|
|
unsigned long (*kallsyms_lookup_name)(const char *name);
|
|
static int (*longest_sym)(void);
|
|
|
|
struct kprobe kp = {
|
|
.symbol_name = "kallsyms_lookup_name",
|
|
};
|
|
|
|
if (register_kprobe(&kp) < 0) {
|
|
pr_info("%s: kprobe not registered", __func__);
|
|
KUNIT_FAIL(test, "test_longest_symbol kallsyms: kprobe not registered\n");
|
|
return;
|
|
}
|
|
|
|
kunit_warn(test, "test_longest_symbol kallsyms: kprobe registered\n");
|
|
kallsyms_lookup_name = (unsigned long (*)(const char *name))kp.addr;
|
|
unregister_kprobe(&kp);
|
|
|
|
longest_sym =
|
|
(void *) kallsyms_lookup_name(__stringify(LONGEST_SYM_NAME));
|
|
KUNIT_EXPECT_EQ(test, RETURN_LONGEST_SYM, longest_sym());
|
|
};
|
|
|
|
static struct kunit_case longest_symbol_test_cases[] = {
|
|
KUNIT_CASE(test_longest_symbol),
|
|
KUNIT_CASE(test_longest_symbol_kallsyms),
|
|
{}
|
|
};
|
|
|
|
static struct kunit_suite longest_symbol_test_suite = {
|
|
.name = "longest-symbol",
|
|
.test_cases = longest_symbol_test_cases,
|
|
};
|
|
kunit_test_suite(longest_symbol_test_suite);
|
|
|
|
MODULE_LICENSE("GPL");
|
|
MODULE_DESCRIPTION("Test the longest symbol length");
|
|
MODULE_AUTHOR("Sergio González Collado");
|