mirror of
https://git.kernel.org/pub/scm/utils/kernel/kmod/kmod.git
synced 2024-11-23 19:03:41 +08:00
4c760f7edd
Signed-off-by: Emil Velikov <emil.l.velikov@gmail.com> Link: https://github.com/kmod-project/kmod/pull/118 Signed-off-by: Lucas De Marchi <lucas.de.marchi@gmail.com>
488 lines
12 KiB
C
488 lines
12 KiB
C
// SPDX-License-Identifier: LGPL-2.1-or-later
|
|
/*
|
|
* Copyright (C) 2012-2013 ProFUSION embedded systems
|
|
*/
|
|
|
|
#include <errno.h>
|
|
#include <inttypes.h>
|
|
#include <stddef.h>
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <unistd.h>
|
|
|
|
#include "testsuite.h"
|
|
|
|
static noreturn int modprobe_show_depends(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"--show-depends",
|
|
"mod-loop-a",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_show_depends,
|
|
.description = "check if output for modprobe --show-depends is correct for loaded modules",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/show-depends",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/show-depends/correct.txt",
|
|
});
|
|
|
|
static noreturn int modprobe_show_depends2(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"--show-depends",
|
|
"mod-simple",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_show_depends2,
|
|
.description = "check if output for modprobe --show-depends is correct",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/show-depends",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/show-depends/correct-mod-simple.txt",
|
|
});
|
|
|
|
static noreturn int modprobe_show_alias_to_none(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
// clang-format off
|
|
progname,
|
|
"--show-depends", "--ignore-install", "--quiet",
|
|
"mod-simple",
|
|
NULL,
|
|
// clang-format on
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_show_alias_to_none,
|
|
.description = "check if modprobe --show-depends doesn't explode with an alias to nothing",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/alias-to-none",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/alias-to-none/correct.txt",
|
|
},
|
|
.modules_loaded = "",
|
|
);
|
|
|
|
static noreturn int modprobe_show_exports(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
// clang-format off
|
|
progname,
|
|
"--show-exports", "--quiet",
|
|
"/mod-loop-a.ko",
|
|
NULL,
|
|
// clang-format on
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_show_exports,
|
|
.description = "check if modprobe --show-depends doesn't explode with an alias to nothing",
|
|
.config = {
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/show-exports",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/show-exports/correct.txt",
|
|
.regex = true,
|
|
});
|
|
|
|
static noreturn int modprobe_builtin(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"unix",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_builtin, .description = "check if modprobe return 0 for builtin",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/builtin",
|
|
});
|
|
|
|
static noreturn int modprobe_builtin_lookup_only(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"-R",
|
|
"unix",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_builtin_lookup_only,
|
|
.description = "check if modprobe -R correctly returns the builtin module",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/builtin",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/builtin/correct.txt",
|
|
});
|
|
|
|
static noreturn int modprobe_softdep_loop(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"mod-loop-b",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_softdep_loop,
|
|
.description = "check if modprobe breaks softdep loop",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/softdep-loop",
|
|
[TC_INIT_MODULE_RETCODES] = "",
|
|
},
|
|
.modules_loaded = "mod-loop-a,mod-loop-b",
|
|
);
|
|
|
|
static noreturn int modprobe_weakdep_loop(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"mod-loop-b",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_weakdep_loop,
|
|
.description = "check if modprobe breaks weakdep loop",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/weakdep-loop",
|
|
[TC_INIT_MODULE_RETCODES] = "",
|
|
},
|
|
.modules_loaded = "mod-loop-b",
|
|
.modules_not_loaded = "mod-loop-a,mod-simple-c",
|
|
);
|
|
|
|
static noreturn int modprobe_install_cmd_loop(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"mod-loop-a",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_install_cmd_loop,
|
|
.description = "check if modprobe breaks install-commands loop",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/install-cmd-loop",
|
|
[TC_INIT_MODULE_RETCODES] = "",
|
|
},
|
|
.env_vars = (const struct keyval[]) {
|
|
{ "MODPROBE", TOOLS_DIR "/modprobe" },
|
|
{ }
|
|
},
|
|
.modules_loaded = "mod-loop-b,mod-loop-a",
|
|
);
|
|
|
|
static noreturn int modprobe_param_kcmdline_show_deps(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"--show-depends",
|
|
"mod-simple",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_param_kcmdline_show_deps,
|
|
.description = "check if params from kcmdline are passed to (f)init_module call",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline/correct.txt",
|
|
},
|
|
.modules_loaded = "",
|
|
);
|
|
|
|
static noreturn int modprobe_param_kcmdline(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"-c",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST_WITH_FUNC(modprobe_param_kcmdline2, modprobe_param_kcmdline,
|
|
.description = "check if params with no value are parsed correctly from kcmdline",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline2",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline2/correct.txt",
|
|
},
|
|
.modules_loaded = "",
|
|
);
|
|
|
|
DEFINE_TEST_WITH_FUNC(modprobe_param_kcmdline3, modprobe_param_kcmdline,
|
|
.description = "check if unrelated strings in kcmdline are correctly ignored",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline3",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline3/correct.txt",
|
|
},
|
|
.modules_loaded = "",
|
|
);
|
|
|
|
DEFINE_TEST_WITH_FUNC(modprobe_param_kcmdline4, modprobe_param_kcmdline,
|
|
.description = "check if unrelated strings in kcmdline are correctly ignored",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline4",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline4/correct.txt",
|
|
},
|
|
.modules_loaded = "",
|
|
);
|
|
|
|
DEFINE_TEST_WITH_FUNC(modprobe_param_kcmdline5, modprobe_param_kcmdline,
|
|
.description = "check if params with spaces are parsed correctly from kcmdline",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline5",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline5/correct.txt",
|
|
},
|
|
.modules_loaded = "",
|
|
);
|
|
|
|
DEFINE_TEST_WITH_FUNC(modprobe_param_kcmdline6, modprobe_param_kcmdline,
|
|
.description = "check if dots on other parts of kcmdline don't confuse our parser",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline6",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline6/correct.txt",
|
|
},
|
|
.modules_loaded = "",
|
|
);
|
|
|
|
DEFINE_TEST_WITH_FUNC(modprobe_param_kcmdline7, modprobe_param_kcmdline,
|
|
.description = "check if dots on other parts of kcmdline don't confuse our parser",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline7",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline7/correct.txt",
|
|
},
|
|
.modules_loaded = "",
|
|
);
|
|
|
|
DEFINE_TEST_WITH_FUNC(modprobe_param_kcmdline8, modprobe_param_kcmdline,
|
|
.description = "check if dots on other parts of kcmdline don't confuse our parser",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline8",
|
|
},
|
|
.output = {
|
|
.out = TESTSUITE_ROOTFS "test-modprobe/module-param-kcmdline8/correct.txt",
|
|
},
|
|
.modules_loaded = "",
|
|
);
|
|
|
|
static noreturn int modprobe_force(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"--force",
|
|
"mod-simple",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_force,
|
|
.description = "check modprobe --force",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/force",
|
|
[TC_INIT_MODULE_RETCODES] = "",
|
|
},
|
|
.modules_loaded = "mod-simple",
|
|
);
|
|
|
|
static noreturn int modprobe_oldkernel(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"mod-simple",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_oldkernel,
|
|
.description = "check modprobe with kernel without finit_module()",
|
|
.config = {
|
|
[TC_UNAME_R] = "3.3.3",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/oldkernel",
|
|
[TC_INIT_MODULE_RETCODES] = "",
|
|
},
|
|
.modules_loaded = "mod-simple",
|
|
);
|
|
|
|
static noreturn int modprobe_oldkernel_force(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"--force",
|
|
"mod-simple",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_oldkernel_force,
|
|
.description = "check modprobe --force with kernel without finit_module()",
|
|
.config = {
|
|
[TC_UNAME_R] = "3.3.3",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/oldkernel-force",
|
|
[TC_INIT_MODULE_RETCODES] = "",
|
|
},
|
|
.modules_loaded = "mod-simple",
|
|
);
|
|
|
|
static noreturn int modprobe_external(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"mod-simple",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_external,
|
|
.description = "check modprobe able to load external module",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/external",
|
|
[TC_INIT_MODULE_RETCODES] = "",
|
|
},
|
|
.modules_loaded = "mod-simple",
|
|
);
|
|
|
|
static noreturn int modprobe_module_from_abspath(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"/home/foo/mod-simple.ko",
|
|
NULL,
|
|
};
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_module_from_abspath,
|
|
.description = "check modprobe able to load module given as an absolute path",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-from-abspath",
|
|
[TC_INIT_MODULE_RETCODES] = "",
|
|
},
|
|
.modules_loaded = "mod-simple",
|
|
);
|
|
|
|
static noreturn int modprobe_module_from_relpath(const struct test *t)
|
|
{
|
|
const char *progname = TOOLS_DIR "/modprobe";
|
|
const char *const args[] = {
|
|
progname,
|
|
"./mod-simple.ko",
|
|
NULL,
|
|
};
|
|
|
|
if (chdir("/home/foo") != 0) {
|
|
perror("failed to change into /home/foo");
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
|
|
test_spawn_prog(progname, args);
|
|
exit(EXIT_FAILURE);
|
|
}
|
|
DEFINE_TEST(modprobe_module_from_relpath,
|
|
.description = "check modprobe able to load module given as a relative path",
|
|
.config = {
|
|
[TC_UNAME_R] = "4.4.4",
|
|
[TC_ROOTFS] = TESTSUITE_ROOTFS "test-modprobe/module-from-relpath",
|
|
[TC_INIT_MODULE_RETCODES] = "",
|
|
},
|
|
.need_spawn = true,
|
|
.modules_loaded = "mod-simple",
|
|
);
|
|
|
|
TESTSUITE_MAIN();
|